Navigation Menu

Skip to content

Instantly share code, notes, and snippets.

@maccman
Created March 3, 2021 02:16
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save maccman/600c52bb59c7cbefc164050a6e05f2bf to your computer and use it in GitHub Desktop.
Save maccman/600c52bb59c7cbefc164050a6e05f2bf to your computer and use it in GitHub Desktop.
import { RefObject, useMemo, useLayoutEffect, useRef, useState } from 'react'
type DOMRectRef = [rect: DOMRect, ref: RefObject<HTMLDivElement>]
export const useDimensions = ():DOMRectRef => {
const ref = useRef<HTMLDivElement>(null)
const [rect, setRect] = useState<DOMRect>(DOMRect.fromRect())
const resizeObserver = useMemo(() => {
if ( !ref.current ) return
const observer = new ResizeObserver(entries => {
for (const entry of entries) {
setRect(entry.contentRect)
}
})
observer.observe(ref.current)
return observer
}, [ref.current])
useLayoutEffect(() => () => {
if (ref.current) {
resizeObserver?.unobserve(ref.current)
}
}, [resizeObserver, ref.current])
return [rect, ref]
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment