@iqoption/affiliate-redux-translations v2.0.2
redux-translations
Translations utils for react-redux apps
Install
npm i @iqoption/affiliate-redux-translationsUsage
Translations middleware
Create and config translations middleware and apply it.
import { createTranslationsMiddleware } from "@iqoption/affiliate-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 "@iqoption/affiliate-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 "@iqoption/affiliate-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 withdictionaryobject.[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) - whencacheistrue, 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.