spa-gettext v1.4.1
STB SDK localization
This localization module is an instance of Emitter module. Contains localization messages data used by other modules and provides methods to requests these messages.
Installation
npm install spa-gettextUsage
Add to the scope:
var gettext = require('spa-gettext');Load localization messages file (./lang/ru.json):
gettext.load({name: 'ru'}, function ( error ) {
    console.log(error);
});Then it's possible to make direct calls to make simple replacement:
console.log(gettext('some line to be localized'));Fetch a particular translation of the textual message:
console.log(pgettext('some context', 'some text'));Native language translation of a textual message whose grammatical form depends on a number:
console.log(ngettext('{0} cat', '{0} cats', 1));It's also possible to listen to instance events (load and error):
gettext.addListener('load', function () {
    // handle localization loading
});
gettext.addListener('error', function () {
    // handle localization loading
});On localization loading for en language real AJAX request is not executed.
There is loader.defaultLanguage option to control this behaviour.
Development mode
There is a global var
DEVELOPwhich activates additional consistency checks and protection logic not available in release mode.
Contribution
If you have any problem or suggestion please open an issue here. Pull requests are welcomed with respect to the JavaScript Code Style.
License
spa-gettext is released under the MIT License.