Get the user preferred languages and use the library of your choice to translate your app !
- Android SDK Build-tools 25.0.3
$ yarn add react-native-languages
# -- OR --
npm i react-native-languages --save
# - THEN -
$ react-native link react-native-languagesInstead of using react-native link, you can use Cocoapods to manage your dependencies.
# Add this line in your Podfile
pod 'ReactNativeLanguages', :path => '../node_modules/react-native-languages'$ pod install- In the XCode's "Project navigator", right click on your project's Libraries folder ➜
Add Files to <...> - Go to
node_modules➜react-native-languages➜ios➜ selectReactNativeLanguages.xcodeproj - Add
ReactNativeLanguages.atoBuild Phases -> Link Binary With Libraries
- Add the following lines to
android/settings.gradle:
include ':react-native-languages'
project(':react-native-languages').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-languages/android')- Add the compile line to the dependencies in
android/app/build.gradle:
dependencies {
// ...
compile project(':react-native-languages')
}- Add the import and link the package in
MainApplication.java:
import com.reactcommunity.reactnativelanguages.ReactNativeLanguagesPackage; // <-- Add the ReactNativeLanguages import
public class MainApplication extends Application implements ReactApplication {
// ...
@Override
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
new MainReactPackage(),
// ...
new ReactNativeLanguagesPackage() // <-- Add it to the packages list
);
}
// ...
}import RNLanguages from 'react-native-languages';
// Current device language
console.log('language', RNLanguages.language);
// User preferred languages (in order)
console.log('languages', RNLanguages.languages);
// Listening for languages changes (on Android)
RNLanguages.addEventListener('change', ({ language, languages }) => {
// Do languages related things…
// RNLanguages.language and RNLanguages.languages will be correct too !
});