@plait/core 0.38.0 → 0.40.0
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 +1 -1
- package/constants/index.d.ts +1 -1
- package/esm2022/board/board.component.mjs +6 -4
- package/esm2022/constants/index.mjs +2 -2
- package/esm2022/interfaces/board.mjs +1 -1
- package/esm2022/interfaces/rectangle-client.mjs +3 -3
- package/esm2022/plugins/create-board.mjs +4 -2
- package/esm2022/plugins/with-board.mjs +10 -3
- package/esm2022/plugins/with-hand.mjs +10 -10
- package/esm2022/plugins/with-moving.mjs +7 -2
- package/esm2022/plugins/with-selection.mjs +69 -31
- package/esm2022/transforms/board.mjs +3 -1
- package/esm2022/utils/common.mjs +4 -2
- package/esm2022/utils/dom/common.mjs +21 -3
- package/esm2022/utils/math.mjs +4 -2
- package/esm2022/utils/moving-element.mjs +4 -1
- package/esm2022/utils/selected-element.mjs +19 -3
- package/esm2022/utils/to-image.mjs +6 -6
- package/esm2022/utils/viewport.mjs +14 -7
- package/esm2022/utils/weak-maps.mjs +2 -1
- package/fesm2022/plait-core.mjs +167 -65
- package/fesm2022/plait-core.mjs.map +1 -1
- package/interfaces/board.d.ts +1 -0
- package/package.json +1 -1
- package/plugins/with-selection.d.ts +2 -0
- package/utils/dom/common.d.ts +15 -2
- package/utils/math.d.ts +1 -1
- package/utils/moving-element.d.ts +1 -0
- package/utils/selected-element.d.ts +1 -1
- package/utils/viewport.d.ts +1 -0
- package/utils/weak-maps.d.ts +1 -0
|
@@ -3,23 +3,23 @@ import { BoardTransforms } from '../transforms';
|
|
|
3
3
|
import { isMainPointer } from '../utils/dom/common';
|
|
4
4
|
import { updateViewportContainerScroll } from '../utils/viewport';
|
|
5
5
|
export function withHandPointer(board) {
|
|
6
|
-
const {
|
|
6
|
+
const { pointerDown, pointerMove, globalPointerUp, keydown, keyup } = board;
|
|
7
7
|
let isMoving = false;
|
|
8
8
|
const plaitBoardMove = {
|
|
9
9
|
x: 0,
|
|
10
10
|
y: 0
|
|
11
11
|
};
|
|
12
|
-
board.
|
|
12
|
+
board.pointerDown = (event) => {
|
|
13
13
|
if (PlaitBoard.isPointer(board, PlaitPointerType.hand) && isMainPointer(event)) {
|
|
14
14
|
isMoving = true;
|
|
15
15
|
PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');
|
|
16
16
|
plaitBoardMove.x = event.x;
|
|
17
17
|
plaitBoardMove.y = event.y;
|
|
18
18
|
}
|
|
19
|
-
|
|
19
|
+
pointerDown(event);
|
|
20
20
|
};
|
|
21
|
-
board.
|
|
22
|
-
if (PlaitBoard.isPointer(board, PlaitPointerType.hand) &&
|
|
21
|
+
board.pointerMove = (event) => {
|
|
22
|
+
if (PlaitBoard.isPointer(board, PlaitPointerType.hand) && isMoving) {
|
|
23
23
|
const viewportContainer = PlaitBoard.getViewportContainer(board);
|
|
24
24
|
const left = viewportContainer.scrollLeft - (event.x - plaitBoardMove.x);
|
|
25
25
|
const top = viewportContainer.scrollTop - (event.y - plaitBoardMove.y);
|
|
@@ -27,16 +27,16 @@ export function withHandPointer(board) {
|
|
|
27
27
|
plaitBoardMove.x = event.x;
|
|
28
28
|
plaitBoardMove.y = event.y;
|
|
29
29
|
}
|
|
30
|
-
|
|
30
|
+
pointerMove(event);
|
|
31
31
|
};
|
|
32
|
-
board.
|
|
33
|
-
if (
|
|
32
|
+
board.globalPointerUp = (event) => {
|
|
33
|
+
if (isMoving) {
|
|
34
34
|
isMoving = false;
|
|
35
35
|
PlaitBoard.getBoardContainer(board).classList.remove('viewport-moving');
|
|
36
36
|
plaitBoardMove.x = 0;
|
|
37
37
|
plaitBoardMove.y = 0;
|
|
38
38
|
}
|
|
39
|
-
|
|
39
|
+
globalPointerUp(event);
|
|
40
40
|
};
|
|
41
41
|
board.keydown = (event) => {
|
|
42
42
|
if (event.code === 'Space') {
|
|
@@ -55,4 +55,4 @@ export function withHandPointer(board) {
|
|
|
55
55
|
};
|
|
56
56
|
return board;
|
|
57
57
|
}
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1oYW5kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcGx1Z2lucy93aXRoLWhhbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFVBQVUsRUFBa0IsTUFBTSxlQUFlLENBQUM7QUFDN0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFbEUsTUFBTSxVQUFVLGVBQWUsQ0FBdUIsS0FBUTtJQUMxRCxNQUFNLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxlQUFlLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxHQUFHLEtBQUssQ0FBQztJQUM1RSxJQUFJLFFBQVEsR0FBWSxLQUFLLENBQUM7SUFDOUIsTUFBTSxjQUFjLEdBQW1CO1FBQ25DLENBQUMsRUFBRSxDQUFDO1FBQ0osQ0FBQyxFQUFFLENBQUM7S0FDUCxDQUFDO0lBRUYsS0FBSyxDQUFDLFdBQVcsR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtRQUN4QyxJQUFJLFVBQVUsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLGFBQWEsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUM1RSxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ2hCLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUM7WUFDckUsY0FBYyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQzNCLGNBQWMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztTQUM5QjtRQUNELFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QixDQUFDLENBQUM7SUFFRixLQUFLLENBQUMsV0FBVyxHQUFHLENBQUMsS0FBbUIsRUFBRSxFQUFFO1FBQ3hDLElBQUksVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksUUFBUSxFQUFFO1lBQ2hFLE1BQU0saUJBQWlCLEdBQUcsVUFBVSxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2pFLE1BQU0sSUFBSSxHQUFHLGlCQUFpQixDQUFDLFVBQVUsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3pFLE1BQU0sR0FBRyxHQUFHLGlCQUFpQixDQUFDLFNBQVMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3ZFLDZCQUE2QixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3ZELGNBQWMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUMzQixjQUFjLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDOUI7UUFDRCxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDdkIsQ0FBQyxDQUFDO0lBRUYsS0FBSyxDQUFDLGVBQWUsR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtRQUM1QyxJQUFJLFFBQVEsRUFBRTtZQUNWLFFBQVEsR0FBRyxLQUFLLENBQUM7WUFDakIsVUFBVSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQztZQUN4RSxjQUFjLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNyQixjQUFjLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUN4QjtRQUNELGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDLENBQUM7SUFFRixLQUFLLENBQUMsT0FBTyxHQUFHLENBQUMsS0FBb0IsRUFBRSxFQUFFO1FBQ3JDLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyxPQUFPLEVBQUU7WUFDeEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDLElBQUksQ0FBQyxFQUFFO2dCQUNyRCxlQUFlLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ25FO1lBQ0QsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1NBQzFCO1FBQ0QsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25CLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxLQUFLLEdBQUcsQ0FBQyxLQUFvQixFQUFFLEVBQUU7UUFDbkMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsUUFBUSxJQUFJLEtBQUssQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFFO1lBQ25ELGVBQWUsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDeEU7UUFDRCxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxLQUFLLENBQUM7QUFDakIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0UG9pbnRlclR5cGUsIFBsYWl0Qm9hcmQsIFBsYWl0Qm9hcmRNb3ZlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBCb2FyZFRyYW5zZm9ybXMgfSBmcm9tICcuLi90cmFuc2Zvcm1zJztcbmltcG9ydCB7IGlzTWFpblBvaW50ZXIgfSBmcm9tICcuLi91dGlscy9kb20vY29tbW9uJztcbmltcG9ydCB7IHVwZGF0ZVZpZXdwb3J0Q29udGFpbmVyU2Nyb2xsIH0gZnJvbSAnLi4vdXRpbHMvdmlld3BvcnQnO1xuXG5leHBvcnQgZnVuY3Rpb24gd2l0aEhhbmRQb2ludGVyPFQgZXh0ZW5kcyBQbGFpdEJvYXJkPihib2FyZDogVCkge1xuICAgIGNvbnN0IHsgcG9pbnRlckRvd24sIHBvaW50ZXJNb3ZlLCBnbG9iYWxQb2ludGVyVXAsIGtleWRvd24sIGtleXVwIH0gPSBib2FyZDtcbiAgICBsZXQgaXNNb3Zpbmc6IGJvb2xlYW4gPSBmYWxzZTtcbiAgICBjb25zdCBwbGFpdEJvYXJkTW92ZTogUGxhaXRCb2FyZE1vdmUgPSB7XG4gICAgICAgIHg6IDAsXG4gICAgICAgIHk6IDBcbiAgICB9O1xuXG4gICAgYm9hcmQucG9pbnRlckRvd24gPSAoZXZlbnQ6IFBvaW50ZXJFdmVudCkgPT4ge1xuICAgICAgICBpZiAoUGxhaXRCb2FyZC5pc1BvaW50ZXIoYm9hcmQsIFBsYWl0UG9pbnRlclR5cGUuaGFuZCkgJiYgaXNNYWluUG9pbnRlcihldmVudCkpIHtcbiAgICAgICAgICAgIGlzTW92aW5nID0gdHJ1ZTtcbiAgICAgICAgICAgIFBsYWl0Qm9hcmQuZ2V0Qm9hcmRDb250YWluZXIoYm9hcmQpLmNsYXNzTGlzdC5hZGQoJ3ZpZXdwb3J0LW1vdmluZycpO1xuICAgICAgICAgICAgcGxhaXRCb2FyZE1vdmUueCA9IGV2ZW50Lng7XG4gICAgICAgICAgICBwbGFpdEJvYXJkTW92ZS55ID0gZXZlbnQueTtcbiAgICAgICAgfVxuICAgICAgICBwb2ludGVyRG93bihldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLnBvaW50ZXJNb3ZlID0gKGV2ZW50OiBQb2ludGVyRXZlbnQpID0+IHtcbiAgICAgICAgaWYgKFBsYWl0Qm9hcmQuaXNQb2ludGVyKGJvYXJkLCBQbGFpdFBvaW50ZXJUeXBlLmhhbmQpICYmIGlzTW92aW5nKSB7XG4gICAgICAgICAgICBjb25zdCB2aWV3cG9ydENvbnRhaW5lciA9IFBsYWl0Qm9hcmQuZ2V0Vmlld3BvcnRDb250YWluZXIoYm9hcmQpO1xuICAgICAgICAgICAgY29uc3QgbGVmdCA9IHZpZXdwb3J0Q29udGFpbmVyLnNjcm9sbExlZnQgLSAoZXZlbnQueCAtIHBsYWl0Qm9hcmRNb3ZlLngpO1xuICAgICAgICAgICAgY29uc3QgdG9wID0gdmlld3BvcnRDb250YWluZXIuc2Nyb2xsVG9wIC0gKGV2ZW50LnkgLSBwbGFpdEJvYXJkTW92ZS55KTtcbiAgICAgICAgICAgIHVwZGF0ZVZpZXdwb3J0Q29udGFpbmVyU2Nyb2xsKGJvYXJkLCBsZWZ0LCB0b3AsIGZhbHNlKTtcbiAgICAgICAgICAgIHBsYWl0Qm9hcmRNb3ZlLnggPSBldmVudC54O1xuICAgICAgICAgICAgcGxhaXRCb2FyZE1vdmUueSA9IGV2ZW50Lnk7XG4gICAgICAgIH1cbiAgICAgICAgcG9pbnRlck1vdmUoZXZlbnQpO1xuICAgIH07XG5cbiAgICBib2FyZC5nbG9iYWxQb2ludGVyVXAgPSAoZXZlbnQ6IFBvaW50ZXJFdmVudCkgPT4ge1xuICAgICAgICBpZiAoaXNNb3ZpbmcpIHtcbiAgICAgICAgICAgIGlzTW92aW5nID0gZmFsc2U7XG4gICAgICAgICAgICBQbGFpdEJvYXJkLmdldEJvYXJkQ29udGFpbmVyKGJvYXJkKS5jbGFzc0xpc3QucmVtb3ZlKCd2aWV3cG9ydC1tb3ZpbmcnKTtcbiAgICAgICAgICAgIHBsYWl0Qm9hcmRNb3ZlLnggPSAwO1xuICAgICAgICAgICAgcGxhaXRCb2FyZE1vdmUueSA9IDA7XG4gICAgICAgIH1cbiAgICAgICAgZ2xvYmFsUG9pbnRlclVwKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgYm9hcmQua2V5ZG93biA9IChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge1xuICAgICAgICBpZiAoZXZlbnQuY29kZSA9PT0gJ1NwYWNlJykge1xuICAgICAgICAgICAgaWYgKCFQbGFpdEJvYXJkLmlzUG9pbnRlcihib2FyZCwgUGxhaXRQb2ludGVyVHlwZS5oYW5kKSkge1xuICAgICAgICAgICAgICAgIEJvYXJkVHJhbnNmb3Jtcy51cGRhdGVQb2ludGVyVHlwZShib2FyZCwgUGxhaXRQb2ludGVyVHlwZS5oYW5kKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIH1cbiAgICAgICAga2V5ZG93bihldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLmtleXVwID0gKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgICAgIGlmICghYm9hcmQub3B0aW9ucy5yZWFkb25seSAmJiBldmVudC5jb2RlID09PSAnU3BhY2UnKSB7XG4gICAgICAgICAgICBCb2FyZFRyYW5zZm9ybXMudXBkYXRlUG9pbnRlclR5cGUoYm9hcmQsIFBsYWl0UG9pbnRlclR5cGUuc2VsZWN0aW9uKTtcbiAgICAgICAgfVxuICAgICAgICBrZXl1cChldmVudCk7XG4gICAgfTtcblxuICAgIHJldHVybiBib2FyZDtcbn1cbiJdfQ==
|
|
@@ -10,6 +10,7 @@ import { addMovingElements, getMovingElements, removeMovingElements } from '../u
|
|
|
10
10
|
import { MERGING } from '../interfaces/history';
|
|
11
11
|
import { isPreventTouchMove, preventTouchMove, handleTouchTarget, getRectangleByElements, distanceBetweenPointAndPoint } from '../utils';
|
|
12
12
|
import { AlignReaction } from '../utils/reaction-manager';
|
|
13
|
+
import { PlaitPointerType } from '../interfaces';
|
|
13
14
|
import { ACTIVE_MOVING_CLASS_NAME, PRESS_AND_MOVE_BUFFER } from '../constants';
|
|
14
15
|
export function withMoving(board) {
|
|
15
16
|
const { pointerDown, pointerMove, globalPointerUp, globalPointerMove } = board;
|
|
@@ -24,7 +25,11 @@ export function withMoving(board) {
|
|
|
24
25
|
const host = BOARD_TO_HOST.get(board);
|
|
25
26
|
const point = transformPoint(board, toPoint(event.x, event.y, host));
|
|
26
27
|
let movableElements = board.children.filter(item => board.isMovable(item));
|
|
27
|
-
if (!PlaitBoard.isReadonly(board) &&
|
|
28
|
+
if (!PlaitBoard.isReadonly(board) &&
|
|
29
|
+
PlaitBoard.isPointer(board, PlaitPointerType.selection) &&
|
|
30
|
+
movableElements.length &&
|
|
31
|
+
!isPreventTouchMove(board) &&
|
|
32
|
+
isMainPointer(event)) {
|
|
28
33
|
startPoint = point;
|
|
29
34
|
const selectedMovableElements = getSelectedElements(board).filter(item => movableElements.includes(item));
|
|
30
35
|
const hitElement = getHitElementByPoint(board, point);
|
|
@@ -124,4 +129,4 @@ export function withMoving(board) {
|
|
|
124
129
|
}
|
|
125
130
|
return board;
|
|
126
131
|
}
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-moving.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-moving.ts"],"names":[],"mappings":"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","sourcesContent":["import { BOARD_TO_HOST } from '../utils/weak-maps';\nimport { PlaitBoard } from '../interfaces/board';\nimport { isInPlaitBoard, transformPoint } from '../utils/board';\nimport { isMainPointer, toPoint } from '../utils/dom/common';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { PlaitElement } from '../interfaces/element';\nimport { getHitElementByPoint, getSelectedElements } from '../utils/selected-element';\nimport { PlaitNode } from '../interfaces/node';\nimport { throttleRAF } from '../utils/common';\nimport { addMovingElements, getMovingElements, removeMovingElements } from '../utils/moving-element';\nimport { MERGING } from '../interfaces/history';\nimport { isPreventTouchMove, preventTouchMove, handleTouchTarget, getRectangleByElements, distanceBetweenPointAndPoint } from '../utils';\nimport { AlignReaction } from '../utils/reaction-manager';\nimport { RectangleClient } from '../interfaces';\nimport { ACTIVE_MOVING_CLASS_NAME, PRESS_AND_MOVE_BUFFER } from '../constants';\n\nexport function withMoving(board: PlaitBoard) {\n    const { pointerDown, pointerMove, globalPointerUp, globalPointerMove } = board;\n\n    let offsetX = 0;\n    let offsetY = 0;\n    let isPreventDefault = false;\n    let startPoint: Point | null;\n    let activeElements: PlaitElement[] = [];\n    let alignG: SVGGElement | null = null;\n    let activeElementsRectangle: RectangleClient | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const host = BOARD_TO_HOST.get(board);\n        const point = transformPoint(board, toPoint(event.x, event.y, host!));\n        let movableElements = board.children.filter(item => board.isMovable(item));\n        if (!PlaitBoard.isReadonly(board) && movableElements.length && !isPreventTouchMove(board) && isMainPointer(event)) {\n            startPoint = point;\n            const selectedMovableElements = getSelectedElements(board).filter(item => movableElements.includes(item));\n            const hitElement = getHitElementByPoint(board, point);\n            if (hitElement && movableElements.includes(hitElement)) {\n                if (selectedMovableElements.includes(hitElement)) {\n                    activeElements = selectedMovableElements;\n                } else {\n                    activeElements = [hitElement];\n                }\n            }\n            if (activeElements.length > 0) {\n                preventTouchMove(board, event, true);\n            }\n            activeElementsRectangle = getRectangleByElements(board, activeElements, true);\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (startPoint && activeElements.length && !PlaitBoard.hasBeenTextEditing(board)) {\n            if (!isPreventDefault) {\n                isPreventDefault = true;\n            }\n            alignG?.remove();\n            const host = BOARD_TO_HOST.get(board);\n            const endPoint = transformPoint(board, toPoint(event.x, event.y, host!));\n            offsetX = endPoint[0] - startPoint[0];\n            offsetY = endPoint[1] - startPoint[1];\n            const distance = distanceBetweenPointAndPoint(...endPoint, ...startPoint);\n            if (distance > PRESS_AND_MOVE_BUFFER || getMovingElements(board).length > 0) {\n                throttleRAF(() => {\n                    if (!activeElementsRectangle) {\n                        return;\n                    }\n                    const newRectangle = {\n                        ...activeElementsRectangle,\n                        x: activeElementsRectangle.x + offsetX,\n                        y: activeElementsRectangle.y + offsetY\n                    };\n                    const reactionManager = new AlignReaction(board, activeElements, newRectangle);\n                    const ref = reactionManager.handleAlign();\n                    offsetX -= ref.deltaX;\n                    offsetY -= ref.deltaY;\n                    alignG = ref.g;\n                    alignG.classList.add(ACTIVE_MOVING_CLASS_NAME);\n                    PlaitBoard.getElementActiveHost(board).append(alignG);\n\n                    handleTouchTarget(board);\n                    const currentElements = activeElements.map(activeElement => {\n                        const points = activeElement.points || [];\n                        const [x, y] = activeElement.points![0];\n                        const newPoints = points.map(p => [p[0] + offsetX, p[1] + offsetY]) as Point[];\n                        const index = board.children.findIndex(item => item.id === activeElement.id);\n                        Transforms.setNode(\n                            board,\n                            {\n                                points: newPoints\n                            },\n                            [index]\n                        );\n                        MERGING.set(board, true);\n                        return PlaitNode.get(board, [index]);\n                    });\n                    PlaitBoard.getBoardContainer(board).classList.add('element-moving');\n                    addMovingElements(board, currentElements as PlaitElement[]);\n                });\n            }\n        }\n        if (isPreventDefault) {\n            // 阻止 move 过程中触发画布滚动行为\n            event.preventDefault();\n        }\n        pointerMove(event);\n    };\n\n    board.globalPointerMove = (event: PointerEvent) => {\n        if (startPoint) {\n            const inPlaitBoardElement = isInPlaitBoard(board, event.x, event.y);\n            if (!inPlaitBoardElement) {\n                cancelMove(board);\n            }\n        }\n        globalPointerMove(event);\n    };\n\n    board.globalPointerUp = event => {\n        isPreventDefault = false;\n        if (startPoint) {\n            cancelMove(board);\n        }\n        preventTouchMove(board, event, false);\n        globalPointerUp(event);\n    };\n\n    function cancelMove(board: PlaitBoard) {\n        alignG?.remove();\n        startPoint = null;\n        activeElementsRectangle = null;\n        offsetX = 0;\n        offsetY = 0;\n        activeElements = [];\n        removeMovingElements(board);\n        MERGING.set(board, false);\n        PlaitBoard.getBoardContainer(board).classList.remove('element-moving');\n    }\n\n    return board;\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-moving.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-moving.ts"],"names":[],"mappings":"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","sourcesContent":["import { BOARD_TO_HOST } from '../utils/weak-maps';\nimport { PlaitBoard } from '../interfaces/board';\nimport { isInPlaitBoard, transformPoint } from '../utils/board';\nimport { isMainPointer, toPoint } from '../utils/dom/common';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { PlaitElement } from '../interfaces/element';\nimport { getHitElementByPoint, getSelectedElements } from '../utils/selected-element';\nimport { PlaitNode } from '../interfaces/node';\nimport { throttleRAF } from '../utils/common';\nimport { addMovingElements, getMovingElements, removeMovingElements } from '../utils/moving-element';\nimport { MERGING } from '../interfaces/history';\nimport { isPreventTouchMove, preventTouchMove, handleTouchTarget, getRectangleByElements, distanceBetweenPointAndPoint } from '../utils';\nimport { AlignReaction } from '../utils/reaction-manager';\nimport { PlaitPointerType, RectangleClient } from '../interfaces';\nimport { ACTIVE_MOVING_CLASS_NAME, PRESS_AND_MOVE_BUFFER } from '../constants';\n\nexport function withMoving(board: PlaitBoard) {\n    const { pointerDown, pointerMove, globalPointerUp, globalPointerMove } = board;\n\n    let offsetX = 0;\n    let offsetY = 0;\n    let isPreventDefault = false;\n    let startPoint: Point | null;\n    let activeElements: PlaitElement[] = [];\n    let alignG: SVGGElement | null = null;\n    let activeElementsRectangle: RectangleClient | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const host = BOARD_TO_HOST.get(board);\n        const point = transformPoint(board, toPoint(event.x, event.y, host!));\n        let movableElements = board.children.filter(item => board.isMovable(item));\n        if (\n            !PlaitBoard.isReadonly(board) &&\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) &&\n            movableElements.length &&\n            !isPreventTouchMove(board) &&\n            isMainPointer(event)\n        ) {\n            startPoint = point;\n            const selectedMovableElements = getSelectedElements(board).filter(item => movableElements.includes(item));\n            const hitElement = getHitElementByPoint(board, point);\n            if (hitElement && movableElements.includes(hitElement)) {\n                if (selectedMovableElements.includes(hitElement)) {\n                    activeElements = selectedMovableElements;\n                } else {\n                    activeElements = [hitElement];\n                }\n            }\n            if (activeElements.length > 0) {\n                preventTouchMove(board, event, true);\n            }\n            activeElementsRectangle = getRectangleByElements(board, activeElements, true);\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (startPoint && activeElements.length && !PlaitBoard.hasBeenTextEditing(board)) {\n            if (!isPreventDefault) {\n                isPreventDefault = true;\n            }\n            alignG?.remove();\n            const host = BOARD_TO_HOST.get(board);\n            const endPoint = transformPoint(board, toPoint(event.x, event.y, host!));\n            offsetX = endPoint[0] - startPoint[0];\n            offsetY = endPoint[1] - startPoint[1];\n            const distance = distanceBetweenPointAndPoint(...endPoint, ...startPoint);\n            if (distance > PRESS_AND_MOVE_BUFFER || getMovingElements(board).length > 0) {\n                throttleRAF(() => {\n                    if (!activeElementsRectangle) {\n                        return;\n                    }\n                    const newRectangle = {\n                        ...activeElementsRectangle,\n                        x: activeElementsRectangle.x + offsetX,\n                        y: activeElementsRectangle.y + offsetY\n                    };\n                    const reactionManager = new AlignReaction(board, activeElements, newRectangle);\n                    const ref = reactionManager.handleAlign();\n                    offsetX -= ref.deltaX;\n                    offsetY -= ref.deltaY;\n                    alignG = ref.g;\n                    alignG.classList.add(ACTIVE_MOVING_CLASS_NAME);\n                    PlaitBoard.getElementActiveHost(board).append(alignG);\n\n                    handleTouchTarget(board);\n                    const currentElements = activeElements.map(activeElement => {\n                        const points = activeElement.points || [];\n                        const [x, y] = activeElement.points![0];\n                        const newPoints = points.map(p => [p[0] + offsetX, p[1] + offsetY]) as Point[];\n                        const index = board.children.findIndex(item => item.id === activeElement.id);\n                        Transforms.setNode(\n                            board,\n                            {\n                                points: newPoints\n                            },\n                            [index]\n                        );\n                        MERGING.set(board, true);\n                        return PlaitNode.get(board, [index]);\n                    });\n                    PlaitBoard.getBoardContainer(board).classList.add('element-moving');\n                    addMovingElements(board, currentElements as PlaitElement[]);\n                });\n            }\n        }\n        if (isPreventDefault) {\n            // 阻止 move 过程中触发画布滚动行为\n            event.preventDefault();\n        }\n        pointerMove(event);\n    };\n\n    board.globalPointerMove = (event: PointerEvent) => {\n        if (startPoint) {\n            const inPlaitBoardElement = isInPlaitBoard(board, event.x, event.y);\n            if (!inPlaitBoardElement) {\n                cancelMove(board);\n            }\n        }\n        globalPointerMove(event);\n    };\n\n    board.globalPointerUp = event => {\n        isPreventDefault = false;\n        if (startPoint) {\n            cancelMove(board);\n        }\n        preventTouchMove(board, event, false);\n        globalPointerUp(event);\n    };\n\n    function cancelMove(board: PlaitBoard) {\n        alignG?.remove();\n        startPoint = null;\n        activeElementsRectangle = null;\n        offsetX = 0;\n        offsetY = 0;\n        activeElements = [];\n        removeMovingElements(board);\n        MERGING.set(board, false);\n        PlaitBoard.getBoardContainer(board).classList.remove('element-moving');\n    }\n\n    return board;\n}\n"]}
|
|
@@ -10,8 +10,9 @@ import { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from '../ut
|
|
|
10
10
|
import { ACTIVE_STROKE_WIDTH, ATTACHED_ELEMENT_CLASS_NAME, SELECTION_RECTANGLE_CLASS_NAME } from '../constants/selection';
|
|
11
11
|
import { drawRectangle, preventTouchMove, throttleRAF } from '../utils';
|
|
12
12
|
import { PlaitPluginKey } from '../interfaces/plugin-key';
|
|
13
|
+
import { Selection } from '../interfaces/selection';
|
|
13
14
|
export function withSelection(board) {
|
|
14
|
-
const { pointerDown, globalPointerMove, globalPointerUp, onChange } = board;
|
|
15
|
+
const { pointerDown, globalPointerMove, globalPointerUp, keyup, onChange, afterChange } = board;
|
|
15
16
|
let start = null;
|
|
16
17
|
let end = null;
|
|
17
18
|
let selectionMovingG;
|
|
@@ -19,11 +20,15 @@ export function withSelection(board) {
|
|
|
19
20
|
let previousSelectedElements;
|
|
20
21
|
// prevent text from being selected when user pressed main pointer and is moving
|
|
21
22
|
let needPreventNativeSelectionWhenMoving = false;
|
|
23
|
+
let isShift = false;
|
|
22
24
|
board.pointerDown = (event) => {
|
|
23
25
|
const isHitText = event.target instanceof Element && event.target.closest('.plait-richtext-container');
|
|
24
|
-
|
|
25
|
-
if (!isHitText && event.shiftKey) {
|
|
26
|
+
if (event.shiftKey) {
|
|
26
27
|
event.preventDefault();
|
|
28
|
+
isShift = true;
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
isShift = false;
|
|
27
32
|
}
|
|
28
33
|
if (!isHitText) {
|
|
29
34
|
needPreventNativeSelectionWhenMoving = true;
|
|
@@ -37,7 +42,7 @@ export function withSelection(board) {
|
|
|
37
42
|
const selection = { anchor: point, focus: point };
|
|
38
43
|
const hitElement = getHitElementByPoint(board, point);
|
|
39
44
|
const selectedElements = getSelectedElements(board);
|
|
40
|
-
if (hitElement && selectedElements.includes(hitElement) && !options.isDisabledSelect) {
|
|
45
|
+
if (!isShift && hitElement && selectedElements.includes(hitElement) && !options.isDisabledSelect) {
|
|
41
46
|
pointerDown(event);
|
|
42
47
|
return;
|
|
43
48
|
}
|
|
@@ -49,12 +54,18 @@ export function withSelection(board) {
|
|
|
49
54
|
Transforms.setSelection(board, selection);
|
|
50
55
|
pointerDown(event);
|
|
51
56
|
};
|
|
57
|
+
board.keyup = (event) => {
|
|
58
|
+
if (isShift && event.key === 'Shift') {
|
|
59
|
+
isShift = false;
|
|
60
|
+
}
|
|
61
|
+
keyup(event);
|
|
62
|
+
};
|
|
52
63
|
board.globalPointerMove = (event) => {
|
|
53
64
|
if (needPreventNativeSelectionWhenMoving) {
|
|
54
65
|
// prevent text from being selected
|
|
55
66
|
event.preventDefault();
|
|
56
67
|
}
|
|
57
|
-
if (start) {
|
|
68
|
+
if (start && PlaitBoard.isPointer(board, PlaitPointerType.selection)) {
|
|
58
69
|
const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
59
70
|
const rectangle = RectangleClient.toRectangleClient([start, movedTarget]);
|
|
60
71
|
selectionMovingG?.remove();
|
|
@@ -110,43 +121,63 @@ export function withSelection(board) {
|
|
|
110
121
|
removeSelectedElement(board, op.node);
|
|
111
122
|
}
|
|
112
123
|
});
|
|
113
|
-
|
|
114
|
-
if (board.pointer !== PlaitPointerType.hand && !options.isDisabledSelect) {
|
|
124
|
+
if (isHandleSelection(board) && isSetSelectionOperation(board)) {
|
|
115
125
|
try {
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
126
|
+
selectionRectangleG?.remove();
|
|
127
|
+
const temporaryElements = getTemporaryElements(board);
|
|
128
|
+
let elements = temporaryElements ? temporaryElements : getHitElementsBySelection(board);
|
|
129
|
+
if (!options.isMultiple && elements.length > 1) {
|
|
130
|
+
elements = [elements[0]];
|
|
131
|
+
}
|
|
132
|
+
if (isShift && board.selection && Selection.isCollapsed(board.selection)) {
|
|
133
|
+
const newSelectedElements = [...getSelectedElements(board)];
|
|
134
|
+
elements.forEach(element => {
|
|
135
|
+
if (newSelectedElements.includes(element)) {
|
|
136
|
+
newSelectedElements.splice(newSelectedElements.indexOf(element), 1);
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
newSelectedElements.push(element);
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
cacheSelectedElements(board, newSelectedElements);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
123
145
|
cacheSelectedElements(board, elements);
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
146
|
+
}
|
|
147
|
+
const newElements = getSelectedElements(board);
|
|
148
|
+
previousSelectedElements = newElements;
|
|
149
|
+
deleteTemporaryElements(board);
|
|
150
|
+
if (!isSelectionMoving(board) && newElements.length > 1) {
|
|
151
|
+
selectionRectangleG = createSelectionRectangleG(board);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
catch (error) {
|
|
155
|
+
console.error(error);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
onChange();
|
|
159
|
+
};
|
|
160
|
+
board.afterChange = () => {
|
|
161
|
+
if (isHandleSelection(board) && !isSetSelectionOperation(board)) {
|
|
162
|
+
try {
|
|
163
|
+
const currentSelectedElements = getSelectedElements(board);
|
|
164
|
+
if (currentSelectedElements.length && currentSelectedElements.length > 1) {
|
|
165
|
+
if (currentSelectedElements.length !== previousSelectedElements.length ||
|
|
166
|
+
currentSelectedElements.some((c, index) => c !== previousSelectedElements[index])) {
|
|
167
|
+
selectionRectangleG?.remove();
|
|
127
168
|
selectionRectangleG = createSelectionRectangleG(board);
|
|
169
|
+
previousSelectedElements = currentSelectedElements;
|
|
128
170
|
}
|
|
129
171
|
}
|
|
130
172
|
else {
|
|
131
|
-
|
|
132
|
-
if (currentSelectedElements.length && currentSelectedElements.length > 1) {
|
|
133
|
-
if (currentSelectedElements.length !== previousSelectedElements.length ||
|
|
134
|
-
currentSelectedElements.some((c, index) => c !== previousSelectedElements[index])) {
|
|
135
|
-
selectionRectangleG?.remove();
|
|
136
|
-
selectionRectangleG = createSelectionRectangleG(board);
|
|
137
|
-
previousSelectedElements = currentSelectedElements;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
else {
|
|
141
|
-
selectionRectangleG?.remove();
|
|
142
|
-
}
|
|
173
|
+
selectionRectangleG?.remove();
|
|
143
174
|
}
|
|
144
175
|
}
|
|
145
176
|
catch (error) {
|
|
146
177
|
console.error(error);
|
|
147
178
|
}
|
|
148
179
|
}
|
|
149
|
-
|
|
180
|
+
afterChange();
|
|
150
181
|
};
|
|
151
182
|
board.setPluginOptions(PlaitPluginKey.withSelection, {
|
|
152
183
|
isMultiple: true,
|
|
@@ -154,6 +185,13 @@ export function withSelection(board) {
|
|
|
154
185
|
});
|
|
155
186
|
return board;
|
|
156
187
|
}
|
|
188
|
+
export function isHandleSelection(board) {
|
|
189
|
+
const options = board.getPluginOptions(PlaitPluginKey.withSelection);
|
|
190
|
+
return board.pointer !== PlaitPointerType.hand && !options.isDisabledSelect && !PlaitBoard.isReadonly(board);
|
|
191
|
+
}
|
|
192
|
+
export function isSetSelectionOperation(board) {
|
|
193
|
+
return !!board.operations.find(value => value.type === 'set_selection');
|
|
194
|
+
}
|
|
157
195
|
export function getTemporaryElements(board) {
|
|
158
196
|
const ref = BOARD_TO_TEMPORARY_ELEMENTS.get(board);
|
|
159
197
|
if (ref) {
|
|
@@ -195,4 +233,4 @@ export function createSelectionRectangleG(board) {
|
|
|
195
233
|
}
|
|
196
234
|
return null;
|
|
197
235
|
}
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { transformPoint } from '../utils/board';\nimport { isMainPointer, toPoint } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    clearSelectedElement,\n    getHitElementByPoint,\n    getHitElementsBySelection,\n    getSelectedElements,\n    removeSelectedElement\n} from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { getRectangleByElements } from '../utils/element';\nimport { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';\nimport { ACTIVE_STROKE_WIDTH, ATTACHED_ELEMENT_CLASS_NAME, SELECTION_RECTANGLE_CLASS_NAME } from '../constants/selection';\nimport { drawRectangle, preventTouchMove, throttleRAF } from '../utils';\nimport { PlaitOptionsBoard, PlaitPluginOptions } from './with-options';\nimport { PlaitPluginKey } from '../interfaces/plugin-key';\n\nexport interface WithPluginOptions extends PlaitPluginOptions {\n    isMultiple: boolean;\n    isDisabledSelect: boolean;\n}\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, globalPointerMove, globalPointerUp, onChange } = board;\n\n    let start: Point | null = null;\n    let end: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionRectangleG: SVGGElement | null;\n    let previousSelectedElements: PlaitElement[];\n\n    // prevent text from being selected when user pressed main pointer and is moving\n    let needPreventNativeSelectionWhenMoving = false;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const isHitText = event.target instanceof Element && event.target.closest('.plait-richtext-container');\n\n        // prevent text from being selected when user pressed shift and pointer down\n        if (!isHitText && event.shiftKey) {\n            event.preventDefault();\n        }\n\n        if (!isHitText) {\n            needPreventNativeSelectionWhenMoving = true;\n        }\n\n        if (!isMainPointer(event)) {\n            pointerDown(event);\n            return;\n        }\n\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const selection = { anchor: point, focus: point };\n        const hitElement = getHitElementByPoint(board, point);\n        const selectedElements = getSelectedElements(board);\n\n        if (hitElement && selectedElements.includes(hitElement) && !options.isDisabledSelect) {\n            pointerDown(event);\n            return;\n        }\n\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && !hitElement && options.isMultiple && !options.isDisabledSelect) {\n            selectionRectangleG?.remove();\n            start = point;\n            preventTouchMove(board, event, true);\n        }\n\n        Transforms.setSelection(board, selection);\n\n        pointerDown(event);\n    };\n\n    board.globalPointerMove = (event: PointerEvent) => {\n        if (needPreventNativeSelectionWhenMoving) {\n            // prevent text from being selected\n            event.preventDefault();\n        }\n\n        if (start) {\n            const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const rectangle = RectangleClient.toRectangleClient([start, movedTarget]);\n            selectionMovingG?.remove();\n            if (Math.hypot(rectangle.width, rectangle.height) > 5) {\n                end = movedTarget;\n                throttleRAF(() => {\n                    if (start && end) {\n                        Transforms.setSelection(board, { anchor: start, focus: end });\n                    }\n                });\n                setSelectionMoving(board);\n                selectionMovingG = drawRectangle(board, rectangle, {\n                    stroke: SELECTION_BORDER_COLOR,\n                    strokeWidth: 1,\n                    fill: SELECTION_FILL_COLOR,\n                    fillStyle: 'solid'\n                });\n                PlaitBoard.getElementActiveHost(board).append(selectionMovingG);\n            }\n        }\n        globalPointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (start && end) {\n            selectionMovingG?.remove();\n            clearSelectionMoving(board);\n            Transforms.setSelection(board, { anchor: start, focus: end });\n        }\n\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);\n            const isInDocument = event.target instanceof Node && document.contains(event.target);\n            const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);\n            // Clear selection when mouse board outside area\n            // The framework needs to determine whether the board is focused through selection\n            if (!isInBoard && !start && !isAttachedElement && isInDocument) {\n                Transforms.setSelection(board, null);\n            }\n        }\n\n        start = null;\n        end = null;\n        needPreventNativeSelectionWhenMoving = false;\n        preventTouchMove(board, event, false);\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        if (options.isDisabledSelect) {\n            clearSelectedElement(board);\n        }\n\n        // remove selected element if include\n        board.operations.forEach(op => {\n            if (op.type === 'remove_node') {\n                removeSelectedElement(board, op.node);\n            }\n        });\n\n        // calc selected elements entry\n        if (board.pointer !== PlaitPointerType.hand && !options.isDisabledSelect) {\n            try {\n                if (board.operations.find(value => value.type === 'set_selection')) {\n                    selectionRectangleG?.remove();\n                    const temporaryElements = getTemporaryElements(board);\n                    let elements = temporaryElements ? temporaryElements : getHitElementsBySelection(board);\n                    if (!options.isMultiple && elements.length > 1) {\n                        elements = [elements[0]];\n                    }\n                    cacheSelectedElements(board, elements);\n                    previousSelectedElements = elements;\n                    deleteTemporaryElements(board);\n                    if (!isSelectionMoving(board) && elements.length > 1) {\n                        selectionRectangleG = createSelectionRectangleG(board);\n                    }\n                } else {\n                    const currentSelectedElements = getSelectedElements(board);\n                    if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                        if (\n                            currentSelectedElements.length !== previousSelectedElements.length ||\n                            currentSelectedElements.some((c, index) => c !== previousSelectedElements[index])\n                        ) {\n                            selectionRectangleG?.remove();\n                            selectionRectangleG = createSelectionRectangleG(board);\n                            previousSelectedElements = currentSelectedElements;\n                        }\n                    } else {\n                        selectionRectangleG?.remove();\n                    }\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    (board as PlaitOptionsBoard).setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, {\n        isMultiple: true,\n        isDisabledSelect: false\n    });\n\n    return board;\n}\n\nexport function getTemporaryElements(board: PlaitBoard) {\n    const ref = BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n    if (ref) {\n        return ref.elements;\n    } else {\n        return undefined;\n    }\n}\n\nexport function getTemporaryRef(board: PlaitBoard) {\n    return BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n}\n\nexport function deleteTemporaryElements(board: PlaitBoard) {\n    BOARD_TO_TEMPORARY_ELEMENTS.delete(board);\n}\n\nexport function isSelectionMoving(board: PlaitBoard) {\n    return !!BOARD_TO_IS_SELECTION_MOVING.get(board);\n}\n\nexport function setSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardContainer(board).classList.add('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.set(board, true);\n}\n\nexport function clearSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardContainer(board).classList.remove('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.delete(board);\n}\n\nexport function createSelectionRectangleG(board: PlaitBoard) {\n    const elements = getSelectedElements(board);\n    const rectangle = getRectangleByElements(board, elements, false);\n    if (rectangle.width > 0 && rectangle.height > 0 && elements.length > 1) {\n        const selectionRectangleG = drawRectangle(board, RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH), {\n            stroke: SELECTION_BORDER_COLOR,\n            strokeWidth: ACTIVE_STROKE_WIDTH,\n            fillStyle: 'solid'\n        });\n        selectionRectangleG.classList.add(SELECTION_RECTANGLE_CLASS_NAME);\n        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG);\n        return selectionRectangleG;\n    }\n    return null;\n}\n"]}
|
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { transformPoint } from '../utils/board';\nimport { isMainPointer, toPoint } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    clearSelectedElement,\n    getHitElementByPoint,\n    getHitElementsBySelection,\n    getSelectedElements,\n    removeSelectedElement\n} from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { getRectangleByElements } from '../utils/element';\nimport { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';\nimport { ACTIVE_STROKE_WIDTH, ATTACHED_ELEMENT_CLASS_NAME, SELECTION_RECTANGLE_CLASS_NAME } from '../constants/selection';\nimport { drawRectangle, preventTouchMove, throttleRAF } from '../utils';\nimport { PlaitOptionsBoard, PlaitPluginOptions } from './with-options';\nimport { PlaitPluginKey } from '../interfaces/plugin-key';\nimport { Selection } from '../interfaces/selection';\n\nexport interface WithPluginOptions extends PlaitPluginOptions {\n    isMultiple: boolean;\n    isDisabledSelect: boolean;\n}\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, globalPointerMove, globalPointerUp, keyup, onChange, afterChange } = board;\n    let start: Point | null = null;\n    let end: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionRectangleG: SVGGElement | null;\n    let previousSelectedElements: PlaitElement[];\n    // prevent text from being selected when user pressed main pointer and is moving\n    let needPreventNativeSelectionWhenMoving = false;\n    let isShift = false;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const isHitText = event.target instanceof Element && event.target.closest('.plait-richtext-container');\n        if (event.shiftKey) {\n            event.preventDefault();\n            isShift = true;\n        } else {\n            isShift = false;\n        }\n\n        if (!isHitText) {\n            needPreventNativeSelectionWhenMoving = true;\n        }\n\n        if (!isMainPointer(event)) {\n            pointerDown(event);\n            return;\n        }\n\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const selection = { anchor: point, focus: point };\n        const hitElement = getHitElementByPoint(board, point);\n        const selectedElements = getSelectedElements(board);\n\n        if (!isShift && hitElement && selectedElements.includes(hitElement) && !options.isDisabledSelect) {\n            pointerDown(event);\n            return;\n        }\n\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && !hitElement && options.isMultiple && !options.isDisabledSelect) {\n            selectionRectangleG?.remove();\n            start = point;\n            preventTouchMove(board, event, true);\n        }\n\n        Transforms.setSelection(board, selection);\n\n        pointerDown(event);\n    };\n\n    board.keyup = (event: KeyboardEvent) => {\n        if (isShift && event.key === 'Shift') {\n            isShift = false;\n        }\n        keyup(event);\n    };\n\n    board.globalPointerMove = (event: PointerEvent) => {\n        if (needPreventNativeSelectionWhenMoving) {\n            // prevent text from being selected\n            event.preventDefault();\n        }\n\n        if (start && PlaitBoard.isPointer(board, PlaitPointerType.selection)) {\n            const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const rectangle = RectangleClient.toRectangleClient([start, movedTarget]);\n            selectionMovingG?.remove();\n            if (Math.hypot(rectangle.width, rectangle.height) > 5) {\n                end = movedTarget;\n                throttleRAF(() => {\n                    if (start && end) {\n                        Transforms.setSelection(board, { anchor: start, focus: end });\n                    }\n                });\n                setSelectionMoving(board);\n                selectionMovingG = drawRectangle(board, rectangle, {\n                    stroke: SELECTION_BORDER_COLOR,\n                    strokeWidth: 1,\n                    fill: SELECTION_FILL_COLOR,\n                    fillStyle: 'solid'\n                });\n                PlaitBoard.getElementActiveHost(board).append(selectionMovingG);\n            }\n        }\n        globalPointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (start && end) {\n            selectionMovingG?.remove();\n            clearSelectionMoving(board);\n            Transforms.setSelection(board, { anchor: start, focus: end });\n        }\n\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);\n            const isInDocument = event.target instanceof Node && document.contains(event.target);\n            const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);\n            // Clear selection when mouse board outside area\n            // The framework needs to determine whether the board is focused through selection\n            if (!isInBoard && !start && !isAttachedElement && isInDocument) {\n                Transforms.setSelection(board, null);\n            }\n        }\n\n        start = null;\n        end = null;\n        needPreventNativeSelectionWhenMoving = false;\n        preventTouchMove(board, event, false);\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n        if (options.isDisabledSelect) {\n            clearSelectedElement(board);\n        }\n        // remove selected element if include\n        board.operations.forEach(op => {\n            if (op.type === 'remove_node') {\n                removeSelectedElement(board, op.node);\n            }\n        });\n        if (isHandleSelection(board) && isSetSelectionOperation(board)) {\n            try {\n                selectionRectangleG?.remove();\n                const temporaryElements = getTemporaryElements(board);\n                let elements = temporaryElements ? temporaryElements : getHitElementsBySelection(board);\n                if (!options.isMultiple && elements.length > 1) {\n                    elements = [elements[0]];\n                }\n                if (isShift && board.selection && Selection.isCollapsed(board.selection)) {\n                    const newSelectedElements = [...getSelectedElements(board)];\n                    elements.forEach(element => {\n                        if (newSelectedElements.includes(element)) {\n                            newSelectedElements.splice(newSelectedElements.indexOf(element), 1);\n                        } else {\n                            newSelectedElements.push(element);\n                        }\n                    });\n                    cacheSelectedElements(board, newSelectedElements);\n                } else {\n                    cacheSelectedElements(board, elements);\n                }\n                const newElements = getSelectedElements(board);\n                previousSelectedElements = newElements;\n                deleteTemporaryElements(board);\n                if (!isSelectionMoving(board) && newElements.length > 1) {\n                    selectionRectangleG = createSelectionRectangleG(board);\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    board.afterChange = () => {\n        if (isHandleSelection(board) && !isSetSelectionOperation(board)) {\n            try {\n                const currentSelectedElements = getSelectedElements(board);\n                if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                    if (\n                        currentSelectedElements.length !== previousSelectedElements.length ||\n                        currentSelectedElements.some((c, index) => c !== previousSelectedElements[index])\n                    ) {\n                        selectionRectangleG?.remove();\n                        selectionRectangleG = createSelectionRectangleG(board);\n                        previousSelectedElements = currentSelectedElements;\n                    }\n                } else {\n                    selectionRectangleG?.remove();\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        afterChange();\n    };\n\n    (board as PlaitOptionsBoard).setPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection, {\n        isMultiple: true,\n        isDisabledSelect: false\n    });\n\n    return board;\n}\n\nexport function isHandleSelection(board: PlaitBoard) {\n    const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n    return board.pointer !== PlaitPointerType.hand && !options.isDisabledSelect && !PlaitBoard.isReadonly(board);\n}\n\nexport function isSetSelectionOperation(board: PlaitBoard) {\n    return !!board.operations.find(value => value.type === 'set_selection');\n}\n\nexport function getTemporaryElements(board: PlaitBoard) {\n    const ref = BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n    if (ref) {\n        return ref.elements;\n    } else {\n        return undefined;\n    }\n}\n\nexport function getTemporaryRef(board: PlaitBoard) {\n    return BOARD_TO_TEMPORARY_ELEMENTS.get(board);\n}\n\nexport function deleteTemporaryElements(board: PlaitBoard) {\n    BOARD_TO_TEMPORARY_ELEMENTS.delete(board);\n}\n\nexport function isSelectionMoving(board: PlaitBoard) {\n    return !!BOARD_TO_IS_SELECTION_MOVING.get(board);\n}\n\nexport function setSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardContainer(board).classList.add('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.set(board, true);\n}\n\nexport function clearSelectionMoving(board: PlaitBoard) {\n    PlaitBoard.getBoardContainer(board).classList.remove('selection-moving');\n    BOARD_TO_IS_SELECTION_MOVING.delete(board);\n}\n\nexport function createSelectionRectangleG(board: PlaitBoard) {\n    const elements = getSelectedElements(board);\n    const rectangle = getRectangleByElements(board, elements, false);\n    if (rectangle.width > 0 && rectangle.height > 0 && elements.length > 1) {\n        const selectionRectangleG = drawRectangle(board, RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH), {\n            stroke: SELECTION_BORDER_COLOR,\n            strokeWidth: ACTIVE_STROKE_WIDTH,\n            fillStyle: 'solid'\n        });\n        selectionRectangleG.classList.add(SELECTION_RECTANGLE_CLASS_NAME);\n        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG);\n        return selectionRectangleG;\n    }\n    return null;\n}\n"]}
|
|
@@ -17,6 +17,8 @@ function updateViewport(board, origination, zoom) {
|
|
|
17
17
|
clearViewportOrigination(board);
|
|
18
18
|
}
|
|
19
19
|
const updatePointerType = (board, pointer) => {
|
|
20
|
+
if (board.pointer === pointer)
|
|
21
|
+
return;
|
|
20
22
|
board.pointer = pointer;
|
|
21
23
|
const boardComponent = BOARD_TO_COMPONENT.get(board);
|
|
22
24
|
boardComponent?.markForCheck();
|
|
@@ -116,4 +118,4 @@ export const BoardTransforms = {
|
|
|
116
118
|
updateThemeColor,
|
|
117
119
|
fitViewportWidth
|
|
118
120
|
};
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/core/src/transforms/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThemeColorMode } from '../interfaces/theme';\nimport { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { toPoint } from '../utils/dom/common';\nimport { getRectangleByElements } from '../utils/element';\nimport { distanceBetweenPointAndRectangle } from '../utils/math';\nimport {\n    clampZoomLevel,\n    clearViewportOrigination,\n    getViewBoxCenterPoint,\n    getViewportOrigination,\n    initializeViewportContainer\n} from '../utils/viewport';\nimport { BOARD_TO_COMPONENT } from '../utils/weak-maps';\nimport { setViewport } from './viewport';\nimport { depthFirstRecursion, getRealScrollBarWidth } from '../utils';\nimport { PlaitElement } from '../interfaces/element';\nimport { setTheme } from './theme';\nimport { FitViewportOptions } from '../interfaces/viewport';\n\nfunction updateViewport(board: PlaitBoard, origination: Point, zoom?: number) {\n    zoom = zoom ?? board.viewport.zoom;\n    setViewport(board, {\n        ...board.viewport,\n        zoom,\n        origination\n    });\n    clearViewportOrigination(board);\n}\n\nconst updatePointerType = <T extends string = PlaitPointerType>(board: PlaitBoard, pointer: T) => {\n    board.pointer = pointer;\n    const boardComponent = BOARD_TO_COMPONENT.get(board);\n    boardComponent?.markForCheck();\n};\n\nfunction updateZoom(board: PlaitBoard, newZoom: number, isCenter = true) {\n    newZoom = clampZoomLevel(newZoom);\n\n    const mousePoint = PlaitBoard.getMovingPointInBoard(board);\n    const nativeElement = PlaitBoard.getBoardContainer(board);\n    const nativeElementRect = nativeElement.getBoundingClientRect();\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];\n\n    if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], nativeElementRect) === 0) {\n        focusPoint = toPoint(mousePoint[0], mousePoint[1], (nativeElement as unknown) as SVGElement);\n    }\n\n    const zoom = board.viewport.zoom;\n    const origination = getViewportOrigination(board);\n    const centerX = origination![0] + focusPoint[0] / zoom;\n    const centerY = origination![1] + focusPoint[1] / zoom;\n    const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewport(board: PlaitBoard) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const zoom = board.viewport.zoom;\n    const autoFitPadding = 16;\n    const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;\n    const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;\n\n    let newZoom = zoom;\n    if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {\n        newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);\n    } else {\n        newZoom = 1;\n    }\n\n    const centerPoint = getViewBoxCenterPoint(board);\n    const newOrigination = [\n        centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,\n        centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewportWidth(board: PlaitBoard, options: FitViewportOptions) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainer = PlaitBoard.getBoardContainer(board);\n    const boardContainerRectangle = boardContainer.getBoundingClientRect();\n\n    let finalWidth = 0;\n    if (options.maxWidth) {\n        finalWidth = options.maxWidth;\n    } else {\n        finalWidth = boardContainerRectangle.width;\n    }\n\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const contentWidth = finalWidth - 2 * options.autoFitPadding;\n    let newZoom = 0;\n    if (contentWidth < elementHostBox.width) {\n        newZoom = Math.min(contentWidth / elementHostBox.width);\n    } else {\n        newZoom = 1;\n    }\n\n    let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;\n    if (finalHeight > options.limitHeight) {\n        const containerEl = boardContainer.closest(`.${options.containerClass}`) as HTMLElement;\n        containerEl.style.height = `${finalHeight}px`;\n        initializeViewportContainer(board);\n    } else {\n        finalHeight = options.limitHeight;\n    }\n\n    const centerX = elementHostBox.x + elementHostBox.width / 2;\n    const centerY = elementHostBox.y + elementHostBox.height / 2;\n    const newOrigination = [\n        centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,\n        centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\n/**\n * apply theme to every element (remove element custom properties)\n * invoke applyThemeColor\n */\nfunction updateThemeColor(board: PlaitBoard, mode: ThemeColorMode) {\n    mode = mode ?? board.theme.themeColorMode;\n    setTheme(board, { themeColorMode: mode });\n\n    depthFirstRecursion((board as unknown) as PlaitElement, element => {\n        board.applyTheme(element);\n    });\n}\n\nexport const BoardTransforms = {\n    updatePointerType,\n    updateViewport,\n    fitViewport,\n    updateZoom,\n    updateThemeColor,\n    fitViewportWidth\n};\n"]}
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/core/src/transforms/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThemeColorMode } from '../interfaces/theme';\nimport { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { PlaitPointerType } from '../interfaces/pointer';\nimport { toPoint } from '../utils/dom/common';\nimport { getRectangleByElements } from '../utils/element';\nimport { distanceBetweenPointAndRectangle } from '../utils/math';\nimport {\n    clampZoomLevel,\n    clearViewportOrigination,\n    getViewBoxCenterPoint,\n    getViewportOrigination,\n    initializeViewportContainer\n} from '../utils/viewport';\nimport { BOARD_TO_COMPONENT } from '../utils/weak-maps';\nimport { setViewport } from './viewport';\nimport { depthFirstRecursion, getRealScrollBarWidth } from '../utils';\nimport { PlaitElement } from '../interfaces/element';\nimport { setTheme } from './theme';\nimport { FitViewportOptions } from '../interfaces/viewport';\n\nfunction updateViewport(board: PlaitBoard, origination: Point, zoom?: number) {\n    zoom = zoom ?? board.viewport.zoom;\n    setViewport(board, {\n        ...board.viewport,\n        zoom,\n        origination\n    });\n    clearViewportOrigination(board);\n}\n\nconst updatePointerType = <T extends string = PlaitPointerType>(board: PlaitBoard, pointer: T) => {\n    if (board.pointer === pointer) return;\n    board.pointer = pointer;\n    const boardComponent = BOARD_TO_COMPONENT.get(board);\n    boardComponent?.markForCheck();\n};\n\nfunction updateZoom(board: PlaitBoard, newZoom: number, isCenter = true) {\n    newZoom = clampZoomLevel(newZoom);\n\n    const mousePoint = PlaitBoard.getMovingPointInBoard(board);\n    const nativeElement = PlaitBoard.getBoardContainer(board);\n    const nativeElementRect = nativeElement.getBoundingClientRect();\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];\n\n    if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], nativeElementRect) === 0) {\n        focusPoint = toPoint(mousePoint[0], mousePoint[1], (nativeElement as unknown) as SVGElement);\n    }\n\n    const zoom = board.viewport.zoom;\n    const origination = getViewportOrigination(board);\n    const centerX = origination![0] + focusPoint[0] / zoom;\n    const centerY = origination![1] + focusPoint[1] / zoom;\n    const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewport(board: PlaitBoard) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const zoom = board.viewport.zoom;\n    const autoFitPadding = 16;\n    const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;\n    const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;\n\n    let newZoom = zoom;\n    if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {\n        newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);\n    } else {\n        newZoom = 1;\n    }\n\n    const centerPoint = getViewBoxCenterPoint(board);\n    const newOrigination = [\n        centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,\n        centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewportWidth(board: PlaitBoard, options: FitViewportOptions) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainer = PlaitBoard.getBoardContainer(board);\n    const boardContainerRectangle = boardContainer.getBoundingClientRect();\n\n    let finalWidth = 0;\n    if (options.maxWidth) {\n        finalWidth = options.maxWidth;\n    } else {\n        finalWidth = boardContainerRectangle.width;\n    }\n\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const contentWidth = finalWidth - 2 * options.autoFitPadding;\n    let newZoom = 0;\n    if (contentWidth < elementHostBox.width) {\n        newZoom = Math.min(contentWidth / elementHostBox.width);\n    } else {\n        newZoom = 1;\n    }\n\n    let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;\n    if (finalHeight > options.limitHeight) {\n        const containerEl = boardContainer.closest(`.${options.containerClass}`) as HTMLElement;\n        containerEl.style.height = `${finalHeight}px`;\n        initializeViewportContainer(board);\n    } else {\n        finalHeight = options.limitHeight;\n    }\n\n    const centerX = elementHostBox.x + elementHostBox.width / 2;\n    const centerY = elementHostBox.y + elementHostBox.height / 2;\n    const newOrigination = [\n        centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,\n        centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\n/**\n * apply theme to every element (remove element custom properties)\n * invoke applyThemeColor\n */\nfunction updateThemeColor(board: PlaitBoard, mode: ThemeColorMode) {\n    mode = mode ?? board.theme.themeColorMode;\n    setTheme(board, { themeColorMode: mode });\n\n    depthFirstRecursion((board as unknown) as PlaitElement, element => {\n        board.applyTheme(element);\n    });\n}\n\nexport const BoardTransforms = {\n    updatePointerType,\n    updateViewport,\n    fitViewport,\n    updateZoom,\n    updateThemeColor,\n    fitViewportWidth\n};\n"]}
|
package/esm2022/utils/common.mjs
CHANGED
|
@@ -24,10 +24,12 @@ export const debounce = (func, wait, options) => {
|
|
|
24
24
|
}
|
|
25
25
|
else {
|
|
26
26
|
if (options?.leading) {
|
|
27
|
-
|
|
27
|
+
timer(0).subscribe(() => {
|
|
28
|
+
func();
|
|
29
|
+
});
|
|
28
30
|
}
|
|
29
31
|
timerSubscription = timer(wait).subscribe();
|
|
30
32
|
}
|
|
31
33
|
};
|
|
32
34
|
};
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdXRpbHMvY29tbW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBZ0IsS0FBSyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTNDLElBQUksT0FBTyxHQUFrQixJQUFJLENBQUM7QUFFbEMsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLENBQUMsRUFBYyxFQUFFLEVBQUU7SUFDMUMsTUFBTSxZQUFZLEdBQUcsR0FBRyxFQUFFO1FBQ3RCLE9BQU8sR0FBRyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUU7WUFDakMsT0FBTyxHQUFHLElBQUksQ0FBQztZQUNmLEVBQUUsRUFBRSxDQUFDO1FBQ1QsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDLENBQUM7SUFDRixJQUFJLE9BQU8sS0FBSyxJQUFJLEVBQUU7UUFDbEIsb0JBQW9CLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDOUIsT0FBTyxHQUFHLElBQUksQ0FBQztLQUNsQjtJQUNELFlBQVksRUFBRSxDQUFDO0FBQ25CLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxDQUFDLElBQWdCLEVBQUUsSUFBWSxFQUFFLE9BQThCLEVBQUUsRUFBRTtJQUN2RixJQUFJLGlCQUFpQixHQUF3QixJQUFJLENBQUM7SUFDbEQsT0FBTyxHQUFHLEVBQUU7UUFDUixJQUFJLGlCQUFpQixJQUFJLENBQUMsaUJBQWlCLENBQUMsTUFBTSxFQUFFO1lBQ2hELGlCQUFpQixDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2hDLGlCQUFpQixHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUMzQyxJQUFJLEVBQUUsQ0FBQztZQUNYLENBQUMsQ0FBQyxDQUFDO1NBQ047YUFBTTtZQUNILElBQUksT0FBTyxFQUFFLE9BQU8sRUFBRTtnQkFDbEIsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7b0JBQ3BCLElBQUksRUFBRSxDQUFDO2dCQUNYLENBQUMsQ0FBQyxDQUFDO2FBQ047WUFDRCxpQkFBaUIsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsU0FBUyxFQUFFLENBQUM7U0FDL0M7SUFDTCxDQUFDLENBQUM7QUFDTixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdWJzY3JpcHRpb24sIHRpbWVyIH0gZnJvbSAncnhqcyc7XG5cbmxldCB0aW1lcklkOiBudW1iZXIgfCBudWxsID0gbnVsbDtcblxuZXhwb3J0IGNvbnN0IHRocm90dGxlUkFGID0gKGZuOiAoKSA9PiB2b2lkKSA9PiB7XG4gICAgY29uc3Qgc2NoZWR1bGVGdW5jID0gKCkgPT4ge1xuICAgICAgICB0aW1lcklkID0gcmVxdWVzdEFuaW1hdGlvbkZyYW1lKCgpID0+IHtcbiAgICAgICAgICAgIHRpbWVySWQgPSBudWxsO1xuICAgICAgICAgICAgZm4oKTtcbiAgICAgICAgfSk7XG4gICAgfTtcbiAgICBpZiAodGltZXJJZCAhPT0gbnVsbCkge1xuICAgICAgICBjYW5jZWxBbmltYXRpb25GcmFtZSh0aW1lcklkKTtcbiAgICAgICAgdGltZXJJZCA9IG51bGw7XG4gICAgfVxuICAgIHNjaGVkdWxlRnVuYygpO1xufTtcblxuZXhwb3J0IGNvbnN0IGRlYm91bmNlID0gKGZ1bmM6ICgpID0+IHZvaWQsIHdhaXQ6IG51bWJlciwgb3B0aW9ucz86IHsgbGVhZGluZzogYm9vbGVhbiB9KSA9PiB7XG4gICAgbGV0IHRpbWVyU3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb24gfCBudWxsID0gbnVsbDtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICBpZiAodGltZXJTdWJzY3JpcHRpb24gJiYgIXRpbWVyU3Vic2NyaXB0aW9uLmNsb3NlZCkge1xuICAgICAgICAgICAgdGltZXJTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICAgICAgICAgIHRpbWVyU3Vic2NyaXB0aW9uID0gdGltZXIod2FpdCkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICBmdW5jKCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGlmIChvcHRpb25zPy5sZWFkaW5nKSB7XG4gICAgICAgICAgICAgICAgdGltZXIoMCkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgZnVuYygpO1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGltZXJTdWJzY3JpcHRpb24gPSB0aW1lcih3YWl0KS5zdWJzY3JpYmUoKTtcbiAgICAgICAgfVxuICAgIH07XG59O1xuIl19
|