Package detail

koa-locales

koajs108.1kMIT1.12.0

koa locales, i18n solution for koa

koa-locales, i18n, locales, koa-i18n

readme

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

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

const app = koa();
const 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.
    • {String} cookieDomain: domain on cookie. Optional, default is ''.
    • {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.

async function home(ctx) {
  ctx.body = {
    message: ctx.__('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'

context.__getLocale()

Get locale from query / cookie and header.

context.setLocale()

Set locale and cookie.

context.__getLocaleOrigin()

Where does locale come from, could be query, cookie, header and default.

app.__(locale, key[, value1[, value2, ...]])

Get the given locale text on application level.

console.log(app.__('zh', 'Hello'));
// stdout '你好' for Chinese

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

changelog

1.12.0 / 2019-06-16

features

1.11.0 / 2019-04-30

features

1.10.0 / 2019-04-29

features

1.9.0 / 2019-04-17

features

1.8.0 / 2018-01-12

features

1.7.0 / 2017-04-27

  • feat: Add more debug information on a 'silly' level

1.6.0 / 2017-04-27

  • feat: support header lang from localeAlias (#27)

1.5.2 / 2017-01-13

  • fix: make sure signed=false on set/get cookie (#24)

1.5.1 / 2016-05-21

  • deps: humanize-ms@1.2.0, use ^ (#22)

1.5.0 / 2016-03-16

  • feat: add localeAlias options
  • chore(package): update benchmark to version 2.0.0

1.4.4 / 2015-12-23

  • fix: return empty if the key-value is empty value

1.4.3 / 2015-12-09

  • fix: if header sent, don't set the cookie
  • doc(options.dirs): fix api doc

1.4.2 / 2015-09-20

  • refact(es6): use es6 syntax.

1.4.1 / 2015-09-18

  • refact(nested-data): transform nested data on load localization data.

1.4.0 / 2015-09-17

  • feat: Support nested locale keys.

1.3.1 / 2015-09-15

  • fix: merge-descriptors should be in dependencies

1.3.0 / 2015-09-14

  • feat: Multiple locale paths support.
  • refact(apply): apply is not too slow than direct call. fixed #2

1.2.0 / 2015-08-31

  • refact(endsWith): endsWith is fast than regexp
  • revert slice arguments to args

1.1.0 / 2015-08-31

  • feat: paramter support object
  • refact: arguments to array.
  • optimize use regexp without caught group

1.0.2 / 2015-05-17

  • feat: support *.properties resource files

1.0.1 / 2015-05-16

  • Optimization killers

1.0.0 / 2015-05-16

  • first release