2022-03-23 05:40:21 -07:00
|
|
|
import * as React from 'react';
|
|
|
|
|
|
|
|
export const useOnScreen = (ref: React.MutableRefObject<HTMLElement>) => {
|
|
|
|
const [isIntersecting, setIntersecting] = React.useState(false);
|
|
|
|
|
|
|
|
const observer = new IntersectionObserver(
|
|
|
|
([entry]) => setIntersecting(entry.isIntersecting),
|
|
|
|
);
|
|
|
|
|
|
|
|
React.useEffect(() => {
|
2022-03-24 08:06:01 -07:00
|
|
|
if (ref.current) {
|
|
|
|
observer.observe(ref.current);
|
|
|
|
}
|
2022-03-23 05:40:21 -07:00
|
|
|
|
|
|
|
return () => {
|
|
|
|
observer.disconnect();
|
|
|
|
};
|
2022-03-24 08:06:01 -07:00
|
|
|
}, [ref.current]);
|
2022-03-23 05:40:21 -07:00
|
|
|
|
|
|
|
return isIntersecting;
|
|
|
|
};
|