1234567891011121314151617181920212223242526272829 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { tryOnScopeDispose } from '@vueuse/shared'
- import { ref } from 'vue'
- export const useTouchDevice = () => {
- const isTouchDevice = ref(false)
- if (window) {
- let mediaQuery: MediaQueryList
- const observeCallback = () => {
- isTouchDevice.value = window.matchMedia('(pointer: coarse)').matches
- mediaQuery?.removeEventListener('change', observeCallback)
- mediaQuery = window.matchMedia('(pointer: coarse)')
- mediaQuery.addEventListener('change', observeCallback, { once: true })
- }
- observeCallback()
- tryOnScopeDispose(() => {
- mediaQuery?.removeEventListener('change', observeCallback)
- })
- }
- return {
- isTouchDevice,
- }
- }
|