Go to file
fengmk2 eae25a474d Release 1.4.1 2015-09-18 16:16:49 +08:00
benchmark feat: Support nested locale keys. 2015-09-17 18:20:10 +08:00
test feat: Support nested locale keys. 2015-09-17 18:20:10 +08:00
.gitignore first commit 2015-05-16 22:06:49 +08:00
.jshintignore first commit 2015-05-16 22:06:49 +08:00
.jshintrc first commit 2015-05-16 22:06:49 +08:00
.travis.yml fix: merge-descriptors should be in dependencies 2015-09-15 01:07:19 +08:00
AUTHORS Release 1.2.0 2015-08-31 01:29:02 +08:00
History.md Release 1.4.1 2015-09-18 16:16:49 +08:00
LICENSE first commit 2015-05-16 22:06:49 +08:00
README.md refact(nested-data): transform nested data on load localization data. 2015-09-18 15:14:38 +08:00
index.js refact(nested-data): transform nested data on load localization data. 2015-09-18 15:14:38 +08:00
package.json Release 1.4.1 2015-09-18 16:16:49 +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.dir.
  2. resources file supports: *.js, *.json and *.properties, 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} dir: locales resources store directory. 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.
    • {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'
}));

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) }}

License

MIT