error.tsx•2.83 kB
import { t } from 'i18next';
import { AlertCircle, RefreshCw, Home } from 'lucide-react';
import { useEffect, useState } from 'react';
import { useNavigate } from 'react-router-dom';
import { Button } from '@/components/ui/button';
import { CardContent } from '@/components/ui/card';
export const Error = () => {
  const navigate = useNavigate();
  const [countdown, setCountdown] = useState(5);
  useEffect(() => {
    const timer = setInterval(() => {
      setCountdown((prev) => {
        if (prev <= 1) {
          navigate('/platform/setup/billing');
          return 0;
        }
        return prev - 1;
      });
    }, 1000);
    return () => clearInterval(timer);
  }, [navigate]);
  return (
    <div className="h-full bg-background flex items-center justify-center p-4">
      <div className="w-full max-w-md border-destructive/20">
        <CardContent className="pt-8 pb-6 px-6">
          <div className="text-center space-y-6">
            <div className="mx-auto w-20 h-20 bg-destructive/10 rounded-full flex items-center justify-center">
              <AlertCircle className="w-10 h-10 text-destructive" />
            </div>
            <div className="space-y-3">
              <h1 className="text-2xl font-semibold text-foreground">
                {t('Something went wrong')}
              </h1>
              <p className="text-lg text-muted-foreground">
                {t('Subscription update failed')}
              </p>
            </div>
            <div className="bg-muted/30 rounded-lg p-4 text-left">
              <h3 className="text-sm font-medium text-foreground mb-2">
                {t('What you can do:')}
              </h3>
              <ul className="text-sm text-muted-foreground space-y-1">
                <li>{t('Verify your payment method')}</li>
                <li>{t('Try again in a few moments')}</li>
                <li>{t('Contact support if issues persist')}</li>
              </ul>
            </div>
            <div className="flex flex-col gap-3 pt-2">
              <Button
                onClick={() => navigate('/platform/setup/billing')}
                className="w-full"
              >
                <RefreshCw className="w-4 h-4 mr-2" />
                {t('Try Again')}
              </Button>
              <Button
                onClick={() => navigate('/dashboard')}
                variant="outline"
                className="w-full"
              >
                <Home className="w-4 h-4 mr-2" />
                {t('Go to Dashboard')}
              </Button>
            </div>
            <p className="text-xs text-muted-foreground">
              {t('Redirecting to billing in {countdown} seconds...', {
                countdown,
              })}
            </p>
          </div>
        </CardContent>
      </div>
    </div>
  );
};