import { useState, useEffect } from "react";
import { useNavigate } from "react-router";
import { Shield } from "lucide-react";
import { Button } from "~/components/ui/button/button";
import { Input } from "~/components/ui/input/input";
import { Label } from "~/components/ui/label/label";
import { useAuth } from "~/hooks/use-auth";
import styles from "./login.module.css";

export default function Login() {
  const [email, setEmail] = useState("");
  const [password, setPassword] = useState("");
  const [error, setError] = useState("");
  const { login, isAuthenticated } = useAuth();
  const navigate = useNavigate();

  useEffect(() => {
    if (isAuthenticated) {
      navigate("/");
    }
  }, [isAuthenticated, navigate]);

  const handleSubmit = (e: React.FormEvent) => {
    e.preventDefault();
    setError("");

    const success = login(email, password);
    if (success) {
      navigate("/");
    } else {
      setError("ایمیل یا رمز عبور نادرست است. لطفا دوباره تلاش کنید.");
    }
  };

  return (
    <div className={styles.container}>
      <div className={styles.card}>
        <div className={styles.header}>
          <div className={styles.logoWrapper}>
            <Shield className={styles.logo} />
          </div>
          <h1 className={styles.title}>پنل مدیریت VPN</h1>
          <p className={styles.subtitle}>برای مدیریت سرویس VPN وارد شوید</p>
        </div>

        <form onSubmit={handleSubmit} className={styles.form}>
          {error && <div className={styles.error}>ایمیل یا رمز عبور نادرست است. لطفا دوباره تلاش کنید.</div>}

          <div className={styles.formGroup}>
            <Label htmlFor="email" className={styles.label}>
              آدرس ایمیل
            </Label>
            <Input
              id="email"
              type="email"
              value={email}
              onChange={(e) => setEmail(e.target.value)}
              placeholder="admin@company.com"
              required
            />
          </div>

          <div className={styles.formGroup}>
            <Label htmlFor="password" className={styles.label}>
              رمز عبور
            </Label>
            <Input
              id="password"
              type="password"
              value={password}
              onChange={(e) => setPassword(e.target.value)}
              placeholder="رمز عبور خود را وارد کنید"
              required
            />
          </div>

          <Button type="submit" className={styles.submitButton}>
            ورود
          </Button>
        </form>

        <div className={styles.demo}>
          <p className={styles.demoTitle}>اطلاعات ورود آزمایشی</p>
          <p className={styles.demoCredentials}>
            ایمیل: admin@company.com
            <br />
            رمز عبور: admin123
          </p>
        </div>
      </div>
    </div>
  );
}
