i18n.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. import LanguageDetector from "i18next-browser-languagedetector";
  2. export const languages = [
  3. { lng: "en", label: "English", data: require("./locales/en.json") },
  4. { lng: "bg-BG", label: "Български", data: require("./locales/bg-BG.json") },
  5. { lng: "de-DE", label: "Deutsch", data: require("./locales/de-DE.json") },
  6. { lng: "es-ES", label: "Español", data: require("./locales/es-ES.json") },
  7. { lng: "el-GR", label: "Ελληνικά", data: require("./locales/el-GR.json") },
  8. { lng: "fr-FR", label: "Français", data: require("./locales/fr-FR.json") },
  9. {
  10. lng: "id-ID",
  11. label: "Bahasa Indonesia",
  12. data: require("./locales/id-ID.json"),
  13. },
  14. { lng: "it-IT", label: "Italiano", data: require("./locales/it-IT.json") },
  15. { lng: "hu-HU", label: "Magyar", data: require("./locales/hu-HU.json") },
  16. { lng: "nl-NL", label: "Nederlands", data: require("./locales/nl-NL.json") },
  17. { lng: "no-No", label: "Norsk", data: require("./locales/no-NO.json") },
  18. { lng: "pl-PL", label: "Polski", data: require("./locales/pl-PL.json") },
  19. { lng: "pt-PT", label: "Português", data: require("./locales/pt-PT.json") },
  20. { lng: "ru-RU", label: "Русский", data: require("./locales/ru-RU.json") },
  21. { lng: "fi-FI", label: "Suomi", data: require("./locales/fi-FI.json") },
  22. { lng: "tr-TR", label: "Türkçe", data: require("./locales/tr-TR.json") },
  23. { lng: "ja-JP", label: "日本語", data: require("./locales/ja-JP.json") },
  24. { lng: "ko-KR", label: "한국어", data: require("./locales/ko-KR.json") },
  25. { lng: "zh-TW", label: "繁體中文", data: require("./locales/zh-TW.json") },
  26. { lng: "zh-CN", label: "简体中文", data: require("./locales/zh-CN.json") },
  27. {
  28. lng: "ar-SA",
  29. label: "العربية",
  30. data: require("./locales/ar-SA.json"),
  31. rtl: true,
  32. },
  33. {
  34. lng: "he-IL",
  35. label: "עברית",
  36. data: require("./locales/he-IL.json"),
  37. rtl: true,
  38. },
  39. ];
  40. let currentLanguage = languages[0];
  41. const fallbackLanguage = languages[0];
  42. export function setLanguage(newLng: string | undefined) {
  43. currentLanguage =
  44. languages.find((language) => language.lng === newLng) || fallbackLanguage;
  45. document.documentElement.dir = currentLanguage.rtl ? "rtl" : "ltr";
  46. languageDetector.cacheUserLanguage(currentLanguage.lng);
  47. }
  48. export function getLanguage() {
  49. return currentLanguage;
  50. }
  51. function findPartsForData(data: any, parts: string[]) {
  52. for (var i = 0; i < parts.length; ++i) {
  53. const part = parts[i];
  54. if (data[part] === undefined) {
  55. return undefined;
  56. }
  57. data = data[part];
  58. }
  59. if (typeof data !== "string") {
  60. return undefined;
  61. }
  62. return data;
  63. }
  64. export function t(path: string, replacement?: { [key: string]: string }) {
  65. const parts = path.split(".");
  66. let translation =
  67. findPartsForData(currentLanguage.data, parts) ||
  68. findPartsForData(fallbackLanguage.data, parts);
  69. if (translation === undefined) {
  70. throw new Error(`Can't find translation for ${path}`);
  71. }
  72. if (replacement) {
  73. for (var key in replacement) {
  74. translation = translation.replace(`{{${key}}}`, replacement[key]);
  75. }
  76. }
  77. return translation;
  78. }
  79. const languageDetector = new LanguageDetector();
  80. languageDetector.init({
  81. languageUtils: {
  82. formatLanguageCode: function (lng: string) {
  83. return lng;
  84. },
  85. isWhitelisted: () => true,
  86. },
  87. checkWhitelist: false,
  88. });
  89. setLanguage(languageDetector.detect());