From 3ddf47cd70ff8e644b0896adca8c2b03fc168bfb Mon Sep 17 00:00:00 2001 From: "kujiu (@rincevent)" Date: Sun, 25 Jul 2021 13:08:41 +0200 Subject: [PATCH] Fix swipe --- static/sphinxgalleria/sphinxgalleria.mjs | 117 +++++++++++++---------- 1 file changed, 68 insertions(+), 49 deletions(-) diff --git a/static/sphinxgalleria/sphinxgalleria.mjs b/static/sphinxgalleria/sphinxgalleria.mjs index ecf3c30..c0b0938 100644 --- a/static/sphinxgalleria/sphinxgalleria.mjs +++ b/static/sphinxgalleria/sphinxgalleria.mjs @@ -170,47 +170,60 @@ export class SphinxGalleria { var moveSwipe = function(ev) {self.moveSwipe(ev);}; var endSwipe = function(ev) {self.endSwipe(ev);}; - self.node_mask.addEventListener('touchstart', startSwipe, true); - self.node_mask.addEventListener('touchmove', moveSwipe, true); - self.node_mask.addEventListener('touchend', endSwipe, true); + self.node_mask.addEventListener('touchstart', startSwipe); + self.node_mask.addEventListener('touchmove', moveSwipe); + self.node_mask.addEventListener('touchend', endSwipe); + self.node_mask.addEventListener('touchcancel', endSwipe); - self.node_target.addEventListener('touchstart', startSwipe, true); + self.node_target.addEventListener('touchstart', startSwipe); self.node_target.addEventListener('touchmove', moveSwipe); - self.node_target.addEventListener('touchend', endSwipe, true); + self.node_target.addEventListener('touchend', endSwipe); + self.node_target.addEventListener('touchcancel', endSwipe); - self.node_image.addEventListener('touchstart', startSwipe, true); - self.node_image.addEventListener('touchmove', moveSwipe); - self.node_image.addEventListener('touchend', endSwipe, true); + self.node_mask.addEventListener('mousedown', startSwipe); + self.node_mask.addEventListener('mousemove', moveSwipe); + self.node_mask.addEventListener('mouseup', endSwipe); - self.dialog_image.addEventListener('touchstart', startSwipe, true); - self.dialog_image.addEventListener('touchmove', moveSwipe); - self.dialog_image.addEventListener('touchend', endSwipe, true); + self.node_target.addEventListener('mousedown', startSwipe); + self.node_target.addEventListener('mousemove', moveSwipe); + self.node_target.addEventListener('mouseup', endSwipe); - self.node_mask.addEventListener('mousedown', startSwipe, true); - self.node_mask.addEventListener('mousemove', moveSwipe, true); - self.node_mask.addEventListener('mouseup', endSwipe, true); - - self.node_target.addEventListener('mousedown', startSwipe, true); - self.node_target.addEventListener('mousemove', moveSwipe, true); - self.node_target.addEventListener('mouseup', endSwipe, true); - - self.node_image.addEventListener('mousedown', startSwipe, true); - self.node_image.addEventListener('mousemove', moveSwipe, true); - self.node_image.addEventListener('mouseup', endSwipe, true); - - self.dialog_image.addEventListener('mousedown', startSwipe, true); - self.dialog_image.addEventListener('mousemove', moveSwipe, true); - self.dialog_image.addEventListener('mouseup', endSwipe, true); - - var removeClick = function(ev) { - if(self.touch_data.noclick) { - self.touch_data.noclick = false; + startSwipe = function(ev) { + if(ev.type !== 'touchstart') { ev.preventDefault(); - ev.stopImmediatePropagation(); } + self.startSwipe(ev); }; - self.node_mask.addEventListener('click', removeClick, true); - self.node_target.addEventListener('click', removeClick, true); + moveSwipe = function(ev) { + if(ev.type !== 'touchmove') { + ev.preventDefault(); + } + self.moveSwipe(ev); + }; + endSwipe = function(ev) { + if(ev.type !== 'touchend' && ev.type !== 'touchcancel') { + ev.preventDefault(); + } + self.endSwipe(ev); + }; + + self.node_image.addEventListener('touchstart', startSwipe); + self.node_image.addEventListener('touchmove', moveSwipe); + self.node_image.addEventListener('touchend', endSwipe); + self.node_image.addEventListener('touchcancel', endSwipe); + + self.dialog_image.addEventListener('touchstart', startSwipe); + self.dialog_image.addEventListener('touchmove', moveSwipe); + self.dialog_image.addEventListener('touchend', endSwipe); + self.dialog_image.addEventListener('touchcancel', endSwipe); + + self.node_image.addEventListener('mousedown', startSwipe); + self.node_image.addEventListener('mousemove', moveSwipe); + self.node_image.addEventListener('mouseup', endSwipe); + + self.dialog_image.addEventListener('mousedown', startSwipe); + self.dialog_image.addEventListener('mousemove', moveSwipe); + self.dialog_image.addEventListener('mouseup', endSwipe); var onprev = function(ev) { var key = ev.key; @@ -476,11 +489,10 @@ export class SphinxGalleria { startSwipe(ev) { var self = this; if(!self.oneimage && self.touch_data.id === -1) { - ev.preventDefault(); if(ev.type === 'touchstart') { self.touch_data.id = ev.changedTouches[0].identifier; self.touch_data.x = ev.changedTouches[0].clientX; - self.touch_data.y = ev.changedTouches[1].clientY; + self.touch_data.y = ev.changedTouches[0].clientY; } else { self.touch_data.id = -2; self.touch_data.x = ev.clientX; @@ -500,16 +512,17 @@ export class SphinxGalleria { moveSwipe(ev) { var self = this; var move = false; + var touch = null; if(!self.oneimage && self.touch_data.x) { - ev.preventDefault(); if(ev.type === 'touchmove') { - ev.changedTouches.forEach(function(touch) { + for(var i=0; i 0) { move = true; self.touch_data.current_x = ev.clientX; @@ -520,17 +533,18 @@ export class SphinxGalleria { endSwipe(ev) { var self = this; var stop = false; + var touch = null; if(!self.oneimage && self.touch_data.x) { - ev.preventDefault(); - if(ev.type === "touchend") { - ev.changedTouches.forEach(function(touch) { + if(ev.type === "touchend" || ev.type === "touchcancel") { + for(var i=0; i self.getMinWidthSwipe()) { - if(width > 0) { + if(width < 0) { self.next(true); - self.touch_data.noclick = true; self.touch_data.swiped = true; } else { self.prev(true); - self.touch_data.noclick = true; self.touch_data.swiped = true; } - } else if(Math.abs(height) > self.node_mask.clientHeight/2) { + } else if(Math.abs(height) > self.node_mask.clientHeight/3) { self.closeModal(); - self.touch_data.noclick = true; + self.touch_data.swiped = true; } } getMinWidthSwipe() { if(this.node_mask.hidden) { - return this.node_image.clientWidth/2; + return this.node_image.clientWidth/3; } - return this.dialog_image.clientWidth/2; + return this.dialog_image.clientWidth/3; } }