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'; import es from './locales/es'; import fr from './locales/fr'; import ja from './locales/ja'; import it from './locales/it'; import ko from './locales/ko'; import ptBR from './locales/pt-BR'; import zhCN from './locales/zh-CN'; import zhTW from './locales/zh-TW'; const resources = { en: { translation: en }, de: { translation: de }, es: { translation: es }, fr: { translation: fr }, ja: { translation: ja }, it: { translation: it }, ko: { translation: ko }, 'pt-BR': { translation: ptBR }, 'zh-CN': { translation: zhCN }, 'zh-TW': { translation: zhTW }, }; i18n .use(LanguageDetector) .use(initReactI18next) .init({ resources, fallbackLng: 'en', supportedLngs: ['en', 'de', 'es', 'fr', 'ja', 'it', 'ko', 'pt-BR', 'zh-CN', 'zh-TW'], 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' }, { code: 'es', name: 'Spanish', nativeName: 'Español' }, { code: 'fr', name: 'French', nativeName: 'Français' }, { code: 'ja', name: 'Japanese', nativeName: '日本語' }, { code: 'it', name: 'Italian', nativeName: 'Italiano' }, { code: 'ko', name: 'Korean', nativeName: '한국어' }, { code: 'pt-BR', name: 'Portuguese (Brazil)', nativeName: 'Português (Brasil)' }, { code: 'zh-CN', name: 'Chinese (Simplified)', nativeName: '简体中文' }, { code: 'zh-TW', name: 'Chinese (Traditional)', nativeName: '繁體中文' }, ];