'use client' import { useEffect, useState } from 'react' import { Check, ChevronRight } from 'lucide-react' import { useParams, usePathname, useRouter } from 'next/navigation' 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 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]) return (