'use client' import { useEffect, useState } from 'react' import { Check, ChevronDown } from 'lucide-react' import { useParams, usePathname, useRouter } from 'next/navigation' import { cn } from '@/lib/utils' const languages = { en: { name: 'English', flag: '🇺🇸' }, es: { name: 'Español', flag: '🇪🇸' }, fr: { name: 'Français', flag: '🇫🇷' }, de: { name: 'Deutsch', flag: '🇩🇪' }, ja: { name: '日本語', flag: '🇯🇵' }, zh: { name: '简体中文', flag: '🇨🇳' }, } export function LanguageDropdown() { const [isOpen, setIsOpen] = useState(false) const [hoveredIndex, setHoveredIndex] = useState(-1) const pathname = usePathname() const params = useParams() const router = useRouter() const [currentLang, setCurrentLang] = useState(() => { const langFromParams = params?.lang as string return langFromParams && Object.keys(languages).includes(langFromParams) ? langFromParams : 'en' }) useEffect(() => { const langFromParams = params?.lang as string if (langFromParams && Object.keys(languages).includes(langFromParams)) { if (langFromParams !== currentLang) { setCurrentLang(langFromParams) } } else { if (currentLang !== 'en') { setCurrentLang('en') } } }, [params, currentLang]) const handleLanguageChange = (locale: string) => { if (locale === currentLang) { setIsOpen(false) return } setIsOpen(false) const segments = pathname.split('/').filter(Boolean) if (segments[0] && Object.keys(languages).includes(segments[0])) { segments.shift() } let newPath = '' if (locale === 'en') { newPath = segments.length > 0 ? `/${segments.join('/')}` : '/introduction' } else { newPath = `/${locale}${segments.length > 0 ? `/${segments.join('/')}` : '/introduction'}` } router.push(newPath) } useEffect(() => { if (!isOpen) return const onKey = (e: KeyboardEvent) => { if (e.key === 'Escape') setIsOpen(false) } window.addEventListener('keydown', onKey) return () => window.removeEventListener('keydown', onKey) }, [isOpen]) // Reset hovered index when popover closes useEffect(() => { if (!isOpen) { setHoveredIndex(-1) } }, [isOpen]) const languageEntries = Object.entries(languages) return (
{isOpen && ( <>
setIsOpen(false)} />
{languageEntries.map(([code, lang], index) => { const isSelected = currentLang === code const isHovered = hoveredIndex === index return ( ) })}
)}
) }