next-chat / components /submit-button.tsx
NeoPy's picture
Upload folder using huggingface_hub
867b17d verified
raw
history blame
814 Bytes
'use client';
import { useFormStatus } from 'react-dom';
import { LoaderIcon } from '@/components/icons';
import { Button } from './ui/button';
export function SubmitButton({
children,
isSuccessful,
}: {
children: React.ReactNode;
isSuccessful: boolean;
}) {
const { pending } = useFormStatus();
return (
<Button
type={pending ? 'button' : 'submit'}
aria-disabled={pending || isSuccessful}
disabled={pending || isSuccessful}
className="relative"
>
{children}
{(pending || isSuccessful) && (
<span className="animate-spin absolute right-4">
<LoaderIcon />
</span>
)}
<output aria-live="polite" className="sr-only">
{pending || isSuccessful ? 'Loading' : 'Submit form'}
</output>
</Button>
);
}