react-use/src/useScroll.ts
2019-03-23 20:00:43 +11:00

49 lines
965 B
TypeScript

import {useState, useEffect, useRef} from 'react';
import {isClient} from './util';
export interface State {
x: number;
y: number;
}
const useScroll = (ref): State => {
const frame = useRef(0);
const [state, setState] = useState<State>({
x: isClient ? window.scrollX : 0,
y: isClient ? window.scrollY : 0
});
useEffect(() => {
const handler = () => {
frame.current = requestAnimationFrame(() => {
setState({
x: ref.current.scrollLeft,
y: ref.current.scrollTop
});
});
}
if (ref && ref.current) {
ref.current.addEventListener('scroll', handler, {
capture: false,
passive: true
});
}
return () => {
if (frame.current) {
cancelAnimationFrame(frame.current);
}
if (ref && ref.current) {
ref.current.removeEventListener('scroll', handler);
}
};
}, [ref]);
return state;
}
export default useScroll