Files
pezkuwi-apps/packages/react-hooks/src/useScroll.ts
T

28 lines
720 B
TypeScript

// Copyright 2017-2026 @pezkuwi/react-hooks authors & contributors
// SPDX-License-Identifier: Apache-2.0
import { useCallback, useEffect, useState } from 'react';
import { createNamedHook } from './createNamedHook.js';
function useScrollImpl (): number {
const [scrollY, setScrollY] = useState(window.scrollY);
const setYOffset = useCallback((): void => setScrollY(window.scrollY), []);
useEffect(() => {
function watchScroll () {
window.addEventListener('scroll', setYOffset);
}
watchScroll();
return () => {
window.removeEventListener('scroll', setYOffset);
};
}, [setYOffset]);
return scrollY;
}
export const useScroll = createNamedHook('useScroll', useScrollImpl);