redux-translations
v2.0.0
Published
translations utils for react-redux apps
Downloads
28
Readme
redux-translations
Translations utils for react-redux apps
Install
npm i redux-translations
Usage
Translations middleware
Create and config translations middleware and apply it.
import { createTranslationsMiddleware } from 'redux-translations';
// Change this function to yours
const functionThatReturnsPromiseWithDictionary = language =>
Promise.resolve(
language === 'en' ? { hello: 'Hello!' } : { hello: 'Привет!' }
);
const translationsMiddleware = createTranslationsMiddleware(
functionThatReturnsPromiseWithDictionary
);
const store = createStore(rootReducer, applyMiddleware(translationsMiddleware));
Translations props
Wrap component with withTranslations
function:
import withTranslations from 'redux-translations';
const MyComponent = ({
dictionary,
currentLang,
loadingLang,
switchLang,
}) =>
<div>
Translated text: { dictionary['hello'] }
<br />
Current language: { currentLang }
<br />
Loading language: { loadingLang }
<button
onClick={ () => switchLang('en') }
>English</button>
<br />
<button
onClick={ () => switchLang('ru') }
>Russian</button>
</div>
const MyComponentTranslated = withTranslations(MyComponent);
You can change language not only in react-component:
import { switchLangActionCreator } from 'redux-translations';
store.dispatch(switchLangActionCreator('en'));
API
createTranslationsMiddleware(getDictionary, [options], [initialState])
Function, that creates redux-middleware for translations. Has next arguments:
getDictionary
(Function) - function with one argument type ofstring
- language, that user is switching to, and returns promise withdictionary
object.[options]
(Object) - options object with next optional fields:
cache
(Boolean) - should cache results ofgetDictionary
, and do not call it if dictionary is already loaded. Defaulttrue
.updateCacheOnSwitch
(Boolean) - whencache
istrue
, should switch immediately to cached dictionary, but load dictionary in background one more time and replace old with the new one. Defaultfalse
.startSwitchCallback
(Function) - callback for every language switching start. Run exactly in switch event, without waiting for fetching dictionary. Takes next arguments:loadingLang
(String) andstore
. Defaultundefined
.endSwitchCallback
(Function) - callback for every language switching end. Run exactly after fetching dictionary. Takes next arguments:loadedLang
(String),dictionary
(Object) andstore
. Defaultundefined
.
[initialState]
(Object) - initial inner state object with next optional fields:
dictionaries
(Object) - hash-table of dictionaries, where key is language name and value is dictionary. Default{}
.currentLang
(String) - current language with fetched dictionary. Defaultnull
.loadingLang
(String) - language that user is switching to, but not fetched dictionary yet. Defaultnull
.
withTranslations(Component, [copyStaticMethods])
React component class wrapper that adds next props to wrapping component class (actually it returns new component class):
currentLang
(String) - language, which dictionary is currently using.loadingLang
(String) - language, which dictionary is currently loading.dictionary
(Object) - object, that is returned bygetDictionary
.switchLang
(Function) - function, that switch language to passed one.
Arguments:
Component
(Function) - component that depends on props, listed above.copyStaticMethods
(Boolean) - whether to copy static methods of Component or not. Defaulttrue
.
switchLangActionCreator(language)
Redux action creator - function with one argument type of string
, returns flux standard action (FSA), that you can dispatch whereever in your app (for example, when initialising your app).
patchState(changes, [updateComponents])
Patch translations inner state without dispatching redux action. Could be useful for server-side rendering or another cases where store.dispatch
function is unreachable. Returns Promise, resolved when all components are updated (if updateComponents === true) or immediately. Has next arguments:
changes
(Object) - partial initial inner state object with next optional fields:
dictionaries
(Object) - hash-table of dictionaries, where key is language name and value is dictionary.currentLang
(String) - current language with fetched dictionary.loadingLang
(String) - language that user is switching to, but not fetched dictionary yet.
updateComponents
(Boolean) - whether to update components or not.