Package Exports
- react-local-translations
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (react-local-translations) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
React Local Translations
This library allows you to define translations both globally for the entire app, as well as component local translations. It uses the lightweight Polyglot.js for internationalization and is really tiny (DIY)
Installation
npm install --save react-local-translationsyarn add react-local-translationsWant the benefits of global translation files? Check out
https://github.com/DeedMob/transform-translations
Uses Polyglot.js
Usage
react-local-translations exports consists for one wrapper component called I18nProvider and one decorator called translate. Depending on the arguments to translate you can expose a function t for fetching local translations, g for global translations (shared across app), setLocale for setting the locale, and getLocale for getting the locale.
You are required to wrap your root component with I18n and pass on a locale like en or fr.
And messages object containing the strings.
import React from 'react';
import { render } from 'react-dom';
import { I18nProvider, LanguageHandler } from '../lib';
import Greeter from './greeter';
const locale = ['de', 'en'][Math.floor(Math.random()*2)];
const globals = {
  "some_global": {
    en: "Hello, %{name}.",
    de: "Hallo, %{name}"
  },
  "num_cars": {
    en: "%{smart_count} car |||| %{smart_count} cars",
    de: "%{smart_count} auto |||| %{smart_count} autos"
  }
}
const localeChangeCallback = (locale) => alert(locale)
export const l = new LanguageHandler("en", ["en", "de"], localeChangeCallback);
// l.locale("de")
// l.locale() i
render(
  <I18nProvider languageHandler={l} globals={globals}>
    <Greeter name="Batsy" />
  </I18nProvider>,
  document.getElementById('app')
);Then inside App or a child component of App you can do:
import React from 'react';
import { translate } from '../lib';
import LanguageSelect from './languageSelect';
console.log(<languageSelect/>);
const translations = {
  "hello_name": {
    en: "In English, Hello Name",
    de: "Auf Deutsch, Hallo Name"
  },
  "some_key": {
    en: "blah",
    de: "irgendwas"
  }
}
const Greeter = ({ name, t, g }) => {
  return (
    <div>
      <h3>{t('hello_name')}<b>{g('some_global', { name })}</b></h3>
      <LanguageSelect/>
    </div>
  )
};
Greeter.propTypes = {
  name: React.PropTypes.string.isRequired,
  t: React.PropTypes.func.isRequired,
  g: React.PropTypes.func.isRequired
};
export default translate(translations, true)(Greeter);
Change the language
import React from 'react';
import {translate} from '../lib';
const translations = {
  english: {
    "de": "Englisch",
    "en": "English"
  },
  german: {
    "de": "Deutch",
    "en": "German"
  },
  selectLanguage: {
    de: "Bitte Sprache Waehlen",
    en: "Select a language"
  }
}
class LanguageSelect extends React.Component {
  shouldComponentUpdate(){
    return false;
  }
  render(){
    const { t, setLocale, getLocale } = this.props;
    const locale = getLocale();
    return (
      <div>
        <h1>{t("selectLanguage")}</h1>
        <select value={locale} onChange={(e) => setLocale(e.target.value)}>
          <option value="en">{t("english")}</option>
          <option value="de">{t("german")}</option>
        </select>
      </div>
    )
  }
}
export default translate(translations, false, true, true)(LanguageSelect)
translate HOC
import { translate } from 'react-local-translations'
Example: translate(translations: Object, exposeGlobal=false, exposeSetLocale=false, exposeGetLocale = false)
The translations for this component are available via the t prop.
passing true to exposeGlobal passes the g function into the React Component's props.
passing true to exposeSetLocale passes the setLocale function into the React Component's props
passing true to exposeGetLocale passes the getLocale function into the React Component's props
getLocale :: () -> string
setLocale :: string -> void
g :: (string, options) -> string
t :: (string, options) -> string
translateApi
import translations from './translations';
import { translateApi } from 'react-local-translations';
const locale = 'en';
const t = translateApi(translations, locale).t;
console.log(t('someKey'));
I18nProvider props
(initialLocale: string, globals: Object)
LanguageHandler class
constructor(initialLocale: string, supportedLanguages: Array
locale :: string -> boolean
Setter, returns true if successful (in supportedLanguages)
locale :: string
Getter, returns the current string.
registerCallback :: f -> void
Adds a callback for when the language changes. Used internally, but you can add any amount of your own callbacks.
Using the LanguageHandler class as an API
Export the instance from wherever you create it and you can call the locale setter or getter to update the current language state.
See above for an example of the translations/globals object