Go to file
fengmk2 1f485fde83 fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +08:00
benchmark refact(es6): use es6 syntax. 2015-09-20 14:56:19 +08:00
test fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +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 first commit 2015-05-16 22:06:49 +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.5.1 2016-05-21 00:40:20 +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 localeAlias options 2016-03-16 20:10:34 +08:00
appveyor.yml fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +08:00
index.js fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +08:00
package.json fix: make sure signed=false on set/get cookie (#24) 2017-01-13 14:38:13 +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 cookie 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',
}));

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