react-native-i18n/README.md

121 lines
3.5 KiB
Markdown
Raw Normal View History

2016-08-18 14:58:33 +02:00
<img src="https://cdn0.iconfinder.com/data/icons/material-design-ii-glyph/614/3010_-_Translate-512.png" width="110" align="left">
2015-06-14 22:09:32 +07:00
# react-native-i18n
2015-06-14 22:12:16 +07:00
Integrates [I18n.js](https://github.com/fnando/i18n-js) with React Native. Uses the device's locale as default.
2016-08-18 14:58:33 +02:00
<br/>
<br/>
2015-06-14 22:09:32 +07:00
2016-08-18 14:58:33 +02:00
## Automatic setup
2015-06-14 22:09:32 +07:00
`$ npm install react-native-i18n --save`
2016-08-18 14:28:57 +02:00
After installing the npm package you need to link the native modules.
If you're using React-Native < 0.29 install [rnpm](https://github.com/rnpm/rnpm) with the command `npm install -g rnpm` and then link the library with the command `rnpm link`.
If you're using React-Native >= 0.29 just link the library with the command `react-native link`.
You can do so using [rnpm](https://github.com/rnpm/rnpm).
2016-03-08 22:25:55 +01:00
2016-08-18 14:50:08 +02:00
If you're having any issue you can also try to install the library manually as follows.
2016-08-18 14:58:33 +02:00
## Manual setup
### iOS
Add `RNI18n.xcodeproj` to **Libraries** and add `libRNI18n.a` to **Link Binary With Libraries** under **Build Phases**.
[More info and screenshots about how to do this is available in the React Native documentation](http://facebook.github.io/react-native/docs/linking-libraries-ios.html#content).
2015-06-14 22:09:32 +07:00
### Android
Add `react-native-i18n` to your `./android/settings.gradle` file as follows:
```
include ':app', ':react-native-i18n'
project(':react-native-i18n').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-i18n/android')
```
Include it as dependency in `./android/app/build.gradle` file:
```
dependencies {
...
compile project(':react-native-i18n')
}
```
2016-08-18 14:50:08 +02:00
Finally, you need to add the package to your MainApplication (`./android/app/src/main/java/your/bundle/MainApplication.java`):
```java
2016-08-18 14:50:08 +02:00
import com.i18n.reactnativei18n.ReactNativeI18n; // <-- Add to ReactNativeI18n to the imports
...
@Override
2016-08-18 14:50:08 +02:00
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
new MainReactPackage(),
...
new ReactNativeI18n(), // <-- Add it to the packages list
...
);
}
...
```
After that, you will need to recompile your project with `react-native run-android`.
2015-06-14 22:09:32 +07:00
## Usage
2016-08-18 14:28:57 +02:00
```javascript
import I18n from 'react-native-i18n'
2015-06-14 22:09:32 +07:00
2016-08-18 14:28:57 +02:00
class Demo extends React.Component {
render () {
2015-06-14 22:09:32 +07:00
return (
<Text>{I18n.t('greeting')}</Text>
)
}
2016-08-18 14:28:57 +02:00
}
2015-06-14 22:09:32 +07:00
2015-07-09 11:29:49 +07:00
// Enable fallbacks if you want `en-US` and `en-GB` to fallback to `en`
2016-08-18 14:28:57 +02:00
I18n.fallbacks = true
2015-07-09 11:29:49 +07:00
2015-06-14 22:09:32 +07:00
I18n.translations = {
en: {
greeting: 'Hi!'
},
fr: {
greeting: 'Bonjour!'
}
}
```
2015-06-14 22:12:16 +07:00
This will render `Hi!` for devices with the English locale, and `Bonjour!` for devices with the French locale.
2015-07-09 11:29:49 +07:00
### Fallbacks
When fallbacks are enabled (which is generally recommended), `i18n.js` will try to look up translations in the following order (for a device with `en_US` locale):
- en-US
- en
**Note**: iOS locales use underscored (`en_US`) but `i18n.js` locales are dasherized (`en-US`). This conversion is done automatically for you.
```js
2016-08-18 14:28:57 +02:00
I18n.fallbacks = true
2015-07-09 11:29:49 +07:00
I18n.translations = {
'en': {
greeting: 'Hi!'
},
'en-GB': {
greeting: 'Hi from the UK!'
}
}
```
For a device with a `en_GB` locale this will return `Hi from the UK!'`, for a device with a `en_US` locale it will return `Hi!`.
2015-06-14 22:09:32 +07:00
### Device's locale
You can get the device's locale with the `RNI18n` native module:
```js
2016-08-18 14:28:57 +02:00
import ReactNativeI18n from 'react-native-i18n'
const deviceLocale = ReactNativeI18n.locale
```
Returns `en-US`.
2015-07-09 11:29:49 +07:00
### I18n.js documentation
For more info about I18n.js methods (`localize`, `pluralize`, etc) and settings see [its documentation](https://github.com/fnando/i18n-js#setting-up).
2015-06-14 22:21:55 +07:00
## Licence
2015-07-09 11:29:49 +07:00
MIT