mirror of
https://github.com/MAGICGrants/campaign-site.git
synced 2026-01-09 20:38:02 -05:00
20 lines
457 B
TypeScript
20 lines
457 B
TypeScript
import { useEffect, useState } from 'react'
|
|
|
|
export function useMediaQuery(query: string) {
|
|
const [value, setValue] = useState(false)
|
|
|
|
useEffect(() => {
|
|
function onChange(event: MediaQueryListEvent) {
|
|
setValue(event.matches)
|
|
}
|
|
|
|
const result = matchMedia(query)
|
|
result.addEventListener('change', onChange)
|
|
setValue(result.matches)
|
|
|
|
return () => result.removeEventListener('change', onChange)
|
|
}, [query])
|
|
|
|
return value
|
|
}
|