@plait/core 0.77.3 → 0.78.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.
Files changed (108) hide show
  1. package/fesm2022/plait-core.mjs.map +1 -1
  2. package/package.json +1 -3
  3. package/esm2022/constants/cursor.mjs +0 -13
  4. package/esm2022/constants/index.mjs +0 -20
  5. package/esm2022/constants/keycodes.mjs +0 -127
  6. package/esm2022/constants/selection.mjs +0 -6
  7. package/esm2022/constants/zoom.mjs +0 -4
  8. package/esm2022/context.mjs +0 -23
  9. package/esm2022/core/element/context-change.mjs +0 -13
  10. package/esm2022/core/element/context.mjs +0 -2
  11. package/esm2022/core/element/element-flavour.mjs +0 -140
  12. package/esm2022/core/element/element-ref.mjs +0 -2
  13. package/esm2022/core/list-render.mjs +0 -217
  14. package/esm2022/differs/default_iterable_differ.mjs +0 -614
  15. package/esm2022/differs/iterable_differs.mjs +0 -9
  16. package/esm2022/interfaces/board.mjs +0 -108
  17. package/esm2022/interfaces/custom-types.mjs +0 -5
  18. package/esm2022/interfaces/direction.mjs +0 -8
  19. package/esm2022/interfaces/element.mjs +0 -43
  20. package/esm2022/interfaces/group.mjs +0 -6
  21. package/esm2022/interfaces/history.mjs +0 -5
  22. package/esm2022/interfaces/index.mjs +0 -19
  23. package/esm2022/interfaces/node.mjs +0 -57
  24. package/esm2022/interfaces/operation.mjs +0 -96
  25. package/esm2022/interfaces/path-ref.mjs +0 -15
  26. package/esm2022/interfaces/path.mjs +0 -183
  27. package/esm2022/interfaces/plugin.mjs +0 -6
  28. package/esm2022/interfaces/point.mjs +0 -27
  29. package/esm2022/interfaces/pointer.mjs +0 -6
  30. package/esm2022/interfaces/rectangle-client.mjs +0 -171
  31. package/esm2022/interfaces/selection.mjs +0 -13
  32. package/esm2022/interfaces/svg-arc-command.mjs +0 -2
  33. package/esm2022/interfaces/theme.mjs +0 -49
  34. package/esm2022/interfaces/viewport.mjs +0 -7
  35. package/esm2022/plait-core.mjs +0 -5
  36. package/esm2022/plugins/create-board.mjs +0 -122
  37. package/esm2022/plugins/index.mjs +0 -11
  38. package/esm2022/plugins/with-board.mjs +0 -20
  39. package/esm2022/plugins/with-hand.mjs +0 -113
  40. package/esm2022/plugins/with-history.mjs +0 -91
  41. package/esm2022/plugins/with-hotkey.mjs +0 -96
  42. package/esm2022/plugins/with-i18n.mjs +0 -13
  43. package/esm2022/plugins/with-moving.mjs +0 -282
  44. package/esm2022/plugins/with-options.mjs +0 -13
  45. package/esm2022/plugins/with-related-fragment.mjs +0 -23
  46. package/esm2022/plugins/with-selection.mjs +0 -230
  47. package/esm2022/public-api.mjs +0 -16
  48. package/esm2022/testing/core/create-board.mjs +0 -15
  49. package/esm2022/testing/core/fake-weak-map.mjs +0 -18
  50. package/esm2022/testing/core/index.mjs +0 -3
  51. package/esm2022/testing/fake-events/event-objects.mjs +0 -131
  52. package/esm2022/testing/fake-events/index.mjs +0 -2
  53. package/esm2022/testing/index.mjs +0 -3
  54. package/esm2022/testing/test-element.mjs +0 -9
  55. package/esm2022/transforms/board.mjs +0 -137
  56. package/esm2022/transforms/element.mjs +0 -22
  57. package/esm2022/transforms/general.mjs +0 -146
  58. package/esm2022/transforms/group.mjs +0 -64
  59. package/esm2022/transforms/index.mjs +0 -17
  60. package/esm2022/transforms/node.mjs +0 -37
  61. package/esm2022/transforms/selection.mjs +0 -26
  62. package/esm2022/transforms/theme.mjs +0 -8
  63. package/esm2022/transforms/viewport.mjs +0 -8
  64. package/esm2022/transforms/z-index.mjs +0 -20
  65. package/esm2022/utils/angle.mjs +0 -164
  66. package/esm2022/utils/board.mjs +0 -18
  67. package/esm2022/utils/clipboard/clipboard.mjs +0 -40
  68. package/esm2022/utils/clipboard/common.mjs +0 -82
  69. package/esm2022/utils/clipboard/data-transfer.mjs +0 -33
  70. package/esm2022/utils/clipboard/index.mjs +0 -3
  71. package/esm2022/utils/clipboard/navigator-clipboard.mjs +0 -71
  72. package/esm2022/utils/clipboard/types.mjs +0 -13
  73. package/esm2022/utils/common.mjs +0 -79
  74. package/esm2022/utils/debug.mjs +0 -91
  75. package/esm2022/utils/dnd.mjs +0 -8
  76. package/esm2022/utils/dom/common.mjs +0 -75
  77. package/esm2022/utils/dom/environment.mjs +0 -2
  78. package/esm2022/utils/dom/foreign.mjs +0 -26
  79. package/esm2022/utils/dom/index.mjs +0 -4
  80. package/esm2022/utils/drawing/arrow.mjs +0 -23
  81. package/esm2022/utils/drawing/circle.mjs +0 -4
  82. package/esm2022/utils/drawing/line.mjs +0 -47
  83. package/esm2022/utils/drawing/rectangle.mjs +0 -36
  84. package/esm2022/utils/element.mjs +0 -90
  85. package/esm2022/utils/environment.mjs +0 -14
  86. package/esm2022/utils/fragment.mjs +0 -27
  87. package/esm2022/utils/group.mjs +0 -239
  88. package/esm2022/utils/helper.mjs +0 -68
  89. package/esm2022/utils/history.mjs +0 -96
  90. package/esm2022/utils/hotkeys.mjs +0 -109
  91. package/esm2022/utils/id-creator.mjs +0 -11
  92. package/esm2022/utils/index.mjs +0 -35
  93. package/esm2022/utils/iterable.mjs +0 -32
  94. package/esm2022/utils/math.mjs +0 -480
  95. package/esm2022/utils/mobile.mjs +0 -6
  96. package/esm2022/utils/moving-element.mjs +0 -17
  97. package/esm2022/utils/pointer.mjs +0 -13
  98. package/esm2022/utils/position.mjs +0 -9
  99. package/esm2022/utils/selected-element.mjs +0 -145
  100. package/esm2022/utils/selection.mjs +0 -151
  101. package/esm2022/utils/snap/snap-moving.mjs +0 -199
  102. package/esm2022/utils/snap/snap.mjs +0 -211
  103. package/esm2022/utils/to-image.mjs +0 -204
  104. package/esm2022/utils/to-point.mjs +0 -74
  105. package/esm2022/utils/tree.mjs +0 -22
  106. package/esm2022/utils/viewport.mjs +0 -227
  107. package/esm2022/utils/weak-maps.mjs +0 -27
  108. package/esm2022/utils/z-index.mjs +0 -166
