@plait/core 0.50.1 → 0.51.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/README.md +30 -28
  2. package/board/board.component.interface.d.ts +0 -5
  3. package/esm2022/board/board.component.interface.mjs +1 -1
  4. package/esm2022/board/board.component.mjs +12 -9
  5. package/esm2022/core/children/children.component.mjs +4 -4
  6. package/esm2022/core/element/element.component.mjs +4 -4
  7. package/esm2022/core/element/plugin-element.mjs +4 -4
  8. package/esm2022/core/island/island-base.component.mjs +7 -7
  9. package/esm2022/interfaces/board.mjs +3 -3
  10. package/esm2022/interfaces/direction.mjs +1 -1
  11. package/esm2022/interfaces/point.mjs +20 -5
  12. package/esm2022/interfaces/rectangle-client.mjs +57 -2
  13. package/esm2022/plugins/create-board.mjs +5 -5
  14. package/esm2022/plugins/with-hand.mjs +6 -6
  15. package/esm2022/plugins/with-history.mjs +4 -4
  16. package/esm2022/plugins/with-hotkey.mjs +10 -56
  17. package/esm2022/plugins/with-moving.mjs +97 -37
  18. package/esm2022/plugins/with-selection.mjs +36 -19
  19. package/esm2022/services/image-context.service.mjs +4 -4
  20. package/esm2022/utils/common.mjs +18 -6
  21. package/esm2022/utils/dom/common.mjs +17 -1
  22. package/esm2022/utils/drawing/arrow.mjs +23 -0
  23. package/esm2022/utils/drawing/circle.mjs +4 -0
  24. package/esm2022/utils/drawing/line.mjs +47 -0
  25. package/esm2022/utils/drawing/rectangle.mjs +34 -0
  26. package/esm2022/utils/element.mjs +11 -22
  27. package/esm2022/utils/helper.mjs +2 -2
  28. package/esm2022/utils/id-creator.mjs +2 -2
  29. package/esm2022/utils/index.mjs +5 -5
  30. package/esm2022/utils/math.mjs +37 -4
  31. package/esm2022/utils/moving-element.mjs +2 -7
  32. package/esm2022/utils/selected-element.mjs +15 -2
  33. package/esm2022/utils/weak-maps.mjs +1 -1
  34. package/fesm2022/plait-core.mjs +447 -288
  35. package/fesm2022/plait-core.mjs.map +1 -1
  36. package/interfaces/board.d.ts +4 -4
  37. package/interfaces/direction.d.ts +2 -0
  38. package/interfaces/point.d.ts +7 -2
  39. package/interfaces/rectangle-client.d.ts +7 -6
  40. package/package.json +1 -1
  41. package/plugins/with-moving.d.ts +4 -0
  42. package/styles/styles.scss +4 -0
  43. package/utils/common.d.ts +2 -1
  44. package/utils/dom/common.d.ts +1 -0
  45. package/utils/helper.d.ts +1 -1
  46. package/utils/index.d.ts +4 -4
  47. package/utils/math.d.ts +14 -1
  48. package/utils/moving-element.d.ts +0 -1
  49. package/utils/selected-element.d.ts +2 -1
  50. package/utils/weak-maps.d.ts +8 -2
  51. package/esm2022/utils/draw/arrow.mjs +0 -23
  52. package/esm2022/utils/draw/circle.mjs +0 -4
  53. package/esm2022/utils/draw/line.mjs +0 -47
  54. package/esm2022/utils/draw/rectangle.mjs +0 -34
  55. /package/utils/{draw → drawing}/arrow.d.ts +0 -0
  56. /package/utils/{draw → drawing}/circle.d.ts +0 -0
  57. /package/utils/{draw → drawing}/line.d.ts +0 -0
  58. /package/utils/{draw → drawing}/rectangle.d.ts +0 -0
@@ -1,15 +1,11 @@
1
1
  import { isHotkey } from 'is-hotkey';
2
- import { MERGING, PlaitBoard, PlaitPluginKey } from '../interfaces';
2
+ import { PlaitBoard, PlaitPluginKey } from '../interfaces';
3
3
  import { BoardTransforms, Transforms } from '../transforms';
