'use client' import { useEffect, useState } from 'react' import { Check, ChevronDown } from 'lucide-react' import { useParams, usePathname } from 'next/navigation' const languages = { en: { name: 'English', flag: '🇺🇸' }, es: { name: 'Español', flag: '🇪🇸' }, fr: { name: 'Français', flag: '🇫🇷' }, zh: { name: '简体中文', flag: '🇨🇳' }, } export function LanguageDropdown() { const [isOpen, setIsOpen] = useState(false) const pathname = usePathname() const params = useParams() 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'}` } window.location.href = newPath } return (
{isOpen && ( <>
setIsOpen(false)} />
{Object.entries(languages).map(([code, lang]) => ( ))}
)}
) }