import { useCallback } from 'react' import { Languages, Check } from 'lucide-react' import { useTranslation } from 'react-i18next' import { useAuthStore } from '@/stores/auth-store' import { api } from '@/lib/api' import { cn } from '@/lib/utils' import { Button } from '@/components/ui/button' import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger, } from '@/components/ui/dropdown-menu' const languages = [ { code: 'en', label: 'English' }, { code: 'zh', label: '中文' }, { code: 'fr', label: 'Français' }, { code: 'ru', label: 'Русский' }, { code: 'ja', label: '日本語' }, { code: 'vi', label: 'Tiếng Việt' }, ] export function LanguageSwitcher() { const { i18n, t } = useTranslation() const user = useAuthStore((s) => s.auth.user) const handleChangeLanguage = useCallback( async (code: string) => { await i18n.changeLanguage(code) if (user) { try { await api.put('/api/user/self', { language: code }) } catch { // Best-effort persistence; don't block the UI on failure } } }, [i18n, user] ) return ( {languages.map((lang) => ( handleChangeLanguage(lang.code)} > {lang.label} ))} ) }