@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.
- package/fesm2022/plait-core.mjs.map +1 -1
- package/package.json +1 -3
- package/esm2022/constants/cursor.mjs +0 -13
- package/esm2022/constants/index.mjs +0 -20
- package/esm2022/constants/keycodes.mjs +0 -127
- package/esm2022/constants/selection.mjs +0 -6
- package/esm2022/constants/zoom.mjs +0 -4
- package/esm2022/context.mjs +0 -23
- package/esm2022/core/element/context-change.mjs +0 -13
- package/esm2022/core/element/context.mjs +0 -2
- package/esm2022/core/element/element-flavour.mjs +0 -140
- package/esm2022/core/element/element-ref.mjs +0 -2
- package/esm2022/core/list-render.mjs +0 -217
- package/esm2022/differs/default_iterable_differ.mjs +0 -614
- package/esm2022/differs/iterable_differs.mjs +0 -9
- package/esm2022/interfaces/board.mjs +0 -108
- package/esm2022/interfaces/custom-types.mjs +0 -5
- package/esm2022/interfaces/direction.mjs +0 -8
- package/esm2022/interfaces/element.mjs +0 -43
- package/esm2022/interfaces/group.mjs +0 -6
- package/esm2022/interfaces/history.mjs +0 -5
- package/esm2022/interfaces/index.mjs +0 -19
- package/esm2022/interfaces/node.mjs +0 -57
- package/esm2022/interfaces/operation.mjs +0 -96
- package/esm2022/interfaces/path-ref.mjs +0 -15
- package/esm2022/interfaces/path.mjs +0 -183
- package/esm2022/interfaces/plugin.mjs +0 -6
- package/esm2022/interfaces/point.mjs +0 -27
- package/esm2022/interfaces/pointer.mjs +0 -6
- package/esm2022/interfaces/rectangle-client.mjs +0 -171
- package/esm2022/interfaces/selection.mjs +0 -13
- package/esm2022/interfaces/svg-arc-command.mjs +0 -2
- package/esm2022/interfaces/theme.mjs +0 -49
- package/esm2022/interfaces/viewport.mjs +0 -7
- package/esm2022/plait-core.mjs +0 -5
- package/esm2022/plugins/create-board.mjs +0 -122
- package/esm2022/plugins/index.mjs +0 -11
- package/esm2022/plugins/with-board.mjs +0 -20
- package/esm2022/plugins/with-hand.mjs +0 -113
- package/esm2022/plugins/with-history.mjs +0 -91
- package/esm2022/plugins/with-hotkey.mjs +0 -96
- package/esm2022/plugins/with-i18n.mjs +0 -13
- package/esm2022/plugins/with-moving.mjs +0 -282
- package/esm2022/plugins/with-options.mjs +0 -13
- package/esm2022/plugins/with-related-fragment.mjs +0 -23
- package/esm2022/plugins/with-selection.mjs +0 -230
- package/esm2022/public-api.mjs +0 -16
- package/esm2022/testing/core/create-board.mjs +0 -15
- package/esm2022/testing/core/fake-weak-map.mjs +0 -18
- package/esm2022/testing/core/index.mjs +0 -3
- package/esm2022/testing/fake-events/event-objects.mjs +0 -131
- package/esm2022/testing/fake-events/index.mjs +0 -2
- package/esm2022/testing/index.mjs +0 -3
- package/esm2022/testing/test-element.mjs +0 -9
- package/esm2022/transforms/board.mjs +0 -137
- package/esm2022/transforms/element.mjs +0 -22
- package/esm2022/transforms/general.mjs +0 -146
- package/esm2022/transforms/group.mjs +0 -64
- package/esm2022/transforms/index.mjs +0 -17
- package/esm2022/transforms/node.mjs +0 -37
- package/esm2022/transforms/selection.mjs +0 -26
- package/esm2022/transforms/theme.mjs +0 -8
- package/esm2022/transforms/viewport.mjs +0 -8
- package/esm2022/transforms/z-index.mjs +0 -20
- package/esm2022/utils/angle.mjs +0 -164
- package/esm2022/utils/board.mjs +0 -18
- package/esm2022/utils/clipboard/clipboard.mjs +0 -40
- package/esm2022/utils/clipboard/common.mjs +0 -82
- package/esm2022/utils/clipboard/data-transfer.mjs +0 -33
- package/esm2022/utils/clipboard/index.mjs +0 -3
- package/esm2022/utils/clipboard/navigator-clipboard.mjs +0 -71
- package/esm2022/utils/clipboard/types.mjs +0 -13
- package/esm2022/utils/common.mjs +0 -79
- package/esm2022/utils/debug.mjs +0 -91
- package/esm2022/utils/dnd.mjs +0 -8
- package/esm2022/utils/dom/common.mjs +0 -75
- package/esm2022/utils/dom/environment.mjs +0 -2
- package/esm2022/utils/dom/foreign.mjs +0 -26
- package/esm2022/utils/dom/index.mjs +0 -4
- package/esm2022/utils/drawing/arrow.mjs +0 -23
- package/esm2022/utils/drawing/circle.mjs +0 -4
- package/esm2022/utils/drawing/line.mjs +0 -47
- package/esm2022/utils/drawing/rectangle.mjs +0 -36
- package/esm2022/utils/element.mjs +0 -90
- package/esm2022/utils/environment.mjs +0 -14
- package/esm2022/utils/fragment.mjs +0 -27
- package/esm2022/utils/group.mjs +0 -239
- package/esm2022/utils/helper.mjs +0 -68
- package/esm2022/utils/history.mjs +0 -96
- package/esm2022/utils/hotkeys.mjs +0 -109
- package/esm2022/utils/id-creator.mjs +0 -11
- package/esm2022/utils/index.mjs +0 -35
- package/esm2022/utils/iterable.mjs +0 -32
- package/esm2022/utils/math.mjs +0 -480
- package/esm2022/utils/mobile.mjs +0 -6
- package/esm2022/utils/moving-element.mjs +0 -17
- package/esm2022/utils/pointer.mjs +0 -13
- package/esm2022/utils/position.mjs +0 -9
- package/esm2022/utils/selected-element.mjs +0 -145
- package/esm2022/utils/selection.mjs +0 -151
- package/esm2022/utils/snap/snap-moving.mjs +0 -199
- package/esm2022/utils/snap/snap.mjs +0 -211
- package/esm2022/utils/to-image.mjs +0 -204
- package/esm2022/utils/to-point.mjs +0 -74
- package/esm2022/utils/tree.mjs +0 -22
- package/esm2022/utils/viewport.mjs +0 -227
- package/esm2022/utils/weak-maps.mjs +0 -27
- package/esm2022/utils/z-index.mjs +0 -166
|
@@ -1,230 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard } from '../interfaces/board';
|
|
2
|
-
import { Transforms } from '../transforms';
|
|
3
|
-
import { isMainPointer } from '../utils/dom/common';
|
|
4
|
-
import { RectangleClient } from '../interfaces/rectangle-client';
|
|
5
|
-
import { cacheSelectedElements, clearSelectedElement, getHitElementsBySelection, getSelectedElements, isHitElement, removeSelectedElement } from '../utils/selected-element';
|
|
6
|
-
import { PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';
|
|
7
|
-
import { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';
|
|
8
|
-
import { clearSelectionMoving, deleteTemporaryElements, drawRectangle, getTemporaryElements, isDragging, isHandleSelection, isSelectionMoving, setSelectionMoving, throttleRAF, toHostPoint, toViewBoxPoint, setSelectedElementsWithGroup, hasSetSelectionOperation, getSelectionOptions, setSelectionOptions, distanceBetweenPointAndPoint, isMobileDeviceEvent, toActivePoint } from '../utils';
|
|
9
|
-
import { Selection } from '../interfaces/selection';
|
|
10
|
-
import { DRAG_SELECTION_PRESS_AND_MOVE_BUFFER } from '../constants';
|
|
11
|
-
export function withSelection(board) {
|
|
12
|
-
const { pointerDown, pointerUp, pointerMove, globalPointerUp, onChange, afterChange, drawSelectionRectangle } = board;
|
|
13
|
-
let screenStart = null;
|
|
14
|
-
let screenEnd = null;
|
|
15
|
-
let selectionMovingG;
|
|
16
|
-
let selectionRectangleG;
|
|
17
|
-
let isShift = false;
|
|
18
|
-
let timerId = null;
|
|
19
|
-
let pointerDownEvent = null;
|
|
20
|
-
board.pointerDown = (event) => {
|
|
21
|
-
if (!isShift && event.shiftKey) {
|
|
22
|
-
isShift = true;
|
|
23
|
-
}
|
|
24
|
-
if (isShift && !event.shiftKey) {
|
|
25
|
-
isShift = false;
|
|
26
|
-
}
|
|
27
|
-
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
28
|
-
const isHitTarget = isHitElement(board, point);
|
|
29
|
-
const options = getSelectionOptions(board);
|
|
30
|
-
if (PlaitBoard.isPointer(board, PlaitPointerType.selection) &&
|
|
31
|
-
isMainPointer(event) &&
|
|
32
|
-
!isHitTarget &&
|
|
33
|
-
options.isMultipleSelection &&
|
|
34
|
-
!options.isDisabledSelection) {
|
|
35
|
-
if (isMobileDeviceEvent(event)) {
|
|
36
|
-
timerId = setTimeout(() => {
|
|
37
|
-
screenStart = [event.x, event.y];
|
|
38
|
-
timerId = null;
|
|
39
|
-
}, 120);
|
|
40
|
-
}
|
|
41
|
-
else {
|
|
42
|
-
screenStart = [event.x, event.y];
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
pointerDownEvent = event;
|
|
46
|
-
pointerDown(event);
|
|
47
|
-
};
|
|
48
|
-
board.pointerMove = (event) => {
|
|
49
|
-
if (timerId &&
|
|
50
|
-
pointerDownEvent &&
|
|
51
|
-
distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > DRAG_SELECTION_PRESS_AND_MOVE_BUFFER) {
|
|
52
|
-
clearTimeout(timerId);
|
|
53
|
-
timerId = null;
|
|
54
|
-
}
|
|
55
|
-
if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && screenStart) {
|
|
56
|
-
event.preventDefault();
|
|
57
|
-
screenEnd = [event.x, event.y];
|
|
58
|
-
const rectangle = RectangleClient.getRectangleByPoints([
|
|
59
|
-
toActivePoint(board, ...screenStart),
|
|
60
|
-
toActivePoint(board, ...screenEnd)
|
|
61
|
-
]);
|
|
62
|
-
selectionMovingG?.remove();
|
|
63
|
-
throttleRAF(board, 'with-selection', () => {
|
|
64
|
-
if (screenStart && screenEnd) {
|
|
65
|
-
Transforms.setSelection(board, {
|
|
66
|
-
anchor: toViewBoxPoint(board, toHostPoint(board, screenStart[0], screenStart[1])),
|
|
67
|
-
focus: toViewBoxPoint(board, toHostPoint(board, screenEnd[0], screenEnd[1]))
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
setSelectionMoving(board);
|
|
72
|
-
selectionMovingG = drawRectangle(board, rectangle, {
|
|
73
|
-
stroke: SELECTION_BORDER_COLOR,
|
|
74
|
-
strokeWidth: 1,
|
|
75
|
-
fill: SELECTION_FILL_COLOR,
|
|
76
|
-
fillStyle: 'solid'
|
|
77
|
-
});
|
|
78
|
-
PlaitBoard.getActiveHost(board).append(selectionMovingG);
|
|
79
|
-
}
|
|
80
|
-
pointerMove(event);
|
|
81
|
-
};
|
|
82
|
-
// handle the end of click select
|
|
83
|
-
board.pointerUp = (event) => {
|
|
84
|
-
const isSetSelectionPointer = PlaitBoard.isPointer(board, PlaitPointerType.selection) || PlaitBoard.isPointer(board, PlaitPointerType.hand);
|
|
85
|
-
const isSkip = !isMainPointer(event) || isDragging(board) || !isSetSelectionPointer;
|
|
86
|
-
if (isSkip) {
|
|
87
|
-
pointerUp(event);
|
|
88
|
-
return;
|
|
89
|
-
}
|
|
90
|
-
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
91
|
-
const selection = { anchor: point, focus: point };
|
|
92
|
-
Transforms.setSelection(board, selection);
|
|
93
|
-
pointerUp(event);
|
|
94
|
-
};
|
|
95
|
-
board.globalPointerUp = (event) => {
|
|
96
|
-
if (screenStart && screenEnd) {
|
|
97
|
-
selectionMovingG?.remove();
|
|
98
|
-
clearSelectionMoving(board);
|
|
99
|
-
Transforms.setSelection(board, {
|
|
100
|
-
anchor: toViewBoxPoint(board, toHostPoint(board, screenStart[0], screenStart[1])),
|
|
101
|
-
focus: toViewBoxPoint(board, toHostPoint(board, screenEnd[0], screenEnd[1]))
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
const options = getSelectionOptions(board);
|
|
105
|
-
if (PlaitBoard.isFocus(board) && !options.isPreventClearSelection) {
|
|
106
|
-
const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);
|
|
107
|
-
const isInDocument = event.target instanceof Node && document.contains(event.target);
|
|
108
|
-
const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);
|
|
109
|
-
// Clear selection when mouse board outside area
|
|
110
|
-
// The framework needs to determine whether the board is focused through selection
|
|
111
|
-
if (!isInBoard && !screenStart && !isAttachedElement && isInDocument) {
|
|
112
|
-
Transforms.setSelection(board, null);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
screenStart = null;
|
|
116
|
-
screenEnd = null;
|
|
117
|
-
if (timerId) {
|
|
118
|
-
clearTimeout(timerId);
|
|
119
|
-
timerId = null;
|
|
120
|
-
}
|
|
121
|
-
pointerDownEvent = null;
|
|
122
|
-
globalPointerUp(event);
|
|
123
|
-
};
|
|
124
|
-
board.onChange = () => {
|
|
125
|
-
const options = getSelectionOptions(board);
|
|
126
|
-
if (options.isDisabledSelection) {
|
|
127
|
-
clearSelectedElement(board);
|
|
128
|
-
}
|
|
129
|
-
// remove selected element if include
|
|
130
|
-
board.operations.forEach((op) => {
|
|
131
|
-
if (op.type === 'remove_node') {
|
|
132
|
-
removeSelectedElement(board, op.node, true);
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
if (isHandleSelection(board) && hasSetSelectionOperation(board)) {
|
|
136
|
-
try {
|
|
137
|
-
if (!isShift) {
|
|
138
|
-
selectionRectangleG?.remove();
|
|
139
|
-
}
|
|
140
|
-
const temporaryElements = getTemporaryElements(board);
|
|
141
|
-
if (temporaryElements) {
|
|
142
|
-
cacheSelectedElements(board, [...temporaryElements]);
|
|
143
|
-
}
|
|
144
|
-
else {
|
|
145
|
-
let elements = getHitElementsBySelection(board);
|
|
146
|
-
if (!options.isMultipleSelection && elements.length > 1) {
|
|
147
|
-
elements = [elements[0]];
|
|
148
|
-
}
|
|
149
|
-
const isHitElementWithGroup = elements.some((item) => item.groupId);
|
|
150
|
-
const selectedElements = getSelectedElements(board);
|
|
151
|
-
if (isHitElementWithGroup) {
|
|
152
|
-
setSelectedElementsWithGroup(board, elements, isShift);
|
|
153
|
-
}
|
|
154
|
-
else {
|
|
155
|
-
if (board.selection && Selection.isCollapsed(board.selection)) {
|
|
156
|
-
const element = board.getOneHitElement(elements);
|
|
157
|
-
if (element) {
|
|
158
|
-
elements = [element];
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
if (isShift) {
|
|
162
|
-
const newElements = [...selectedElements];
|
|
163
|
-
if (board.selection && Selection.isCollapsed(board.selection)) {
|
|
164
|
-
elements.forEach((element) => {
|
|
165
|
-
if (newElements.includes(element)) {
|
|
166
|
-
newElements.splice(newElements.indexOf(element), 1);
|
|
167
|
-
}
|
|
168
|
-
else {
|
|
169
|
-
newElements.push(element);
|
|
170
|
-
}
|
|
171
|
-
});
|
|
172
|
-
cacheSelectedElements(board, newElements);
|
|
173
|
-
}
|
|
174
|
-
else {
|
|
175
|
-
elements.forEach((element) => {
|
|
176
|
-
if (!newElements.includes(element)) {
|
|
177
|
-
newElements.push(element);
|
|
178
|
-
}
|
|
179
|
-
});
|
|
180
|
-
cacheSelectedElements(board, [...newElements]);
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
else {
|
|
184
|
-
cacheSelectedElements(board, [...elements]);
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
const newElements = getSelectedElements(board);
|
|
189
|
-
deleteTemporaryElements(board);
|
|
190
|
-
if (!isSelectionMoving(board)) {
|
|
191
|
-
selectionRectangleG?.remove();
|
|
192
|
-
if (newElements.length > 1) {
|
|
193
|
-
selectionRectangleG = board.drawSelectionRectangle();
|
|
194
|
-
PlaitBoard.getActiveHost(board).append(selectionRectangleG);
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
catch (error) {
|
|
199
|
-
console.error(error);
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
onChange();
|
|
203
|
-
};
|
|
204
|
-
board.afterChange = () => {
|
|
205
|
-
if (isHandleSelection(board) && !hasSetSelectionOperation(board)) {
|
|
206
|
-
try {
|
|
207
|
-
const currentSelectedElements = getSelectedElements(board);
|
|
208
|
-
if (currentSelectedElements.length && currentSelectedElements.length > 1) {
|
|
209
|
-
selectionRectangleG?.remove();
|
|
210
|
-
selectionRectangleG = board.drawSelectionRectangle();
|
|
211
|
-
PlaitBoard.getActiveHost(board).append(selectionRectangleG);
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
selectionRectangleG?.remove();
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
catch (error) {
|
|
218
|
-
console.error(error);
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
afterChange();
|
|
222
|
-
};
|
|
223
|
-
setSelectionOptions(board, {
|
|
224
|
-
isMultipleSelection: true,
|
|
225
|
-
isDisabledSelection: false,
|
|
226
|
-
isPreventClearSelection: false
|
|
227
|
-
});
|
|
228
|
-
return board;
|
|
229
|
-
}
|
|
230
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-selection.js","sourceRoot":"","sources":["../../../../packages/core/src/plugins/with-selection.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { Transforms } from '../transforms';\nimport { isMainPointer } from '../utils/dom/common';\nimport { RectangleClient } from '../interfaces/rectangle-client';\nimport {\n    cacheSelectedElements,\n    clearSelectedElement,\n    getHitElementsBySelection,\n    getSelectedElements,\n    isHitElement,\n    removeSelectedElement\n} from '../utils/selected-element';\nimport { PlaitPointerType, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR } from '../interfaces';\nimport { ATTACHED_ELEMENT_CLASS_NAME } from '../constants/selection';\nimport {\n    clearSelectionMoving,\n    deleteTemporaryElements,\n    drawRectangle,\n    getTemporaryElements,\n    isDragging,\n    isHandleSelection,\n    isSelectionMoving,\n    setSelectionMoving,\n    throttleRAF,\n    toHostPoint,\n    toViewBoxPoint,\n    setSelectedElementsWithGroup,\n    hasSetSelectionOperation,\n    getSelectionOptions,\n    setSelectionOptions,\n    distanceBetweenPointAndPoint,\n    isMobileDeviceEvent,\n    toActivePoint\n} from '../utils';\nimport { Selection } from '../interfaces/selection';\nimport { DRAG_SELECTION_PRESS_AND_MOVE_BUFFER } from '../constants';\n\nexport function withSelection(board: PlaitBoard) {\n    const { pointerDown, pointerUp, pointerMove, globalPointerUp, onChange, afterChange, drawSelectionRectangle } = board;\n    let screenStart: Point | null = null;\n    let screenEnd: Point | null = null;\n    let selectionMovingG: SVGGElement;\n    let selectionRectangleG: SVGGElement | null;\n    let isShift = false;\n    let timerId: ReturnType<typeof setTimeout> | null = null;\n    let pointerDownEvent: PointerEvent | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (!isShift && event.shiftKey) {\n            isShift = true;\n        }\n        if (isShift && !event.shiftKey) {\n            isShift = false;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const isHitTarget = isHitElement(board, point);\n        const options = getSelectionOptions(board);\n        if (\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) &&\n            isMainPointer(event) &&\n            !isHitTarget &&\n            options.isMultipleSelection &&\n            !options.isDisabledSelection\n        ) {\n            if (isMobileDeviceEvent(event)) {\n                timerId = setTimeout(() => {\n                    screenStart = [event.x, event.y];\n                    timerId = null;\n                }, 120);\n            } else {\n                screenStart = [event.x, event.y];\n            }\n        }\n        pointerDownEvent = event;\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (\n            timerId &&\n            pointerDownEvent &&\n            distanceBetweenPointAndPoint(pointerDownEvent.x, pointerDownEvent.y, event.x, event.y) > DRAG_SELECTION_PRESS_AND_MOVE_BUFFER\n        ) {\n            clearTimeout(timerId);\n            timerId = null;\n        }\n        if (PlaitBoard.isPointer(board, PlaitPointerType.selection) && screenStart) {\n            event.preventDefault();\n            screenEnd = [event.x, event.y];\n            const rectangle = RectangleClient.getRectangleByPoints([\n                toActivePoint(board, ...screenStart),\n                toActivePoint(board, ...screenEnd)\n            ]);\n            selectionMovingG?.remove();\n            throttleRAF(board, 'with-selection', () => {\n                if (screenStart && screenEnd) {\n                    Transforms.setSelection(board, {\n                        anchor: toViewBoxPoint(board, toHostPoint(board, screenStart[0], screenStart[1])),\n                        focus: toViewBoxPoint(board, toHostPoint(board, screenEnd[0], screenEnd[1]))\n                    });\n                }\n            });\n            setSelectionMoving(board);\n            selectionMovingG = drawRectangle(board, rectangle, {\n                stroke: SELECTION_BORDER_COLOR,\n                strokeWidth: 1,\n                fill: SELECTION_FILL_COLOR,\n                fillStyle: 'solid'\n            });\n            PlaitBoard.getActiveHost(board).append(selectionMovingG);\n        }\n        pointerMove(event);\n    };\n\n    // handle the end of click select\n    board.pointerUp = (event: PointerEvent) => {\n        const isSetSelectionPointer =\n            PlaitBoard.isPointer(board, PlaitPointerType.selection) || PlaitBoard.isPointer(board, PlaitPointerType.hand);\n        const isSkip = !isMainPointer(event) || isDragging(board) || !isSetSelectionPointer;\n        if (isSkip) {\n            pointerUp(event);\n            return;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const selection = { anchor: point, focus: point };\n        Transforms.setSelection(board, selection);\n        pointerUp(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (screenStart && screenEnd) {\n            selectionMovingG?.remove();\n            clearSelectionMoving(board);\n            Transforms.setSelection(board, {\n                anchor: toViewBoxPoint(board, toHostPoint(board, screenStart[0], screenStart[1])),\n                focus: toViewBoxPoint(board, toHostPoint(board, screenEnd[0], screenEnd[1]))\n            });\n        }\n        const options = getSelectionOptions(board);\n        if (PlaitBoard.isFocus(board) && !options.isPreventClearSelection) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);\n            const isInDocument = event.target instanceof Node && document.contains(event.target);\n            const isAttachedElement = event.target instanceof Element && event.target.closest(`.${ATTACHED_ELEMENT_CLASS_NAME}`);\n            // Clear selection when mouse board outside area\n            // The framework needs to determine whether the board is focused through selection\n            if (!isInBoard && !screenStart && !isAttachedElement && isInDocument) {\n                Transforms.setSelection(board, null);\n            }\n        }\n        screenStart = null;\n        screenEnd = null;\n        if (timerId) {\n            clearTimeout(timerId);\n            timerId = null;\n        }\n        pointerDownEvent = null;\n        globalPointerUp(event);\n    };\n\n    board.onChange = () => {\n        const options = getSelectionOptions(board);\n        if (options.isDisabledSelection) {\n            clearSelectedElement(board);\n        }\n        // remove selected element if include\n        board.operations.forEach((op) => {\n            if (op.type === 'remove_node') {\n                removeSelectedElement(board, op.node, true);\n            }\n        });\n        if (isHandleSelection(board) && hasSetSelectionOperation(board)) {\n            try {\n                if (!isShift) {\n                    selectionRectangleG?.remove();\n                }\n                const temporaryElements = getTemporaryElements(board);\n                if (temporaryElements) {\n                    cacheSelectedElements(board, [...temporaryElements]);\n                } else {\n                    let elements = getHitElementsBySelection(board);\n                    if (!options.isMultipleSelection && elements.length > 1) {\n                        elements = [elements[0]];\n                    }\n                    const isHitElementWithGroup = elements.some((item) => item.groupId);\n                    const selectedElements = getSelectedElements(board);\n                    if (isHitElementWithGroup) {\n                        setSelectedElementsWithGroup(board, elements, isShift);\n                    } else {\n                        if (board.selection && Selection.isCollapsed(board.selection)) {\n                            const element = board.getOneHitElement(elements);\n                            if (element) {\n                                elements = [element];\n                            }\n                        }\n                        if (isShift) {\n                            const newElements = [...selectedElements];\n                            if (board.selection && Selection.isCollapsed(board.selection)) {\n                                elements.forEach((element) => {\n                                    if (newElements.includes(element)) {\n                                        newElements.splice(newElements.indexOf(element), 1);\n                                    } else {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, newElements);\n                            } else {\n                                elements.forEach((element) => {\n                                    if (!newElements.includes(element)) {\n                                        newElements.push(element);\n                                    }\n                                });\n                                cacheSelectedElements(board, [...newElements]);\n                            }\n                        } else {\n                            cacheSelectedElements(board, [...elements]);\n                        }\n                    }\n                }\n                const newElements = getSelectedElements(board);\n                deleteTemporaryElements(board);\n                if (!isSelectionMoving(board)) {\n                    selectionRectangleG?.remove();\n                    if (newElements.length > 1) {\n                        selectionRectangleG = board.drawSelectionRectangle();\n                        PlaitBoard.getActiveHost(board).append(selectionRectangleG!);\n                    }\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        onChange();\n    };\n\n    board.afterChange = () => {\n        if (isHandleSelection(board) && !hasSetSelectionOperation(board)) {\n            try {\n                const currentSelectedElements = getSelectedElements(board);\n                if (currentSelectedElements.length && currentSelectedElements.length > 1) {\n                    selectionRectangleG?.remove();\n                    selectionRectangleG = board.drawSelectionRectangle();\n                    PlaitBoard.getActiveHost(board).append(selectionRectangleG!);\n                } else {\n                    selectionRectangleG?.remove();\n                }\n            } catch (error) {\n                console.error(error);\n            }\n        }\n        afterChange();\n    };\n\n    setSelectionOptions(board, {\n        isMultipleSelection: true,\n        isDisabledSelection: false,\n        isPreventClearSelection: false\n    });\n\n    return board;\n}\n"]}
|
package/esm2022/public-api.mjs
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Public API Surface of plait
|
|
3
|
-
*/
|
|
4
|
-
export * from './constants';
|
|
5
|
-
export * from './core/element/context-change';
|
|
6
|
-
export * from './core/element/element-flavour';
|
|
7
|
-
export * from './core/element/element-ref';
|
|
8
|
-
export * from './core/list-render';
|
|
9
|
-
export * from './interfaces';
|
|
10
|
-
export * from './transforms';
|
|
11
|
-
export * from './utils';
|
|
12
|
-
export * from './context';
|
|
13
|
-
export * from './plugins';
|
|
14
|
-
export * from './testing';
|
|
15
|
-
export * from './utils/debug';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBwbGFpdFxuICovXG5leHBvcnQgKiBmcm9tICcuL2NvbnN0YW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2NvcmUvZWxlbWVudC9jb250ZXh0LWNoYW5nZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvcmUvZWxlbWVudC9lbGVtZW50LWZsYXZvdXInO1xuZXhwb3J0ICogZnJvbSAnLi9jb3JlL2VsZW1lbnQvZWxlbWVudC1yZWYnO1xuZXhwb3J0ICogZnJvbSAnLi9jb3JlL2xpc3QtcmVuZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zZm9ybXMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnRleHQnO1xuZXhwb3J0ICogZnJvbSAnLi9wbHVnaW5zJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdGluZyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL2RlYnVnJztcbiJdfQ==
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { createBoard } from '../../plugins/create-board';
|
|
2
|
-
import { KEY_TO_ELEMENT_MAP } from '../../utils';
|
|
3
|
-
/**
|
|
4
|
-
* 1.create board instance
|
|
5
|
-
* 2.build fake node weak map
|
|
6
|
-
*/
|
|
7
|
-
export const createTestingBoard = (plugins, children, options = { readonly: false, hideScrollbar: true, disabledScrollOnNonFocus: false }) => {
|
|
8
|
-
let board = createBoard(children, options);
|
|
9
|
-
plugins.forEach(plugin => {
|
|
10
|
-
board = plugin(board);
|
|
11
|
-
});
|
|
12
|
-
KEY_TO_ELEMENT_MAP.set(board, new Map());
|
|
13
|
-
return board;
|
|
14
|
-
};
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdGVzdGluZy9jb3JlL2NyZWF0ZS1ib2FyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRWpEOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQzlCLE9BQXNCLEVBQ3RCLFFBQXdCLEVBQ3hCLFVBQTZCLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLHdCQUF3QixFQUFFLEtBQUssRUFBRSxFQUN4RyxFQUFFO0lBQ0EsSUFBSSxLQUFLLEdBQUcsV0FBVyxDQUFDLFFBQVEsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMzQyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1FBQ3JCLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDMUIsQ0FBQyxDQUFDLENBQUM7SUFDSCxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksR0FBRyxFQUFFLENBQUMsQ0FBQztJQUN6QyxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkT3B0aW9ucywgUGxhaXRFbGVtZW50LCBQbGFpdFBsdWdpbiB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgY3JlYXRlQm9hcmQgfSBmcm9tICcuLi8uLi9wbHVnaW5zL2NyZWF0ZS1ib2FyZCc7XG5pbXBvcnQgeyBLRVlfVE9fRUxFTUVOVF9NQVAgfSBmcm9tICcuLi8uLi91dGlscyc7XG5cbi8qKlxuICogMS5jcmVhdGUgYm9hcmQgaW5zdGFuY2VcbiAqIDIuYnVpbGQgZmFrZSBub2RlIHdlYWsgbWFwXG4gKi9cbmV4cG9ydCBjb25zdCBjcmVhdGVUZXN0aW5nQm9hcmQgPSAoXG4gICAgcGx1Z2luczogUGxhaXRQbHVnaW5bXSxcbiAgICBjaGlsZHJlbjogUGxhaXRFbGVtZW50W10sXG4gICAgb3B0aW9uczogUGxhaXRCb2FyZE9wdGlvbnMgPSB7IHJlYWRvbmx5OiBmYWxzZSwgaGlkZVNjcm9sbGJhcjogdHJ1ZSwgZGlzYWJsZWRTY3JvbGxPbk5vbkZvY3VzOiBmYWxzZSB9XG4pID0+IHtcbiAgICBsZXQgYm9hcmQgPSBjcmVhdGVCb2FyZChjaGlsZHJlbiwgb3B0aW9ucyk7XG4gICAgcGx1Z2lucy5mb3JFYWNoKHBsdWdpbiA9PiB7XG4gICAgICAgIGJvYXJkID0gcGx1Z2luKGJvYXJkKTtcbiAgICB9KTtcbiAgICBLRVlfVE9fRUxFTUVOVF9NQVAuc2V0KGJvYXJkLCBuZXcgTWFwKCkpO1xuICAgIHJldHVybiBib2FyZDtcbn07XG4iXX0=
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { NODE_TO_INDEX, NODE_TO_PARENT } from '../../utils/weak-maps';
|
|
2
|
-
export const fakeNodeWeakMap = (object) => {
|
|
3
|
-
const children = object.children || [];
|
|
4
|
-
children.forEach((value, index) => {
|
|
5
|
-
NODE_TO_PARENT.set(value, object);
|
|
6
|
-
NODE_TO_INDEX.set(value, index);
|
|
7
|
-
fakeNodeWeakMap(value);
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
|
-
export const clearNodeWeakMap = (object) => {
|
|
11
|
-
const children = object.children || [];
|
|
12
|
-
children.forEach(value => {
|
|
13
|
-
NODE_TO_PARENT.delete(value);
|
|
14
|
-
NODE_TO_INDEX.delete(value);
|
|
15
|
-
clearNodeWeakMap(value);
|
|
16
|
-
});
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFrZS13ZWFrLW1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3Rlc3RpbmcvY29yZS9mYWtlLXdlYWstbWFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxhQUFhLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFdEUsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLENBQUMsTUFBOEIsRUFBRSxFQUFFO0lBQzlELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLElBQUksRUFBRSxDQUFDO0lBQ3ZDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLEVBQUUsS0FBYSxFQUFFLEVBQUU7UUFDdEMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDbEMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDaEMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxNQUE4QixFQUFFLEVBQUU7SUFDL0QsTUFBTSxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsSUFBSSxFQUFFLENBQUM7SUFDdkMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUNyQixjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzdCLGFBQWEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDNUIsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUIsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBQbGFpdE5vZGUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL25vZGUnO1xuaW1wb3J0IHsgTk9ERV9UT19JTkRFWCwgTk9ERV9UT19QQVJFTlQgfSBmcm9tICcuLi8uLi91dGlscy93ZWFrLW1hcHMnO1xuXG5leHBvcnQgY29uc3QgZmFrZU5vZGVXZWFrTWFwID0gKG9iamVjdDogUGxhaXROb2RlIHwgUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IGNoaWxkcmVuID0gb2JqZWN0LmNoaWxkcmVuIHx8IFtdO1xuICAgIGNoaWxkcmVuLmZvckVhY2goKHZhbHVlLCBpbmRleDogbnVtYmVyKSA9PiB7XG4gICAgICAgIE5PREVfVE9fUEFSRU5ULnNldCh2YWx1ZSwgb2JqZWN0KTtcbiAgICAgICAgTk9ERV9UT19JTkRFWC5zZXQodmFsdWUsIGluZGV4KTtcbiAgICAgICAgZmFrZU5vZGVXZWFrTWFwKHZhbHVlKTtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBjbGVhck5vZGVXZWFrTWFwID0gKG9iamVjdDogUGxhaXROb2RlIHwgUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IGNoaWxkcmVuID0gb2JqZWN0LmNoaWxkcmVuIHx8IFtdO1xuICAgIGNoaWxkcmVuLmZvckVhY2godmFsdWUgPT4ge1xuICAgICAgICBOT0RFX1RPX1BBUkVOVC5kZWxldGUodmFsdWUpO1xuICAgICAgICBOT0RFX1RPX0lOREVYLmRlbGV0ZSh2YWx1ZSk7XG4gICAgICAgIGNsZWFyTm9kZVdlYWtNYXAodmFsdWUpO1xuICAgIH0pO1xufTtcbiJdfQ==
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export * from './create-board';
|
|
2
|
-
export * from './fake-weak-map';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy90ZXN0aW5nL2NvcmUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jcmVhdGUtYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9mYWtlLXdlYWstbWFwJztcbiJdfQ==
|
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { IS_MAC } from '../../utils/dom/environment';
|
|
9
|
-
/** Used to generate unique IDs for events. */
|
|
10
|
-
let uniqueIds = 0;
|
|
11
|
-
/**
|
|
12
|
-
* Creates a browser MouseEvent with the specified options.
|
|
13
|
-
* @docs-private
|
|
14
|
-
*/
|
|
15
|
-
export function createMouseEvent(type, clientX = 0, clientY = 0, offsetX = 1, offsetY = 1, button = 0, modifiers = {}) {
|
|
16
|
-
// Note: We cannot determine the position of the mouse event based on the screen
|
|
17
|
-
// because the dimensions and position of the browser window are not available
|
|
18
|
-
// To provide reasonable `screenX` and `screenY` coordinates, we simply use the
|
|
19
|
-
// client coordinates as if the browser is opened in fullscreen.
|
|
20
|
-
const screenX = clientX;
|
|
21
|
-
const screenY = clientY;
|
|
22
|
-
const event = new MouseEvent(type, {
|
|
23
|
-
bubbles: true,
|
|
24
|
-
cancelable: true,
|
|
25
|
-
composed: true, // Required for shadow DOM events.
|
|
26
|
-
view: window,
|
|
27
|
-
detail: 0,
|
|
28
|
-
relatedTarget: null,
|
|
29
|
-
screenX,
|
|
30
|
-
screenY,
|
|
31
|
-
clientX,
|
|
32
|
-
clientY,
|
|
33
|
-
ctrlKey: modifiers.control,
|
|
34
|
-
altKey: modifiers.alt,
|
|
35
|
-
shiftKey: modifiers.shift,
|
|
36
|
-
metaKey: modifiers.meta,
|
|
37
|
-
button: button,
|
|
38
|
-
buttons: 1
|
|
39
|
-
});
|
|
40
|
-
// The `MouseEvent` constructor doesn't allow us to pass these properties into the constructor.
|
|
41
|
-
// Override them to `1`, because they're used for fake screen reader event detection.
|
|
42
|
-
if (offsetX != null) {
|
|
43
|
-
defineReadonlyEventProperty(event, 'offsetX', offsetX);
|
|
44
|
-
}
|
|
45
|
-
if (offsetY != null) {
|
|
46
|
-
defineReadonlyEventProperty(event, 'offsetY', offsetY);
|
|
47
|
-
}
|
|
48
|
-
return event;
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Creates a browser `PointerEvent` with the specified options. Pointer events
|
|
52
|
-
* by default will appear as if they are the primary pointer of their type.
|
|
53
|
-
* https://www.w3.org/TR/pointerevents2/#dom-pointerevent-isprimary.
|
|
54
|
-
*
|
|
55
|
-
* For example, if pointer events for a multi-touch interaction are created, the non-primary
|
|
56
|
-
* pointer touches would need to be represented by non-primary pointer events.
|
|
57
|
-
*
|
|
58
|
-
* @docs-private
|
|
59
|
-
*/
|
|
60
|
-
export function createPointerEvent(type, clientX = 0, clientY = 0, offsetX, offsetY, options = { isPrimary: true }) {
|
|
61
|
-
const event = new PointerEvent(type, {
|
|
62
|
-
bubbles: true,
|
|
63
|
-
cancelable: true,
|
|
64
|
-
composed: true, // Required for shadow DOM events.
|
|
65
|
-
view: window,
|
|
66
|
-
clientX,
|
|
67
|
-
clientY,
|
|
68
|
-
...options
|
|
69
|
-
});
|
|
70
|
-
if (offsetX != null) {
|
|
71
|
-
defineReadonlyEventProperty(event, 'offsetX', offsetX);
|
|
72
|
-
}
|
|
73
|
-
if (offsetY != null) {
|
|
74
|
-
defineReadonlyEventProperty(event, 'offsetY', offsetY);
|
|
75
|
-
}
|
|
76
|
-
return event;
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* Creates a browser TouchEvent with the specified pointer coordinates.
|
|
80
|
-
* @docs-private
|
|
81
|
-
*/
|
|
82
|
-
export function createTouchEvent(type, pageX = 0, pageY = 0, clientX = 0, clientY = 0) {
|
|
83
|
-
// We cannot use the `TouchEvent` or `Touch` because Firefox and Safari lack support.
|
|
84
|
-
const event = document.createEvent('UIEvent');
|
|
85
|
-
const touchDetails = { pageX, pageY, clientX, clientY, identifier: uniqueIds++ };
|
|
86
|
-
// TS3.6 removes the initUIEvent method and suggests porting to "new UIEvent()".
|
|
87
|
-
event.initUIEvent(type, true, true, window, 0);
|
|
88
|
-
// Most of the browsers don't have a "initTouchEvent" method that can be used to define
|
|
89
|
-
// the touch details.
|
|
90
|
-
defineReadonlyEventProperty(event, 'touches', [touchDetails]);
|
|
91
|
-
defineReadonlyEventProperty(event, 'targetTouches', [touchDetails]);
|
|
92
|
-
defineReadonlyEventProperty(event, 'changedTouches', [touchDetails]);
|
|
93
|
-
return event;
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Creates a keyboard event with the specified key and modifiers.
|
|
97
|
-
* @docs-private
|
|
98
|
-
*/
|
|
99
|
-
export function createKeyboardEvent(type, keyCode = 0, key = '', modifiers = {}) {
|
|
100
|
-
return new KeyboardEvent(type, {
|
|
101
|
-
bubbles: true,
|
|
102
|
-
cancelable: true,
|
|
103
|
-
composed: true, // Required for shadow DOM events.
|
|
104
|
-
view: window,
|
|
105
|
-
keyCode: keyCode,
|
|
106
|
-
key: key,
|
|
107
|
-
shiftKey: modifiers.shift,
|
|
108
|
-
metaKey: modifiers.meta,
|
|
109
|
-
altKey: modifiers.alt,
|
|
110
|
-
ctrlKey: modifiers.control
|
|
111
|
-
});
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* Creates a fake event object with any desired event type.
|
|
115
|
-
* @docs-private
|
|
116
|
-
*/
|
|
117
|
-
export function createFakeEvent(type, bubbles = false, cancelable = true, composed = true) {
|
|
118
|
-
return new Event(type, { bubbles, cancelable, composed });
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* Defines a readonly property on the given event object. Readonly properties on an event object
|
|
122
|
-
* are always set as configurable as that matches default readonly properties for DOM event objects.
|
|
123
|
-
*/
|
|
124
|
-
function defineReadonlyEventProperty(event, propertyName, value) {
|
|
125
|
-
Object.defineProperty(event, propertyName, { get: () => value, configurable: true });
|
|
126
|
-
}
|
|
127
|
-
export function createModModifierKeys() {
|
|
128
|
-
const modifiers = IS_MAC ? { meta: true } : { control: true };
|
|
129
|
-
return modifiers;
|
|
130
|
-
}
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-objects.js","sourceRoot":"","sources":["../../../../../packages/core/src/testing/fake-events/event-objects.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAGrD,8CAA8C;AAC9C,IAAI,SAAS,GAAG,CAAC,CAAC;AAElB;;;GAGG;AACH,MAAM,UAAU,gBAAgB,CAC5B,IAAY,EACZ,OAAO,GAAG,CAAC,EACX,OAAO,GAAG,CAAC,EACX,OAAO,GAAG,CAAC,EACX,OAAO,GAAG,CAAC,EACX,MAAM,GAAG,CAAC,EACV,YAA0B,EAAE;IAE5B,gFAAgF;IAChF,8EAA8E;IAC9E,+EAA+E;IAC/E,gEAAgE;IAChE,MAAM,OAAO,GAAG,OAAO,CAAC;IACxB,MAAM,OAAO,GAAG,OAAO,CAAC;IAExB,MAAM,KAAK,GAAG,IAAI,UAAU,CAAC,IAAI,EAAE;QAC/B,OAAO,EAAE,IAAI;QACb,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,IAAI,EAAE,kCAAkC;QAClD,IAAI,EAAE,MAAM;QACZ,MAAM,EAAE,CAAC;QACT,aAAa,EAAE,IAAI;QACnB,OAAO;QACP,OAAO;QACP,OAAO;QACP,OAAO;QACP,OAAO,EAAE,SAAS,CAAC,OAAO;QAC1B,MAAM,EAAE,SAAS,CAAC,GAAG;QACrB,QAAQ,EAAE,SAAS,CAAC,KAAK;QACzB,OAAO,EAAE,SAAS,CAAC,IAAI;QACvB,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,CAAC;KACb,CAAC,CAAC;IAEH,+FAA+F;IAC/F,qFAAqF;IACrF,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;QAClB,2BAA2B,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAED,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;QAClB,2BAA2B,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAED,OAAO,KAAK,CAAC;AACjB,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,kBAAkB,CAC9B,IAAY,EACZ,OAAO,GAAG,CAAC,EACX,OAAO,GAAG,CAAC,EACX,OAAgB,EAChB,OAAgB,EAChB,UAA4B,EAAE,SAAS,EAAE,IAAI,EAAE;IAE/C,MAAM,KAAK,GAAG,IAAI,YAAY,CAAC,IAAI,EAAE;QACjC,OAAO,EAAE,IAAI;QACb,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,IAAI,EAAE,kCAAkC;QAClD,IAAI,EAAE,MAAM;QACZ,OAAO;QACP,OAAO;QACP,GAAG,OAAO;KACb,CAAC,CAAC;IAEH,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;QAClB,2BAA2B,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAED,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;QAClB,2BAA2B,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAED,OAAO,KAAK,CAAC;AACjB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,gBAAgB,CAAC,IAAY,EAAE,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,OAAO,GAAG,CAAC,EAAE,OAAO,GAAG,CAAC;IACzF,qFAAqF;IACrF,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IAC9C,MAAM,YAAY,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,EAAE,CAAC;IAEjF,gFAAgF;IAC/E,KAAa,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;IAExD,uFAAuF;IACvF,qBAAqB;IACrB,2BAA2B,CAAC,KAAK,EAAE,SAAS,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAC9D,2BAA2B,CAAC,KAAK,EAAE,eAAe,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IACpE,2BAA2B,CAAC,KAAK,EAAE,gBAAgB,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAErE,OAAO,KAAK,CAAC;AACjB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,IAAY,EAAE,UAAkB,CAAC,EAAE,MAAc,EAAE,EAAE,YAA0B,EAAE;IACjH,OAAO,IAAI,aAAa,CAAC,IAAI,EAAE;QAC3B,OAAO,EAAE,IAAI;QACb,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,IAAI,EAAE,kCAAkC;QAClD,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,OAAO;QAChB,GAAG,EAAE,GAAG;QACR,QAAQ,EAAE,SAAS,CAAC,KAAK;QACzB,OAAO,EAAE,SAAS,CAAC,IAAI;QACvB,MAAM,EAAE,SAAS,CAAC,GAAG;QACrB,OAAO,EAAE,SAAS,CAAC,OAAO;KAC7B,CAAC,CAAC;AACP,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,IAAY,EAAE,OAAO,GAAG,KAAK,EAAE,UAAU,GAAG,IAAI,EAAE,QAAQ,GAAG,IAAI;IAC7F,OAAO,IAAI,KAAK,CAAC,IAAI,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC9D,CAAC;AAED;;;GAGG;AACH,SAAS,2BAA2B,CAAC,KAAY,EAAE,YAAoB,EAAE,KAAU;IAC/E,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,YAAY,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC;AACzF,CAAC;AAED,MAAM,UAAU,qBAAqB;IACjC,MAAM,SAAS,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC9D,OAAO,SAAS,CAAC;AACrB,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { IS_MAC } from '../../utils/dom/environment';\nimport { ModifierKeys } from '../test-element';\n\n/** Used to generate unique IDs for events. */\nlet uniqueIds = 0;\n\n/**\n * Creates a browser MouseEvent with the specified options.\n * @docs-private\n */\nexport function createMouseEvent(\n    type: string,\n    clientX = 0,\n    clientY = 0,\n    offsetX = 1,\n    offsetY = 1,\n    button = 0,\n    modifiers: ModifierKeys = {}\n) {\n    // Note: We cannot determine the position of the mouse event based on the screen\n    // because the dimensions and position of the browser window are not available\n    // To provide reasonable `screenX` and `screenY` coordinates, we simply use the\n    // client coordinates as if the browser is opened in fullscreen.\n    const screenX = clientX;\n    const screenY = clientY;\n\n    const event = new MouseEvent(type, {\n        bubbles: true,\n        cancelable: true,\n        composed: true, // Required for shadow DOM events.\n        view: window,\n        detail: 0,\n        relatedTarget: null,\n        screenX,\n        screenY,\n        clientX,\n        clientY,\n        ctrlKey: modifiers.control,\n        altKey: modifiers.alt,\n        shiftKey: modifiers.shift,\n        metaKey: modifiers.meta,\n        button: button,\n        buttons: 1\n    });\n\n    // The `MouseEvent` constructor doesn't allow us to pass these properties into the constructor.\n    // Override them to `1`, because they're used for fake screen reader event detection.\n    if (offsetX != null) {\n        defineReadonlyEventProperty(event, 'offsetX', offsetX);\n    }\n\n    if (offsetY != null) {\n        defineReadonlyEventProperty(event, 'offsetY', offsetY);\n    }\n\n    return event;\n}\n\n/**\n * Creates a browser `PointerEvent` with the specified options. Pointer events\n * by default will appear as if they are the primary pointer of their type.\n * https://www.w3.org/TR/pointerevents2/#dom-pointerevent-isprimary.\n *\n * For example, if pointer events for a multi-touch interaction are created, the non-primary\n * pointer touches would need to be represented by non-primary pointer events.\n *\n * @docs-private\n */\nexport function createPointerEvent(\n    type: string,\n    clientX = 0,\n    clientY = 0,\n    offsetX?: number,\n    offsetY?: number,\n    options: PointerEventInit = { isPrimary: true }\n) {\n    const event = new PointerEvent(type, {\n        bubbles: true,\n        cancelable: true,\n        composed: true, // Required for shadow DOM events.\n        view: window,\n        clientX,\n        clientY,\n        ...options\n    });\n\n    if (offsetX != null) {\n        defineReadonlyEventProperty(event, 'offsetX', offsetX);\n    }\n\n    if (offsetY != null) {\n        defineReadonlyEventProperty(event, 'offsetY', offsetY);\n    }\n\n    return event;\n}\n\n/**\n * Creates a browser TouchEvent with the specified pointer coordinates.\n * @docs-private\n */\nexport function createTouchEvent(type: string, pageX = 0, pageY = 0, clientX = 0, clientY = 0) {\n    // We cannot use the `TouchEvent` or `Touch` because Firefox and Safari lack support.\n    const event = document.createEvent('UIEvent');\n    const touchDetails = { pageX, pageY, clientX, clientY, identifier: uniqueIds++ };\n\n    // TS3.6 removes the initUIEvent method and suggests porting to \"new UIEvent()\".\n    (event as any).initUIEvent(type, true, true, window, 0);\n\n    // Most of the browsers don't have a \"initTouchEvent\" method that can be used to define\n    // the touch details.\n    defineReadonlyEventProperty(event, 'touches', [touchDetails]);\n    defineReadonlyEventProperty(event, 'targetTouches', [touchDetails]);\n    defineReadonlyEventProperty(event, 'changedTouches', [touchDetails]);\n\n    return event;\n}\n\n/**\n * Creates a keyboard event with the specified key and modifiers.\n * @docs-private\n */\nexport function createKeyboardEvent(type: string, keyCode: number = 0, key: string = '', modifiers: ModifierKeys = {}) {\n    return new KeyboardEvent(type, {\n        bubbles: true,\n        cancelable: true,\n        composed: true, // Required for shadow DOM events.\n        view: window,\n        keyCode: keyCode,\n        key: key,\n        shiftKey: modifiers.shift,\n        metaKey: modifiers.meta,\n        altKey: modifiers.alt,\n        ctrlKey: modifiers.control\n    });\n}\n\n/**\n * Creates a fake event object with any desired event type.\n * @docs-private\n */\nexport function createFakeEvent(type: string, bubbles = false, cancelable = true, composed = true) {\n    return new Event(type, { bubbles, cancelable, composed });\n}\n\n/**\n * Defines a readonly property on the given event object. Readonly properties on an event object\n * are always set as configurable as that matches default readonly properties for DOM event objects.\n */\nfunction defineReadonlyEventProperty(event: Event, propertyName: string, value: any) {\n    Object.defineProperty(event, propertyName, { get: () => value, configurable: true });\n}\n\nexport function createModModifierKeys() {\n    const modifiers = IS_MAC ? { meta: true } : { control: true };\n    return modifiers;\n}\n"]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export * from './event-objects';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy90ZXN0aW5nL2Zha2UtZXZlbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2V2ZW50LW9iamVjdHMnO1xuIl19
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export * from './core';
|
|
2
|
-
export * from './fake-events';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy90ZXN0aW5nL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb3JlJztcbmV4cG9ydCAqIGZyb20gJy4vZmFrZS1ldmVudHMnO1xuIl19
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC1lbGVtZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdGVzdGluZy90ZXN0LWVsZW1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKiBNb2RpZmllciBrZXlzIHRoYXQgbWF5IGJlIGhlbGQgd2hpbGUgdHlwaW5nLiAqL1xuZXhwb3J0IGludGVyZmFjZSBNb2RpZmllcktleXMge1xuICAgIGNvbnRyb2w/OiBib29sZWFuO1xuICAgIGFsdD86IGJvb2xlYW47XG4gICAgc2hpZnQ/OiBib29sZWFuO1xuICAgIG1ldGE/OiBib29sZWFuO1xufVxuIl19
|