Files
FastGPT/packages/web/hooks/useI18n.ts
Archer 048f5a2d53 fix: emb page cannot save lng;feat: Add classify error log (#3367)
* fix: emb page cannot save lng

* perf: i18n check
2024-12-11 14:18:48 +08:00

66 lines
1.6 KiB
TypeScript

import Cookies from 'js-cookie';
import { useTranslation } from 'next-i18next';
import { LangEnum } from '../../../projects/app/src/web/common/utils/i18n';
const LANG_KEY = 'NEXT_LOCALE';
const isInIframe = () => {
try {
return window.self !== window.top;
} catch (e) {
return true;
}
};
const setLang = (value: string) => {
if (isInIframe()) {
localStorage.setItem(LANG_KEY, value);
} else {
// 不在 iframe 中,同时使用 Cookie 和 localStorage
Cookies.set(LANG_KEY, value, { expires: 30 });
localStorage.setItem(LANG_KEY, value);
}
};
const getLang = () => {
return localStorage.getItem(LANG_KEY) || Cookies.get(LANG_KEY);
};
export const useI18nLng = () => {
const { i18n } = useTranslation();
const languageMap: Record<string, string> = {
zh: LangEnum.zh_CN,
'zh-CN': LangEnum.zh_CN,
'zh-Hans': LangEnum.zh_CN,
'zh-HK': LangEnum.zh_Hant,
'zh-TW': LangEnum.zh_Hant,
'zh-Hant': LangEnum.zh_Hant,
en: LangEnum.en,
'en-US': LangEnum.en
};
const onChangeLng = async (lng: string) => {
const lang = languageMap[lng] || 'en';
const prevLang = getLang();
setLang(lang);
await i18n?.changeLanguage?.(lang);
if (prevLang && prevLang !== lang) {
window?.location?.reload?.();
}
};
const setUserDefaultLng = () => {
if (!navigator || !localStorage) return;
if (getLang()) return onChangeLng(getLang() as string);
const lang = languageMap[navigator.language] || 'en';
// currentLng not in userLang
return onChangeLng(lang);
};
return {
onChangeLng,
setUserDefaultLng
};
};