'use client'; import { useEffect } from 'react'; import { useRouter } from 'next/navigation'; import Link from 'next/link'; import { usePathname } from 'next/navigation'; import { useLanguage } from '@/context/LanguageContext'; import { useAuth } from '@/context/AuthContext'; import LanguageToggle from '@/components/LanguageToggle'; import Button from '@/components/ui/Button'; import { HomeIcon, CalendarIcon, TicketIcon, UsersIcon, CreditCardIcon, EnvelopeIcon, InboxIcon, PhotoIcon, Cog6ToothIcon, ArrowLeftOnRectangleIcon, Bars3Icon, XMarkIcon, BanknotesIcon, QrCodeIcon, DocumentTextIcon, QuestionMarkCircleIcon, } from '@heroicons/react/24/outline'; import clsx from 'clsx'; import { useState } from 'react'; export default function AdminLayout({ children, }: { children: React.ReactNode; }) { const router = useRouter(); const pathname = usePathname(); const { t, locale } = useLanguage(); const { user, hasAdminAccess, isLoading, logout } = useAuth(); const [sidebarOpen, setSidebarOpen] = useState(false); type Role = 'admin' | 'organizer' | 'staff' | 'marketing'; const userRole = (user?.role || 'user') as Role; const navigationWithRoles: { name: string; href: string; icon: typeof HomeIcon; allowedRoles: Role[] }[] = [ { name: t('admin.nav.dashboard'), href: '/admin', icon: HomeIcon, allowedRoles: ['admin', 'organizer'] }, { name: t('admin.nav.events'), href: '/admin/events', icon: CalendarIcon, allowedRoles: ['admin', 'organizer', 'staff'] }, { name: t('admin.nav.bookings'), href: '/admin/bookings', icon: TicketIcon, allowedRoles: ['admin', 'organizer'] }, { name: locale === 'es' ? 'Escáner' : 'Scanner', href: '/admin/scanner', icon: QrCodeIcon, allowedRoles: ['admin', 'organizer', 'staff'] }, { name: t('admin.nav.users'), href: '/admin/users', icon: UsersIcon, allowedRoles: ['admin'] }, { name: t('admin.nav.payments'), href: '/admin/payments', icon: CreditCardIcon, allowedRoles: ['admin', 'organizer'] }, { name: locale === 'es' ? 'Opciones de Pago' : 'Payment Options', href: '/admin/payment-options', icon: BanknotesIcon, allowedRoles: ['admin', 'organizer'] }, { name: t('admin.nav.contacts'), href: '/admin/contacts', icon: EnvelopeIcon, allowedRoles: ['admin', 'organizer', 'marketing'] }, { name: t('admin.nav.emails'), href: '/admin/emails', icon: InboxIcon, allowedRoles: ['admin', 'organizer'] }, { name: t('admin.nav.gallery'), href: '/admin/gallery', icon: PhotoIcon, allowedRoles: ['admin', 'organizer'] }, { name: locale === 'es' ? 'Páginas Legales' : 'Legal Pages', href: '/admin/legal-pages', icon: DocumentTextIcon, allowedRoles: ['admin'] }, { name: 'FAQ', href: '/admin/faq', icon: QuestionMarkCircleIcon, allowedRoles: ['admin'] }, { name: locale === 'es' ? 'Configuración' : 'Settings', href: '/admin/settings', icon: Cog6ToothIcon, allowedRoles: ['admin'] }, ]; const allowedPathsForRole = new Set( navigationWithRoles.filter((item) => item.allowedRoles.includes(userRole)).map((item) => item.href) ); const defaultAdminRoute = userRole === 'staff' ? '/admin/scanner' : userRole === 'marketing' ? '/admin/contacts' : '/admin'; // All hooks must be called unconditionally before any early returns useEffect(() => { if (!isLoading && (!user || !hasAdminAccess)) { router.push('/login'); } }, [user, hasAdminAccess, isLoading, router]); useEffect(() => { if (!user || !hasAdminAccess) return; if (!pathname.startsWith('/admin')) return; if (pathname === '/admin' && (userRole === 'staff' || userRole === 'marketing')) { router.replace(defaultAdminRoute); return; } const isPathAllowed = (path: string) => { if (allowedPathsForRole.has(path)) return true; return Array.from(allowedPathsForRole).some((allowed) => path.startsWith(allowed + '/')); }; if (!isPathAllowed(pathname)) { router.replace(defaultAdminRoute); } }, [pathname, userRole, defaultAdminRoute, router, user, hasAdminAccess]); if (isLoading) { return (