Fixed Unable to preventDefault errors in Chrome (#130)
* Fixed Unable to preventDefault errors in Chrome * Cleanup wheel event listener
This commit is contained in:
parent
34b8883739
commit
aa01be2dbe
@ -940,6 +940,8 @@ class App extends React.Component<{}, AppState> {
|
|||||||
this.forceUpdate();
|
this.forceUpdate();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private removeWheelEventListener: (() => void) | undefined;
|
||||||
|
|
||||||
public render() {
|
public render() {
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
@ -1110,13 +1112,18 @@ class App extends React.Component<{}, AppState> {
|
|||||||
id="canvas"
|
id="canvas"
|
||||||
width={window.innerWidth - CANVAS_WINDOW_OFFSET_LEFT}
|
width={window.innerWidth - CANVAS_WINDOW_OFFSET_LEFT}
|
||||||
height={window.innerHeight - CANVAS_WINDOW_OFFSET_TOP}
|
height={window.innerHeight - CANVAS_WINDOW_OFFSET_TOP}
|
||||||
onWheel={e => {
|
ref={canvas => {
|
||||||
e.preventDefault();
|
if (this.removeWheelEventListener) {
|
||||||
const { deltaX, deltaY } = e;
|
this.removeWheelEventListener();
|
||||||
this.setState(state => ({
|
this.removeWheelEventListener = undefined;
|
||||||
scrollX: state.scrollX - deltaX,
|
}
|
||||||
scrollY: state.scrollY - deltaY
|
if (canvas) {
|
||||||
}));
|
canvas.addEventListener("wheel", this.handleWheel, {
|
||||||
|
passive: false
|
||||||
|
});
|
||||||
|
this.removeWheelEventListener = () =>
|
||||||
|
canvas.removeEventListener("wheel", this.handleWheel);
|
||||||
|
}
|
||||||
}}
|
}}
|
||||||
onMouseDown={e => {
|
onMouseDown={e => {
|
||||||
// only handle left mouse button
|
// only handle left mouse button
|
||||||
@ -1172,7 +1179,7 @@ class App extends React.Component<{}, AppState> {
|
|||||||
isResizingElements = true;
|
isResizingElements = true;
|
||||||
} else {
|
} else {
|
||||||
let hitElement = null;
|
let hitElement = null;
|
||||||
|
|
||||||
// We need to to hit testing from front (end of the array) to back (beginning of the array)
|
// We need to to hit testing from front (end of the array) to back (beginning of the array)
|
||||||
for (let i = elements.length - 1; i >= 0; --i) {
|
for (let i = elements.length - 1; i >= 0; --i) {
|
||||||
if (hitTest(elements[i], x, y)) {
|
if (hitTest(elements[i], x, y)) {
|
||||||
@ -1394,6 +1401,15 @@ class App extends React.Component<{}, AppState> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private handleWheel = (e: WheelEvent) => {
|
||||||
|
e.preventDefault();
|
||||||
|
const { deltaX, deltaY } = e;
|
||||||
|
this.setState(state => ({
|
||||||
|
scrollX: state.scrollX - deltaX,
|
||||||
|
scrollY: state.scrollY - deltaY
|
||||||
|
}));
|
||||||
|
};
|
||||||
|
|
||||||
componentDidUpdate() {
|
componentDidUpdate() {
|
||||||
renderScene(rc, context, {
|
renderScene(rc, context, {
|
||||||
scrollX: this.state.scrollX,
|
scrollX: this.state.scrollX,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user