| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- 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: '繁體中文' },
- ];
|