import { useState } from 'react'; import { Link, useNavigate } from 'react-router-dom'; import { register, initiateGoogleLogin } from '../services/authService'; import { useAuthStore } from '../store/useAuthStore'; import { RESERVED_USERNAMES } from '../utils/reservedUsernames'; import { useSEO } from '../utils/useSEO'; export const RegisterPage: React.FC = () => { useSEO({ title: 'Create Account — Velxio', description: 'Create a free Velxio account to save your Arduino projects and share simulations.', url: 'https://velxio.dev/register', noindex: true, }); const navigate = useNavigate(); const setUser = useAuthStore((s) => s.setUser); const [username, setUsername] = useState(''); const [email, setEmail] = useState(''); const [password, setPassword] = useState(''); const [error, setError] = useState(''); const [loading, setLoading] = useState(false); const validateUsername = (name: string): string | null => { const lower = name.toLowerCase(); if (RESERVED_USERNAMES.has(lower)) return 'That username is reserved.'; if (!/^[a-z0-9_-]{3,30}$/.test(lower)) return 'Username must be 3-30 chars (a-z, 0-9, _, -)'; return null; }; const handleSubmit = async (e: React.FormEvent) => { e.preventDefault(); setError(''); const usernameErr = validateUsername(username); if (usernameErr) { setError(usernameErr); return; } if (password.length < 8) { setError('Password must be at least 8 characters.'); return; } setLoading(true); try { const user = await register(username.toLowerCase(), email, password); setUser(user); navigate('/editor'); } catch (err: any) { setError(err?.response?.data?.detail || 'Registration failed.'); } finally { setLoading(false); } }; return (

Create account

Start building for free

{error &&
{error}
}
setUsername(e.target.value)} required className="ap-input" autoFocus placeholder="e.g. alice" />
setEmail(e.target.value)} required className="ap-input" />
setPassword(e.target.value)} required className="ap-input" placeholder="At least 8 characters" />
or

Already have an account? Sign in

); };