feat: responsive popovers & menus (#1323)
This commit is contained in:
25
packages/web/src/javascripts/Hooks/useDocumentRect.ts
Normal file
25
packages/web/src/javascripts/Hooks/useDocumentRect.ts
Normal file
@@ -0,0 +1,25 @@
|
||||
import { useEffect, useState } from 'react'
|
||||
|
||||
const DebounceTimeInMs = 100
|
||||
|
||||
export const useDocumentRect = (): DOMRect => {
|
||||
const [documentRect, setDocumentRect] = useState<DOMRect>(document.documentElement.getBoundingClientRect())
|
||||
|
||||
useEffect(() => {
|
||||
let debounceTimeout: number
|
||||
|
||||
const handleWindowResize = () => {
|
||||
window.clearTimeout(debounceTimeout)
|
||||
|
||||
window.setTimeout(() => {
|
||||
setDocumentRect(document.documentElement.getBoundingClientRect())
|
||||
}, DebounceTimeInMs)
|
||||
}
|
||||
|
||||
window.addEventListener('resize', handleWindowResize)
|
||||
|
||||
return () => window.removeEventListener('resize', handleWindowResize)
|
||||
}, [])
|
||||
|
||||
return documentRect
|
||||
}
|
||||
Reference in New Issue
Block a user