@@ -1,13 +0,0 @@
1
- export const isMobileDeviceEvent = (event) => {
2
- return isPencilEvent(event) || isTouchEvent(event);
3
- };
4
- export const isPencilEvent = (event) => {
5
- return event.pointerType === 'pen';
6
- };
7
- export const isTouchEvent = (event) => {
8
- return event.pointerType === 'touch';
9
- };
10
- export const isMouseEvent = (event) => {
11
- return event.pointerType === 'mouse';
12
- };
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9pbnRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3V0aWxzL3BvaW50ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxLQUFtQixFQUFFLEVBQUU7SUFDdkQsT0FBTyxhQUFhLENBQUMsS0FBSyxDQUFDLElBQUksWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQ3ZELENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtJQUNqRCxPQUFPLEtBQUssQ0FBQyxXQUFXLEtBQUssS0FBSyxDQUFDO0FBQ3ZDLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtJQUNoRCxPQUFPLEtBQUssQ0FBQyxXQUFXLEtBQUssT0FBTyxDQUFDO0FBQ3pDLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtJQUNoRCxPQUFPLEtBQUssQ0FBQyxXQUFXLEtBQUssT0FBTyxDQUFDO0FBQ3pDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBpc01vYmlsZURldmljZUV2ZW50ID0gKGV2ZW50OiBQb2ludGVyRXZlbnQpID0+IHtcbiAgICByZXR1cm4gaXNQZW5jaWxFdmVudChldmVudCkgfHwgaXNUb3VjaEV2ZW50KGV2ZW50KTtcbn07XG5cbmV4cG9ydCBjb25zdCBpc1BlbmNpbEV2ZW50ID0gKGV2ZW50OiBQb2ludGVyRXZlbnQpID0+IHtcbiAgICByZXR1cm4gZXZlbnQucG9pbnRlclR5cGUgPT09ICdwZW4nO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzVG91Y2hFdmVudCA9IChldmVudDogUG9pbnRlckV2ZW50KSA9PiB7XG4gICAgcmV0dXJuIGV2ZW50LnBvaW50ZXJUeXBlID09PSAndG91Y2gnO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzTW91c2VFdmVudCA9IChldmVudDogUG9pbnRlckV2ZW50KSA9PiB7XG4gICAgcmV0dXJuIGV2ZW50LnBvaW50ZXJUeXBlID09PSAnbW91c2UnO1xufTtcbiJdfQ==
@@ -1,9 +0,0 @@
1
- import { PlaitBoard } from '../interfaces';
2
- export const sortElements = (board, elements, ascendingOrder = true) => {
3
- return [...elements].sort((a, b) => {
4
- const pathA = PlaitBoard.findPath(board, a);
5
- const pathB = PlaitBoard.findPath(board, b);
6
- return ascendingOrder ? pathA[0] - pathB[0] : pathB[0] - pathA[0];
7
- });
8
- };
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zaXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy91dGlscy9wb3NpdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFnQixNQUFNLGVBQWUsQ0FBQztBQUV6RCxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxLQUFpQixFQUFFLFFBQXdCLEVBQUUsY0FBYyxHQUFHLElBQUksRUFBRSxFQUFFO0lBQy9GLE9BQU8sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQWUsRUFBRSxDQUFlLEVBQUUsRUFBRTtRQUMzRCxNQUFNLEtBQUssR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM1QyxNQUFNLEtBQUssR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM1QyxPQUFPLGNBQWMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN0RSxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgY29uc3Qgc29ydEVsZW1lbnRzID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50czogUGxhaXRFbGVtZW50W10sIGFzY2VuZGluZ09yZGVyID0gdHJ1ZSkgPT4ge1xuICAgIHJldHVybiBbLi4uZWxlbWVudHNdLnNvcnQoKGE6IFBsYWl0RWxlbWVudCwgYjogUGxhaXRFbGVtZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IHBhdGhBID0gUGxhaXRCb2FyZC5maW5kUGF0aChib2FyZCwgYSk7XG4gICAgICAgIGNvbnN0IHBhdGhCID0gUGxhaXRCb2FyZC5maW5kUGF0aChib2FyZCwgYik7XG4gICAgICAgIHJldHVybiBhc2NlbmRpbmdPcmRlciA/IHBhdGhBWzBdIC0gcGF0aEJbMF0gOiBwYXRoQlswXSAtIHBhdGhBWzBdO1xuICAgIH0pO1xufTtcbiJdfQ==
@@ -1,145 +0,0 @@
1
- import { PlaitBoard } from '../interfaces/board';
2
- import { depthFirstRecursion, getIsRecursionFunc } from './tree';
3
- import { BOARD_TO_SELECTED_ELEMENT } from './weak-maps';
4
- import { Selection } from '../interfaces/selection';
5
- import { PlaitElement } from '../interfaces/element';
6
- import { sortElements } from './position';
7
- import { RectangleClient } from '../interfaces/rectangle-client';
8
- import { getRectangleByElements } from './element';
9
- import { isDebug } from './debug';
10
- import { PlaitPluginKey } from '../interfaces/plugin';
11
- export const getHitElementsBySelection = (board, selection, match = () => true) => {
12
- const newSelection = selection || board.selection;
13
- const rectangleHitElements = [];
14
- if (!newSelection) {
15
- return [];
16
- }
17
- const isCollapsed = Selection.isCollapsed(newSelection);
18
- if (isCollapsed) {
19
- const hitElements = getHitElementsByPoint(board, newSelection.anchor, match);
20
- if (hitElements?.length) {
21
- return hitElements;
22
- }
23
- else {
24
- return [];
25
- }
26
- }
27
- depthFirstRecursion(board, (node) => {
28
- if (!PlaitBoard.isBoard(node) && match(node)) {
29
- let isRectangleHit = false;
30
- try {
31
- isRectangleHit = board.isRectangleHit(node, newSelection);
32
- }
33
- catch (error) {
34
- if (isDebug()) {
35
- console.error('isRectangleHit', error, 'node', node);
36
- }
37
- }
38
- if (isRectangleHit) {
39
- rectangleHitElements.push(node);
40
- }
41
- }
42
- }, getIsRecursionFunc(board), true);
43
- return rectangleHitElements;
44
- };
45
- export const getHitElementsByPoint = (board, point, match = () => true, isStrict = true) => {
46
- let hitElements = [];
47
- depthFirstRecursion(board, (node) => {
48
- if (PlaitBoard.isBoard(node) || !match(node) || !PlaitElement.hasMounted(node)) {
49
- return;
50
- }
51
- let isHit = false;
52
- try {
53
- isHit = board.isHit(node, point, isStrict);
54
- }
55
- catch (error) {
56
- if (isDebug()) {
57
- console.error('isHit', error, 'node', node);
58
- }
59
- }
60
- if (isHit) {
61
- hitElements.push(node);
62
- return;
63
- }
64
- }, getIsRecursionFunc(board), true);
65
- return hitElements;
66
- };
67
- export const getHitElementByPoint = (board, point, match = () => true, isStrict = true) => {
68
- const pointHitElements = getHitElementsByPoint(board, point, match, isStrict);
69
- const hitElement = board.getOneHitElement(pointHitElements);
70
- return hitElement;
71
- };
72
- export const getHitSelectedElements = (board, point) => {
73
- const selectedElements = getSelectedElements(board);
74
- const targetRectangle = selectedElements.length > 0 && getRectangleByElements(board, selectedElements, false);
75
- const isInTargetRectangle = targetRectangle && RectangleClient.isPointInRectangle(targetRectangle, point);
76
- if (isInTargetRectangle) {
77
- return selectedElements;
78
- }
79
- else {
80
- return [];
81
- }
82
- };
83
- export const cacheSelectedElements = (board, selectedElements) => {
84
- const sortedElements = sortElements(board, selectedElements);
85
- BOARD_TO_SELECTED_ELEMENT.set(board, sortedElements);
86
- };
87
- export const getSelectedElements = (board) => {
88
- return BOARD_TO_SELECTED_ELEMENT.get(board) || [];
89
- };
90
- export const addSelectedElement = (board, element) => {
91
- let elements = [];
92
- if (Array.isArray(element)) {
93
- elements.push(...element);
94
- }
95
- else {
96
- elements.push(element);
97
- }
98
- const selectedElements = getSelectedElements(board);
99
- cacheSelectedElements(board, [...selectedElements, ...elements]);
100
- };
101
- export const removeSelectedElement = (board, element, isRemoveChildren = false) => {
102
- const selectedElements = getSelectedElements(board);
103
- if (selectedElements.includes(element)) {
104
- const targetElements = [];
105
- if (board.isRecursion(element) && isRemoveChildren) {
106
- depthFirstRecursion(element, (node) => {
107
- targetElements.push(node);
108
- }, (node) => board.isRecursion(node));
109
- }
110
- else {
111
- targetElements.push(element);
112
- }
113
- const newSelectedElements = selectedElements.filter((value) => !targetElements.includes(value));
114
- cacheSelectedElements(board, newSelectedElements);
115
- }
116
- };
117
- export const replaceSelectedElement = (board, element, newElement) => {
118
- const selectedElements = getSelectedElements(board);
119
- selectedElements.splice(selectedElements.indexOf(element), 1, newElement);
120
- };
121
- export const clearSelectedElement = (board) => {
122
- cacheSelectedElements(board, []);
123
- };
124
- export const isSelectedElement = (board, element) => {
125
- const selectedElements = getSelectedElements(board);
126
- return !!selectedElements.find((value) => value === element);
127
- };
128
- export const temporaryDisableSelection = (board) => {
129
- const currentOptions = board.getPluginOptions(PlaitPluginKey.withSelection);
130
- board.setPluginOptions(PlaitPluginKey.withSelection, {
131
- isDisabledSelection: true
132
- });
133
- setTimeout(() => {
134
- board.setPluginOptions(PlaitPluginKey.withSelection, { ...currentOptions });
135
- }, 0);
136
- };
137
- export const isHitSelectedRectangle = (board, point) => {
138
- const hitSelectedElements = getHitSelectedElements(board, point);
139
- return hitSelectedElements.length > 0;
140
- };
141
- export const isHitElement = (board, point) => {
142
- const hitElement = getHitElementByPoint(board, point);
143
- return !!hitElement || isHitSelectedRectangle(board, point);
144
- };
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selected-element.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/selected-element.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Ancestor } from '../interfaces/node';\nimport { depthFirstRecursion, getIsRecursionFunc } from './tree';\nimport { BOARD_TO_SELECTED_ELEMENT } from './weak-maps';\nimport { Selection } from '../interfaces/selection';\nimport { PlaitElement } from '../interfaces/element';\nimport { Point } from '../interfaces/point';\nimport { sortElements } from './position';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport { getRectangleByElements } from './element';\nimport { PlaitOptionsBoard } from '../plugins/with-options';\nimport { isDebug } from './debug';\nimport { PlaitPluginKey, WithSelectionPluginOptions } from '../interfaces/plugin';\n\nexport const getHitElementsBySelection = (\n    board: PlaitBoard,\n    selection?: Selection,\n    match: (element: PlaitElement) => boolean = () => true\n) => {\n    const newSelection = selection || (board.selection as Selection);\n    const rectangleHitElements: PlaitElement[] = [];\n    if (!newSelection) {\n        return [];\n    }\n    const isCollapsed = Selection.isCollapsed(newSelection);\n    if (isCollapsed) {\n        const hitElements = getHitElementsByPoint(board, newSelection.anchor, match);\n        if (hitElements?.length) {\n            return hitElements;\n        } else {\n            return [];\n        }\n    }\n    depthFirstRecursion<Ancestor>(\n        board,\n        (node) => {\n            if (!PlaitBoard.isBoard(node) && match(node)) {\n                let isRectangleHit = false;\n                try {\n                    isRectangleHit = board.isRectangleHit(node, newSelection);\n                } catch (error) {\n                    if (isDebug()) {\n                        console.error('isRectangleHit', error, 'node', node);\n                    }\n                }\n                if (isRectangleHit) {\n                    rectangleHitElements.push(node);\n                }\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return rectangleHitElements;\n};\n\nexport const getHitElementsByPoint = (\n    board: PlaitBoard,\n    point: Point,\n    match: (element: PlaitElement) => boolean = () => true,\n    isStrict = true\n): PlaitElement[] => {\n    let hitElements: PlaitElement[] = [];\n    depthFirstRecursion<Ancestor>(\n        board,\n        (node) => {\n            if (PlaitBoard.isBoard(node) || !match(node) || !PlaitElement.hasMounted(node)) {\n                return;\n            }\n            let isHit = false;\n            try {\n                isHit = board.isHit(node, point, isStrict);\n            } catch (error) {\n                if (isDebug()) {\n                    console.error('isHit', error, 'node', node);\n                }\n            }\n            if (isHit) {\n                hitElements.push(node);\n                return;\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n    return hitElements;\n};\n\nexport const getHitElementByPoint = (\n    board: PlaitBoard,\n    point: Point,\n    match: (element: PlaitElement) => boolean = () => true,\n    isStrict = true\n): undefined | PlaitElement => {\n    const pointHitElements = getHitElementsByPoint(board, point, match, isStrict);\n    const hitElement = board.getOneHitElement(pointHitElements);\n    return hitElement;\n};\n\nexport const getHitSelectedElements = (board: PlaitBoard, point: Point) => {\n    const selectedElements = getSelectedElements(board);\n    const targetRectangle = selectedElements.length > 0 && getRectangleByElements(board, selectedElements, false);\n    const isInTargetRectangle = targetRectangle && RectangleClient.isPointInRectangle(targetRectangle, point);\n    if (isInTargetRectangle) {\n        return selectedElements;\n    } else {\n        return [];\n    }\n};\n\nexport const cacheSelectedElements = (board: PlaitBoard, selectedElements: PlaitElement[]) => {\n    const sortedElements = sortElements(board, selectedElements);\n    BOARD_TO_SELECTED_ELEMENT.set(board, sortedElements);\n};\n\nexport const getSelectedElements = (board: PlaitBoard) => {\n    return BOARD_TO_SELECTED_ELEMENT.get(board) || [];\n};\n\nexport const addSelectedElement = (board: PlaitBoard, element: PlaitElement | PlaitElement[]) => {\n    let elements = [];\n    if (Array.isArray(element)) {\n        elements.push(...element);\n    } else {\n        elements.push(element);\n    }\n    const selectedElements = getSelectedElements(board);\n    cacheSelectedElements(board, [...selectedElements, ...elements]);\n};\n\nexport const removeSelectedElement = (board: PlaitBoard, element: PlaitElement, isRemoveChildren = false) => {\n    const selectedElements = getSelectedElements(board);\n    if (selectedElements.includes(element)) {\n        const targetElements: PlaitElement[] = [];\n        if (board.isRecursion(element) && isRemoveChildren) {\n            depthFirstRecursion(\n                element,\n                (node) => {\n                    targetElements.push(node);\n                },\n                (node) => board.isRecursion(node)\n            );\n        } else {\n            targetElements.push(element);\n        }\n        const newSelectedElements = selectedElements.filter((value) => !targetElements.includes(value));\n        cacheSelectedElements(board, newSelectedElements);\n    }\n};\n\nexport const replaceSelectedElement = (board: PlaitBoard, element: PlaitElement, newElement: PlaitElement) => {\n    const selectedElements = getSelectedElements(board);\n    selectedElements.splice(selectedElements.indexOf(element), 1, newElement);\n};\n\nexport const clearSelectedElement = (board: PlaitBoard) => {\n    cacheSelectedElements(board, []);\n};\n\nexport const isSelectedElement = (board: PlaitBoard, element: PlaitElement) => {\n    const selectedElements = getSelectedElements(board);\n    return !!selectedElements.find((value) => value === element);\n};\n\nexport const temporaryDisableSelection = (board: PlaitOptionsBoard) => {\n    const currentOptions = board.getPluginOptions(PlaitPluginKey.withSelection);\n    board.setPluginOptions<WithSelectionPluginOptions>(PlaitPluginKey.withSelection, {\n        isDisabledSelection: true\n    });\n    setTimeout(() => {\n        board.setPluginOptions<WithSelectionPluginOptions>(PlaitPluginKey.withSelection, { ...currentOptions });\n    }, 0);\n};\n\nexport const isHitSelectedRectangle = (board: PlaitBoard, point: Point) => {\n    const hitSelectedElements = getHitSelectedElements(board, point);\n    return hitSelectedElements.length > 0;\n};\n\nexport const isHitElement = (board: PlaitBoard, point: Point) => {\n    const hitElement = getHitElementByPoint(board, point);\n    return !!hitElement || isHitSelectedRectangle(board, point);\n};\n"]}
@@ -1,151 +0,0 @@
1
- import { ACTIVE_STROKE_WIDTH, SELECTION_RECTANGLE_BOUNDING_CLASS_NAME, SELECTION_RECTANGLE_CLASS_NAME } from '../constants';
2
- import { PlaitBoard, PlaitOperation, PlaitPluginKey, PlaitPointerType, RectangleClient, SELECTION_BORDER_COLOR } from '../interfaces';
3
- import { setDragging } from './dnd';
4
- import { getRectangleByElements } from './element';
5
- import { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from './weak-maps';
6
- import { drawRectangle } from './drawing/rectangle';
7
- import { cacheSelectedElements, getSelectedElements } from './selected-element';
8
- import { getSelectionAngle, setAngleForG } from './angle';
9
- import { filterSelectedGroups, getAllElementsInGroup, getElementsInGroup, getElementsInGroupByElement, getGroupByElement } from './group';
10
- import { uniqueById } from './helper';
11
- import { Selection } from '../interfaces/selection';
12
- import { toActiveRectangleFromViewBoxRectangle } from './to-point';
13
- export function isSelectionMoving(board) {
14
- return !!BOARD_TO_IS_SELECTION_MOVING.get(board);
15
- }
16
- export function setSelectionMoving(board) {
17
- PlaitBoard.getBoardContainer(board).classList.add('selection-moving');
18
- BOARD_TO_IS_SELECTION_MOVING.set(board, true);
19
- setDragging(board, true);
20
- }
21
- export function clearSelectionMoving(board) {
22
- PlaitBoard.getBoardContainer(board).classList.remove('selection-moving');
23
- BOARD_TO_IS_SELECTION_MOVING.delete(board);
24
- setDragging(board, false);
25
- }
26
- export function isHandleSelection(board) {
27
- const options = getSelectionOptions(board);
28
- return board.pointer !== PlaitPointerType.hand && !options.isDisabledSelection && !PlaitBoard.isReadonly(board);
29
- }
30
- export function hasSetSelectionOperation(board) {
31
- return !!board.operations.find((op) => PlaitOperation.isSetSelectionOperation(op));
32
- }
33
- export function getTemporaryElements(board) {
34
- const ref = BOARD_TO_TEMPORARY_ELEMENTS.get(board);
35
- if (ref) {
36
- return ref.elements;
37
- }
38
- else {
39
- return undefined;
40
- }
41
- }
42
- export function getTemporaryRef(board) {
43
- return BOARD_TO_TEMPORARY_ELEMENTS.get(board);
44
- }
45
- export function deleteTemporaryElements(board) {
46
- BOARD_TO_TEMPORARY_ELEMENTS.delete(board);
47
- }
48
- export function drawSelectionRectangleG(board) {
49
- const elements = getSelectedElements(board);
50
- const rectangle = getRectangleByElements(board, elements, false);
51
- const activeRectangle = toActiveRectangleFromViewBoxRectangle(board, rectangle);
52
- if (activeRectangle.width > 0 && activeRectangle.height > 0 && elements.length > 1) {
53
- const selectionRectangleG = drawRectangle(board, RectangleClient.inflate(activeRectangle, ACTIVE_STROKE_WIDTH), {
54
- stroke: SELECTION_BORDER_COLOR,
55
- strokeWidth: ACTIVE_STROKE_WIDTH,
56
- fillStyle: 'solid'
57
- });
58
- selectionRectangleG.classList.add(SELECTION_RECTANGLE_CLASS_NAME, SELECTION_RECTANGLE_BOUNDING_CLASS_NAME);
59
- const angle = getSelectionAngle(elements);
60
- if (angle) {
61
- setAngleForG(selectionRectangleG, RectangleClient.getCenterPoint(activeRectangle), angle);
62
- }
63
- return selectionRectangleG;
64
- }
65
- return null;
66
- }
67
- export function setSelectedElementsWithGroup(board, elements, isShift) {
68
- if (!board.selection) {
69
- return;
70
- }
71
- const selectedElements = getSelectedElements(board);
72
- if (!Selection.isCollapsed(board.selection)) {
73
- let newElements = [...selectedElements];
74
- elements.forEach((item) => {
75
- if (!item.groupId) {
76
- newElements.push(item);
77
- }
78
- else {
79
- newElements.push(...getElementsInGroupByElement(board, item));
80
- }
81
- });
82
- cacheSelectedElements(board, uniqueById(newElements));
83
- return;
84
- }
85
- if (Selection.isCollapsed(board.selection)) {
86
- const hitElement = elements[0];
87
- const hitElementGroups = getGroupByElement(board, hitElement, true);
88
- if (hitElementGroups.length) {
89
- const elementsInHighestGroup = getElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true) || [];
90
- const isSelectGroupElement = selectedElements.some((element) => elementsInHighestGroup.map((item) => item.id).includes(element.id));
91
- if (isShift) {
92
- cacheSelectedElementsWithGroupOnShift(board, elements, isSelectGroupElement, elementsInHighestGroup);
93
- }
94
- else {
95
- cacheSelectedElementsWithGroup(board, elements, isSelectGroupElement, hitElementGroups);
96
- }
97
- }
98
- }
99
- }
100
- export function cacheSelectedElementsWithGroupOnShift(board, elements, isSelectGroupElement, elementsInHighestGroup) {
101
- const selectedElements = getSelectedElements(board);
102
- let newElements = [...selectedElements];
103
- const hitElement = elements[0];
104
- let pendingElements = [];
105
- if (!isSelectGroupElement) {
106
- pendingElements = elementsInHighestGroup;
107
- }
108
- else {
109
- const isHitSelectedElement = selectedElements.some((item) => item.id === hitElement.id);
110
- const selectedElementsInGroup = elementsInHighestGroup.filter((item) => selectedElements.includes(item));
111
- if (isHitSelectedElement) {
112
- pendingElements = selectedElementsInGroup.filter((item) => item.id !== hitElement.id);
113
- }
114
- else {
115
- pendingElements.push(...selectedElementsInGroup, ...elements);
116
- }
117
- }
118
- elementsInHighestGroup.forEach((element) => {
119
- if (newElements.includes(element)) {
120
- newElements.splice(newElements.indexOf(element), 1);
121
- }
122
- });
123
- if (pendingElements.length) {
124
- newElements.push(...pendingElements);
125
- }
126
- cacheSelectedElements(board, uniqueById(newElements));
127
- }
128
- export function cacheSelectedElementsWithGroup(board, elements, isSelectGroupElement, hitElementGroups) {
129
- let newElements = [...elements];
130
- const selectedGroups = filterSelectedGroups(board, hitElementGroups);
131
- if (selectedGroups.length > 0) {
132
- if (selectedGroups.length > 1) {
133
- newElements = getAllElementsInGroup(board, selectedGroups[selectedGroups.length - 2], true);
134
- }
135
- }
136
- else {
137
- const elementsInGroup = getAllElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true);
138
- if (!isSelectGroupElement) {
139
- newElements = elementsInGroup;
140
- }
141
- }
142
- cacheSelectedElements(board, uniqueById(newElements));
143
- }
144
- export const getSelectionOptions = (board) => {
145
- const options = board.getPluginOptions(PlaitPluginKey.withSelection);
146
- return options;
147
- };
148
- export const setSelectionOptions = (board, options) => {
149
- board.setPluginOptions(PlaitPluginKey.withSelection, options);
150
- };
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { ACTIVE_STROKE_WIDTH, SELECTION_RECTANGLE_BOUNDING_CLASS_NAME, SELECTION_RECTANGLE_CLASS_NAME } from '../constants';\nimport {\n    PlaitBoard,\n    PlaitElement,\n    PlaitGroup,\n    PlaitOperation,\n    PlaitPluginKey,\n    PlaitPointerType,\n    RectangleClient,\n    SELECTION_BORDER_COLOR,\n    WithSelectionPluginOptions\n} from '../interfaces';\nimport { setDragging } from './dnd';\nimport { getRectangleByElements } from './element';\nimport { BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_TEMPORARY_ELEMENTS } from './weak-maps';\nimport { drawRectangle } from './drawing/rectangle';\nimport { cacheSelectedElements, getSelectedElements } from './selected-element';\nimport { getSelectionAngle, setAngleForG } from './angle';\nimport { filterSelectedGroups, getAllElementsInGroup, getElementsInGroup, getElementsInGroupByElement, getGroupByElement } from './group';\nimport { uniqueById } from './helper';\nimport { Selection } from '../interfaces/selection';\nimport { PlaitOptionsBoard } from '../plugins/with-options';\nimport { toActiveRectangleFromViewBoxRectangle } from './to-point';\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    setDragging(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    setDragging(board, false);\n}\n\nexport function isHandleSelection(board: PlaitBoard) {\n    const options = getSelectionOptions(board);\n    return board.pointer !== PlaitPointerType.hand && !options.isDisabledSelection && !PlaitBoard.isReadonly(board);\n}\n\nexport function hasSetSelectionOperation(board: PlaitBoard) {\n    return !!board.operations.find((op) => PlaitOperation.isSetSelectionOperation(op));\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 drawSelectionRectangleG(board: PlaitBoard) {\n    const elements = getSelectedElements(board);\n    const rectangle = getRectangleByElements(board, elements, false);\n    const activeRectangle = toActiveRectangleFromViewBoxRectangle(board, rectangle);\n    if (activeRectangle.width > 0 && activeRectangle.height > 0 && elements.length > 1) {\n        const selectionRectangleG = drawRectangle(board, RectangleClient.inflate(activeRectangle, 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, SELECTION_RECTANGLE_BOUNDING_CLASS_NAME);\n        const angle = getSelectionAngle(elements);\n        if (angle) {\n            setAngleForG(selectionRectangleG, RectangleClient.getCenterPoint(activeRectangle), angle);\n        }\n        return selectionRectangleG;\n    }\n    return null;\n}\n\nexport function setSelectedElementsWithGroup(board: PlaitBoard, elements: PlaitElement[], isShift: boolean) {\n    if (!board.selection) {\n        return;\n    }\n    const selectedElements = getSelectedElements(board);\n    if (!Selection.isCollapsed(board.selection)) {\n        let newElements = [...selectedElements];\n        elements.forEach((item) => {\n            if (!item.groupId) {\n                newElements.push(item);\n            } else {\n                newElements.push(...getElementsInGroupByElement(board, item));\n            }\n        });\n        cacheSelectedElements(board, uniqueById(newElements));\n        return;\n    }\n    if (Selection.isCollapsed(board.selection)) {\n        const hitElement = elements[0];\n        const hitElementGroups = getGroupByElement(board, hitElement, true) as PlaitGroup[];\n        if (hitElementGroups.length) {\n            const elementsInHighestGroup = getElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true) || [];\n            const isSelectGroupElement = selectedElements.some((element) =>\n                elementsInHighestGroup.map((item) => item.id).includes(element.id)\n            );\n            if (isShift) {\n                cacheSelectedElementsWithGroupOnShift(board, elements, isSelectGroupElement, elementsInHighestGroup);\n            } else {\n                cacheSelectedElementsWithGroup(board, elements, isSelectGroupElement, hitElementGroups);\n            }\n        }\n    }\n}\n\nexport function cacheSelectedElementsWithGroupOnShift(\n    board: PlaitBoard,\n    elements: PlaitElement[],\n    isSelectGroupElement: boolean,\n    elementsInHighestGroup: PlaitElement[]\n) {\n    const selectedElements = getSelectedElements(board);\n    let newElements = [...selectedElements];\n    const hitElement = elements[0];\n    let pendingElements: PlaitElement[] = [];\n    if (!isSelectGroupElement) {\n        pendingElements = elementsInHighestGroup;\n    } else {\n        const isHitSelectedElement = selectedElements.some((item) => item.id === hitElement.id);\n        const selectedElementsInGroup = elementsInHighestGroup.filter((item) => selectedElements.includes(item));\n        if (isHitSelectedElement) {\n            pendingElements = selectedElementsInGroup.filter((item) => item.id !== hitElement.id);\n        } else {\n            pendingElements.push(...selectedElementsInGroup, ...elements);\n        }\n    }\n    elementsInHighestGroup.forEach((element) => {\n        if (newElements.includes(element)) {\n            newElements.splice(newElements.indexOf(element), 1);\n        }\n    });\n    if (pendingElements.length) {\n        newElements.push(...pendingElements);\n    }\n    cacheSelectedElements(board, uniqueById(newElements));\n}\n\nexport function cacheSelectedElementsWithGroup(\n    board: PlaitBoard,\n    elements: PlaitElement[],\n    isSelectGroupElement: boolean,\n    hitElementGroups: PlaitGroup[]\n) {\n    let newElements = [...elements];\n    const selectedGroups = filterSelectedGroups(board, hitElementGroups);\n    if (selectedGroups.length > 0) {\n        if (selectedGroups.length > 1) {\n            newElements = getAllElementsInGroup(board, selectedGroups[selectedGroups.length - 2], true);\n        }\n    } else {\n        const elementsInGroup = getAllElementsInGroup(board, hitElementGroups[hitElementGroups.length - 1], true);\n        if (!isSelectGroupElement) {\n            newElements = elementsInGroup;\n        }\n    }\n    cacheSelectedElements(board, uniqueById(newElements));\n}\n\nexport const getSelectionOptions = (board: PlaitBoard) => {\n    const options = (board as PlaitOptionsBoard).getPluginOptions<WithSelectionPluginOptions>(PlaitPluginKey.withSelection);\n    return options;\n};\n\nexport const setSelectionOptions = (board: PlaitBoard, options: Partial<WithSelectionPluginOptions>) => {\n    (board as PlaitOptionsBoard).setPluginOptions<WithSelectionPluginOptions>(PlaitPluginKey.withSelection, options);\n};\n"]}
@@ -1,199 +0,0 @@
1
- import { createG } from '../dom/common';
2
- import { RectangleClient } from '../../interfaces';
3
- import { drawPointSnapLines, drawSolidLines, getMinPointDelta, getSnapRectangles, getTripleAxis, SNAP_TOLERANCE } from './snap';
4
- export function getSnapMovingRef(board, activeRectangle, activeElements) {
5
- const snapRectangles = getSnapRectangles(board, activeElements);
6
- const snapG = createG();
7
- let snapDelta = getPointLineDelta(activeRectangle, snapRectangles);
8
- const pointLinesG = drawMovingPointSnapLines(board, snapDelta, activeRectangle, snapRectangles);
9
- snapG.append(pointLinesG);
10
- const result = getGapSnapLinesAndDelta(board, snapDelta, activeRectangle, snapRectangles);
11
- snapDelta = result.snapDelta;
12
- snapG.append(result.snapG);
13
- return { ...snapDelta, snapG };
14
- }
15
- function getPointLineDeltas(activeRectangle, snapRectangles, isHorizontal) {
16
- const axis = getTripleAxis(activeRectangle, isHorizontal);
17
- const deltaStart = getMinPointDelta(snapRectangles, axis[0], isHorizontal);
18
- const deltaMiddle = getMinPointDelta(snapRectangles, axis[1], isHorizontal);
19
- const deltaEnd = getMinPointDelta(snapRectangles, axis[2], isHorizontal);
20
- return [deltaStart, deltaMiddle, deltaEnd];
21
- }
22
- function getPointLineDelta(activeRectangle, snapRectangles) {
23
- let snapDelta = {
24
- deltaX: 0,
25
- deltaY: 0
26
- };
27
- function getDelta(isHorizontal) {
28
- let delta = 0;
29
- const deltas = getPointLineDeltas(activeRectangle, snapRectangles, isHorizontal);
30
- for (let i = 0; i < deltas.length; i++) {
31
- if (Math.abs(deltas[i]) < SNAP_TOLERANCE) {
32
- delta = deltas[i];
33
- break;
34
- }
35
- }
36
- return delta;
37
- }
38
- snapDelta.deltaX = getDelta(true);
39
- snapDelta.deltaY = getDelta(false);
40
- return snapDelta;
41
- }
42
- function updateActiveRectangle(snapDelta, activeRectangle) {
43
- const { deltaX, deltaY } = snapDelta;
44
- const { x, y, width, height } = activeRectangle;
45
- return {
46
- x: x + deltaX,
47
- y: y + deltaY,
48
- width,
49
- height
50
- };
51
- }
52
- function drawMovingPointSnapLines(board, snapDelta, activeRectangle, snapRectangles) {
53
- const newActiveRectangle = updateActiveRectangle(snapDelta, activeRectangle);
54
- return drawPointSnapLines(board, newActiveRectangle, snapRectangles, true, true, true);
55
- }
56
- function getGapSnapLinesAndDelta(board, snapDelta, activeRectangle, snapRectangles) {
57
- let deltaX = snapDelta.deltaX;
58
- let deltaY = snapDelta.deltaY;
59
- const gapHorizontalResult = getGapLinesAndDelta(activeRectangle, snapRectangles, true);
60
- const gapVerticalResult = getGapLinesAndDelta(activeRectangle, snapRectangles, false);
61
- const gapSnapLines = [...gapHorizontalResult.lines, ...gapVerticalResult.lines];
62
- if (gapHorizontalResult.delta) {
63
- deltaX = gapHorizontalResult.delta;
64
- }
65
- if (gapVerticalResult.delta) {
66
- deltaY = gapVerticalResult.delta;
67
- }
68
- return {
69
- snapDelta: { deltaX, deltaY },
70
- snapG: drawSolidLines(board, gapSnapLines)
71
- };
72
- }
73
- function getGapLinesAndDelta(activeRectangle, snapRectangles, isHorizontal) {
74
- let lines = [];
75
- let delta = 0;
76
- let rectangles = [];
77
- const axis = isHorizontal ? 'x' : 'y';
78
- const side = isHorizontal ? 'width' : 'height';
79
- const activeRectangleCenter = activeRectangle[axis] + activeRectangle[side] / 2;
80
- snapRectangles.forEach(rec => {
81
- const isCross = isHorizontal ? isHorizontalCross(rec, activeRectangle) : isVerticalCross(rec, activeRectangle);
82
- if (isCross && !RectangleClient.isHit(rec, activeRectangle)) {
83
- rectangles.push(rec);
84
- }
85
- });
86
- rectangles = [...rectangles, activeRectangle].sort((a, b) => a[axis] - b[axis]);
87
- const refArray = [];
88
- let gapDistance = 0;
89
- let beforeIndex = undefined;
90
- let afterIndex = undefined;
91
- for (let i = 0; i < rectangles.length; i++) {
92
- for (let j = i + 1; j < rectangles.length; j++) {
93
- const before = rectangles[i];
94
- const after = rectangles[j];
95
- const distance = after[axis] - (before[axis] + before[side]);
96
- let dif = Infinity;
97
- if (refArray[i]?.after) {
98
- refArray[i].after.push({ distance, index: j });
99
- }
100
- else {
101
- refArray[i] = { ...refArray[i], after: [{ distance, index: j }] };
102
- }
103
- if (refArray[j]?.before) {
104
- refArray[j].before.push({ distance, index: i });
105
- }
106
- else {
107
- refArray[j] = { ...refArray[j], before: [{ distance, index: i }] };
108
- }
109
- //middle
110
- let _center = (before[axis] + before[side] + after[axis]) / 2;
111
- dif = Math.abs(_center - activeRectangleCenter);
112
- if (dif < SNAP_TOLERANCE) {
113
- gapDistance = (after[axis] - (before[axis] + before[side]) - activeRectangle[side]) / 2;
114
- delta = _center - activeRectangleCenter;
115
- beforeIndex = i;
116
- afterIndex = j;
117
- }
118
- //after
119
- const distanceRight = after[axis] - (before[axis] + before[side]);
120
- _center = after[axis] + after[side] + distanceRight + activeRectangle[side] / 2;
121
- dif = Math.abs(_center - activeRectangleCenter);
122
- if ((!gapDistance || gapDistance !== distanceRight) && dif < SNAP_TOLERANCE) {
123
- gapDistance = distanceRight;
124
- beforeIndex = j;
125
- delta = _center - activeRectangleCenter;
126
- }
127
- //before
128
- const distanceBefore = after[axis] - (before[axis] + before[side]);
129
- _center = before[axis] - distanceBefore - activeRectangle[side] / 2;
130
- dif = Math.abs(_center - activeRectangleCenter);
131
- if (!gapDistance && dif < SNAP_TOLERANCE) {
132
- gapDistance = distanceBefore;
133
- afterIndex = i;
134
- delta = _center - activeRectangleCenter;
135
- }
136
- }
137
- }
138
- const activeIndex = rectangles.indexOf(activeRectangle);
139
- let beforeIndexes = [];
140
- let afterIndexes = [];
141
- if (beforeIndex !== undefined) {
142
- beforeIndexes.push(beforeIndex);
143
- findRectangle(gapDistance, refArray[beforeIndex], 'before', beforeIndexes);
144
- }
145
- if (afterIndex !== undefined) {
146
- afterIndexes.push(afterIndex);
147
- findRectangle(gapDistance, refArray[afterIndex], 'after', afterIndexes);
148
- }
149
- if (beforeIndexes.length || afterIndexes.length) {
150
- const indexArr = [...beforeIndexes.reverse(), activeIndex, ...afterIndexes];
151
- activeRectangle[axis] += delta;
152
- for (let i = 1; i < indexArr.length; i++) {
153
- lines.push(getLinePoints(rectangles[indexArr[i - 1]], rectangles[indexArr[i]]));
154
- }
155
- }
156
- function findRectangle(distance, ref, direction, rectangleIndexes) {
157
- const arr = ref[direction];
158
- const index = refArray.indexOf(ref);
159
- if ((index === 0 && direction === 'before') || (index === refArray.length - 1 && direction === 'after'))
160
- return;
161
- for (let i = 0; i < arr.length; i++) {
162
- if (Math.abs(arr[i].distance - distance) < 0.1) {
163
- rectangleIndexes.push(arr[i].index);
164
- findRectangle(distance, refArray[arr[i].index], direction, rectangleIndexes);
165
- return;
166
- }
167
- }
168
- }
169
- function getLinePoints(beforeRectangle, afterRectangle) {
170
- const oppositeAxis = axis === 'x' ? 'y' : 'x';
171
- const oppositeSide = side === 'width' ? 'height' : 'width';
172
- const snap = [
173
- beforeRectangle[oppositeAxis],
174
- beforeRectangle[oppositeAxis] + beforeRectangle[oppositeSide],
175
- afterRectangle[oppositeAxis],
176
- afterRectangle[oppositeAxis] + afterRectangle[oppositeSide]
177
- ];
178
- const sortArr = snap.sort((a, b) => a - b);
179
- const average = (sortArr[1] + sortArr[2]) / 2;
180
- const offset = 3;
181
- return isHorizontal
182
- ? [
183
- [beforeRectangle.x + beforeRectangle.width + offset, average],
184
- [afterRectangle.x - offset, average]
185
- ]
186
- : [
187
- [average, beforeRectangle.y + beforeRectangle.height + offset],
188
- [average, afterRectangle.y - offset]
189
- ];
190
- }
191
- return { delta, lines };
192
- }
193
- function isHorizontalCross(rectangle, other) {
194
- return !(rectangle.y + rectangle.height < other.y || rectangle.y > other.y + other.height);
195
- }
196
- function isVerticalCross(rectangle, other) {
197
- return !(rectangle.x + rectangle.width < other.x || rectangle.x > other.x + other.width);
198
- }
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snap-moving.js","sourceRoot":"","sources":["../../../../../packages/core/src/utils/snap/snap-moving.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAExC,OAAO,EAAS,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EACH,kBAAkB,EAClB,cAAc,EAEd,gBAAgB,EAChB,iBAAiB,EACjB,aAAa,EACb,cAAc,EAGjB,MAAM,QAAQ,CAAC;AAEhB,MAAM,UAAU,gBAAgB,CAAC,KAAiB,EAAE,eAAgC,EAAE,cAA8B;IAChH,MAAM,cAAc,GAAG,iBAAiB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;IAChE,MAAM,KAAK,GAAG,OAAO,EAAE,CAAC;IACxB,IAAI,SAAS,GAAG,iBAAiB,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC;IACnE,MAAM,WAAW,GAAG,wBAAwB,CAAC,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,cAAc,CAAC,CAAC;IAChG,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;IAC1B,MAAM,MAAM,GAAG,uBAAuB,CAAC,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,cAAc,CAAC,CAAC;IAC1F,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;IAC7B,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC3B,OAAO,EAAE,GAAG,SAAS,EAAE,KAAK,EAAE,CAAC;AACnC,CAAC;AAED,SAAS,kBAAkB,CAAC,eAAgC,EAAE,cAAiC,EAAE,YAAqB;IAClH,MAAM,IAAI,GAAG,aAAa,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;IAC1D,MAAM,UAAU,GAAG,gBAAgB,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;IAC3E,MAAM,WAAW,GAAG,gBAAgB,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;IAC5E,MAAM,QAAQ,GAAG,gBAAgB,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;IACzE,OAAO,CAAC,UAAU,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;AAC/C,CAAC;AAED,SAAS,iBAAiB,CAAC,eAAgC,EAAE,cAAiC;IAC1F,IAAI,SAAS,GAAc;QACvB,MAAM,EAAE,CAAC;QACT,MAAM,EAAE,CAAC;KACZ,CAAC;IACF,SAAS,QAAQ,CAAC,YAAqB;QACnC,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,MAAM,MAAM,GAAG,kBAAkB,CAAC,eAAe,EAAE,cAAc,EAAE,YAAY,CAAC,CAAC;QACjF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACrC,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,cAAc,EAAE,CAAC;gBACvC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;gBAClB,MAAM;YACV,CAAC;QACL,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,SAAS,CAAC,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAClC,SAAS,CAAC,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACnC,OAAO,SAAS,CAAC;AACrB,CAAC;AAED,SAAS,qBAAqB,CAAC,SAAoB,EAAE,eAAgC;IACjF,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IACrC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,eAAe,CAAC;IAChD,OAAO;QACH,CAAC,EAAE,CAAC,GAAG,MAAM;QACb,CAAC,EAAE,CAAC,GAAG,MAAM;QACb,KAAK;QACL,MAAM;KACT,CAAC;AACN,CAAC;AAED,SAAS,wBAAwB,CAC7B,KAAiB,EACjB,SAAoB,EACpB,eAAgC,EAChC,cAAiC;IAEjC,MAAM,kBAAkB,GAAG,qBAAqB,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;IAC7E,OAAO,kBAAkB,CAAC,KAAK,EAAE,kBAAkB,EAAE,cAAc,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAC3F,CAAC;AAED,SAAS,uBAAuB,CAC5B,KAAiB,EACjB,SAAoB,EACpB,eAAgC,EAChC,cAAiC;IAEjC,IAAI,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;IAC9B,IAAI,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;IAC9B,MAAM,mBAAmB,GAAG,mBAAmB,CAAC,eAAe,EAAE,cAAc,EAAE,IAAI,CAAC,CAAC;IACvF,MAAM,iBAAiB,GAAG,mBAAmB,CAAC,eAAe,EAAE,cAAc,EAAE,KAAK,CAAC,CAAC;IACtF,MAAM,YAAY,GAAc,CAAC,GAAG,mBAAmB,CAAC,KAAK,EAAE,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAC3F,IAAI,mBAAmB,CAAC,KAAK,EAAE,CAAC;QAC5B,MAAM,GAAG,mBAAmB,CAAC,KAAK,CAAC;IACvC,CAAC;IACD,IAAI,iBAAiB,CAAC,KAAK,EAAE,CAAC;QAC1B,MAAM,GAAG,iBAAiB,CAAC,KAAK,CAAC;IACrC,CAAC;IACD,OAAO;QACH,SAAS,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;QAC7B,KAAK,EAAE,cAAc,CAAC,KAAK,EAAE,YAAY,CAAC;KAC7C,CAAC;AACN,CAAC;AAED,SAAS,mBAAmB,CAAC,eAAgC,EAAE,cAAiC,EAAE,YAAqB;IACnH,IAAI,KAAK,GAAU,EAAE,CAAC;IACtB,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,IAAI,UAAU,GAAsB,EAAE,CAAC;IACvC,MAAM,IAAI,GAAG,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IACtC,MAAM,IAAI,GAAG,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC;IAE/C,MAAM,qBAAqB,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAChF,cAAc,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QACzB,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,iBAAiB,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC;QAC/G,IAAI,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,CAAC;YAC1D,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACzB,CAAC;IACL,CAAC,CAAC,CAAC;IACH,UAAU,GAAG,CAAC,GAAG,UAAU,EAAE,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAEhF,MAAM,QAAQ,GAAiB,EAAE,CAAC;IAClC,IAAI,WAAW,GAAG,CAAC,CAAC;IACpB,IAAI,WAAW,GAAG,SAAS,CAAC;IAC5B,IAAI,UAAU,GAAG,SAAS,CAAC;IAE3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACzC,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC7C,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC7B,MAAM,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC5B,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YAC7D,IAAI,GAAG,GAAG,QAAQ,CAAC;YACnB,IAAI,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC;gBACrB,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;YACnD,CAAC;iBAAM,CAAC;gBACJ,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;YACtE,CAAC;YAED,IAAI,QAAQ,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC;gBACtB,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;YACpD,CAAC;iBAAM,CAAC;gBACJ,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;YACvE,CAAC;YAED,QAAQ;YACR,IAAI,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YAC9D,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,qBAAqB,CAAC,CAAC;YAChD,IAAI,GAAG,GAAG,cAAc,EAAE,CAAC;gBACvB,WAAW,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;gBACxF,KAAK,GAAG,OAAO,GAAG,qBAAqB,CAAC;gBACxC,WAAW,GAAG,CAAC,CAAC;gBAChB,UAAU,GAAG,CAAC,CAAC;YACnB,CAAC;YAED,OAAO;YACP,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YAClE,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,aAAa,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChF,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,qBAAqB,CAAC,CAAC;YAChD,IAAI,CAAC,CAAC,WAAW,IAAI,WAAW,KAAK,aAAa,CAAC,IAAI,GAAG,GAAG,cAAc,EAAE,CAAC;gBAC1E,WAAW,GAAG,aAAa,CAAC;gBAC5B,WAAW,GAAG,CAAC,CAAC;gBAChB,KAAK,GAAG,OAAO,GAAG,qBAAqB,CAAC;YAC5C,CAAC;YAED,QAAQ;YACR,MAAM,cAAc,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YACnE,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,cAAc,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACpE,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,qBAAqB,CAAC,CAAC;YAEhD,IAAI,CAAC,WAAW,IAAI,GAAG,GAAG,cAAc,EAAE,CAAC;gBACvC,WAAW,GAAG,cAAc,CAAC;gBAC7B,UAAU,GAAG,CAAC,CAAC;gBACf,KAAK,GAAG,OAAO,GAAG,qBAAqB,CAAC;YAC5C,CAAC;QACL,CAAC;IACL,CAAC;IAED,MAAM,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;IACxD,IAAI,aAAa,GAAa,EAAE,CAAC;IACjC,IAAI,YAAY,GAAa,EAAE,CAAC;IAChC,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;QAC5B,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAChC,aAAa,CAAC,WAAW,EAAE,QAAQ,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;IAC/E,CAAC;IAED,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;QAC3B,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC9B,aAAa,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;IAC5E,CAAC;IAED,IAAI,aAAa,CAAC,MAAM,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;QAC9C,MAAM,QAAQ,GAAG,CAAC,GAAG,aAAa,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,GAAG,YAAY,CAAC,CAAC;QAC5E,eAAe,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC;QAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACvC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpF,CAAC;IACL,CAAC;IAED,SAAS,aAAa,CAAC,QAAgB,EAAE,GAAe,EAAE,SAAiB,EAAE,gBAA0B;QACnG,MAAM,GAAG,GAAG,GAAG,CAAC,SAA6B,CAAC,CAAC;QAC/C,MAAM,KAAK,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACpC,IAAI,CAAC,KAAK,KAAK,CAAC,IAAI,SAAS,KAAK,QAAQ,CAAC,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,SAAS,KAAK,OAAO,CAAC;YAAE,OAAO;QAChH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAClC,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,QAAQ,CAAC,GAAG,GAAG,EAAE,CAAC;gBAC7C,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBACpC,aAAa,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,gBAAgB,CAAC,CAAC;gBAC7E,OAAO;YACX,CAAC;QACL,CAAC;IACL,CAAC;IAED,SAAS,aAAa,CAAC,eAAgC,EAAE,cAA+B;QACpF,MAAM,YAAY,GAAG,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QAC9C,MAAM,YAAY,GAAG,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC;QAC3D,MAAM,IAAI,GAAG;YACT,eAAe,CAAC,YAAY,CAAC;YAC7B,eAAe,CAAC,YAAY,CAAC,GAAG,eAAe,CAAC,YAAY,CAAC;YAC7D,cAAc,CAAC,YAAY,CAAC;YAC5B,cAAc,CAAC,YAAY,CAAC,GAAG,cAAc,CAAC,YAAY,CAAC;SAC9D,CAAC;QACF,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC3C,MAAM,OAAO,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,CAAC,CAAC;QACjB,OAAO,YAAY;YACf,CAAC,CAAC;gBACI,CAAC,eAAe,CAAC,CAAC,GAAG,eAAe,CAAC,KAAK,GAAG,MAAM,EAAE,OAAO,CAAC;gBAC7D,CAAC,cAAc,CAAC,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC;aACvC;YACH,CAAC,CAAC;gBACI,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC,GAAG,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC;gBAC9D,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,GAAG,MAAM,CAAC;aACvC,CAAC;IACZ,CAAC;IACD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AAC5B,CAAC;AAED,SAAS,iBAAiB,CAAC,SAA0B,EAAE,KAAsB;IACzE,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;AAC/F,CAAC;AAED,SAAS,eAAe,CAAC,SAA0B,EAAE,KAAsB;IACvE,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;AAC7F,CAAC","sourcesContent":["import { PlaitBoard } from '../../interfaces/board';\nimport { createG } from '../dom/common';\nimport { PlaitElement } from '../../interfaces/element';\nimport { Point, RectangleClient } from '../../interfaces';\nimport {\n    drawPointSnapLines,\n    drawSolidLines,\n    GapSnapRef,\n    getMinPointDelta,\n    getSnapRectangles,\n    getTripleAxis,\n    SNAP_TOLERANCE,\n    SnapDelta,\n    SnapRef\n} from './snap';\n\nexport function getSnapMovingRef(board: PlaitBoard, activeRectangle: RectangleClient, activeElements: PlaitElement[]): SnapRef {\n    const snapRectangles = getSnapRectangles(board, activeElements);\n    const snapG = createG();\n    let snapDelta = getPointLineDelta(activeRectangle, snapRectangles);\n    const pointLinesG = drawMovingPointSnapLines(board, snapDelta, activeRectangle, snapRectangles);\n    snapG.append(pointLinesG);\n    const result = getGapSnapLinesAndDelta(board, snapDelta, activeRectangle, snapRectangles);\n    snapDelta = result.snapDelta;\n    snapG.append(result.snapG);\n    return { ...snapDelta, snapG };\n}\n\nfunction getPointLineDeltas(activeRectangle: RectangleClient, snapRectangles: RectangleClient[], isHorizontal: boolean) {\n    const axis = getTripleAxis(activeRectangle, isHorizontal);\n    const deltaStart = getMinPointDelta(snapRectangles, axis[0], isHorizontal);\n    const deltaMiddle = getMinPointDelta(snapRectangles, axis[1], isHorizontal);\n    const deltaEnd = getMinPointDelta(snapRectangles, axis[2], isHorizontal);\n    return [deltaStart, deltaMiddle, deltaEnd];\n}\n\nfunction getPointLineDelta(activeRectangle: RectangleClient, snapRectangles: RectangleClient[]) {\n    let snapDelta: SnapDelta = {\n        deltaX: 0,\n        deltaY: 0\n    };\n    function getDelta(isHorizontal: boolean) {\n        let delta = 0;\n        const deltas = getPointLineDeltas(activeRectangle, snapRectangles, isHorizontal);\n        for (let i = 0; i < deltas.length; i++) {\n            if (Math.abs(deltas[i]) < SNAP_TOLERANCE) {\n                delta = deltas[i];\n                break;\n            }\n        }\n        return delta;\n    }\n    snapDelta.deltaX = getDelta(true);\n    snapDelta.deltaY = getDelta(false);\n    return snapDelta;\n}\n\nfunction updateActiveRectangle(snapDelta: SnapDelta, activeRectangle: RectangleClient) {\n    const { deltaX, deltaY } = snapDelta;\n    const { x, y, width, height } = activeRectangle;\n    return {\n        x: x + deltaX,\n        y: y + deltaY,\n        width,\n        height\n    };\n}\n\nfunction drawMovingPointSnapLines(\n    board: PlaitBoard,\n    snapDelta: SnapDelta,\n    activeRectangle: RectangleClient,\n    snapRectangles: RectangleClient[]\n) {\n    const newActiveRectangle = updateActiveRectangle(snapDelta, activeRectangle);\n    return drawPointSnapLines(board, newActiveRectangle, snapRectangles, true, true, true);\n}\n\nfunction getGapSnapLinesAndDelta(\n    board: PlaitBoard,\n    snapDelta: SnapDelta,\n    activeRectangle: RectangleClient,\n    snapRectangles: RectangleClient[]\n) {\n    let deltaX = snapDelta.deltaX;\n    let deltaY = snapDelta.deltaY;\n    const gapHorizontalResult = getGapLinesAndDelta(activeRectangle, snapRectangles, true);\n    const gapVerticalResult = getGapLinesAndDelta(activeRectangle, snapRectangles, false);\n    const gapSnapLines: Point[][] = [...gapHorizontalResult.lines, ...gapVerticalResult.lines];\n    if (gapHorizontalResult.delta) {\n        deltaX = gapHorizontalResult.delta;\n    }\n    if (gapVerticalResult.delta) {\n        deltaY = gapVerticalResult.delta;\n    }\n    return {\n        snapDelta: { deltaX, deltaY },\n        snapG: drawSolidLines(board, gapSnapLines)\n    };\n}\n\nfunction getGapLinesAndDelta(activeRectangle: RectangleClient, snapRectangles: RectangleClient[], isHorizontal: boolean) {\n    let lines: any[] = [];\n    let delta = 0;\n    let rectangles: RectangleClient[] = [];\n    const axis = isHorizontal ? 'x' : 'y';\n    const side = isHorizontal ? 'width' : 'height';\n\n    const activeRectangleCenter = activeRectangle[axis] + activeRectangle[side] / 2;\n    snapRectangles.forEach(rec => {\n        const isCross = isHorizontal ? isHorizontalCross(rec, activeRectangle) : isVerticalCross(rec, activeRectangle);\n        if (isCross && !RectangleClient.isHit(rec, activeRectangle)) {\n            rectangles.push(rec);\n        }\n    });\n    rectangles = [...rectangles, activeRectangle].sort((a, b) => a[axis] - b[axis]);\n\n    const refArray: GapSnapRef[] = [];\n    let gapDistance = 0;\n    let beforeIndex = undefined;\n    let afterIndex = undefined;\n\n    for (let i = 0; i < rectangles.length; i++) {\n        for (let j = i + 1; j < rectangles.length; j++) {\n            const before = rectangles[i];\n            const after = rectangles[j];\n            const distance = after[axis] - (before[axis] + before[side]);\n            let dif = Infinity;\n            if (refArray[i]?.after) {\n                refArray[i].after.push({ distance, index: j });\n            } else {\n                refArray[i] = { ...refArray[i], after: [{ distance, index: j }] };\n            }\n\n            if (refArray[j]?.before) {\n                refArray[j].before.push({ distance, index: i });\n            } else {\n                refArray[j] = { ...refArray[j], before: [{ distance, index: i }] };\n            }\n\n            //middle\n            let _center = (before[axis] + before[side] + after[axis]) / 2;\n            dif = Math.abs(_center - activeRectangleCenter);\n            if (dif < SNAP_TOLERANCE) {\n                gapDistance = (after[axis] - (before[axis] + before[side]) - activeRectangle[side]) / 2;\n                delta = _center - activeRectangleCenter;\n                beforeIndex = i;\n                afterIndex = j;\n            }\n\n            //after\n            const distanceRight = after[axis] - (before[axis] + before[side]);\n            _center = after[axis] + after[side] + distanceRight + activeRectangle[side] / 2;\n            dif = Math.abs(_center - activeRectangleCenter);\n            if ((!gapDistance || gapDistance !== distanceRight) && dif < SNAP_TOLERANCE) {\n                gapDistance = distanceRight;\n                beforeIndex = j;\n                delta = _center - activeRectangleCenter;\n            }\n\n            //before\n            const distanceBefore = after[axis] - (before[axis] + before[side]);\n            _center = before[axis] - distanceBefore - activeRectangle[side] / 2;\n            dif = Math.abs(_center - activeRectangleCenter);\n\n            if (!gapDistance && dif < SNAP_TOLERANCE) {\n                gapDistance = distanceBefore;\n                afterIndex = i;\n                delta = _center - activeRectangleCenter;\n            }\n        }\n    }\n\n    const activeIndex = rectangles.indexOf(activeRectangle);\n    let beforeIndexes: number[] = [];\n    let afterIndexes: number[] = [];\n    if (beforeIndex !== undefined) {\n        beforeIndexes.push(beforeIndex);\n        findRectangle(gapDistance, refArray[beforeIndex], 'before', beforeIndexes);\n    }\n\n    if (afterIndex !== undefined) {\n        afterIndexes.push(afterIndex);\n        findRectangle(gapDistance, refArray[afterIndex], 'after', afterIndexes);\n    }\n\n    if (beforeIndexes.length || afterIndexes.length) {\n        const indexArr = [...beforeIndexes.reverse(), activeIndex, ...afterIndexes];\n        activeRectangle[axis] += delta;\n        for (let i = 1; i < indexArr.length; i++) {\n            lines.push(getLinePoints(rectangles[indexArr[i - 1]], rectangles[indexArr[i]]));\n        }\n    }\n\n    function findRectangle(distance: number, ref: GapSnapRef, direction: string, rectangleIndexes: number[]) {\n        const arr = ref[direction as keyof GapSnapRef];\n        const index = refArray.indexOf(ref);\n        if ((index === 0 && direction === 'before') || (index === refArray.length - 1 && direction === 'after')) return;\n        for (let i = 0; i < arr.length; i++) {\n            if (Math.abs(arr[i].distance - distance) < 0.1) {\n                rectangleIndexes.push(arr[i].index);\n                findRectangle(distance, refArray[arr[i].index], direction, rectangleIndexes);\n                return;\n            }\n        }\n    }\n\n    function getLinePoints(beforeRectangle: RectangleClient, afterRectangle: RectangleClient) {\n        const oppositeAxis = axis === 'x' ? 'y' : 'x';\n        const oppositeSide = side === 'width' ? 'height' : 'width';\n        const snap = [\n            beforeRectangle[oppositeAxis],\n            beforeRectangle[oppositeAxis] + beforeRectangle[oppositeSide],\n            afterRectangle[oppositeAxis],\n            afterRectangle[oppositeAxis] + afterRectangle[oppositeSide]\n        ];\n        const sortArr = snap.sort((a, b) => a - b);\n        const average = (sortArr[1] + sortArr[2]) / 2;\n        const offset = 3;\n        return isHorizontal\n            ? [\n                  [beforeRectangle.x + beforeRectangle.width + offset, average],\n                  [afterRectangle.x - offset, average]\n              ]\n            : [\n                  [average, beforeRectangle.y + beforeRectangle.height + offset],\n                  [average, afterRectangle.y - offset]\n              ];\n    }\n    return { delta, lines };\n}\n\nfunction isHorizontalCross(rectangle: RectangleClient, other: RectangleClient) {\n    return !(rectangle.y + rectangle.height < other.y || rectangle.y > other.y + other.height);\n}\n\nfunction isVerticalCross(rectangle: RectangleClient, other: RectangleClient) {\n    return !(rectangle.x + rectangle.width < other.x || rectangle.x > other.x + other.width);\n}\n"]}