Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | import i18n from 'i18next'; import { initReactI18next } from 'react-i18next'; import LanguageDetector from 'i18next-browser-languagedetector'; // Import translations directly for bundling import en from './locales/en'; import de from './locales/de'; const resources = { en: { translation: en }, de: { translation: de }, }; i18n .use(LanguageDetector) .use(initReactI18next) .init({ resources, fallbackLng: 'en', supportedLngs: ['en', 'de'], detection: { // Order of detection methods order: ['localStorage', 'navigator', 'htmlTag'], // Key to use in localStorage lookupLocalStorage: 'bambutrack_language', // Cache user language caches: ['localStorage'], }, interpolation: { escapeValue: false, // React already escapes }, react: { useSuspense: false, }, }); export default i18n; // Helper to get available languages export const availableLanguages = [ { code: 'en', name: 'English', nativeName: 'English' }, { code: 'de', name: 'German', nativeName: 'Deutsch' }, ]; |