Reaja projeto nativo com expo-localização e i18n-js
Atualmente, estou tentando implementar a localização, dependendo do idioma do sistema do dispositivo, mas algo não está funcionando conforme necessário.
Eu segui exatamente o mesmo código na documentação da Expo, por exemplo. para o botão que tenho, continuo recebendo em [MISSING "EN-GB.LOGIN" TRANSLATION]
vez de LOGIN
.
Aqui está o meu código:
welcomeScreen.js
import * as Localization from 'expo-localization';
import i18n from 'i18n-js';
i18n.translations = {
en: { login: 'LOGIN'},
ar: { login: 'تسجيل الدخول'},
};
i18n.locale = Localization.locale;
i18n.fallbacks = true;
function WelcomeScreen() {
return (
<Button
title={i18n.t('login')}
/>
)}
Então, em vez do código acima, decidi seguir este:
i18n.js
import i18n from 'i18n-js';
import * as Localization from 'expo-localization';
import ar from './locales/ar';
import en from './locales/en';
i18n.translations = {
'en': en,
'ar': ar,
};
i18n.locale = Localization.locale.search(/-|_/) !== -1?
Localization.locale.slice(0, 2): Localization.locale;
i18n.fallbacks = true;
export default i18n;
en.js
const en = {
'SignUp':{
SignUp:"Sign Up"
}}
ar.js
const ar = {
'SignUp':{
SignUp:"الاشتراك"
}}
SignUpScreen.js
import I18n from '../config/i18n';
function RegisterScreen(props) {
return(
<Button title={I18n.t('SignUp.SignUp')}
)}
Respostas
1 HendEl-Sahli
Se você tentar console.log(Localization.locale)
... não vai ser apenas en
(a chave é i18n.translations
esperada por i18n
) ... seria na forma de en_countryCode
... então você tem que cortar essa parte
i18n.locale = Localization.locale.search(/-|_/) !== -1
? Localization.locale.slice(0, 2)
: Localization.locale;
O que significa um erro “Não é possível encontrar o símbolo” ou “Não é possível resolver o símbolo”?
Christopher Nolan uma vez se arrependeu de ter lido o 'roteiro de Pulp Fiction' de Quentin Tarantino