index.ts 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. import CN from "./cn";
  2. import EN from "./en";
  3. import TW from "./tw";
  4. import ES from "./es";
  5. import IT from "./it";
  6. import TR from "./tr";
  7. import JP from "./jp";
  8. import DE from "./de";
  9. import VI from "./vi";
  10. import RU from "./ru";
  11. export type { LocaleType } from "./cn";
  12. export const AllLangs = [
  13. "en",
  14. "cn",
  15. "tw",
  16. "es",
  17. "it",
  18. "tr",
  19. "jp",
  20. "de",
  21. "vi",
  22. "ru",
  23. ] as const;
  24. export type Lang = (typeof AllLangs)[number];
  25. const LANG_KEY = "lang";
  26. const DEFAULT_LANG = "en";
  27. function getItem(key: string) {
  28. try {
  29. return localStorage.getItem(key);
  30. } catch {
  31. return null;
  32. }
  33. }
  34. function setItem(key: string, value: string) {
  35. try {
  36. localStorage.setItem(key, value);
  37. } catch {}
  38. }
  39. function getLanguage() {
  40. try {
  41. return navigator.language.toLowerCase();
  42. } catch {
  43. console.log("[Lang] failed to detect user lang.");
  44. return DEFAULT_LANG;
  45. }
  46. }
  47. export function getLang(): Lang {
  48. const savedLang = getItem(LANG_KEY);
  49. if (AllLangs.includes((savedLang ?? "") as Lang)) {
  50. return savedLang as Lang;
  51. }
  52. const lang = getLanguage();
  53. for (const option of AllLangs) {
  54. if (lang.includes(option)) {
  55. return option;
  56. }
  57. }
  58. return DEFAULT_LANG;
  59. }
  60. export function changeLang(lang: Lang) {
  61. setItem(LANG_KEY, lang);
  62. location.reload();
  63. }
  64. export default {
  65. en: EN,
  66. cn: CN,
  67. tw: TW,
  68. es: ES,
  69. it: IT,
  70. tr: TR,
  71. jp: JP,
  72. de: DE,
  73. vi: VI,
  74. ru: RU,
  75. }[getLang()] as typeof CN;