@plait/core 0.75.0-next.1 → 0.75.0-next.3

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.
@@ -1,7 +1,7 @@
1
1
  import { PRESS_AND_MOVE_BUFFER } from '../constants';
2
2
  import { PlaitPointerType, PlaitBoard, PlaitPluginKey } from '../interfaces';
3
3
  import { BoardTransforms } from '../transforms';
4
- import { distanceBetweenPointAndPoint, isMovingElements, isSelectionMoving } from '../utils';
4
+ import { distanceBetweenPointAndPoint, isHitElement, isMovingElements, isSelectionMoving, toHostPoint, toViewBoxPoint } from '../utils';
5
5
  import { isMainPointer } from '../utils/dom/common';
6
6
  import { isSmartHand } from '../utils/mobile';
7
7
  import { updateViewportContainerScroll } from '../utils/viewport';
@@ -12,7 +12,9 @@ export function withHandPointer(board) {
12
12
  let pointerDownEvent = null;
13
13
  board.pointerDown = (event) => {
14
14
  const options = board.getPluginOptions(PlaitPluginKey.withHand);
15
- if ((options?.isHandMode(board, event) || isSmartHand(board, event)) && isMainPointer(event)) {
15
+ const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
16
+ const isHitTarget = isHitElement(board, point);
17
+ if ((options?.isHandMode(board, event) || (isSmartHand(board, event) && !isHitTarget)) && isMainPointer(event)) {
16
18
  movingPoint = {
17
19
  x: event.x,
18
20
  y: event.y
@@ -29,7 +31,7 @@ export function withHandPointer(board) {
29
31
  // Must exceed the PRESS_AND_MOVE_BUFFER threshold defined in withSelection's pointerMove.
30
32
  // The system first checks for drag selection state eligibility
31
33
  // withHand behavior is only triggered if drag selection state is not initiated.
32
- const triggerDistance = PRESS_AND_MOVE_BUFFER + 3;
34
+ const triggerDistance = PRESS_AND_MOVE_BUFFER * 2;
33
35
  if (movingPoint &&
34
36
  !isMoving &&
35
37
  !isSelectionMoving(board) &&
@@ -39,7 +41,11 @@ export function withHandPointer(board) {
39
41
  isMoving = true;
40
42
  PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');
41
43
  }
42
- if ((options?.isHandMode(board, event) || isSmartHand(board, event)) && isMoving && movingPoint && !isSelectionMoving(board)) {
44
+ if ((options?.isHandMode(board, event) || isSmartHand(board, event)) &&
45
+ isMoving &&
46
+ movingPoint &&
47
+ !isSelectionMoving(board) &&
48
+ !isMovingElements(board)) {
43
49
  const viewportContainer = PlaitBoard.getViewportContainer(board);
44
50
  const left = viewportContainer.scrollLeft - (event.x - movingPoint.x);
45
51
  const top = viewportContainer.scrollTop - (event.y - movingPoint.y);
@@ -82,4 +88,4 @@ export function withHandPointer(board) {
82
88
  };
83
89
  return board;
84
90
  }
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-hand.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-hand.ts"],"names":[],"mappings":"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","sourcesContent":["import { PRESS_AND_MOVE_BUFFER } from '../constants';\nimport { PlaitPointerType, PlaitBoard, PlaitBoardMove, WithHandPluginOptions, PlaitPluginKey } from '../interfaces';\nimport { BoardTransforms } from '../transforms';\nimport { distanceBetweenPointAndPoint, isMovingElements, isSelectionMoving } from '../utils';\nimport { isMainPointer } from '../utils/dom/common';\nimport { isSmartHand } from '../utils/mobile';\nimport { updateViewportContainerScroll } from '../utils/viewport';\nimport { PlaitOptionsBoard } from './with-options';\n\nexport function withHandPointer<T extends PlaitBoard>(board: T) {\n    const { pointerDown, pointerMove, globalPointerUp, keyDown, keyUp, pointerUp } = board;\n    let isMoving: boolean = false;\n    let movingPoint: PlaitBoardMove | null = null;\n    let pointerDownEvent: PointerEvent | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const options = (board as unknown as PlaitOptionsBoard).getPluginOptions<WithHandPluginOptions>(PlaitPluginKey.withHand);\n        if ((options?.isHandMode(board, event) || isSmartHand(board, event)) && isMainPointer(event)) {\n            movingPoint = {\n                x: event.x,\n                y: event.y\n            };\n        }\n        pointerDownEvent = event;\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        const options = (board as unknown as PlaitOptionsBoard).getPluginOptions<WithHandPluginOptions>(PlaitPluginKey.withHand);\n        // 阈值必须大于 withSelection 中 pointerMove 的 PRESS_AND_MOVE_BUFFER：\n        // 1. 首先检测是否满足进入拖选状态的条件\n        // 2. 仅当不满足拖选条件时，才会考虑触发 withHand 行为\n        // Must exceed the PRESS_AND_MOVE_BUFFER threshold defined in withSelection's pointerMove.\n        // The system first checks for drag selection state eligibility\n        // withHand behavior is only triggered if drag selection state is not initiated.\n        const triggerDistance = PRESS_AND_MOVE_BUFFER + 3;\n        if (\n            movingPoint &&\n            !isMoving &&\n            !isSelectionMoving(board) &&\n            pointerDownEvent &&\n            distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > triggerDistance &&\n            !isMovingElements(board)\n        ) {\n            isMoving = true;\n            PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');\n        }\n        if ((options?.isHandMode(board, event) || isSmartHand(board, event)) && isMoving && movingPoint && !isSelectionMoving(board)) {\n            const viewportContainer = PlaitBoard.getViewportContainer(board);\n            const left = viewportContainer.scrollLeft - (event.x - movingPoint.x);\n            const top = viewportContainer.scrollTop - (event.y - movingPoint.y);\n            updateViewportContainerScroll(board, left, top, false);\n            movingPoint.x = event.x;\n            movingPoint.y = event.y;\n        }\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        if (isMoving) {\n            return;\n        }\n        pointerUp(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (movingPoint) {\n            movingPoint = null;\n        }\n        if (isMoving) {\n            isMoving = false;\n            PlaitBoard.getBoardContainer(board).classList.remove('viewport-moving');\n        }\n        globalPointerUp(event);\n    };\n\n    board.keyDown = (event: KeyboardEvent) => {\n        if (event.code === 'Space') {\n            if (!PlaitBoard.isPointer(board, PlaitPointerType.hand)) {\n                BoardTransforms.updatePointerType(board, PlaitPointerType.hand);\n            }\n            event.preventDefault();\n        }\n        keyDown(event);\n    };\n\n    board.keyUp = (event: KeyboardEvent) => {\n        if (!board.options.readonly && event.code === 'Space') {\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n        keyUp(event);\n    };\n\n    return board;\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-hand.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-hand.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAyC,cAAc,EAAE,MAAM,eAAe,CAAC;AACpH,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,4BAA4B,EAAE,YAAY,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AACxI,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,6BAA6B,EAAE,MAAM,mBAAmB,CAAC;AAGlE,MAAM,UAAU,eAAe,CAAuB,KAAQ;IAC1D,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,eAAe,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC;IACvF,IAAI,QAAQ,GAAY,KAAK,CAAC;IAC9B,IAAI,WAAW,GAA0B,IAAI,CAAC;IAC9C,IAAI,gBAAgB,GAAwB,IAAI,CAAC;IAEjD,KAAK,CAAC,WAAW,GAAG,CAAC,KAAmB,EAAE,EAAE;QACxC,MAAM,OAAO,GAAI,KAAsC,CAAC,gBAAgB,CAAwB,cAAc,CAAC,QAAQ,CAAC,CAAC;QACzH,MAAM,KAAK,GAAG,cAAc,CAAC,KAAK,EAAE,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,WAAW,GAAG,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC;YAC7G,WAAW,GAAG;gBACV,CAAC,EAAE,KAAK,CAAC,CAAC;gBACV,CAAC,EAAE,KAAK,CAAC,CAAC;aACb,CAAC;QACN,CAAC;QACD,gBAAgB,GAAG,KAAK,CAAC;QACzB,WAAW,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC,CAAC;IAEF,KAAK,CAAC,WAAW,GAAG,CAAC,KAAmB,EAAE,EAAE;QACxC,MAAM,OAAO,GAAI,KAAsC,CAAC,gBAAgB,CAAwB,cAAc,CAAC,QAAQ,CAAC,CAAC;QACzH,8DAA8D;QAC9D,uBAAuB;QACvB,mCAAmC;QACnC,0FAA0F;QAC1F,+DAA+D;QAC/D,gFAAgF;QAChF,MAAM,eAAe,GAAG,qBAAqB,GAAG,CAAC,CAAC;QAClD,IACI,WAAW;YACX,CAAC,QAAQ;YACT,CAAC,iBAAiB,CAAC,KAAK,CAAC;YACzB,gBAAgB;YAChB,4BAA4B,CAAC,gBAAgB,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,eAAe;YACxG,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAC1B,CAAC;YACC,QAAQ,GAAG,IAAI,CAAC;YAChB,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACzE,CAAC;QACD,IACI,CAAC,OAAO,EAAE,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YAChE,QAAQ;YACR,WAAW;YACX,CAAC,iBAAiB,CAAC,KAAK,CAAC;YACzB,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAC1B,CAAC;YACC,MAAM,iBAAiB,GAAG,UAAU,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YACjE,MAAM,IAAI,GAAG,iBAAiB,CAAC,UAAU,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;YACtE,MAAM,GAAG,GAAG,iBAAiB,CAAC,SAAS,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;YACpE,6BAA6B,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;YACvD,WAAW,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;YACxB,WAAW,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,CAAC;QACD,WAAW,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC,CAAC;IAEF,KAAK,CAAC,SAAS,GAAG,CAAC,KAAmB,EAAE,EAAE;QACtC,IAAI,QAAQ,EAAE,CAAC;YACX,OAAO;QACX,CAAC;QACD,SAAS,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,KAAK,CAAC,eAAe,GAAG,CAAC,KAAmB,EAAE,EAAE;QAC5C,IAAI,WAAW,EAAE,CAAC;YACd,WAAW,GAAG,IAAI,CAAC;QACvB,CAAC;QACD,IAAI,QAAQ,EAAE,CAAC;YACX,QAAQ,GAAG,KAAK,CAAC;YACjB,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC5E,CAAC;QACD,eAAe,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC,CAAC;IAEF,KAAK,CAAC,OAAO,GAAG,CAAC,KAAoB,EAAE,EAAE;QACrC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YACzB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,EAAE,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC;gBACtD,eAAe,CAAC,iBAAiB,CAAC,KAAK,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC;YACpE,CAAC;YACD,KAAK,CAAC,cAAc,EAAE,CAAC;QAC3B,CAAC;QACD,OAAO,CAAC,KAAK,CAAC,CAAC;IACnB,CAAC,CAAC;IAEF,KAAK,CAAC,KAAK,GAAG,CAAC,KAAoB,EAAE,EAAE;QACnC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YACpD,eAAe,CAAC,iBAAiB,CAAC,KAAK,EAAE,gBAAgB,CAAC,SAAS,CAAC,CAAC;QACzE,CAAC;QACD,KAAK,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC,CAAC;IAEF,OAAO,KAAK,CAAC;AACjB,CAAC","sourcesContent":["import { PRESS_AND_MOVE_BUFFER } from '../constants';\nimport { PlaitPointerType, PlaitBoard, PlaitBoardMove, WithHandPluginOptions, PlaitPluginKey } from '../interfaces';\nimport { BoardTransforms } from '../transforms';\nimport { distanceBetweenPointAndPoint, isHitElement, isMovingElements, isSelectionMoving, toHostPoint, toViewBoxPoint } from '../utils';\nimport { isMainPointer } from '../utils/dom/common';\nimport { isSmartHand } from '../utils/mobile';\nimport { updateViewportContainerScroll } from '../utils/viewport';\nimport { PlaitOptionsBoard } from './with-options';\n\nexport function withHandPointer<T extends PlaitBoard>(board: T) {\n    const { pointerDown, pointerMove, globalPointerUp, keyDown, keyUp, pointerUp } = board;\n    let isMoving: boolean = false;\n    let movingPoint: PlaitBoardMove | null = null;\n    let pointerDownEvent: PointerEvent | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        const options = (board as unknown as PlaitOptionsBoard).getPluginOptions<WithHandPluginOptions>(PlaitPluginKey.withHand);\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const isHitTarget = isHitElement(board, point);\n        if ((options?.isHandMode(board, event) || (isSmartHand(board, event) && !isHitTarget)) && isMainPointer(event)) {\n            movingPoint = {\n                x: event.x,\n                y: event.y\n            };\n        }\n        pointerDownEvent = event;\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        const options = (board as unknown as PlaitOptionsBoard).getPluginOptions<WithHandPluginOptions>(PlaitPluginKey.withHand);\n        // 阈值必须大于 withSelection 中 pointerMove 的 PRESS_AND_MOVE_BUFFER：\n        // 1. 首先检测是否满足进入拖选状态的条件\n        // 2. 仅当不满足拖选条件时，才会考虑触发 withHand 行为\n        // Must exceed the PRESS_AND_MOVE_BUFFER threshold defined in withSelection's pointerMove.\n        // The system first checks for drag selection state eligibility\n        // withHand behavior is only triggered if drag selection state is not initiated.\n        const triggerDistance = PRESS_AND_MOVE_BUFFER * 2;\n        if (\n            movingPoint &&\n            !isMoving &&\n            !isSelectionMoving(board) &&\n            pointerDownEvent &&\n            distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > triggerDistance &&\n            !isMovingElements(board)\n        ) {\n            isMoving = true;\n            PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');\n        }\n        if (\n            (options?.isHandMode(board, event) || isSmartHand(board, event)) &&\n            isMoving &&\n            movingPoint &&\n            !isSelectionMoving(board) &&\n            !isMovingElements(board)\n        ) {\n            const viewportContainer = PlaitBoard.getViewportContainer(board);\n            const left = viewportContainer.scrollLeft - (event.x - movingPoint.x);\n            const top = viewportContainer.scrollTop - (event.y - movingPoint.y);\n            updateViewportContainerScroll(board, left, top, false);\n            movingPoint.x = event.x;\n            movingPoint.y = event.y;\n        }\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        if (isMoving) {\n            return;\n        }\n        pointerUp(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (movingPoint) {\n            movingPoint = null;\n        }\n        if (isMoving) {\n            isMoving = false;\n            PlaitBoard.getBoardContainer(board).classList.remove('viewport-moving');\n        }\n        globalPointerUp(event);\n    };\n\n    board.keyDown = (event: KeyboardEvent) => {\n        if (event.code === 'Space') {\n            if (!PlaitBoard.isPointer(board, PlaitPointerType.hand)) {\n                BoardTransforms.updatePointerType(board, PlaitPointerType.hand);\n            }\n            event.preventDefault();\n        }\n        keyDown(event);\n    };\n\n    board.keyUp = (event: KeyboardEvent) => {\n        if (!board.options.readonly && event.code === 'Space') {\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n        keyUp(event);\n    };\n\n    return board;\n}\n"]}
@@ -5,7 +5,7 @@ import { RectangleClient } from '../interfaces/rectangle-client';
5
5
  import { cacheSelectedElements, clearSelectedElement, getHitElementsBySelection, getSelectedElements, isHitElement, removeSelectedElement } from '../utils/selected-element';
6
6
  import { PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';
7
7
  import { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';
8
- import { clearSelectionMoving, deleteTemporaryElements, drawRectangle, getTemporaryElements, isDragging, isHandleSelection, isSelectionMoving, setSelectionMoving, throttleRAF, toHostPoint, toViewBoxPoint, setSelectedElementsWithGroup, hasSetSelectionOperation, getSelectionOptions, setSelectionOptions, distanceBetweenPointAndPoint } from '../utils';
8
+ import { clearSelectionMoving, deleteTemporaryElements, drawRectangle, getTemporaryElements, isDragging, isHandleSelection, isSelectionMoving, setSelectionMoving, throttleRAF, toHostPoint, toViewBoxPoint, setSelectedElementsWithGroup, hasSetSelectionOperation, getSelectionOptions, setSelectionOptions, distanceBetweenPointAndPoint, isMobileDeviceEvent } from '../utils';
9
9
  import { Selection } from '../interfaces/selection';
10
10
  import { PRESS_AND_MOVE_BUFFER } from '../constants';
11
11
  export function withSelection(board) {
@@ -32,11 +32,17 @@ export function withSelection(board) {
32
32
  !isHitTarget &&
33
33
  options.isMultipleSelection &&
34
34
  !options.isDisabledSelection) {
35
- // start rectangle selection
36
- timerId = setTimeout(() => {
35
+ // start drag selection
36
+ if (isMobileDeviceEvent(event)) {
37
+ timerId = setTimeout(() => {
38
+ start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
39
+ timerId = null;
40
+ console.log('enter selection');
41
+ }, 500);
42
+ }
43
+ else {
37
44
  start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
38
- timerId = null;
39
- }, 500);
45
+ }
40
46
  }
41
47
  pointerDownEvent = event;
42
48
  pointerDown(event);
@@ -52,22 +58,20 @@ export function withSelection(board) {
52
58
  const movedTarget = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
53
59
  const rectangle = RectangleClient.getRectangleByPoints([start, movedTarget]);
54
60
  selectionMovingG?.remove();
55
- if (Math.hypot(rectangle.width, rectangle.height) > PRESS_AND_MOVE_BUFFER || isSelectionMoving(board)) {
56
- end = movedTarget;
57
- throttleRAF(board, 'with-selection', () => {
58
- if (start && end) {
59
- Transforms.setSelection(board, { anchor: start, focus: end });
60
- }
61
- });
62
- setSelectionMoving(board);
63
- selectionMovingG = drawRectangle(board, rectangle, {
64
- stroke: SELECTION_BORDER_COLOR,
65
- strokeWidth: 1,
66
- fill: SELECTION_FILL_COLOR,
67
- fillStyle: 'solid'
68
- });
69
- PlaitBoard.getElementActiveHost(board).append(selectionMovingG);
70
- }
61
+ end = movedTarget;
62
+ throttleRAF(board, 'with-selection', () => {
63
+ if (start && end) {
64
+ Transforms.setSelection(board, { anchor: start, focus: end });
65
+ }
66
+ });
67
+ setSelectionMoving(board);
68
+ selectionMovingG = drawRectangle(board, rectangle, {
69
+ stroke: SELECTION_BORDER_COLOR,
70
+ strokeWidth: 1,
71
+ fill: SELECTION_FILL_COLOR,
72
+ fillStyle: 'solid'
73
+ });
74
+ PlaitBoard.getElementActiveHost(board).append(selectionMovingG);
71
75
  }
72
76
  pointerMove(event);
73
77
  };
@@ -103,6 +107,11 @@ export function withSelection(board) {
103
107
  }
104
108
  start = null;
105
109
  end = null;
110
+ if (timerId) {
111
+ clearTimeout(timerId);
112
+ timerId = null;
113
+ }
114
+ pointerDownEvent = null;
106
115
  globalPointerUp(event);
107
116
  };
108
117
  board.onChange = () => {
@@ -217,4 +226,4 @@ export function withSelection(board) {
217
226
  });
218
227
  return board;
219
228
  }
220
- //# 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 { isMainPointer } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    clearSelectedElement,\n    getHitElementsBySelection,\n    getSelectedElements,\n    isHitElement,\n    removeSelectedElement\n} from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';\nimport {\n    clearSelectionMoving,\n    deleteTemporaryElements,\n    drawRectangle,\n    getTemporaryElements,\n    isDragging,\n    isHandleSelection,\n    isSelectionMoving,\n    setSelectionMoving,\n    throttleRAF,\n    toHostPoint,\n    toViewBoxPoint,\n    setSelectedElementsWithGroup,\n    hasSetSelectionOperation,\n    getSelectionOptions,\n    setSelectionOptions,\n    distanceBetweenPointAndPoint\n} from '../utils';\nimport { Selection } from '../interfaces/selection';\nimport { PRESS_AND_MOVE_BUFFER } from '../constants';\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, pointerUp, pointerMove, globalPointerUp, onChange, afterChange, drawSelectionRectangle } = 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    let isShift = false;\n    let timerId: ReturnType<typeof setTimeout> | null = null;\n    let pointerDownEvent: PointerEvent | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (!isShift && event.shiftKey) {\n            isShift = true;\n        }\n        if (isShift && !event.shiftKey) {\n            isShift = false;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const isHitTarget = isHitElement(board, point);\n        const options = getSelectionOptions(board);\n        if (\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) &&\n            !isHitTarget &&\n            options.isMultipleSelection &&\n            !options.isDisabledSelection\n        ) {\n            // start rectangle selection\n            timerId = setTimeout(() => {\n                start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n                timerId = null;\n            }, 500);\n        }\n        pointerDownEvent = event;\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (\n            timerId &&\n            pointerDownEvent &&\n            distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > PRESS_AND_MOVE_BUFFER\n        ) {\n            clearTimeout(timerId);\n            timerId = null;\n        }\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && start) {\n            const movedTarget = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            const rectangle = RectangleClient.getRectangleByPoints([start, movedTarget]);\n            selectionMovingG?.remove();\n            if (Math.hypot(rectangle.width, rectangle.height) > PRESS_AND_MOVE_BUFFER || isSelectionMoving(board)) {\n                end = movedTarget;\n                throttleRAF(board, 'with-selection', () => {\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        pointerMove(event);\n    };\n\n    // handle the end of click select\n    board.pointerUp = (event: PointerEvent) => {\n        const isSetSelectionPointer =\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) || PlaitBoard.isPointer(board, PlaitPointerType.hand);\n        const isSkip = !isMainPointer(event) || isDragging(board) || !isSetSelectionPointer;\n        if (isSkip) {\n            pointerUp(event);\n            return;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const selection = { anchor: point, focus: point };\n        Transforms.setSelection(board, selection);\n        pointerUp(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        const options = getSelectionOptions(board);\n        if (PlaitBoard.isFocus(board) && !options.isPreventClearSelection) {\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        start = null;\n        end = null;\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = getSelectionOptions(board);\n        if (options.isDisabledSelection) {\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, true);\n            }\n        });\n        if (isHandleSelection(board) && hasSetSelectionOperation(board)) {\n            try {\n                if (!isShift) {\n                    selectionRectangleG?.remove();\n                }\n                const temporaryElements = getTemporaryElements(board);\n                if (temporaryElements) {\n                    cacheSelectedElements(board, [...temporaryElements]);\n                } else {\n                    let elements = getHitElementsBySelection(board);\n                    if (!options.isMultipleSelection && elements.length > 1) {\n                        elements = [elements[0]];\n                    }\n                    const isHitElementWithGroup = elements.some((item) => item.groupId);\n                    const selectedElements = getSelectedElements(board);\n                    if (isHitElementWithGroup) {\n                        setSelectedElementsWithGroup(board, elements, isShift);\n                    } else {\n                        if (board.selection && Selection.isCollapsed(board.selection)) {\n                            const element = board.getOneHitElement(elements);\n                            if (element) {\n                                elements = [element];\n                            }\n                        }\n                        if (isShift) {\n                            const newElements = [...selectedElements];\n                            if (board.selection && Selection.isCollapsed(board.selection)) {\n                                elements.forEach((element) => {\n                                    if (newElements.includes(element)) {\n                                        newElements.splice(newElements.indexOf(element), 1);\n                                    } else {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, newElements);\n                            } else {\n                                elements.forEach((element) => {\n                                    if (!newElements.includes(element)) {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, [...newElements]);\n                            }\n                        } else {\n                            cacheSelectedElements(board, [...elements]);\n                        }\n                    }\n                }\n                const newElements = getSelectedElements(board);\n                previousSelectedElements = [...newElements];\n                deleteTemporaryElements(board);\n                if (!isSelectionMoving(board)) {\n                    selectionRectangleG?.remove();\n                    if (newElements.length > 1) {\n                        selectionRectangleG = board.drawSelectionRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                    }\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    board.afterChange = () => {\n        if (isHandleSelection(board) && !hasSetSelectionOperation(board)) {\n            try {\n                const currentSelectedElements = getSelectedElements(board);\n                if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                    if (\n                        previousSelectedElements &&\n                        (currentSelectedElements.length !== previousSelectedElements.length ||\n                            currentSelectedElements.some((c, index) => c !== previousSelectedElements[index]))\n                    ) {\n                        selectionRectangleG?.remove();\n                        selectionRectangleG = board.drawSelectionRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                        previousSelectedElements = [...currentSelectedElements];\n                    }\n                } else {\n                    selectionRectangleG?.remove();\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        afterChange();\n    };\n\n    setSelectionOptions(board, {\n        isMultipleSelection: true,\n        isDisabledSelection: false,\n        isPreventClearSelection: false\n    });\n\n    return board;\n}\n"]}
229
+ //# 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 { isMainPointer } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    clearSelectedElement,\n    getHitElementsBySelection,\n    getSelectedElements,\n    isHitElement,\n    removeSelectedElement\n} from '../utils/selected-element';\nimport { PlaitElement, PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';\nimport {\n    clearSelectionMoving,\n    deleteTemporaryElements,\n    drawRectangle,\n    getTemporaryElements,\n    isDragging,\n    isHandleSelection,\n    isSelectionMoving,\n    setSelectionMoving,\n    throttleRAF,\n    toHostPoint,\n    toViewBoxPoint,\n    setSelectedElementsWithGroup,\n    hasSetSelectionOperation,\n    getSelectionOptions,\n    setSelectionOptions,\n    distanceBetweenPointAndPoint,\n    isMobileDeviceEvent\n} from '../utils';\nimport { Selection } from '../interfaces/selection';\nimport { PRESS_AND_MOVE_BUFFER } from '../constants';\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, pointerUp, pointerMove, globalPointerUp, onChange, afterChange, drawSelectionRectangle } = 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    let isShift = false;\n    let timerId: ReturnType<typeof setTimeout> | null = null;\n    let pointerDownEvent: PointerEvent | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (!isShift && event.shiftKey) {\n            isShift = true;\n        }\n        if (isShift && !event.shiftKey) {\n            isShift = false;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const isHitTarget = isHitElement(board, point);\n        const options = getSelectionOptions(board);\n        if (\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) &&\n            !isHitTarget &&\n            options.isMultipleSelection &&\n            !options.isDisabledSelection\n        ) {\n            // start drag selection\n            if (isMobileDeviceEvent(event)) {\n                timerId = setTimeout(() => {\n                    start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n                    timerId = null;\n                    console.log('enter selection');\n                }, 500);\n            } else {\n                start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            }\n        }\n        pointerDownEvent = event;\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (\n            timerId &&\n            pointerDownEvent &&\n            distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > PRESS_AND_MOVE_BUFFER\n        ) {\n            clearTimeout(timerId);\n            timerId = null;\n        }\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && start) {\n            const movedTarget = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n            const rectangle = RectangleClient.getRectangleByPoints([start, movedTarget]);\n            selectionMovingG?.remove();\n            end = movedTarget;\n            throttleRAF(board, 'with-selection', () => {\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        pointerMove(event);\n    };\n\n    // handle the end of click select\n    board.pointerUp = (event: PointerEvent) => {\n        const isSetSelectionPointer =\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) || PlaitBoard.isPointer(board, PlaitPointerType.hand);\n        const isSkip = !isMainPointer(event) || isDragging(board) || !isSetSelectionPointer;\n        if (isSkip) {\n            pointerUp(event);\n            return;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const selection = { anchor: point, focus: point };\n        Transforms.setSelection(board, selection);\n        pointerUp(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        const options = getSelectionOptions(board);\n        if (PlaitBoard.isFocus(board) && !options.isPreventClearSelection) {\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        start = null;\n        end = null;\n        if (timerId) {\n            clearTimeout(timerId);\n            timerId = null;\n        }\n        pointerDownEvent = null;\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = getSelectionOptions(board);\n        if (options.isDisabledSelection) {\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, true);\n            }\n        });\n        if (isHandleSelection(board) && hasSetSelectionOperation(board)) {\n            try {\n                if (!isShift) {\n                    selectionRectangleG?.remove();\n                }\n                const temporaryElements = getTemporaryElements(board);\n                if (temporaryElements) {\n                    cacheSelectedElements(board, [...temporaryElements]);\n                } else {\n                    let elements = getHitElementsBySelection(board);\n                    if (!options.isMultipleSelection && elements.length > 1) {\n                        elements = [elements[0]];\n                    }\n                    const isHitElementWithGroup = elements.some((item) => item.groupId);\n                    const selectedElements = getSelectedElements(board);\n                    if (isHitElementWithGroup) {\n                        setSelectedElementsWithGroup(board, elements, isShift);\n                    } else {\n                        if (board.selection && Selection.isCollapsed(board.selection)) {\n                            const element = board.getOneHitElement(elements);\n                            if (element) {\n                                elements = [element];\n                            }\n                        }\n                        if (isShift) {\n                            const newElements = [...selectedElements];\n                            if (board.selection && Selection.isCollapsed(board.selection)) {\n                                elements.forEach((element) => {\n                                    if (newElements.includes(element)) {\n                                        newElements.splice(newElements.indexOf(element), 1);\n                                    } else {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, newElements);\n                            } else {\n                                elements.forEach((element) => {\n                                    if (!newElements.includes(element)) {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, [...newElements]);\n                            }\n                        } else {\n                            cacheSelectedElements(board, [...elements]);\n                        }\n                    }\n                }\n                const newElements = getSelectedElements(board);\n                previousSelectedElements = [...newElements];\n                deleteTemporaryElements(board);\n                if (!isSelectionMoving(board)) {\n                    selectionRectangleG?.remove();\n                    if (newElements.length > 1) {\n                        selectionRectangleG = board.drawSelectionRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                    }\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    board.afterChange = () => {\n        if (isHandleSelection(board) && !hasSetSelectionOperation(board)) {\n            try {\n                const currentSelectedElements = getSelectedElements(board);\n                if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                    if (\n                        previousSelectedElements &&\n                        (currentSelectedElements.length !== previousSelectedElements.length ||\n                            currentSelectedElements.some((c, index) => c !== previousSelectedElements[index]))\n                    ) {\n                        selectionRectangleG?.remove();\n                        selectionRectangleG = board.drawSelectionRectangle();\n                        PlaitBoard.getElementActiveHost(board).append(selectionRectangleG!);\n                        previousSelectedElements = [...currentSelectedElements];\n                    }\n                } else {\n                    selectionRectangleG?.remove();\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        afterChange();\n    };\n\n    setSelectionOptions(board, {\n        isMultipleSelection: true,\n        isDisabledSelection: false,\n        isPreventClearSelection: false\n    });\n\n    return board;\n}\n"]}
@@ -5525,7 +5525,9 @@ function withHandPointer(board) {
5525
5525
  let pointerDownEvent = null;
5526
5526
  board.pointerDown = (event) => {
5527
5527
  const options = board.getPluginOptions(PlaitPluginKey.withHand);
5528
- if ((options?.isHandMode(board, event) || isSmartHand(board, event)) && isMainPointer(event)) {
5528
+ const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
5529
+ const isHitTarget = isHitElement(board, point);
5530
+ if ((options?.isHandMode(board, event) || (isSmartHand(board, event) && !isHitTarget)) && isMainPointer(event)) {
5529
5531
  movingPoint = {
5530
5532
  x: event.x,
5531
5533
  y: event.y
@@ -5542,7 +5544,7 @@ function withHandPointer(board) {
5542
5544
  // Must exceed the PRESS_AND_MOVE_BUFFER threshold defined in withSelection's pointerMove.
5543
5545
  // The system first checks for drag selection state eligibility
5544
5546
  // withHand behavior is only triggered if drag selection state is not initiated.
5545
- const triggerDistance = PRESS_AND_MOVE_BUFFER + 3;
5547
+ const triggerDistance = PRESS_AND_MOVE_BUFFER * 2;
5546
5548
  if (movingPoint &&
5547
5549
  !isMoving &&
5548
5550
  !isSelectionMoving(board) &&
@@ -5552,7 +5554,11 @@ function withHandPointer(board) {
5552
5554
  isMoving = true;
5553
5555
  PlaitBoard.getBoardContainer(board).classList.add('viewport-moving');
5554
5556
  }
5555
- if ((options?.isHandMode(board, event) || isSmartHand(board, event)) && isMoving && movingPoint && !isSelectionMoving(board)) {
5557
+ if ((options?.isHandMode(board, event) || isSmartHand(board, event)) &&
5558
+ isMoving &&
5559
+ movingPoint &&
5560
+ !isSelectionMoving(board) &&
5561
+ !isMovingElements(board)) {
5556
5562
  const viewportContainer = PlaitBoard.getViewportContainer(board);
5557
5563
  const left = viewportContainer.scrollLeft - (event.x - movingPoint.x);
5558
5564
  const top = viewportContainer.scrollTop - (event.y - movingPoint.y);
@@ -6297,11 +6303,17 @@ function withSelection(board) {
6297
6303
  !isHitTarget &&
6298
6304
  options.isMultipleSelection &&
6299
6305
  !options.isDisabledSelection) {
6300
- // start rectangle selection
6301
- timerId = setTimeout(() => {
6306
+ // start drag selection
6307
+ if (isMobileDeviceEvent(event)) {
6308
+ timerId = setTimeout(() => {
6309
+ start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
6310
+ timerId = null;
6311
+ console.log('enter selection');
6312
+ }, 500);
6313
+ }
6314
+ else {
6302
6315
  start = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
6303
- timerId = null;
6304
- }, 500);
6316
+ }
6305
6317
  }
6306
6318
  pointerDownEvent = event;
6307
6319
  pointerDown(event);
@@ -6317,22 +6329,20 @@ function withSelection(board) {
6317
6329
  const movedTarget = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
6318
6330
  const rectangle = RectangleClient.getRectangleByPoints([start, movedTarget]);
6319
6331
  selectionMovingG?.remove();
6320
- if (Math.hypot(rectangle.width, rectangle.height) > PRESS_AND_MOVE_BUFFER || isSelectionMoving(board)) {
6321
- end = movedTarget;
6322
- throttleRAF(board, 'with-selection', () => {
6323
- if (start && end) {
6324
- Transforms.setSelection(board, { anchor: start, focus: end });
6325
- }
6326
- });
6327
- setSelectionMoving(board);
6328
- selectionMovingG = drawRectangle(board, rectangle, {
6329
- stroke: SELECTION_BORDER_COLOR,
6330
- strokeWidth: 1,
6331
- fill: SELECTION_FILL_COLOR,
6332
- fillStyle: 'solid'
6333
- });
6334
- PlaitBoard.getElementActiveHost(board).append(selectionMovingG);
6335
- }
6332
+ end = movedTarget;
6333
+ throttleRAF(board, 'with-selection', () => {
6334
+ if (start && end) {
6335
+ Transforms.setSelection(board, { anchor: start, focus: end });
6336
+ }
6337
+ });
6338
+ setSelectionMoving(board);
6339
+ selectionMovingG = drawRectangle(board, rectangle, {
6340
+ stroke: SELECTION_BORDER_COLOR,
6341
+ strokeWidth: 1,
6342
+ fill: SELECTION_FILL_COLOR,
6343
+ fillStyle: 'solid'
6344
+ });
6345
+ PlaitBoard.getElementActiveHost(board).append(selectionMovingG);
6336
6346
  }
6337
6347
  pointerMove(event);
6338
6348
  };
@@ -6368,6 +6378,11 @@ function withSelection(board) {
6368
6378
  }
6369
6379
  start = null;
6370
6380
  end = null;
6381
+ if (timerId) {
6382
+ clearTimeout(timerId);
6383
+ timerId = null;
6384
+ }
6385
+ pointerDownEvent = null;
6371
6386
  globalPointerUp(event);
6372
6387
  };
6373
6388
  board.onChange = () => {