i18n.ts 2.1 KB

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