'use client'; import { useState } from 'react'; import { motion } from 'framer-motion'; import { useRouter } from 'next/navigation'; import Link from 'next/link'; import { User, Mail, Phone, Lock, Eye, EyeOff, CheckCircle, XCircle, ArrowLeft, Home, Loader2, Shield, KeyRound } from 'lucide-react'; import toast, { Toaster } from 'react-hot-toast'; import { addCustomer, loginWithEmail, sendEmailOTP, verifyEmail } from '../../utils/api'; import AuthService from '../../services/AuthService'; import { CustomerType, CustomerTypeLabels } from '../../enums'; export default function TenantRegisterPage() { const router = useRouter(); const [step, setStep] = useState(1); // 1=form, 2=OTP const [showPassword, setShowPassword] = useState(false); const [showConfirmPassword, setShowConfirmPassword] = useState(false); const [isLoading, setIsLoading] = useState(false); const [formData, setFormData] = useState({ name: '', email: '', phone: '', password: '', confirmPassword: '', customerType: CustomerType.PERSONAL, agreeTerms: false }); const [otpCode, setOtpCode] = useState(''); const [errors, setErrors] = useState({}); const validateEmail = (email) => /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email); const validatePhone = (phone) => /^(09|05)[0-9]{8}$/.test(phone); const validateForm = () => { const newErrors = {}; if (!formData.name) newErrors.name = 'الاسم الكامل مطلوب'; else if (formData.name.length < 3) newErrors.name = 'الاسم يجب أن يكون 3 أحرف على الأقل'; if (!formData.email) newErrors.email = 'البريد الإلكتروني مطلوب'; else if (!validateEmail(formData.email)) newErrors.email = 'البريد الإلكتروني غير صالح'; if (!formData.phone) newErrors.phone = 'رقم الهاتف مطلوب'; else if (!validatePhone(formData.phone)) newErrors.phone = 'رقم الهاتف غير صالح (يجب أن يبدأ 09 أو 05)'; if (!formData.password) newErrors.password = 'كلمة المرور مطلوبة'; else if (formData.password.length < 6) newErrors.password = 'كلمة المرور يجب أن تكون 6 أحرف على الأقل'; if (formData.password !== formData.confirmPassword) newErrors.confirmPassword = 'كلمات المرور غير متطابقة'; setErrors(newErrors); return Object.keys(newErrors).length === 0; }; // ─── Main signup handler ─── const handleSubmit = async (e) => { e.preventDefault(); if (!validateForm()) { toast.error('يرجى تصحيح الأخطاء في النموذج'); return; } if (!formData.agreeTerms) { toast.error('يجب الموافقة على الشروط والأحكام'); return; } setIsLoading(true); console.log('[CustomerRegister] Submitting customer registration...'); const payload = { name: formData.name, email: formData.email, phoneNumber: formData.phone, password: formData.password, customerType: formData.customerType, }; try { const res = await addCustomer(payload); console.log('[CustomerRegister] addCustomer response:', res); if (res.status === 200 || res.ok) { // ── Store temp token for OTP flow ── const tempToken = res.data; if (tempToken) { AuthService.addToken(tempToken); console.log('[CustomerRegister] Temp token stored for OTP'); } const apiMessage = res.message || res.data?.message; toast.success(apiMessage || 'تم إنشاء الحساب! يرجى التحقق من بريدك الإلكتروني', { duration: 4000, }); // ── Auto-login to trigger OTP ── console.log('[CustomerRegister] Auto-login to send OTP...'); const loginRes = await loginWithEmail(formData.email, formData.password); console.log('[CustomerRegister] login response:', loginRes); if (loginRes.status === 206) { // OTP sent — move to OTP step const otpToken = loginRes.data; if (otpToken) { AuthService.addToken(otpToken); console.log('[CustomerRegister] OTP token stored'); } const loginMsg = loginRes.message || loginRes.data?.message; toast(loginMsg || 'تم إرسال رمز التحقق إلى بريدك الإلكتروني', { icon: '📧' }); setStep(2); } else if (loginRes.status === 200) { // Direct login success (no OTP needed) const loginToken = loginRes.data; if (loginToken) { AuthService.addToken(loginToken); } toast.success(loginRes.message || 'تم تسجيل الدخول بنجاح!'); router.push('/'); } } else { // Registration failed const errMsg = res.message || res.data?.message || 'فشل في إنشاء الحساب'; console.error('[CustomerRegister] Registration failed:', errMsg); toast.error(errMsg); } } catch (err) { console.error('[CustomerRegister] Error:', err); toast.error(err.message || 'حدث خطأ أثناء التسجيل'); } finally { setIsLoading(false); } }; // ─── OTP verification handler ─── const handleVerifyOTP = async () => { if (!otpCode || otpCode.length < 4) { toast.error('يرجى إدخال رمز التحقق'); return; } setIsLoading(true); console.log('[CustomerRegister] Verifying OTP:', otpCode); try { const res = await verifyEmail(otpCode); console.log('[CustomerRegister] VerifyEmail response:', res); if (res.status === 200) { // ── Verified! Remove temp token, redirect to login ── AuthService.deleteToken(); console.log('[CustomerRegister] Temp token removed after verification'); toast.success(res.message || 'تم التحقق من البريد الإلكتروني بنجاح!', { duration: 3000, }); setTimeout(() => { router.push('/login'); }, 1500); } else { const errMsg = res.message || res.data?.message || 'رمز التحقق غير صحيح'; console.error('[CustomerRegister] Verification failed:', errMsg); toast.error(errMsg); } } catch (err) { console.error('[CustomerRegister] Verify error:', err); toast.error(err.message || 'حدث خطأ أثناء التحقق'); } finally { setIsLoading(false); } }; // ─── Resend OTP ─── const handleResendOTP = async () => { setIsLoading(true); console.log('[CustomerRegister] Resending email OTP...'); try { await sendEmailOTP(); toast.success('تم إرسال رمز تحقق جديد'); } catch (err) { console.error('[CustomerRegister] Resend OTP error:', err); toast.error('فشل في إرسال الرمز'); } finally { setIsLoading(false); } }; const fadeInUp = { initial: { opacity: 0, y: 20 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.5 } }; const staggerContainer = { animate: { transition: { staggerChildren: 0.1 } } }; return (
{step === 1 ? 'انضم إلينا وابحث عن منزل أحلامك' : 'أدخل رمز التحقق المرسل إلى بريدك'}
{errors.name}
}{errors.email}
}{errors.phone}
}المحدد: {CustomerTypeLabels[formData.customerType]}
[Console] customerType = {formData.customerType}
{errors.password}
}{errors.confirmPassword}
}تم إرسال رمز التحقق إلى
{formData.email}