reword-js is a zero dependency, minimal translation library written in JavaScript. Working in the browser and nodejs applications, reword-js provides an easy way to translate texts either by key or text content, with possibility to add dynamic parameters.
via npm
$ npm install reword-js
via yarn
$ yarn add reword-js
As a node module
const reword = require('reword-js');
reword.config(
{
/* ...dictionary */
},
{
/* ...options */
}
);
reword.translate`Default language text`; // translated language text
reword.translateKey('someKey'); // translated language text
As an ecmascript module
import { config, translate, translateKey } from 'reword-js';
config(
{
/* ...dictionary */
},
{
/* ...options */
}
);
translate`Default language text`; // translated language text
translateKey('someKey'); // translated language text
As a script tag
<!DOCTYPE html>
<html lang="en">
<head> </head>
<body>
<script src="<path-to-the-module>/reword.umd.js"></script>
<script type="text/javascript">
reword.config(
{
/* ...dictionary */
},
{
/* ...options */
}
);
reword.translate`Default language text`; // translated language text
reword.translateKey('someKey'); // translated language text
</script>
</body>
</html>
Reword can be used as a global instance, or separate instances created manually.
Example:
import { Dictionary, config } from 'reword-js';
//initialize as a standalone instance
const reword = new Dictionary(dictionary, options);
//initialize as a global instance
config(dictionary, options);
Translating text can be acomplished in two ways. Either by key or by actual text. Reasoning behind text translation is that we have a natural fallback if translation key does not exist, interpolation also works just like a plain string which is more easier to read. Key translation is implemented for convenience as it is commonly used throughout other packages/languages.
Example:
import { translate, translateKey } from 'reword-js';
const dictionary = {
'en-US': {
example: 'Translated language text'
},
'xx-XX': {
example: 'Translated other language text'
}
};
config(dictionary, { locale: 'xx-XX' });
// Translate by text.
reword.translate`Translated language text`; // Translated language text
// Translate by key.
reword.translateKey('example'); // Translated other language text
Adding dynamic values to translations is as easy as adding them to a hard coded string. Reword will also change variable order if the destination language has them ordered differently.
Example:
import { translate, translateKey, config } from 'reword-js';
const dictionary = {
'en-US': {
example: 'Text with param {one} and param {two}'
},
'xx-XX': {
example: 'Text replaced with param {two} and param {one}'
}
};
config(dictionary, { locale: 'xx-XX' });
const one = 'Foo';
const two = 'Bar';
// Text based translation
translate`Text with param ${one} and param ${two}`; // Text replaced with param Bar and param Foo
// Key based translation
translateKey('example', one, two); // Text replaced with param Bar and param Foo
Dictionary is the primary object that holds all of the languages and translations. Must include a default language (see options object) and at least one of the translations. dictionary object can be nested as well.
Example:
const dictionary = {
// Default language which is specified in options
'en-US': {
example: 'Translated language text',
nested: {
example: 'Translated nested language text'
}
},
// One or more languages with coresponding keys.
'xx-XX': {
example: 'Translated other language text',
nested: {
example: 'Translated nested other language text'
}
}
};
config
or Dictionary
instance accepts an options
object, which is shallow merged with the default options:
defaultLocale
: Sets base locale for reword all of the translations are based on the default language (defaults toen-US
)locale
: Sets initial locale so reword know which is the destination language (defaults toen-US
)variableMatcher
: Regular expression pattern which identifies variables for interpolation (defaults to/\{(.*?)\}/g
)translationNotFoundMessage
: Content display when a translation is not found. Only applies when translating by key. (defaults toTRANSLATION_NOT_FOUND
)debug
: Debugging option which provides information on missing translations/parameters see Debugging. (defaults toproduction
when used as aumd
module and respectsprocess.env.NODE_ENV
while usingcjs
ores
modules)
Example:
import { Dictionary, config } from 'reword-js';
const dictionary = {};
const options = {
defaultLocale: 'en-US', // defaults to en-US
locale: 'es-ES'
variableMatcher: /\{(.*?)\}/g,
translationNotFoundMessage: 'Could not find any key to translate'
debug: true // or false
};
// Using with global instance
config(dictionary, options)
// Using with dedicated instance
const translations = new Dictionary(dictionary, options);
Reword public instance is initialized on module import thus contains all of the methods described in the api refrence.
Works like a constructor method, used to re-initialize the dictionary.
Changes destination language to a desired one.
Overwrites dictionary with a new one. Does not update any options.
Can be called as template string or as a regular function.
const translateString = `String with {numberOfParams}`;
translate`String with ${numberOfParams}`;
translate(translateString, numberOfParams);
A dictionary key can be provided to translate via key instead of text. If no key was found it will show text defined in the options object see Options object
translateKey('example'); // Translated text is returned;
translateKey('example', param1, param2); // Translated text with parameters returned;
reword-js provides some debugging capabilities if debug
option is enabled. see Options object.
If translation is not found reword-js will throw a console.warn
message.
Example:
When loading up dictionary it's being validated and outputs information on what's missing.
Example:
Since reword-js is not tied to the state or store in react applications, thus it does not trigger a re-render. The easiest way is to trigger a re-render when language changes is by setting a key
prop on the top most component in your React application. Once the key changes, React will re-render the DOM tree underneath.
Example:
import React, { PureComponent } from 'react';
import { config, translate, changeLocale } from 'reword-js';
class App extends PureComponent {
constructor() {
super();
config({}, { locale: this.state.locale });
}
state = {
locale: 'en-US'
};
changeLanguage = ({ target }) => {
changeLocale(target.value);
this.setState({
locale: target.value
});
};
render() {
return (
<div key={this.state.locale}>
<button onClick={this.changeLanguage} value="en-US">
English
</button>
<button onClick={this.changeLanguage} value="es-ES">
Spanish
</button>
{translate`Translated text`}
</div>
);
}
}