This is a middleware to use i18next in express.js.
Source can be loaded via npm.
# npm package
$ npm install i18next-express-middleware
var i18next = require('i18next');
var middleware = require('i18next-express-middleware');
var express = require('express');
i18next.init(i18nextOptions);
var app = express();
app.use(middleware.handle(i18next));
// in your request handler
app.get('myRoute', function(req, res) {
var lng = req.language; // 'de-CH'
var lngs = req.languages; // ['de-CH', 'de', 'en']
req.i18n.changeLanguage('en'); // will not load that!!! assert it was preloaded
var exists = req.i18n.exists('myKey');
var translation = req.t('myKey');
});
// in your views, eg. in jade
div=t('myKey')
// missing keys
app.post('/locales/add/:lng/:ns', middleware.missingKeyHandler(i18next));
// multiload backend route
app.get('/locales/resources.json', middleware.getResourcesHandler(i18next));
Detects user language from current request. Comes with support for:
- path
- cookie
- header
- querystring
- session
Wiring up:
var i18next = require('i18next');
var middleware = require('i18next-express-middleware');
i18next
.use(middleware.LanguageDetector)
.init(i18nextOptions);
As with all modules you can either pass the constructor function (class) to the i18next.use or a concrete instance.
{
// order and from where user language should be detected
order: [/*'path', 'session', */ 'querystring', 'cookie', 'header'],
// keys or params to lookup language from
lookupQuerystring: 'lng',
lookupCookie: 'i18next',
lookupSession: 'lng',
lookupFromPathIndex: 0,
// cache user language
caches: false, // ['cookie']
// optional expire and domain for set cookie
cookieExpirationDate: new Date(),
cookieDomain: 'myDomain'
}
Options can be passed in:
preferred - by setting options.detection in i18next.init:
var i18next = require('i18next');
var middleware = require('i18next-express-middleware');
i18next
.use(middleware.LngDetector)
.init({
detection: options
});
on construction:
var middleware = require('i18next-express-middleware');
var lngDetector = new middleware.LngDetector(null, options);
via calling init:
var middleware = require('i18next-express-middleware');
var lngDetector = new middleware.LngDetector();
lngDetector.init(options);
module.exports {
name: 'myDetectorsName',
lookup: function(req, res, options) {
// options -> are passed in options
return 'en';
},
cacheUserLanguage: function(req, res, lng, options) {
// options -> are passed in options
// lng -> current language, will be called after init and on changeLanguage
// store it
}
};
var i18next = require('i18next');
var middleware = require('i18next-express-middleware');
var lngDetector = new middleware.LngDetector();
lngDetector.addDetector(myDetector);
i18next
.use(lngDetector)
.init({
detection: options
});