import { useState, useEffect } from "react"; import { Link, useNavigate } from "react-router-dom"; import { useAuth } from "../contexts/AuthContext"; function RegisterPage() { const [login, setLogin] = useState(""); const [email, setEmail] = useState(""); const [password, setPassword] = useState(""); const [confirmPassword, setConfirmPassword] = useState(""); const [error, setError] = useState(""); const [loading, setLoading] = useState(false); const { user, userProfile, loading: authLoading, register, isInitialized } = useAuth(); const navigate = useNavigate(); useEffect(() => { if (!authLoading && isInitialized) { if (user && userProfile) { navigate("/"); } } }, [user, userProfile, authLoading, isInitialized, navigate]); const handleSubmit = async (e) => { e.preventDefault(); if (!login || !password || !confirmPassword) { setError("Заполни обязательные поля"); return; } if (password !== confirmPassword) { setError("Хмм, пароли не совпадают..."); return; } if (password.length < 6) { setError("Коротковато..."); return; } if (!/^[a-zA-Z0-9_]+$/.test(login)) { setError("Логин может содержать только латинские буквы, цифры и знак подчеркивания"); return; } if (login.length < 3 || login.length > 20) { setError("Логин должен быть от 3 до 20 символов"); return; } try { setError(""); setLoading(true); await register(login, password, email || null); } catch (err) { if (err.response && err.response.data) { const errorData = err.response.data; if (errorData.login && errorData.login.code === 'validation_not_unique') { setError("Этот логин уже занят"); } else if (errorData.email && errorData.email.code === 'validation_not_unique') { setError("Пользователь с таким email уже существует"); } else { setError(err.message || "Произошла ошибка при регистрации"); } } else { setError(err.message || "Произошла ошибка при регистрации"); } } finally { setLoading(false); } }; if (authLoading || !isInitialized) { return (
); } return (

Присоединиться к CampFire мнеие

Создай свою учетную запись CampFire, чтобы оценивать и рецензировать все что движется.

{error && (
{error}
)}
setLogin(e.target.value)} className="input w-full px-3 py-2 bg-campfire-dark text-campfire-light border border-campfire-ash/30 rounded-md focus:outline-none focus:ring-campfire-amber focus:border-campfire-amber transition-colors" placeholder="Введите логин" required autoComplete="username" />

От 3 до 20 символов, только латинские буквы, цифры и _

Логин чувствителен к регистру букв

setEmail(e.target.value)} className="input w-full px-3 py-2 bg-campfire-dark text-campfire-light border border-campfire-ash/30 rounded-md focus:outline-none focus:ring-campfire-amber focus:border-campfire-amber transition-colors" placeholder="your@campfiregg.ru" autoComplete="email" />
setPassword(e.target.value)} className="input w-full px-3 py-2 bg-campfire-dark text-campfire-light border border-campfire-ash/30 rounded-md focus:outline-none focus:ring-campfire-amber focus:border-campfire-amber transition-colors" placeholder="••••••••" required autoComplete="new-password" />

Не меньше 6 знаков

setConfirmPassword(e.target.value)} className="input w-full px-3 py-2 bg-campfire-dark text-campfire-light border border-campfire-ash/30 rounded-md focus:outline-none focus:ring-campfire-amber focus:border-campfire-amber transition-colors" placeholder="••••••••" required autoComplete="new-password" />
Уже в строю?{" "} Войти
); } export default RegisterPage;