From 57d92f23873cfd38365e61f2d63584b47b74a07f Mon Sep 17 00:00:00 2001 From: Michael Date: Sat, 21 Aug 2021 22:58:29 +0300 Subject: [PATCH] fix: fix disabling scrolling on mobile devices --- src/composable/scroll.ts | 26 +++++++++++++++++++++----- src/helper/scroll.helper.ts | 14 ++++++++++++++ src/index.ts | 2 ++ src/scss/main.scss | 3 +++ 4 files changed, 40 insertions(+), 5 deletions(-) create mode 100644 src/scss/main.scss diff --git a/src/composable/scroll.ts b/src/composable/scroll.ts index 2083a4e..9790a2d 100644 --- a/src/composable/scroll.ts +++ b/src/composable/scroll.ts @@ -1,6 +1,6 @@ import { Ref } from 'vue' -import { noScrollableParent } from '../helper/scroll.helper' +import { noScrollableParent, getScrollbarWidth } from '../helper/scroll.helper' type ScrollParams = { overlay: Ref @@ -12,6 +12,7 @@ export const useScroll = ({ content, }: ScrollParams) => { let disabled = false + let disableType: 'byEvents' | 'byOverflow' = null const eventListener = (event: WheelEvent) => { if(event.target === overlay.value @@ -27,9 +28,19 @@ export const useScroll = ({ return } - window.addEventListener('wheel', eventListener, { - passive: false, - }) + const scrollbarWidth = getScrollbarWidth() + + // The mobile has a scroll bar width of 0 + if (scrollbarWidth === 0) { + disableType = 'byOverflow' + document.documentElement.classList.add('overflow-y-hidden') + } else { + disableType = 'byEvents' + window.addEventListener('wheel', eventListener, { + passive: false, + }) + } + disabled = true } @@ -38,7 +49,12 @@ export const useScroll = ({ return } - window.removeEventListener('wheel', eventListener) + if(disableType === 'byEvents') { + window.removeEventListener('wheel', eventListener) + }else if (disableType === 'byOverflow') { + document.documentElement.classList.remove('overflow-y-hidden') + } + disabled = false } diff --git a/src/helper/scroll.helper.ts b/src/helper/scroll.helper.ts index 2a6bb00..5874d93 100644 --- a/src/helper/scroll.helper.ts +++ b/src/helper/scroll.helper.ts @@ -55,3 +55,17 @@ export const noScrollableParent = (event: WheelEvent, content: Element | undefin return true } + +export const getScrollbarWidth = () => { + const container = document.createElement('div') + container.style.visibility = 'hidden' + container.style.overflow = 'scroll' + const inner = document.createElement('div') + + container.appendChild(inner) + document.body.appendChild(container) + const scrollbarWidth = container.offsetWidth - inner.offsetWidth + document.body.removeChild(container) + + return scrollbarWidth +} \ No newline at end of file diff --git a/src/index.ts b/src/index.ts index 05003f8..d03275d 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,3 +1,5 @@ +import './scss/main.scss' + // standalone component export { default as GDialog } from './components/GDialog.vue' diff --git a/src/scss/main.scss b/src/scss/main.scss new file mode 100644 index 0000000..ac1c926 --- /dev/null +++ b/src/scss/main.scss @@ -0,0 +1,3 @@ +html.overflow-y-hidden { + overflow-y: hidden; +}