'use client'; import { useState, useRef } from 'react'; import { motion, AnimatePresence } from 'framer-motion'; import { useRouter } from 'next/navigation'; import Link from 'next/link'; import Image from 'next/image'; import { User, Mail, Phone, Lock, Eye, EyeOff, MessageCircle, Camera, X, CheckCircle, XCircle, ArrowLeft, Building, Loader2, Shield, KeyRound } from 'lucide-react'; import toast, { Toaster } from 'react-hot-toast'; import { addOwner, loginWithEmail, sendEmailOTP, verifyEmail } from '../../utils/api'; import AuthService from '../../services/AuthService'; import { OwnerType, OwnerTypeLabels } from '../../enums'; export default function OwnerRegisterPage() { const router = useRouter(); const [step, setStep] = useState(1); // 1=form, 2=id images, 3=OTP const [showPassword, setShowPassword] = useState(false); const [showConfirmPassword, setShowConfirmPassword] = useState(false); const [isLoading, setIsLoading] = useState(false); const [formData, setFormData] = useState({ name: '', email: '', phone: '', whatsapp: '', password: '', confirmPassword: '', ownerType: OwnerType.PERSON, agreeTerms: false }); const [idImages, setIdImages] = useState({ front: null, back: null }); const [idImagePreviews, setIdImagePreviews] = useState({ front: '', back: '' }); const [otpCode, setOtpCode] = useState(''); const [errors, setErrors] = useState({}); const fileInputFrontRef = useRef(null); const fileInputBackRef = useRef(null); const handleImageUpload = (side, file) => { if (!file) return; if (!file.type.startsWith('image/')) { toast.error('الرجاء اختيار صورة صالحة'); return; } if (file.size > 5 * 1024 * 1024) { toast.error('حجم الصورة يجب أن يكون أقل من 5 ميجابايت'); return; } const reader = new FileReader(); reader.onloadend = () => { setIdImagePreviews(prev => ({ ...prev, [side]: reader.result })); }; reader.readAsDataURL(file); setIdImages(prev => ({ ...prev, [side]: file })); console.log('[OwnerRegister] Image uploaded:', side); toast.success('تم رفع الصورة بنجاح', { style: { background: '#dcfce7', color: '#166534' } }); }; const validateEmail = (email) => /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email); const validatePhone = (phone) => /^(09|05)[0-9]{8}$/.test(phone); const validateStep1 = () => { 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.whatsapp) newErrors.whatsapp = 'رقم الواتساب مطلوب'; else if (!validatePhone(formData.whatsapp)) newErrors.whatsapp = 'رقم الواتساب غير صالح (يجب أن يبدأ 09 أو 05)'; if (formData.phone && !validatePhone(formData.phone)) newErrors.phone = 'رقم الهاتف غير صالح'; 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; }; const validateStep2 = () => { const newErrors = {}; if (!idImages.front) newErrors.front = 'صورة الوجه الأمامي للهوية مطلوبة'; if (!idImages.back) newErrors.back = 'صورة الوجه الخلفي للهوية مطلوبة'; setErrors(newErrors); return Object.keys(newErrors).length === 0; }; const handleNextStep = () => { if (validateStep1()) { console.log('[OwnerRegister] Step 1 valid, moving to step 2'); setStep(2); window.scrollTo({ top: 0, behavior: 'smooth' }); } else { toast.error('يرجى تصحيح الأخطاء في النموذج'); } }; // ─── Main signup handler ─── const handleSubmit = async (e) => { e.preventDefault(); if (!validateStep2()) { toast.error('يرجى إكمال جميع الصور المطلوبة'); return; } if (!formData.agreeTerms) { toast.error('يجب الموافقة على الشروط والأحكام'); return; } setIsLoading(true); console.log('[OwnerRegister] Submitting owner registration...'); const payload = { name: formData.name, email: formData.email, phoneNumber: formData.phone || '', whatsAppNumber: formData.whatsapp, password: formData.password, ownerType: formData.ownerType, }; try { const res = await addOwner(payload); console.log('[OwnerRegister] addOwner 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('[OwnerRegister] Temp token stored for OTP'); } const apiMessage = res.message || res.data?.message; toast.success(apiMessage || 'تم إنشاء الحساب! يرجى التحقق من بريدك الإلكتروني', { duration: 4000, }); // ── Auto-login to trigger OTP ── console.log('[OwnerRegister] Auto-login to send OTP...'); const loginRes = await loginWithEmail(formData.email, formData.password); console.log('[OwnerRegister] login response:', loginRes); if (loginRes.status === 206) { // OTP sent — move to OTP step const otpToken = loginRes.data; if (otpToken) { AuthService.addToken(otpToken); console.log('[OwnerRegister] OTP token stored'); } const loginMsg = loginRes.message || loginRes.data?.message; toast(loginMsg || 'تم إرسال رمز التحقق إلى بريدك الإلكتروني', { icon: '📧' }); setStep(3); } 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('[OwnerRegister] Registration failed:', errMsg); toast.error(errMsg); } } catch (err) { console.error('[OwnerRegister] 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('[OwnerRegister] Verifying OTP:', otpCode); try { const res = await verifyEmail(otpCode); console.log('[OwnerRegister] VerifyEmail response:', res); if (res.status === 200) { // ── Verified! Remove temp token, redirect to login ── AuthService.deleteToken(); console.log('[OwnerRegister] 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('[OwnerRegister] Verification failed:', errMsg); toast.error(errMsg); } } catch (err) { console.error('[OwnerRegister] Verify error:', err); toast.error(err.message || 'حدث خطأ أثناء التحقق'); } finally { setIsLoading(false); } }; // ─── Resend OTP ─── const handleResendOTP = async () => { setIsLoading(true); console.log('[OwnerRegister] Resending email OTP...'); try { await sendEmailOTP(); toast.success('تم إرسال رمز تحقق جديد'); } catch (err) { console.error('[OwnerRegister] 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 (
{/* Background blobs */}
{[...Array(20)].map((_, i) => ( ))}
{/* Progress bar */}
العودة خطوة {step} من 3
{[1, 2, 3].map((s) => ( = s ? 'bg-amber-500' : 'bg-gray-700'}`} animate={{ scaleX: step >= s ? 1 : 0.5 }} /> ))}
{/* Header */}
{step === 3 ? : }

{step === 1 ? 'معلومات المالك' : step === 2 ? 'الوثائق الرسمية' : 'التحقق من البريد'}

{step === 1 ? 'أدخل معلوماتك الأساسية' : step === 2 ? 'يرجى رفع صور الهوية للتحقق' : 'أدخل رمز التحقق المرسل إلى بريدك'}

{ e.preventDefault(); handleVerifyOTP(); }} className="space-y-6" > {/* ─── STEP 1: Form fields ─── */} {step === 1 && ( <>
{ setFormData({...formData, name: e.target.value}); setErrors({...errors, name: null}); }} className={`w-full pr-12 pl-4 py-3 bg-white/5 border rounded-xl focus:outline-none focus:ring-2 focus:ring-amber-500 focus:border-transparent text-white placeholder-gray-500 transition-all ${errors.name ? 'border-red-500' : 'border-gray-700'}`} placeholder="أدخل اسمك الكامل" />
{errors.name &&

{errors.name}

}
{ setFormData({...formData, email: e.target.value}); setErrors({...errors, email: null}); }} className={`w-full pr-12 pl-4 py-3 bg-white/5 border rounded-xl focus:outline-none focus:ring-2 focus:ring-amber-500 focus:border-transparent text-white placeholder-gray-500 transition-all ${errors.email ? 'border-red-500' : 'border-gray-700'}`} placeholder="أدخل بريدك الإلكتروني" />
{errors.email &&

{errors.email}

}
{ setFormData({...formData, phone: e.target.value}); setErrors({...errors, phone: null}); }} className="w-full pr-12 pl-4 py-3 bg-white/5 border border-gray-700 rounded-xl focus:outline-none focus:ring-2 focus:ring-amber-500 focus:border-transparent text-white placeholder-gray-500 transition-all" placeholder="أدخل رقم هاتفك (اختياري)" />
{errors.phone &&

{errors.phone}

}
{ setFormData({...formData, whatsapp: e.target.value}); setErrors({...errors, whatsapp: null}); }} className={`w-full pr-12 pl-4 py-3 bg-white/5 border rounded-xl focus:outline-none focus:ring-2 focus:ring-amber-500 focus:border-transparent text-white placeholder-gray-500 transition-all ${errors.whatsapp ? 'border-red-500' : 'border-gray-700'}`} placeholder="أدخل رقم الواتساب" />
{errors.whatsapp &&

{errors.whatsapp}

}
{/* Owner Type */}

المحدد: {OwnerTypeLabels[formData.ownerType]}

[Console] ownerType = {formData.ownerType}

{ setFormData({...formData, password: e.target.value}); setErrors({...errors, password: null}); }} className={`w-full pr-12 pl-12 py-3 bg-white/5 border rounded-xl focus:outline-none focus:ring-2 focus:ring-amber-500 focus:border-transparent text-white placeholder-gray-500 transition-all ${errors.password ? 'border-red-500' : 'border-gray-700'}`} placeholder="أدخل كلمة المرور" />
{errors.password &&

{errors.password}

}
{ setFormData({...formData, confirmPassword: e.target.value}); setErrors({...errors, confirmPassword: null}); }} className={`w-full pr-12 pl-12 py-3 bg-white/5 border rounded-xl focus:outline-none focus:ring-2 focus:ring-amber-500 focus:border-transparent text-white placeholder-gray-500 transition-all ${errors.confirmPassword ? 'border-red-500' : 'border-gray-700'}`} placeholder="أعد إدخال كلمة المرور" /> {formData.confirmPassword && (
{formData.password === formData.confirmPassword ? : }
)}
{errors.confirmPassword &&

{errors.confirmPassword}

}
)} {/* ─── STEP 2: ID Images ─── */} {step === 2 && ( <>
fileInputFrontRef.current?.click()} className={`relative border-2 border-dashed rounded-xl p-6 text-center cursor-pointer transition-all ${idImagePreviews.front ? 'border-green-500 bg-green-500/10' : errors.front ? 'border-red-500 bg-red-500/10' : 'border-gray-700 hover:border-amber-500 hover:bg-white/5'}`}> handleImageUpload('front', e.target.files?.[0])} className="hidden" /> {idImagePreviews.front ? (
Front ID
) : ( <>

اضغط لرفع الصورة

JPEG, PNG, JPG • حتى 5MB

)}
{errors.front &&

{errors.front}

}
fileInputBackRef.current?.click()} className={`relative border-2 border-dashed rounded-xl p-6 text-center cursor-pointer transition-all ${idImagePreviews.back ? 'border-green-500 bg-green-500/10' : errors.back ? 'border-red-500 bg-red-500/10' : 'border-gray-700 hover:border-amber-500 hover:bg-white/5'}`}> handleImageUpload('back', e.target.files?.[0])} className="hidden" /> {idImagePreviews.back ? (
Back ID
) : ( <>

اضغط لرفع الصورة

JPEG, PNG, JPG • حتى 5MB

)}
{errors.back &&

{errors.back}

}
setFormData({...formData, agreeTerms: e.target.checked})} className="w-4 h-4 rounded border-gray-600 bg-white/5 text-amber-500 focus:ring-amber-500 focus:ring-offset-0" required /> )} {/* ─── STEP 3: OTP ─── */} {step === 3 && (

تم إرسال رمز التحقق إلى

{formData.email}

setOtpCode(e.target.value)} className="w-full pr-12 pl-4 py-3 bg-white/5 border border-gray-700 rounded-xl focus:outline-none focus:ring-2 focus:ring-amber-500 focus:border-transparent text-white placeholder-gray-500 text-center tracking-[0.5em] text-xl transition-all" placeholder="------" />
)} {/* ─── Navigation Buttons ─── */} {step === 1 && ( <> )} {step === 2 && ( <> )} {step === 3 && ( )}
); }