react-multi-language
v0.4.2
Published
Helps you create multi-language pages
Downloads
52
Maintainers
Readme
In the Name of Allah
react-multi-language
Helps you create multi-language pages.
- No server needed.
- Async support.
- No dependencies.
- Universal.
- Micro library.
Installation
Via npm:
npm install react-multi-language --save
Via yarn:
yarn add react-multi-language
API Reference
Determinator
returns a string or component.
Props:
children
:union(function, string, object)
:function
: can be an async function, the function will receive two arguments:- First is the current language, the function will be called anytime language changes(by
MultiLang
). - Second is a function which updates the currently displayed content by
Determinator
to the content that it receives according to the new language.
- First is the current language, the function will be called anytime language changes(by
string
: it will return the string with no mutation.object
: it must follow below pattern and returns the value of the matched key (based onprops.lang
ofMultiLang
).
{
[language]: [content]
}
// e.g.
{
fr: "Bonjour le monde",
en: "Hello World"
}
till
:union(component, string)
:Determinator
renders the value ofprops.till
untill the async function that is passed asprops.children
toDeterminator
update the currently displayed content.
MultiLang
must be after all the Determinators.
Props:
lang
: string
: the current language will be applied to the Determinators.
withLang
A higher-order component, it is very similar to Determinator
withLang(children)(Component)
children
:union(function, object)
:function
: can be an async function, the function will receive two arguments:- First is the current language, the function will be called anytime language changes(by
MultiLang
). - Second is a function which updates the currently displayed content to the content that it receives according to the new language.
- First is the current language, the function will be called anytime language changes(by
object
: it must follow below pattern and returns the value of the matched key (based onprops.lang
ofMultiLang
).
{
[language]: [content]
}
// e.g.
{
fr: {
Hello: "Bonjour",
World: "monde",
imageURL: "https://example.com/200x200DB570BC6-F1CA-101F-C227-37B227673AD6.jpg?lang=fr"
},
en: {
Hello: "Hello",
World: "world",
imageURL: "https://example.com/200x200DB570BC6-F1CA-101F-C227-37B227673AD6.jpg?lang=en"
}
}
The wrapped component receives three props:
lang
: the current language.langProps
: the content of the current language.determinator
: is similar toDeterminator
but it is not component and does not support functions.
determinator({children, till});
using props.determinator
rather than Determinator
is recommended.
Examples
import React, { Component } from "react";
import { MultiLang, Determinator } from "react-multilang";
class App extends Component {
state = {
lang: "en",
};
changeLang = () => {
this.setState(state => ({ lang: state.lang === "en" ? "fr" : "en" }));
};
render() {
return (
<div onClick={this.changeLang}>
<Determinator>
{{
fr: "Bonjour le monde",
en: "Hello World"
}}
</Determinator>
<Determinator till={<span>Loading...</span>}>
{async (lang, add) => {
setTimeout(() => {
if (lang == 'fr')
add("Bonjour le monde")
if (lang == 'en')
add("Hello World");
}
, 1000);
}}
</Determinator>
<Determinator>
{"Hello World"}
</Determinator>
{/*MultiLang component must be after all the Determinators*/}
<MultiLang lang={this.state.lang}/>
</div>
);
}
}
export default App;
Fetching data when needed is one of the most common use cases for async functions:
import React, { Component } from "react";
import { MultiLang, Determinator } from "react-multilang";
class App extends Component {
state = {
lang: "en",
};
changeLang = () => {
this.setState(state => ({ lang: state.lang === "en" ? "fr" : "en" }));
};
render() {
return (
<div onClick={this.changeLang}>
<Determinator till={<span>Loading...</span>}>
{async (lang, add) => {
fetch(`http://example.com/${lang}.json`)
.then(response => {
return response.json();
})
.then(json => {
add(JSON.stringify(json).content);
});
}}
</Determinator>
{/*MultiLang component must be after all the Determinators*/}
<MultiLang lang={this.state.lang}/>
</div>
);
}
}
export default App;
Using withLang
:
import React, {Component} from "react";
import {MultiLang, withLang} from "react-multilang";
const MyComponent = withLang({
fr: {
HW: "Bonjour le monde",
imageURL: "http://example.com/200x200DB570BC6-F1CA-101F-C227-37B227673AD6.jpg?lang=fr"
},
en: {
HW: "Hello World",
imageURL: "http://example.com/200x200DB570BC6-F1CA-101F-C227-37B227673AD6.jpg?lang=en"
}
})(props => (
<div>
<p>{props.lang}</p>
<p>{props.langProps.HW}</p>
<img src={props.langProps.imageURL}/>
<img src={"http://example.com/200x200DB570BC6-F1CA-101F-C227-37B227673AD6.jpg?lang=" + props.lang}/>
</div>
));
class App extends Component {
state = {
lang: "en"
};
changeLang = () => {
this.setState(state => ({
lang: state.lang === "en"
? "fr"
: "en"
}));
};
render() {
return (
<div onClick={this.changeLang}>
<MyComponent/>
<MultiLang lang={this.state.lang}/>
</div>
);
}
}
export default App;
License
MIT License