next-chat / hooks /use-scroll-to-bottom.tsx
NeoPy's picture
Upload folder using huggingface_hub
867b17d verified
raw
history blame
1.18 kB
import useSWR from 'swr';
import { useRef, useEffect, useCallback } from 'react';
type ScrollFlag = ScrollBehavior | false;
export function useScrollToBottom() {
const containerRef = useRef<HTMLDivElement>(null);
const endRef = useRef<HTMLDivElement>(null);
const { data: isAtBottom = false, mutate: setIsAtBottom } = useSWR(
'messages:is-at-bottom',
null,
{ fallbackData: false },
);
const { data: scrollBehavior = false, mutate: setScrollBehavior } =
useSWR<ScrollFlag>('messages:should-scroll', null, { fallbackData: false });
useEffect(() => {
if (scrollBehavior) {
endRef.current?.scrollIntoView({ behavior: scrollBehavior });
setScrollBehavior(false);
}
}, [setScrollBehavior, scrollBehavior]);
const scrollToBottom = useCallback(
(scrollBehavior: ScrollBehavior = 'smooth') => {
setScrollBehavior(scrollBehavior);
},
[setScrollBehavior],
);
function onViewportEnter() {
setIsAtBottom(true);
}
function onViewportLeave() {
setIsAtBottom(false);
}
return {
containerRef,
endRef,
isAtBottom,
scrollToBottom,
onViewportEnter,
onViewportLeave,
};
}