import React, { useState } from 'react'; import { useAuth } from '../contexts/AuthContext'; import { useLanguage } from '../contexts/LanguageContext'; import { t } from '../i18n/translations'; import { ArrowLeft } from 'lucide-react'; export function RegisterPage() { const { language } = useLanguage(); const { register, completeRegistration } = useAuth(); const [step, setStep] = useState<'register' | 'setup-otp' | 'verify-otp'>('register'); const [email, setEmail] = useState(''); const [password, setPassword] = useState(''); const [confirmPassword, setConfirmPassword] = useState(''); const [otpCode, setOtpCode] = useState(''); const [userID, setUserID] = useState(''); const [otpSecret, setOtpSecret] = useState(''); const [qrCodeURL, setQrCodeURL] = useState(''); const [error, setError] = useState(''); const [loading, setLoading] = useState(false); const handleRegister = async (e: React.FormEvent) => { e.preventDefault(); setError(''); if (password !== confirmPassword) { setError(t('passwordMismatch', language)); return; } if (password.length < 6) { setError(t('passwordTooShort', language)); return; } setLoading(true); const result = await register(email, password); if (result.success && result.userID) { setUserID(result.userID); setOtpSecret(result.otpSecret || ''); setQrCodeURL(result.qrCodeURL || ''); setStep('setup-otp'); } else { setError(result.message || t('registrationFailed', language)); } setLoading(false); }; const handleSetupComplete = () => { setStep('verify-otp'); }; const handleOTPVerify = async (e: React.FormEvent) => { e.preventDefault(); setError(''); setLoading(true); const result = await completeRegistration(userID, otpCode); if (!result.success) { setError(result.message || t('registrationFailed', language)); } // 成功的话AuthContext会自动处理登录状态 setLoading(false); }; const copyToClipboard = (text: string) => { navigator.clipboard.writeText(text); }; return (
{/* Back to Home */} {step === 'register' && ( )} {/* Logo */}
NOFX

{t('appTitle', language)}

{step === 'register' && t('registerTitle', language)} {step === 'setup-otp' && t('setupTwoFactor', language)} {step === 'verify-otp' && t('verifyOTP', language)}

{/* Registration Form */}
{step === 'register' && (
setEmail(e.target.value)} className="w-full px-3 py-2 rounded" style={{ background: '#0B0E11', border: '1px solid #2B3139', color: '#EAECEF' }} placeholder={t('emailPlaceholder', language)} required />
setPassword(e.target.value)} className="w-full px-3 py-2 rounded" style={{ background: '#0B0E11', border: '1px solid #2B3139', color: '#EAECEF' }} placeholder={t('passwordPlaceholder', language)} required />
setConfirmPassword(e.target.value)} className="w-full px-3 py-2 rounded" style={{ background: '#0B0E11', border: '1px solid #2B3139', color: '#EAECEF' }} placeholder={t('confirmPasswordPlaceholder', language)} required />
{error && (
{error}
)}
)} {step === 'setup-otp' && (
📱

{t('setupTwoFactor', language)}

{t('setupTwoFactorDesc', language)}

{t('step1Title', language)}

{t('step1Desc', language)}

{t('step2Title', language)}

{t('step2Desc', language)}

{qrCodeURL && (

{t('qrCodeHint', language)}

QR Code
)}

{t('otpSecret', language)}

{otpSecret}

{t('step3Title', language)}

{t('step3Desc', language)}

)} {step === 'verify-otp' && (
🔐

{t('enterOTPCode', language)}
{t('completeRegistrationSubtitle', language)}

setOtpCode(e.target.value.replace(/\D/g, '').slice(0, 6))} className="w-full px-3 py-2 rounded text-center text-2xl font-mono" style={{ background: '#0B0E11', border: '1px solid #2B3139', color: '#EAECEF' }} placeholder={t('otpPlaceholder', language)} maxLength={6} required />
{error && (
{error}
)}
)}
{/* Login Link */} {step === 'register' && (

已有账户?{' '}

)}
); }