hts/apps/migrant/components-ai/button-scroll-to-bottom.tsx

37 lines
847 B
TypeScript

'use client'
import * as React from 'react'
import { cn } from '@/lib/utils'
import { Button, type ButtonProps } from './ui/button'
import { IconArrowDown } from './ui/icons'
interface ButtonScrollToBottomProps extends ButtonProps {
isAtBottom: boolean
scrollToBottom: () => void
}
export function ButtonScrollToBottom({
className,
isAtBottom,
scrollToBottom,
...props
}: ButtonScrollToBottomProps) {
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={() => scrollToBottom()}
{...props}
>
<IconArrowDown />
<span className="sr-only">Scroll to bottom</span>
</Button>
)
}