File size: 840 Bytes
052672d
 
 
 
 
 
64defdf
 
052672d
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
'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/Buttons';
import { IconArrowDown } from '@/components/ui/Icon';

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>
	);
}