Make modal easier to close if there is only one image

This commit is contained in:
tusooa 2023-01-14 10:19:08 -05:00
parent e74482d84b
commit 274d384572
No known key found for this signature in database
GPG key ID: 7B467EDE43A08224
3 changed files with 13 additions and 0 deletions

View file

@ -63,6 +63,11 @@ const MediaModal = {
}, },
type () { type () {
return this.currentMedia ? this.getType(this.currentMedia) : null return this.currentMedia ? this.getType(this.currentMedia) : null
},
swipeDisableClickThreshold () {
// If there is only one media, allow more mouse movements to close the modal
// because there is less chance that the user wants to switch to another image
return () => this.canNavigate ? 1 : 30
} }
}, },
methods: { methods: {

View file

@ -10,6 +10,7 @@
class="modal-image-container" class="modal-image-container"
:direction="swipeDirection" :direction="swipeDirection"
:threshold="swipeThreshold" :threshold="swipeThreshold"
:disable-click-threshold="swipeDisableClickThreshold"
@preview-requested="handleSwipePreview" @preview-requested="handleSwipePreview"
@swipe-finished="handleSwipeEnd" @swipe-finished="handleSwipeEnd"
@swipeless-clicked="hide" @swipeless-clicked="hide"

View file

@ -5,6 +5,8 @@ import GestureService from '../../services/gesture_service/gesture_service'
* direction: a vector that indicates the direction of the intended swipe * direction: a vector that indicates the direction of the intended swipe
* threshold: the minimum distance in pixels the swipe has moved on `direction' * threshold: the minimum distance in pixels the swipe has moved on `direction'
* for swipe-finished() to have a non-zero sign * for swipe-finished() to have a non-zero sign
* disableClickThreshold: the minimum distance in pixels for the swipe to
* not trigger a click
* perpendicularTolerance: see gesture_service * perpendicularTolerance: see gesture_service
* *
* Events: * Events:
@ -34,6 +36,10 @@ const SwipeClick = {
type: Function, type: Function,
default: () => 30 default: () => 30
}, },
disableClickThreshold: {
type: Function,
default: () => 1
},
perpendicularTolerance: { perpendicularTolerance: {
type: Number, type: Number,
default: 1.0 default: 1.0
@ -72,6 +78,7 @@ const SwipeClick = {
this.$gesture = new GestureService.SwipeAndClickGesture({ this.$gesture = new GestureService.SwipeAndClickGesture({
direction: this.direction, direction: this.direction,
threshold: this.threshold, threshold: this.threshold,
disableClickThreshold: this.disableClickThreshold,
perpendicularTolerance: this.perpendicularTolerance, perpendicularTolerance: this.perpendicularTolerance,
swipePreviewCallback: this.preview, swipePreviewCallback: this.preview,
swipeEndCallback: this.end, swipeEndCallback: this.end,