i18n.ts 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. import LanguageDetector from "i18next-browser-languagedetector";
  2. export const languages = [
  3. { lng: "en", label: "English", data: require("./locales/en.json") },
  4. { lng: "de-DE", label: "Deutsch", data: require("./locales/de-DE.json") },
  5. { lng: "es-ES", label: "Español", data: require("./locales/es-ES.json") },
  6. { lng: "fr-FR", label: "Français", data: require("./locales/fr-FR.json") },
  7. {
  8. lng: "id-ID",
  9. label: "Bahasa Indonesia",
  10. data: require("./locales/id-ID.json"),
  11. },
  12. { lng: "hu-HU", label: "Magyar", data: require("./locales/hu-HU.json") },
  13. { lng: "no-No", label: "Norsk", data: require("./locales/no-NO.json") },
  14. { lng: "pl-PL", label: "Polski", data: require("./locales/pl-PL.json") },
  15. { lng: "pt-PT", label: "Português", data: require("./locales/pt-PT.json") },
  16. { lng: "ru-RU", label: "Русский", data: require("./locales/ru-RU.json") },
  17. { lng: "tr-TR", label: "Türkçe", data: require("./locales/tr-TR.json") },
  18. { lng: "ko-KR", label: "한국어", data: require("./locales/ko-KR.json") },
  19. { lng: "zh-TW", label: "繁體中文", data: require("./locales/zh-TW.json") },
  20. { lng: "zh-CN", label: "简体中文", data: require("./locales/zh-CN.json") },
  21. ];
  22. let currentLanguage = languages[0];
  23. const fallbackLanguage = languages[0];
  24. export function setLanguage(newLng: string | undefined) {
  25. currentLanguage =
  26. languages.find(language => language.lng === newLng) || fallbackLanguage;
  27. languageDetector.cacheUserLanguage(currentLanguage.lng);
  28. }
  29. export function getLanguage() {
  30. return currentLanguage.lng;
  31. }
  32. function findPartsForData(data: any, parts: string[]) {
  33. for (var i = 0; i < parts.length; ++i) {
  34. const part = parts[i];
  35. if (data[part] === undefined) {
  36. return undefined;
  37. }
  38. data = data[part];
  39. }
  40. if (typeof data !== "string") {
  41. return undefined;
  42. }
  43. return data;
  44. }
  45. export function t(path: string, replacement?: { [key: string]: string }) {
  46. const parts = path.split(".");
  47. let translation =
  48. findPartsForData(currentLanguage.data, parts) ||
  49. findPartsForData(fallbackLanguage.data, parts);
  50. if (translation === undefined) {
  51. throw new Error(`Can't find translation for ${path}`);
  52. }
  53. if (replacement) {
  54. for (var key in replacement) {
  55. translation = translation.replace(`{{${key}}}`, replacement[key]);
  56. }
  57. }
  58. return translation;
  59. }
  60. const languageDetector = new LanguageDetector();
  61. languageDetector.init({
  62. languageUtils: {
  63. formatLanguageCode: function(lng: string) {
  64. return lng;
  65. },
  66. isWhitelisted: () => true,
  67. },
  68. checkWhitelist: false,
  69. });
  70. setLanguage(languageDetector.detect());