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 (
Создай свою учетную запись CampFire, чтобы оценивать и рецензировать все что движется.