2020-06-04 20:09:35 +02:00
|
|
|
'use strict';
|
|
|
|
|
2019-04-08 17:25:52 +02:00
|
|
|
const direction = {
|
|
|
|
NONE: null,
|
|
|
|
LEFT: 'left',
|
|
|
|
RIGHT: 'right',
|
|
|
|
DOWN: 'down',
|
|
|
|
UP: 'up'
|
|
|
|
};
|
|
|
|
|
|
|
|
function handleTouchStart(handler, evt) {
|
|
|
|
const touchEvent = evt.touches[0];
|
|
|
|
handler._xStart = touchEvent.clientX;
|
|
|
|
handler._yStart = touchEvent.clientY;
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleTouchMove(handler, evt) {
|
|
|
|
if (!handler._xStart || !handler._yStart) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const xDirection = handler._xStart - evt.touches[0].clientX;
|
|
|
|
const yDirection = handler._yStart - evt.touches[0].clientY;
|
|
|
|
|
|
|
|
if (Math.abs(xDirection) > Math.abs(yDirection)) {
|
|
|
|
if (xDirection > 0) {
|
|
|
|
handler._direction = direction.LEFT;
|
|
|
|
} else {
|
|
|
|
handler._direction = direction.RIGHT;
|
|
|
|
}
|
2020-06-04 20:09:35 +02:00
|
|
|
} else if (yDirection > 0) {
|
|
|
|
handler._direction = direction.DOWN;
|
2019-04-08 17:25:52 +02:00
|
|
|
} else {
|
2020-06-04 20:09:35 +02:00
|
|
|
handler._direction = direction.UP;
|
2019-04-08 17:25:52 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleTouchEnd(handler) {
|
|
|
|
switch (handler._direction) {
|
2020-06-04 20:09:35 +02:00
|
|
|
case direction.NONE:
|
|
|
|
return;
|
|
|
|
case direction.LEFT:
|
|
|
|
handler._swipeLeftTask();
|
|
|
|
break;
|
|
|
|
case direction.RIGHT:
|
|
|
|
handler._swipeRightTask();
|
|
|
|
break;
|
|
|
|
case direction.DOWN:
|
|
|
|
handler._swipeDownTask();
|
|
|
|
break;
|
|
|
|
case direction.UP:
|
|
|
|
handler._swipeUpTask();
|
|
|
|
// no default
|
2019-04-08 17:25:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
handler._xStart = null;
|
|
|
|
handler._yStart = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
class Touch {
|
|
|
|
constructor(target,
|
2020-06-04 20:09:35 +02:00
|
|
|
swipeLeft = () => {},
|
|
|
|
swipeRight = () => {},
|
|
|
|
swipeUp = () => {},
|
|
|
|
swipeDown = () => {}) {
|
2019-04-08 17:25:52 +02:00
|
|
|
this._target = target;
|
|
|
|
|
|
|
|
this._swipeLeftTask = swipeLeft;
|
|
|
|
this._swipeRightTask = swipeRight;
|
|
|
|
this._swipeUpTask = swipeUp;
|
|
|
|
this._swipeDownTask = swipeDown;
|
|
|
|
|
|
|
|
this._xStart = null;
|
|
|
|
this._yStart = null;
|
|
|
|
this._direction = direction.NONE;
|
|
|
|
|
|
|
|
this._target.addEventListener('touchstart',
|
2020-06-04 20:09:35 +02:00
|
|
|
evt => {
|
|
|
|
handleTouchStart(this, evt);
|
|
|
|
});
|
2019-04-08 17:25:52 +02:00
|
|
|
this._target.addEventListener('touchmove',
|
2020-06-04 20:09:35 +02:00
|
|
|
evt => {
|
|
|
|
handleTouchMove(this, evt);
|
|
|
|
});
|
2019-04-08 17:25:52 +02:00
|
|
|
this._target.addEventListener('touchend',
|
2020-06-04 20:09:35 +02:00
|
|
|
() => {
|
|
|
|
handleTouchEnd(this);
|
|
|
|
});
|
2019-04-08 17:25:52 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-04 20:09:35 +02:00
|
|
|
module.exports = Touch;
|