Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xcarpentier/ex-react-native-i18n
💱 ex-react-native-i18n for Expo
https://github.com/xcarpentier/ex-react-native-i18n
exponent react-native
Last synced: 2 months ago
JSON representation
💱 ex-react-native-i18n for Expo
- Host: GitHub
- URL: https://github.com/xcarpentier/ex-react-native-i18n
- Owner: xcarpentier
- Fork: true (AlexanderZaytsev/react-native-i18n)
- Created: 2016-11-07T15:42:13.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2021-11-28T15:48:27.000Z (about 3 years ago)
- Last Synced: 2024-05-19T04:52:52.258Z (8 months ago)
- Topics: exponent, react-native
- Language: JavaScript
- Homepage:
- Size: 56.6 KB
- Stars: 83
- Watchers: 4
- Forks: 27
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
[![NPM version](https://badge.fury.io/js/ex-react-native-i18n.svg)](http://badge.fury.io/js/ex-react-native-i18n)
[![Downloads](https://img.shields.io/npm/dm/ex-react-native-i18n.svg)](https://www.npmjs.com/package/ex-react-native-i18n)
[![reactnative.gallery](https://img.shields.io/badge/reactnative.gallery-%E2%99%A5-red.svg)](https://reactnative.gallery)# ex-react-native-i18n for Expo
Integrates [I18n.js](https://github.com/fnando/i18n-js) with React Native and ***Expo***. Uses the device's locale as default.
## Automatic setup
`$ npm install ex-react-native-i18n --save`or
`$ yarn add ex-react-native-i18n`
## Usage
Before copy usage see this issue: https://github.com/xcarpentier/ex-react-native-i18n/issues/7
```javascript
import I18n from 'react-native-i18n'class Demo extends React.Component {
// Async call to init the locale
componentWillMount() {
I18n.initAsync();
}
render () {
return (
{I18n.t('greeting')}
)
}
}// Enable fallbacks if you want `en-US` and `en-GB` to fallback to `en`
I18n.fallbacks = trueI18n.translations = {
en: {
greeting: 'Hi!'
},
fr: {
greeting: 'Bonjour!'
}
}
```This will render `Hi!` for devices with the English locale, and `Bonjour!` for devices with the French locale.
### 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
I18n.fallbacks = trueI18n.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!`.### Device's locale
You can get the device's locale with the `RNI18n` native module:
```js
import I18n from 'ex-react-native-i18n'
const deviceLocale = I18n.locale
```Returns `en-US`.
### 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).## Hire an expert!
Looking for a ReactNative freelance expert with more than 12 years experience? Contact me from my [website](https://xaviercarpentier.com)!