|
|
|
@ -1315,11 +1315,14 @@ class App extends React.Component<AppProps, AppState> {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
private onTapEnd = (event: TouchEvent) => {
|
|
|
|
|
this.resetContextMenuTimer();
|
|
|
|
|
if (event.touches.length > 0) {
|
|
|
|
|
this.setState({
|
|
|
|
|
previousSelectedElementIds: {},
|
|
|
|
|
selectedElementIds: this.state.previousSelectedElementIds,
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
gesture.pointers.clear();
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
@ -1532,11 +1535,8 @@ class App extends React.Component<AppProps, AppState> {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
removePointer = (event: React.PointerEvent<HTMLElement> | PointerEvent) => {
|
|
|
|
|
// remove touch handler for context menu on touch devices
|
|
|
|
|
if (event.pointerType === "touch" && touchTimeout) {
|
|
|
|
|
clearTimeout(touchTimeout);
|
|
|
|
|
touchTimeout = 0;
|
|
|
|
|
invalidateContextMenu = false;
|
|
|
|
|
if (touchTimeout) {
|
|
|
|
|
this.resetContextMenuTimer();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
gesture.pointers.delete(event.pointerId);
|
|
|
|
@ -2937,6 +2937,12 @@ class App extends React.Component<AppProps, AppState> {
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
private resetContextMenuTimer = () => {
|
|
|
|
|
clearTimeout(touchTimeout);
|
|
|
|
|
touchTimeout = 0;
|
|
|
|
|
invalidateContextMenu = false;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
private maybeCleanupAfterMissingPointerUp(
|
|
|
|
|
event: React.PointerEvent<HTMLCanvasElement>,
|
|
|
|
|
): void {
|
|
|
|
|