Язык по умолчанию на основе выбранного языка профиля пользователя

Я работаю над переводом языка с использованием i18n. У меня есть ToggleSwitch для изменения языка контента, который работает нормально. Но я хочу сделать язык по умолчанию в соответствии с выбранным языком профиля пользователя.

Это код, который я использую.

Любая помощь?

constructor(props) {
    super(props)
    this._retrieveData()
    this.state = {
        isOnBlueToggleSwitch: false
    }
}
onToggle = (isOn) => {
    I18n.locale = isOn ? "th" : "en"
}
_retrieveData = async () => {
    try {
        const value = await AsyncStorage.getItem('user');
        if (value !== null) {
            localLanguage = JSON.parse(value);
            I18n.locale = localLanguage.lang;
        }
    } catch (error) {
        console.log(error)
    }
}
render() {
    return (
        <View style={styles.container}>
            <ToggleSwitch
                onColor="#52a557"
                size='small'
                isOn={this.state.isOnBlueToggleSwitch}
                onToggle={isOnBlueToggleSwitch => {
                    this.setState({ isOnBlueToggleSwitch });
                    this.onToggle(isOnBlueToggleSwitch);
                }}
            />
        </View>
    )
}

i18n.js

'use strict';
import I18n from 'react-native-i18n';

I18n.fallbacks = true;

// List of language
I18n.translations = {
    'en': require('./en'), //for English
    'th': require('./th'), 
};

export default I18n;

0 ответов

Другие вопросы по тегам