Added multiple language options and fixed a bug where the Settings mode box was reset to browser language when opened

This commit is contained in:
wsh 2024-08-17 22:57:51 +08:00
parent d2ddb2d261
commit cdb49b25a1

View File

@ -3,38 +3,41 @@ import i18n from '../../i18n';
import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from "../ui/select";
import './LanguageSelector.css';
type Languages = 'en' | 'zh';
type Languages = 'en' | 'zh' | 'ja' | 'ko' | 'de' | 'ru' | 'fr';
const LanguageSelector: React.FC = () => {
const getBrowserLanguage = () => {
const browserLang = navigator.language.split('-')[0];
return (['en', 'zh'].includes(browserLang) ? browserLang : 'en') as Languages;
};
const [selectedLang, setSelectedLang] = useState<Languages>(i18n.language as Languages);
useEffect(() => {
const defaultLang = getBrowserLanguage();
if (defaultLang !== i18n.language) {
i18n.changeLanguage(defaultLang);
setSelectedLang(defaultLang);
}
const handleLanguageChanged = (lang: string) => {
setSelectedLang(lang as Languages);
};
i18n.on('languageChanged', handleLanguageChanged);
return () => {
i18n.off('languageChanged', handleLanguageChanged);
};
}, []);
const handleLanguageChange = (value: string) => {
const nextLang = value as Languages;
i18n.changeLanguage(nextLang);
setSelectedLang(nextLang);
};
return (
<Select onValueChange={handleLanguageChange} value={selectedLang}>
<SelectTrigger className="w-[100px]">
<SelectTrigger className="w-[120px]">
<SelectValue placeholder="Language" />
</SelectTrigger>
<SelectContent>
<SelectItem value="en">English</SelectItem>
<SelectItem value="zh"></SelectItem>
<SelectItem value="zh"></SelectItem>
<SelectItem value="ja"></SelectItem>
<SelectItem value="ko"></SelectItem>
<SelectItem value="de">Deutsch</SelectItem>
<SelectItem value="ru">Русский</SelectItem>
<SelectItem value="fr">Français</SelectItem>
</SelectContent>
</Select>
);