mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-25 23:07:58 +00:00
28 lines
720 B
TypeScript
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);
|