4
- import { depthFirstRecursion, getSelectedElements, hotkeys, throttleRAF } from '../utils';
4
+ import { depthFirstRecursion, getSelectedElements, hotkeys } from '../utils';
5
5
  export const withHotkey = (board) => {
6
- const { keydown, keyup, globalKeydown } = board;
7
- let isShift = false;
8
- board.keydown = (event) => {
6
+ const { keyDown, keyUp, globalKeyDown } = board;
7
+ board.keyDown = (event) => {
9
8
  const options = board.getPluginOptions(PlaitPluginKey.withSelection);
10
- if (hotkeys.isShift(event)) {
11
- isShift = true;
12
- }
13
9
  if (!PlaitBoard.isReadonly(board) && options.isMultiple && isHotkey('mod+a', event)) {
14
10
  event.preventDefault();
15
11
  let elements = [];
@@ -36,54 +32,12 @@ export const withHotkey = (board) => {
36
32
  event.preventDefault();
37
33
  board.deleteFragment(null);
38
34
  }
39
- if (!PlaitBoard.isReadonly(board) && selectedElements.length > 0 && (hotkeys.isArrow(event) || hotkeys.isExtendArrow(event))) {
40
- event.preventDefault();
41
- const offset = [0, 0];
42
- const buffer = isShift ? 10 : 1;
43
- switch (true) {
44
- case hotkeys.isMoveUp(event) || hotkeys.isExtendUp(event): {
45
- offset[1] = -buffer;
46
- break;
47
- }
48
- case hotkeys.isMoveDown(event) || hotkeys.isExtendDown(event): {
49
- offset[1] = buffer;
50
- break;
51
- }
52
- case hotkeys.isMoveBackward(event) || hotkeys.isExtendBackward(event): {
53
- offset[0] = -buffer;
54
- break;
55
- }
56
- case hotkeys.isMoveForward(event) || hotkeys.isExtendForward(event): {
57
- offset[0] = buffer;
58
- break;
59
- }
60
- }
61
- const selectedElements = getSelectedElements(board);
62
- const relatedElements = board.getRelatedFragment([]);
63
- const movableElements = board.children.filter(item => board.isMovable(item));
64
- throttleRAF(() => {
65
- [...selectedElements, ...relatedElements]
66
- .filter(element => movableElements.includes(element))
67
- .forEach(element => {
68
- const points = element.points || [];
69
- const newPoints = points.map(p => [p[0] + offset[0], p[1] + offset[1]]);
70
- Transforms.setNode(board, {
71
- points: newPoints
72
- }, PlaitBoard.findPath(board, element));
73
- MERGING.set(board, true);
74
- });
75
- });
76
- }
77
- keydown(event);
35
+ keyDown(event);
78
36
  };
79
- board.keyup = (event) => {
80
- if (event.key === 'Shift') {
81
- isShift = false;
82
- }
83
- MERGING.set(board, false);
84
- keyup(event);
37
+ board.keyUp = (event) => {
38
+ keyUp(event);
85
39
  };
86
- board.globalKeydown = (event) => {
40
+ board.globalKeyDown = (event) => {
87
41
  if (PlaitBoard.getMovingPointInBoard(board) || PlaitBoard.isMovingPointInBoard(board)) {
88
42
  if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {
89
43
  event.preventDefault();
@@ -106,8 +60,8 @@ export const withHotkey = (board) => {
106
60
  return;
107
61
  }
108
62
  }
109
- globalKeydown(event);
63
+ globalKeyDown(event);
110
64
  };
111
65
  return board;
112
66
  };
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-hotkey.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-hotkey.ts"],"names":[],"mappings":"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","sourcesContent":["import { isHotkey } from 'is-hotkey';\nimport { Ancestor, MERGING, PlaitBoard, PlaitElement, PlaitPluginKey, Point } from '../interfaces';\nimport { BoardTransforms, Transforms } from '../transforms';\nimport { depthFirstRecursion, getSelectedElements, hotkeys, throttleRAF } from '../utils';\nimport { PlaitOptionsBoard } from './with-options';\nimport { WithPluginOptions } from './with-selection';\n\nexport const withHotkey = (board: PlaitBoard) => {\n    const { keydown, keyup, globalKeydown } = board;\n\n    let isShift = false;\n\n    board.keydown = (event: KeyboardEvent) => {\n        const options = (board as PlaitOptionsBoard).getPluginOptions<WithPluginOptions>(PlaitPluginKey.withSelection);\n\n        if (hotkeys.isShift(event)) {\n            isShift = true;\n        }\n\n        if (!PlaitBoard.isReadonly(board) && options.isMultiple && isHotkey('mod+a', event)) {\n            event.preventDefault();\n            let elements: PlaitElement[] = [];\n            depthFirstRecursion<Ancestor>(\n                board,\n                node => {\n                    if (PlaitBoard.isBoard(node)) {\n                        return;\n                    }\n                    elements.push(node as PlaitElement);\n                },\n                node => {\n                    if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {\n                        return true;\n                    } else {\n                        return false;\n                    }\n                },\n                true\n            );\n            Transforms.addSelectionWithTemporaryElements(board, elements);\n            return;\n        }\n\n        const selectedElements = getSelectedElements(board);\n        if (\n            !PlaitBoard.isReadonly(board) &&\n            selectedElements.length > 0 &&\n            (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))\n        ) {\n            event.preventDefault();\n            board.deleteFragment(null);\n        }\n\n        if (!PlaitBoard.isReadonly(board) && selectedElements.length > 0 && (hotkeys.isArrow(event) || hotkeys.isExtendArrow(event))) {\n            event.preventDefault();\n            const offset = [0, 0];\n            const buffer = isShift ? 10 : 1;\n            switch (true) {\n                case hotkeys.isMoveUp(event) || hotkeys.isExtendUp(event): {\n                    offset[1] = -buffer;\n                    break;\n                }\n                case hotkeys.isMoveDown(event) || hotkeys.isExtendDown(event): {\n                    offset[1] = buffer;\n                    break;\n                }\n                case hotkeys.isMoveBackward(event) || hotkeys.isExtendBackward(event): {\n                    offset[0] = -buffer;\n                    break;\n                }\n                case hotkeys.isMoveForward(event) || hotkeys.isExtendForward(event): {\n                    offset[0] = buffer;\n                    break;\n                }\n            }\n            const selectedElements = getSelectedElements(board);\n            const relatedElements = board.getRelatedFragment([]);\n            const movableElements = board.children.filter(item => board.isMovable(item));\n\n            throttleRAF(() => {\n                [...selectedElements, ...relatedElements]\n                    .filter(element => movableElements.includes(element))\n                    .forEach(element => {\n                        const points = element.points || [];\n                        const newPoints = points.map(p => [p[0] + offset[0], p[1] + offset[1]]) as Point[];\n                        Transforms.setNode(\n                            board,\n                            {\n                                points: newPoints\n                            },\n                            PlaitBoard.findPath(board, element)\n                        );\n                        MERGING.set(board, true);\n                    });\n            });\n        }\n\n        keydown(event);\n    };\n\n    board.keyup = (event: KeyboardEvent) => {\n        if (event.key === 'Shift') {\n            isShift = false;\n        }\n        MERGING.set(board, false);\n        keyup(event);\n    };\n\n    board.globalKeydown = (event: KeyboardEvent) => {\n        if (PlaitBoard.getMovingPointInBoard(board) || PlaitBoard.isMovingPointInBoard(board)) {\n            if (isHotkey(['mod+=', 'mod++'], { byKey: true })(event)) {\n                event.preventDefault();\n                BoardTransforms.updateZoom(board, board.viewport.zoom + 0.1, false);\n                return;\n            }\n            if (isHotkey(['mod+shift+=', 'mod+shift++'], { byKey: true })(event)) {\n                event.preventDefault();\n                BoardTransforms.fitViewport(board);\n                return;\n            }\n            if (isHotkey(['mod+-', 'mod+shift+-'])(event)) {\n                event.preventDefault();\n                BoardTransforms.updateZoom(board, board.viewport.zoom - 0.1);\n                return;\n            }\n            if (isHotkey(['mod+0', 'mod+shift+0'], { byKey: true })(event)) {\n                event.preventDefault();\n                BoardTransforms.updateZoom(board, 1);\n                return;\n            }\n        }\n        globalKeydown(event);\n    };\n\n    return board;\n};\n"]}
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1ob3RrZXkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9wbHVnaW5zL3dpdGgtaG90a2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDckMsT0FBTyxFQUFZLFVBQVUsRUFBZ0IsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxlQUFlLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxtQkFBbUIsRUFBRSxPQUFPLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFJN0UsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQzVDLE1BQU0sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSxHQUFHLEtBQUssQ0FBQztJQUVoRCxLQUFLLENBQUMsT0FBTyxHQUFHLENBQUMsS0FBb0IsRUFBRSxFQUFFO1FBQ3JDLE1BQU0sT0FBTyxHQUFJLEtBQTJCLENBQUMsZ0JBQWdCLENBQW9CLGNBQWMsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMvRyxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsSUFBSSxPQUFPLENBQUMsVUFBVSxJQUFJLFFBQVEsQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEVBQUU7WUFDakYsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLElBQUksUUFBUSxHQUFtQixFQUFFLENBQUM7WUFDbEMsbUJBQW1CLENBQ2YsS0FBSyxFQUNMLElBQUksQ0FBQyxFQUFFO2dCQUNILElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDMUIsT0FBTztpQkFDVjtnQkFDRCxRQUFRLENBQUMsSUFBSSxDQUFDLElBQW9CLENBQUMsQ0FBQztZQUN4QyxDQUFDLEVBQ0QsSUFBSSxDQUFDLEVBQUU7Z0JBQ0gsSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUU7b0JBQ3JELE9BQU8sSUFBSSxDQUFDO2lCQUNmO3FCQUFNO29CQUNILE9BQU8sS0FBSyxDQUFDO2lCQUNoQjtZQUNMLENBQUMsRUFDRCxJQUFJLENBQ1AsQ0FBQztZQUNGLFVBQVUsQ0FBQyxpQ0FBaUMsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7WUFDOUQsT0FBTztTQUNWO1FBRUQsTUFBTSxnQkFBZ0IsR0FBRyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwRCxJQUNJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUM7WUFDN0IsZ0JBQWdCLENBQUMsTUFBTSxHQUFHLENBQUM7WUFDM0IsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUNyRTtZQUNFLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN2QixLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzlCO1FBRUQsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25CLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxLQUFLLEdBQUcsQ0FBQyxLQUFvQixFQUFFLEVBQUU7UUFDbkMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pCLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxhQUFhLEdBQUcsQ0FBQyxLQUFvQixFQUFFLEVBQUU7UUFDM0MsSUFBSSxVQUFVLENBQUMscUJBQXFCLENBQUMsS0FBSyxDQUFDLElBQUksVUFBVSxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ25GLElBQUksUUFBUSxDQUFDLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxFQUFFLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ3RELEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztnQkFDdkIsZUFBZSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO2dCQUNwRSxPQUFPO2FBQ1Y7WUFDRCxJQUFJLFFBQVEsQ0FBQyxDQUFDLGFBQWEsRUFBRSxhQUFhLENBQUMsRUFBRSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUNsRSxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQ3ZCLGVBQWUsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQ25DLE9BQU87YUFDVjtZQUNELElBQUksUUFBUSxDQUFDLENBQUMsT0FBTyxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzNDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztnQkFDdkIsZUFBZSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUM7Z0JBQzdELE9BQU87YUFDVjtZQUNELElBQUksUUFBUSxDQUFDLENBQUMsT0FBTyxFQUFFLGFBQWEsQ0FBQyxFQUFFLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzVELEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztnQkFDdkIsZUFBZSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7Z0JBQ3JDLE9BQU87YUFDVjtTQUNKO1FBQ0QsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3pCLENBQUMsQ0FBQztJQUVGLE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzSG90a2V5IH0gZnJvbSAnaXMtaG90a2V5JztcbmltcG9ydCB7IEFuY2VzdG9yLCBQbGFpdEJvYXJkLCBQbGFpdEVsZW1lbnQsIFBsYWl0UGx1Z2luS2V5IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBCb2FyZFRyYW5zZm9ybXMsIFRyYW5zZm9ybXMgfSBmcm9tICcuLi90cmFuc2Zvcm1zJztcbmltcG9ydCB7IGRlcHRoRmlyc3RSZWN1cnNpb24sIGdldFNlbGVjdGVkRWxlbWVudHMsIGhvdGtleXMgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBQbGFpdE9wdGlvbnNCb2FyZCB9IGZyb20gJy4vd2l0aC1vcHRpb25zJztcbmltcG9ydCB7IFdpdGhQbHVnaW5PcHRpb25zIH0gZnJvbSAnLi93aXRoLXNlbGVjdGlvbic7XG5cbmV4cG9ydCBjb25zdCB3aXRoSG90a2V5ID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3QgeyBrZXlEb3duLCBrZXlVcCwgZ2xvYmFsS2V5RG93biB9ID0gYm9hcmQ7XG5cbiAgICBib2FyZC5rZXlEb3duID0gKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IG9wdGlvbnMgPSAoYm9hcmQgYXMgUGxhaXRPcHRpb25zQm9hcmQpLmdldFBsdWdpbk9wdGlvbnM8V2l0aFBsdWdpbk9wdGlvbnM+KFBsYWl0UGx1Z2luS2V5LndpdGhTZWxlY3Rpb24pO1xuICAgICAgICBpZiAoIVBsYWl0Qm9hcmQuaXNSZWFkb25seShib2FyZCkgJiYgb3B0aW9ucy5pc011bHRpcGxlICYmIGlzSG90a2V5KCdtb2QrYScsIGV2ZW50KSkge1xuICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgIGxldCBlbGVtZW50czogUGxhaXRFbGVtZW50W10gPSBbXTtcbiAgICAgICAgICAgIGRlcHRoRmlyc3RSZWN1cnNpb248QW5jZXN0b3I+KFxuICAgICAgICAgICAgICAgIGJvYXJkLFxuICAgICAgICAgICAgICAgIG5vZGUgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoUGxhaXRCb2FyZC5pc0JvYXJkKG5vZGUpKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgZWxlbWVudHMucHVzaChub2RlIGFzIFBsYWl0RWxlbWVudCk7XG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBub2RlID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKFBsYWl0Qm9hcmQuaXNCb2FyZChub2RlKSB8fCBib2FyZC5pc1JlY3Vyc2lvbihub2RlKSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHRydWVcbiAgICAgICAgICAgICk7XG4gICAgICAgICAgICBUcmFuc2Zvcm1zLmFkZFNlbGVjdGlvbldpdGhUZW1wb3JhcnlFbGVtZW50cyhib2FyZCwgZWxlbWVudHMpO1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qgc2VsZWN0ZWRFbGVtZW50cyA9IGdldFNlbGVjdGVkRWxlbWVudHMoYm9hcmQpO1xuICAgICAgICBpZiAoXG4gICAgICAgICAgICAhUGxhaXRCb2FyZC5pc1JlYWRvbmx5KGJvYXJkKSAmJlxuICAgICAgICAgICAgc2VsZWN0ZWRFbGVtZW50cy5sZW5ndGggPiAwICYmXG4gICAgICAgICAgICAoaG90a2V5cy5pc0RlbGV0ZUJhY2t3YXJkKGV2ZW50KSB8fCBob3RrZXlzLmlzRGVsZXRlRm9yd2FyZChldmVudCkpXG4gICAgICAgICkge1xuICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgIGJvYXJkLmRlbGV0ZUZyYWdtZW50KG51bGwpO1xuICAgICAgICB9XG5cbiAgICAgICAga2V5RG93bihldmVudCk7XG4gICAgfTtcblxuICAgIGJvYXJkLmtleVVwID0gKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgICAgIGtleVVwKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgYm9hcmQuZ2xvYmFsS2V5RG93biA9IChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge1xuICAgICAgICBpZiAoUGxhaXRCb2FyZC5nZXRNb3ZpbmdQb2ludEluQm9hcmQoYm9hcmQpIHx8IFBsYWl0Qm9hcmQuaXNNb3ZpbmdQb2ludEluQm9hcmQoYm9hcmQpKSB7XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2QrPScsICdtb2QrKyddLCB7IGJ5S2V5OiB0cnVlIH0pKGV2ZW50KSkge1xuICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgQm9hcmRUcmFuc2Zvcm1zLnVwZGF0ZVpvb20oYm9hcmQsIGJvYXJkLnZpZXdwb3J0Lnpvb20gKyAwLjEsIGZhbHNlKTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2Qrc2hpZnQrPScsICdtb2Qrc2hpZnQrKyddLCB7IGJ5S2V5OiB0cnVlIH0pKGV2ZW50KSkge1xuICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgQm9hcmRUcmFuc2Zvcm1zLmZpdFZpZXdwb3J0KGJvYXJkKTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2QrLScsICdtb2Qrc2hpZnQrLSddKShldmVudCkpIHtcbiAgICAgICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgIEJvYXJkVHJhbnNmb3Jtcy51cGRhdGVab29tKGJvYXJkLCBib2FyZC52aWV3cG9ydC56b29tIC0gMC4xKTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoaXNIb3RrZXkoWydtb2QrMCcsICdtb2Qrc2hpZnQrMCddLCB7IGJ5S2V5OiB0cnVlIH0pKGV2ZW50KSkge1xuICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgQm9hcmRUcmFuc2Zvcm1zLnVwZGF0ZVpvb20oYm9hcmQsIDEpO1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBnbG9iYWxLZXlEb3duKGV2ZW50KTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIGJvYXJkO1xufTtcbiJdfQ==
@@ -5,12 +5,13 @@ import { Transforms } from '../transforms';
5
5
  import { getHitElementByPoint, getSelectedElements } from '../utils/selected-element';
6
6
  import { PlaitNode } from '../interfaces/node';
7
7
  import { throttleRAF } from '../utils/common';
8
- import { addMovingElements, getMovingElements, removeMovingElements } from '../utils/moving-element';
8
+ import { cacheMovingElements, getMovingElements, isMovingElements, removeMovingElements } from '../utils/moving-element';
9
9
  import { MERGING } from '../interfaces/history';
10
- import { isPreventTouchMove, preventTouchMove, handleTouchTarget, getRectangleByElements, distanceBetweenPointAndPoint, toHostPoint, toViewBoxPoint } from '../utils';
10
+ import { isPreventTouchMove, preventTouchMove, handleTouchTarget, getRectangleByElements, distanceBetweenPointAndPoint, toHostPoint, toViewBoxPoint, hotkeys } from '../utils';
11
11
  import { AlignReaction } from '../utils/reaction-manager';
12
- import { PlaitPointerType } from '../interfaces';
12
+ import { PlaitPointerType, RectangleClient } from '../interfaces';
13
13
  import { ACTIVE_MOVING_CLASS_NAME, PRESS_AND_MOVE_BUFFER } from '../constants';
14
+ import { addSelectionWithTemporaryElements } from '../transforms/selection';
14
15
  export function withMoving(board) {
15
16
  const { pointerDown, pointerMove, globalPointerUp, globalPointerMove } = board;
16
17
  let offsetX = 0;
@@ -21,29 +22,32 @@ export function withMoving(board) {
21
22
  let alignG = null;
22
23
  let activeElementsRectangle = null;
23
24
  board.pointerDown = (event) => {
25
+ if (PlaitBoard.isReadonly(board) ||
26
+ !PlaitBoard.isPointer(board, PlaitPointerType.selection) ||
27
+ isPreventTouchMove(board) ||
28
+ !isMainPointer(event)) {
29
+ pointerDown(event);
30
+ }
24
31
  const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
25
- let movableElements = board.children.filter(item => board.isMovable(item));
26
- if (!PlaitBoard.isReadonly(board) &&
27
- PlaitBoard.isPointer(board, PlaitPointerType.selection) &&
28
- movableElements.length &&
29
- !isPreventTouchMove(board) &&
30
- isMainPointer(event)) {
32
+ const targetElements = getTargetElements(board);
33
+ const targetRectangle = targetElements.length > 0 && getRectangleByElements(board, targetElements, false);
34
+ const isInTargetRectangle = targetRectangle && RectangleClient.isPointInRectangle(targetRectangle, point);
35
+ if (isInTargetRectangle) {
31
36
  startPoint = point;
32
- const selectedMovableElements = getSelectedElements(board).filter(item => movableElements.includes(item));
33
- const hitElement = getHitElementByPoint(board, point);
34
- if (hitElement && movableElements.includes(hitElement)) {
35
- if (selectedMovableElements.includes(hitElement)) {
36
- const relatedElements = board.getRelatedFragment([]);
37
- activeElements = [...selectedMovableElements, ...relatedElements];
38
- }
39
- else {
40
- activeElements = [hitElement];
37
+ activeElements = targetElements;
38
+ preventTouchMove(board, event, true);
39
+ activeElementsRectangle = getRectangleByElements(board, activeElements, true);
40
+ }
41
+ else {
42
+ const targetElement = getHitElementByPoint(board, point, el => board.isMovable(el));
43
+ if (targetElement) {
44
+ startPoint = point;
45
+ activeElements = [targetElement];
46
+ if (targetElements.length > 0) {
47
+ addSelectionWithTemporaryElements(board, []);
41
48
  }
49
+ activeElementsRectangle = getRectangleByElements(board, activeElements, true);
42
50
  }
43
- if (activeElements.length > 0) {
44
- preventTouchMove(board, event, true);
45
- }
46
- activeElementsRectangle = getRectangleByElements(board, activeElements, true);
47
51
  }
48
52
  pointerDown(event);
49
53
  };
@@ -58,7 +62,7 @@ export function withMoving(board) {
58
62
  offsetY = endPoint[1] - startPoint[1];
59
63
  const distance = distanceBetweenPointAndPoint(...endPoint, ...startPoint);
60
64
  if (distance > PRESS_AND_MOVE_BUFFER || getMovingElements(board).length > 0) {
61
- throttleRAF(() => {
65
+ throttleRAF(board, 'with-moving', () => {
62
66
  if (!activeElementsRectangle) {
63
67
  return;
64
68
  }
@@ -75,19 +79,9 @@ export function withMoving(board) {
75
79
  alignG.classList.add(ACTIVE_MOVING_CLASS_NAME);
76
80
  PlaitBoard.getElementActiveHost(board).append(alignG);
77
81
  handleTouchTarget(board);
78
- const currentElements = activeElements.map(activeElement => {
79
- const points = activeElement.points || [];
80
- const [x, y] = activeElement.points[0];
81
- const newPoints = points.map(p => [p[0] + offsetX, p[1] + offsetY]);
82
- const index = board.children.findIndex(item => item.id === activeElement.id);
83
- Transforms.setNode(board, {
84
- points: newPoints
85
- }, [index]);
86
- MERGING.set(board, true);
87
- return PlaitNode.get(board, [index]);
88
- });
82
+ const currentElements = updatePoints(board, activeElements, offsetX, offsetY);
89
83
  PlaitBoard.getBoardContainer(board).classList.add('element-moving');
90
- addMovingElements(board, currentElements);
84
+ cacheMovingElements(board, currentElements);
91
85
  });
92
86
  }
93
87
  }
@@ -121,10 +115,76 @@ export function withMoving(board) {
121
115
  offsetX = 0;
122
116
  offsetY = 0;
123
117
  activeElements = [];
124
- removeMovingElements(board);
118
+ if (isMovingElements(board)) {
119
+ removeMovingElements(board);
120
+ }
125
121
  MERGING.set(board, false);
126
122
  PlaitBoard.getBoardContainer(board).classList.remove('element-moving');
127
123
  }
124
+ return withArrowMoving(board);
125
+ }
126
+ export function withArrowMoving(board) {
127
+ const { keyDown, keyUp } = board;
128
+ board.keyDown = (event) => {
129
+ const selectedElements = getSelectedElements(board);
130
+ if (!PlaitBoard.isReadonly(board) && selectedElements.length > 0 && (hotkeys.isArrow(event) || hotkeys.isExtendArrow(event))) {
131
+ event.preventDefault();
132
+ const isShift = event.shiftKey ? true : false;
133
+ const offset = [0, 0];
134
+ const buffer = isShift ? 10 : 1;
135
+ switch (true) {
136
+ case hotkeys.isMoveUp(event) || hotkeys.isExtendUp(event): {
137
+ offset[1] = -buffer;
138
+ break;
139
+ }
140
+ case hotkeys.isMoveDown(event) || hotkeys.isExtendDown(event): {
141
+ offset[1] = buffer;
142
+ break;
143
+ }
144
+ case hotkeys.isMoveBackward(event) || hotkeys.isExtendBackward(event): {
145
+ offset[0] = -buffer;
146
+ break;
147
+ }
148
+ case hotkeys.isMoveForward(event) || hotkeys.isExtendForward(event): {
149
+ offset[0] = buffer;
150
+ break;
151
+ }
152
+ }
153
+ const targetElements = getTargetElements(board);
154
+ throttleRAF(board, 'with-arrow-moving', () => {
155
+ updatePoints(board, targetElements, offset[0], offset[1]);
156
+ });
157
+ }
158
+ keyDown(event);
159
+ };
160
+ board.keyUp = (event) => {
161
+ MERGING.set(board, false);
162
+ keyUp(event);
163
+ };
128
164
  return board;
129
165
  }
130
- //# 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 { PlaitBoard } from '../interfaces/board';\nimport { isInPlaitBoard } from '../utils/board';\nimport { isMainPointer } 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 {\n    isPreventTouchMove,\n    preventTouchMove,\n    handleTouchTarget,\n    getRectangleByElements,\n    distanceBetweenPointAndPoint,\n    toHostPoint,\n    toViewBoxPoint\n} 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 point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\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                    const relatedElements = board.getRelatedFragment([]);\n                    activeElements = [...selectedMovableElements, ...relatedElements];\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 endPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\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            // Prevent canvas scrolling behavior from being triggered during 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"]}
166
+ export function getTargetElements(board) {
167
+ const selectedElements = getSelectedElements(board);
168
+ const movableElements = board.children.filter(item => board.isMovable(item));
169
+ const targetElements = selectedElements.filter(element => {
170
+ return movableElements.includes(element);
171
+ });
172
+ const relatedElements = board.getRelatedFragment([]);
173
+ targetElements.push(...relatedElements);
174
+ return targetElements;
175
+ }
176
+ export function updatePoints(board, targetElements, offsetX, offsetY) {
177
+ const validElements = targetElements.filter(element => board.children.findIndex(item => item.id === element.id) > -1);
178
+ const currentElements = validElements.map(element => {
179
+ const points = element.points || [];
180
+ const newPoints = points.map(p => [p[0] + offsetX, p[1] + offsetY]);
181
+ const index = board.children.findIndex(item => item.id === element.id);
182
+ Transforms.setNode(board, {
183
+ points: newPoints
184
+ }, [index]);
185
+ MERGING.set(board, true);
186
+ return PlaitNode.get(board, [index]);
187
+ });
188
+ return currentElements;
189
+ }
190
+ //# 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 { PlaitBoard } from '../interfaces/board';\nimport { isInPlaitBoard } from '../utils/board';\nimport { isMainPointer } 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 { cacheMovingElements, getMovingElements, isMovingElements, removeMovingElements } from '../utils/moving-element';\nimport { MERGING } from '../interfaces/history';\nimport {\n    isPreventTouchMove,\n    preventTouchMove,\n    handleTouchTarget,\n    getRectangleByElements,\n    distanceBetweenPointAndPoint,\n    toHostPoint,\n    toViewBoxPoint,\n    hotkeys\n} from '../utils';\nimport { AlignReaction } from '../utils/reaction-manager';\nimport { PlaitPointerType, RectangleClient } from '../interfaces';\nimport { ACTIVE_MOVING_CLASS_NAME, PRESS_AND_MOVE_BUFFER } from '../constants';\nimport { addSelectionWithTemporaryElements } from '../transforms/selection';\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        if (\n            PlaitBoard.isReadonly(board) ||\n            !PlaitBoard.isPointer(board, PlaitPointerType.selection) ||\n            isPreventTouchMove(board) ||\n            !isMainPointer(event)\n        ) {\n            pointerDown(event);\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const targetElements = getTargetElements(board);\n        const targetRectangle = targetElements.length > 0 && getRectangleByElements(board, targetElements, false);\n        const isInTargetRectangle = targetRectangle && RectangleClient.isPointInRectangle(targetRectangle, point);\n        if (isInTargetRectangle) {\n            startPoint = point;\n            activeElements = targetElements;\n            preventTouchMove(board, event, true);\n            activeElementsRectangle = getRectangleByElements(board, activeElements, true);\n        } else {\n            const targetElement = getHitElementByPoint(board, point, el => board.isMovable(el));\n            if (targetElement) {\n                startPoint = point;\n                activeElements = [targetElement];\n                if (targetElements.length > 0) {\n                    addSelectionWithTemporaryElements(board, []);\n                }\n                activeElementsRectangle = getRectangleByElements(board, activeElements, true);\n            }\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 endPoint = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\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(board, 'with-moving', () => {\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                    handleTouchTarget(board);\n                    const currentElements = updatePoints(board, activeElements, offsetX, offsetY);\n                    PlaitBoard.getBoardContainer(board).classList.add('element-moving');\n                    cacheMovingElements(board, currentElements as PlaitElement[]);\n                });\n            }\n        }\n        if (isPreventDefault) {\n            // Prevent canvas scrolling behavior from being triggered during 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        if (isMovingElements(board)) {\n            removeMovingElements(board);\n        }\n        MERGING.set(board, false);\n        PlaitBoard.getBoardContainer(board).classList.remove('element-moving');\n    }\n\n    return withArrowMoving(board);\n}\n\nexport function withArrowMoving(board: PlaitBoard) {\n    const { keyDown, keyUp } = board;\n    board.keyDown = (event: KeyboardEvent) => {\n        const selectedElements = getSelectedElements(board);\n        if (!PlaitBoard.isReadonly(board) && selectedElements.length > 0 && (hotkeys.isArrow(event) || hotkeys.isExtendArrow(event))) {\n            event.preventDefault();\n            const isShift = event.shiftKey ? true : false;\n            const offset = [0, 0];\n            const buffer = isShift ? 10 : 1;\n            switch (true) {\n                case hotkeys.isMoveUp(event) || hotkeys.isExtendUp(event): {\n                    offset[1] = -buffer;\n                    break;\n                }\n                case hotkeys.isMoveDown(event) || hotkeys.isExtendDown(event): {\n                    offset[1] = buffer;\n                    break;\n                }\n                case hotkeys.isMoveBackward(event) || hotkeys.isExtendBackward(event): {\n                    offset[0] = -buffer;\n                    break;\n                }\n                case hotkeys.isMoveForward(event) || hotkeys.isExtendForward(event): {\n                    offset[0] = buffer;\n                    break;\n                }\n            }\n            const targetElements = getTargetElements(board);\n            throttleRAF(board, 'with-arrow-moving', () => {\n                updatePoints(board, targetElements, offset[0], offset[1]);\n            });\n        }\n        keyDown(event);\n    };\n\n    board.keyUp = (event: KeyboardEvent) => {\n        MERGING.set(board, false);\n        keyUp(event);\n    };\n    return board;\n}\n\nexport function getTargetElements(board: PlaitBoard) {\n    const selectedElements = getSelectedElements(board);\n    const movableElements = board.children.filter(item => board.isMovable(item));\n    const targetElements = selectedElements.filter(element => {\n        return movableElements.includes(element);\n    });\n    const relatedElements = board.getRelatedFragment([]);\n    targetElements.push(...relatedElements);\n    return targetElements;\n}\n\nexport function updatePoints(board: PlaitBoard, targetElements: PlaitElement[], offsetX: number, offsetY: number) {\n    const validElements = targetElements.filter(element => board.children.findIndex(item => item.id === element.id) > -1);\n    const currentElements = validElements.map(element => {\n        const points = element.points || [];\n        const newPoints = points.map(p => [p[0] + offsetX, p[1] + offsetY]) as Point[];\n        const index = board.children.findIndex(item => item.id === element.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    return currentElements;\n}\n"]}