Go to file
Roger Fos Soler c46d049a5e feat: Add more debug information on a 'silly' level 2017-04-27 16:11:25 +08:00
benchmark refact(es6): use es6 syntax. 2015-09-20 14:56:19 +08:00
test feat: support header lang from localeAlias (#27) 2017-04-27 16:04:15 +08:00
.eslintignore refact(es6): use es6 syntax. 2015-09-20 14:56:19 +08:00
.eslintrc refact(es6): use es6 syntax. 2015-09-20 14:56:19 +08:00
.gitignore feat: Add more debug information on a 'silly' level 2017-04-27 16:11:25 +08:00
.travis.yml fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +08:00
AUTHORS Release 1.4.4 2015-12-23 10:46:33 +08:00
History.md Release 1.6.0 2017-04-27 16:08:30 +08:00
LICENSE fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +08:00
README.md feat: Add more debug information on a 'silly' level 2017-04-27 16:11:25 +08:00
appveyor.yml fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +08:00
index.js feat: Add more debug information on a 'silly' level 2017-04-27 16:11:25 +08:00
package.json Release 1.6.0 2017-04-27 16:08:30 +08:00

README.md

koa-locales

NPM version build status Test coverage David deps npm download

koa locales, i18n solution for koa:

  1. All locales resources location on options.dirs.
  2. resources file supports: *.js, *.json and *.properties, see examples.
  3. One api: __(key[, value, ...]).
  4. Auto detect request locale from query, cookie and header: Accept-Language.

Installation

$ npm install koa-locales --save

Quick start

var koa = require('koa');
var locales = require('koa-locales');

var app = koa();
var options = {
  dirs: [__dirname + '/locales', __dirname + '/foo/locales'],
};
locales(app, options);

API Reference

locales(app, options)

Patch locales functions to koa app.

  • {Application} app: koa app instance.
  • {Object} options: optional params.
    • {String} functionName: locale function name patch on koa context. Optional, default is __.
    • {String} dirs: locales resources store directories. Optional, default is ['$PWD/locales'].
    • {String} defaultLocale: default locale. Optional, default is en-US.
    • {String} queryField: locale field name on query. Optional, default is locale.
    • {String} cookieField: locale field name on cookie. Optional, default is locale.
    • {Object} localeAlias: locale value map. Optional, default is {}.
    • {String|Number} cookieMaxAge: set locale cookie value max age. Optional, default is 1y, expired after one year.
locales({
  app: app,
  dirs: [__dirname + '/app/locales'],
  defaultLocale: 'zh-CN',
});

Aliases

The key options.localeAlias allows to not repeat dictionary files, as you can configure to use the same file for es_ES for es, or en_UK for en.

locales({
	localeAlias: {
		es: es_ES,
		en: en_UK
	}
});

context.__(key[, value1[, value2, ...]])

Get current request locale text.

function* home() {
  this.body = {
    message: this.__('Hello, %s', 'fengmk2'),
  };
}

Examples:

__('Hello, %s. %s', 'fengmk2', 'koa rock!')
=>
'Hello fengmk2. koa rock!'

__('{0} {0} {1} {1} {1}', ['foo', 'bar'])
=>
'foo foo bar bar bar'

__('{a} {a} {b} {b} {b}', {a: 'foo', b: 'bar'})
=>
'foo foo bar bar bar'

Usage on template

this.state.__ = this.__.bind(this);

Nunjucks example:

{{ __('Hello, %s', user.name) }}

Pug example:

p= __('Hello, %s', user.name)

Koa-pug integration:

You can set the property locals on the KoaPug instance, where the default locals are stored.

app.use(async (ctx, next) => {
    koaPug.locals.__ = ctx.__.bind(ctx);
    await next()
});

Debugging

If you are interested on knowing what locale was chosen and why you can enable the debug messages from debug.

There is two level of verbosity:

$ DEBUG=koa-locales node .

With this line it only will show one line per request, with the chosen language and the origin where the locale come from (queryString, header or cookie).

$ DEBUG=koa-locales:silly node .

Use this level if something doesn't work as you expect. This is going to debug everything, including each translated line of text.

License

MIT