26
common/resources/client/ui/navigation/use-scroll-to-top.ts
Executable file
26
common/resources/client/ui/navigation/use-scroll-to-top.ts
Executable file
@@ -0,0 +1,26 @@
|
||||
import {useLocation} from 'react-router-dom';
|
||||
import {RefObject, useEffect} from 'react';
|
||||
import {usePrevious} from '@common/utils/hooks/use-previous';
|
||||
import {getScrollParent} from '@react-aria/utils';
|
||||
|
||||
export function useScrollToTop(ref?: RefObject<HTMLElement>) {
|
||||
const {pathname} = useLocation();
|
||||
|
||||
const previousPathname = usePrevious(pathname);
|
||||
|
||||
useEffect(() => {
|
||||
if (previousPathname !== pathname) {
|
||||
scrollToTop(ref);
|
||||
}
|
||||
}, [pathname, previousPathname, ref]);
|
||||
}
|
||||
|
||||
export function scrollToTop(ref?: RefObject<HTMLElement>) {
|
||||
const scrollParent = ref?.current
|
||||
? getScrollParent(ref.current)
|
||||
: document.documentElement;
|
||||
scrollParent.scrollTo({
|
||||
top: 0,
|
||||
left: 0,
|
||||
});
|
||||
}
|
||||
Reference in New Issue
Block a user