index.ts 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import i18n from 'i18next';
  2. import { initReactI18next } from 'react-i18next';
  3. import LanguageDetector from 'i18next-browser-languagedetector';
  4. // Import translations directly for bundling
  5. import en from './locales/en';
  6. import de from './locales/de';
  7. import es from './locales/es';
  8. import fr from './locales/fr';
  9. import ja from './locales/ja';
  10. import it from './locales/it';
  11. import ko from './locales/ko';
  12. import ptBR from './locales/pt-BR';
  13. import zhCN from './locales/zh-CN';
  14. import zhTW from './locales/zh-TW';
  15. const resources = {
  16. en: { translation: en },
  17. de: { translation: de },
  18. es: { translation: es },
  19. fr: { translation: fr },
  20. ja: { translation: ja },
  21. it: { translation: it },
  22. ko: { translation: ko },
  23. 'pt-BR': { translation: ptBR },
  24. 'zh-CN': { translation: zhCN },
  25. 'zh-TW': { translation: zhTW },
  26. };
  27. i18n
  28. .use(LanguageDetector)
  29. .use(initReactI18next)
  30. .init({
  31. resources,
  32. fallbackLng: 'en',
  33. supportedLngs: ['en', 'de', 'es', 'fr', 'ja', 'it', 'ko', 'pt-BR', 'zh-CN', 'zh-TW'],
  34. detection: {
  35. // Order of detection methods
  36. order: ['localStorage', 'navigator', 'htmlTag'],
  37. // Key to use in localStorage
  38. lookupLocalStorage: 'bambutrack_language',
  39. // Cache user language
  40. caches: ['localStorage'],
  41. },
  42. interpolation: {
  43. escapeValue: false, // React already escapes
  44. },
  45. react: {
  46. useSuspense: false,
  47. },
  48. });
  49. export default i18n;
  50. // Helper to get available languages
  51. export const availableLanguages = [
  52. { code: 'en', name: 'English', nativeName: 'English' },
  53. { code: 'de', name: 'German', nativeName: 'Deutsch' },
  54. { code: 'es', name: 'Spanish', nativeName: 'Español' },
  55. { code: 'fr', name: 'French', nativeName: 'Français' },
  56. { code: 'ja', name: 'Japanese', nativeName: '日本語' },
  57. { code: 'it', name: 'Italian', nativeName: 'Italiano' },
  58. { code: 'ko', name: 'Korean', nativeName: '한국어' },
  59. { code: 'pt-BR', name: 'Portuguese (Brazil)', nativeName: 'Português (Brasil)' },
  60. { code: 'zh-CN', name: 'Chinese (Simplified)', nativeName: '简体中文' },
  61. { code: 'zh-TW', name: 'Chinese (Traditional)', nativeName: '繁體中文' },
  62. ];