"use client" import { Button } from "@/components/ui/button" import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from "@/components/ui/dropdown-menu" import { cn } from "@/lib/utils" import { CheckCircleIcon, LanguageIcon } from "@heroicons/react/20/solid" import { useTranslation } from "react-i18next" export function LanguageSwitcher() { const { t, i18n } = useTranslation() const customBackgroundImage = (window.CustomBackgroundImage as string) !== "" ? window.CustomBackgroundImage : undefined const locale = i18n.languages[0] const handleSelect = (e: Event, newLocale: string) => { e.preventDefault() // 阻止默认的关闭行为 i18n.changeLanguage(newLocale) } const localeItems = [ { name: t("language.zh-CN"), code: "zh-CN" }, { name: t("language.zh-TW"), code: "zh-TW" }, { name: t("language.en-US"), code: "en-US" }, { name: t("language.ru-RU"), code: "ru-RU" }, { name: t("language.es-ES"), code: "es-ES" }, { name: t("language.de-DE"), code: "de-DE" }, { name: t("language.ta-IN"), code: "ta-IN" }, ] return ( {localeItems.map((item) => ( handleSelect(e, item.code)} className={locale === item.code ? "bg-muted gap-3" : ""}> {item.name} {locale === item.code && } ))} ) }