vision-agent / components /chat /ButtonScrollToBottom.tsx
MingruiZhang's picture
done (#4)
f80b091 unverified
raw
history blame
906 Bytes
'use client';
import * as React from 'react';
import { cn } from '@/lib/utils';
import { useAtBottom } from '@/lib/hooks/useAtBottom';
import { Button, type ButtonProps } from '@/components/ui/Button';
import { IconArrowDown } from '@/components/ui/Icons';
export function ButtonScrollToBottom({ className, ...props }: ButtonProps) {
const isAtBottom = useAtBottom();
return (
<Button
variant="outline"
size="icon"
className={cn(
'absolute right-4 top-1 z-10 bg-background transition-opacity duration-300 sm:right-8 md:top-2',
isAtBottom ? 'opacity-0' : 'opacity-100',
className,
)}
onClick={() =>
window.scrollTo({
top: document.body.offsetHeight,
behavior: 'smooth',
})
}
{...props}
>
<IconArrowDown />
<span className="sr-only">Scroll to bottom</span>
</Button>
);
}