@eggjs/i18n 3.0.0 → 4.0.0-beta.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/README.md +10 -18
  2. package/dist/app/extend/application.d.ts +12 -0
  3. package/dist/app/extend/application.js +48 -0
  4. package/dist/app/extend/context.d.ts +76 -0
  5. package/dist/app/extend/context.js +152 -0
  6. package/dist/{commonjs/app.d.ts → app.d.ts} +10 -8
  7. package/dist/app.js +96 -0
  8. package/{src/types.ts → dist/config/config.default.d.ts} +7 -33
  9. package/dist/config/config.default.js +15 -0
  10. package/dist/index.d.ts +1 -0
  11. package/dist/index.js +4 -0
  12. package/dist/locales.d.ts +7 -0
  13. package/dist/locales.js +53 -0
  14. package/dist/types.d.ts +29 -0
  15. package/dist/types.js +1 -0
  16. package/dist/utils.d.ts +5 -0
  17. package/dist/utils.js +10 -0
  18. package/package.json +54 -73
  19. package/dist/commonjs/app/extend/application.d.ts +0 -8
  20. package/dist/commonjs/app/extend/application.js +0 -80
  21. package/dist/commonjs/app/extend/context.d.ts +0 -72
  22. package/dist/commonjs/app/extend/context.js +0 -177
  23. package/dist/commonjs/app.js +0 -95
  24. package/dist/commonjs/config/config.default.d.ts +0 -5
  25. package/dist/commonjs/config/config.default.js +0 -16
  26. package/dist/commonjs/index.d.ts +0 -1
  27. package/dist/commonjs/index.js +0 -4
  28. package/dist/commonjs/locales.d.ts +0 -3
  29. package/dist/commonjs/locales.js +0 -71
  30. package/dist/commonjs/package.json +0 -3
  31. package/dist/commonjs/types.d.ts +0 -74
  32. package/dist/commonjs/types.js +0 -3
  33. package/dist/commonjs/utils.d.ts +0 -2
  34. package/dist/commonjs/utils.js +0 -12
  35. package/dist/esm/app/extend/application.d.ts +0 -8
  36. package/dist/esm/app/extend/application.js +0 -76
  37. package/dist/esm/app/extend/context.d.ts +0 -72
  38. package/dist/esm/app/extend/context.js +0 -174
  39. package/dist/esm/app.d.ts +0 -56
  40. package/dist/esm/app.js +0 -89
  41. package/dist/esm/config/config.default.d.ts +0 -5
  42. package/dist/esm/config/config.default.js +0 -14
  43. package/dist/esm/index.d.ts +0 -1
  44. package/dist/esm/index.js +0 -2
  45. package/dist/esm/locales.d.ts +0 -3
  46. package/dist/esm/locales.js +0 -65
  47. package/dist/esm/package.json +0 -3
  48. package/dist/esm/types.d.ts +0 -74
  49. package/dist/esm/types.js +0 -2
  50. package/dist/esm/utils.d.ts +0 -2
  51. package/dist/esm/utils.js +0 -8
  52. package/dist/package.json +0 -4
  53. package/src/app/extend/application.ts +0 -91
  54. package/src/app/extend/context.ts +0 -192
  55. package/src/app.ts +0 -99
  56. package/src/config/config.default.ts +0 -15
  57. package/src/index.ts +0 -1
  58. package/src/locales.ts +0 -73
  59. package/src/typings/index.d.ts +0 -4
  60. package/src/utils.ts +0 -8
@@ -1,71 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.loadLocaleResources = loadLocaleResources;
7
- const node_util_1 = require("node:util");
8
- const promises_1 = __importDefault(require("node:fs/promises"));
9
- const node_path_1 = __importDefault(require("node:path"));
10
- const ini_1 = __importDefault(require("ini"));
11
- const js_yaml_1 = __importDefault(require("js-yaml"));
12
- const utility_1 = require("utility");
13
- const utils_1 = require("@eggjs/utils");
14
- const application_js_1 = require("./app/extend/application.js");
15
- const utils_js_1 = require("./utils.js");
16
- const debug = (0, node_util_1.debuglog)('@eggjs/i18n/locales');
17
- async function loadLocaleResources(app, options) {
18
- const localeDirs = options.dirs;
19
- const resources = {};
20
- if (options.dir && !localeDirs.includes(options.dir)) {
21
- localeDirs.push(options.dir);
22
- }
23
- for (const dir of localeDirs) {
24
- if (!(await (0, utility_1.exists)(dir))) {
25
- continue;
26
- }
27
- const names = await promises_1.default.readdir(dir);
28
- for (const name of names) {
29
- const filepath = node_path_1.default.join(dir, name);
30
- // support en_US.js => en-US.js
31
- const locale = (0, utils_js_1.formatLocale)(name.split('.')[0]);
32
- let resource = {};
33
- if (name.endsWith('.js') || name.endsWith('.ts')) {
34
- resource = flattening(await (0, utils_1.importModule)(filepath, {
35
- importDefaultOnly: true,
36
- }));
37
- }
38
- else if (name.endsWith('.json')) {
39
- resource = flattening(await (0, utility_1.readJSON)(filepath));
40
- }
41
- else if (name.endsWith('.properties')) {
42
- resource = ini_1.default.parse(await promises_1.default.readFile(filepath, 'utf8'));
43
- }
44
- else if (name.endsWith('.yml') || name.endsWith('.yaml')) {
45
- resource = flattening(js_yaml_1.default.load(await promises_1.default.readFile(filepath, 'utf8')));
46
- }
47
- resources[locale] = resources[locale] || {};
48
- Object.assign(resources[locale], resource);
49
- }
50
- }
51
- debug('Init locales with %j, got %j resources', options, Object.keys(resources));
52
- app[application_js_1.I18N_RESOURCES] = resources;
53
- }
54
- function flattening(data) {
55
- const result = {};
56
- function deepFlat(data, prefix) {
57
- for (const key in data) {
58
- const value = data[key];
59
- const k = prefix ? prefix + '.' + key : key;
60
- if ((0, utils_js_1.isObject)(value)) {
61
- deepFlat(value, k);
62
- }
63
- else {
64
- result[k] = String(value);
65
- }
66
- }
67
- }
68
- deepFlat(data, '');
69
- return result;
70
- }
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9sb2NhbGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBYUEsa0RBdUNDO0FBcERELHlDQUFxQztBQUNyQyxnRUFBa0M7QUFDbEMsMERBQTZCO0FBQzdCLDhDQUFzQjtBQUN0QixzREFBMkI7QUFDM0IscUNBQTJDO0FBQzNDLHdDQUE0QztBQUU1QyxnRUFBOEU7QUFDOUUseUNBQW9EO0FBRXBELE1BQU0sS0FBSyxHQUFHLElBQUEsb0JBQVEsRUFBQyxxQkFBcUIsQ0FBQyxDQUFDO0FBRXZDLEtBQUssVUFBVSxtQkFBbUIsQ0FBQyxHQUFvQixFQUFFLE9BQW1CO0lBQ2pGLE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUM7SUFDaEMsTUFBTSxTQUFTLEdBQTJDLEVBQUUsQ0FBQztJQUU3RCxJQUFJLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3JELFVBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxLQUFLLE1BQU0sR0FBRyxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQzdCLElBQUksQ0FBQyxDQUFDLE1BQU0sSUFBQSxnQkFBTSxFQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUN6QixTQUFTO1FBQ1gsQ0FBQztRQUVELE1BQU0sS0FBSyxHQUFHLE1BQU0sa0JBQUUsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDcEMsS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUN6QixNQUFNLFFBQVEsR0FBRyxtQkFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDdEMsK0JBQStCO1lBQy9CLE1BQU0sTUFBTSxHQUFHLElBQUEsdUJB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
@@ -1,3 +0,0 @@
1
- {
2
- "type": "commonjs"
3
- }
@@ -1,74 +0,0 @@
1
- /**
2
- * I18n options
3
- * @member Config#i18n
4
- */
5
- export interface I18nConfig {
6
- /**
7
- * 默认语言是美式英语,毕竟支持多语言,基本都是以英语为母板
8
- * 默认值是 `en_US`
9
- */
10
- defaultLocale: string;
11
- /**
12
- * 多语言资源文件存放路径,不建议修改
13
- * 默认值是 `[]`
14
- */
15
- dirs: string[];
16
- /**
17
- * @deprecated please use `dirs` instead
18
- */
19
- dir?: string;
20
- /**
21
- * 设置当前语言的 query 参数字段名,默认通过 `query.locale` 获取
22
- * 如果你想修改为 `query.lang`,那么请通过修改此配置实现
23
- * 默认值是 `locale`
24
- */
25
- queryField: string;
26
- /**
27
- * 如果当前请求用户语言有变化,都会设置到 cookie 中保持着,
28
- * 默认是存储在key 为 locale 的 cookie 中
29
- * 默认值是 `locale`
30
- */
31
- cookieField: string;
32
- /**
33
- * 存储 locale 的 cookie domain 配置,默认不设置,为当前域名才有效
34
- * 默认值是 `''`
35
- */
36
- cookieDomain: string;
37
- /**
38
- * cookie 默认一年后过期,如果设置为 Number,则单位为 ms
39
- * 默认值是 `'1y'`
40
- */
41
- cookieMaxAge: string | number;
42
- /**
43
- * locale 别名,比如 zh_CN => cn
44
- * 默认值是 `{}`
45
- */
46
- localeAlias: Record<string, string>;
47
- /**
48
- * 是否写入 cookie
49
- * 默认值是 `true`
50
- */
51
- writeCookie: boolean;
52
- }
53
- declare module '@eggjs/core' {
54
- interface EggAppConfig {
55
- i18n: I18nConfig;
56
- }
57
- interface Context {
58
- /**
59
- * get and set current request locale
60
- * @member Context#locale
61
- * @return {String} lower case locale string, e.g.: 'zh-cn', 'en-us'
62
- */
63
- locale: string;
64
- gettext(key: string, value?: any, ...args: any[]): string;
65
- __(key: string, value?: any, ...args: any[]): string;
66
- __getLocale(): string;
67
- __setLocale(l: string): void;
68
- }
69
- interface EggCore {
70
- isSupportLocale(locale: string): boolean;
71
- gettext(locale: string, key: string, value?: any, ...args: any[]): string;
72
- __(locale: string, key: string, value?: any, ...args: any[]): string;
73
- }
74
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -1,2 +0,0 @@
1
- export declare function isObject(obj: any): boolean;
2
- export declare function formatLocale(locale: string): string;
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isObject = isObject;
4
- exports.formatLocale = formatLocale;
5
- function isObject(obj) {
6
- return Object.prototype.toString.call(obj) === '[object Object]';
7
- }
8
- function formatLocale(locale) {
9
- // support zh_CN, en_US => zh-CN, en-US
10
- return locale.replace('_', '-').toLowerCase();
11
- }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw0QkFFQztBQUVELG9DQUdDO0FBUEQsU0FBZ0IsUUFBUSxDQUFDLEdBQVE7SUFDL0IsT0FBTyxNQUFNLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssaUJBQWlCLENBQUM7QUFDbkUsQ0FBQztBQUVELFNBQWdCLFlBQVksQ0FBQyxNQUFjO0lBQ3pDLHVDQUF1QztJQUN2QyxPQUFPLE1BQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO0FBQ2hELENBQUMifQ==
@@ -1,8 +0,0 @@
1
- import { EggCore } from '@eggjs/core';
2
- export declare const I18N_RESOURCES: unique symbol;
3
- export default class I18nApplication extends EggCore {
4
- [I18N_RESOURCES]: Record<string, Record<string, string>>;
5
- isSupportLocale(locale: string): boolean;
6
- gettext(locale: string, key: string, value?: any, ...args: any[]): string;
7
- __(locale: string, key: string, value?: any, ...args: any[]): string;
8
- }
@@ -1,76 +0,0 @@
1
- import { debuglog, format } from 'node:util';
2
- import { EggCore } from '@eggjs/core';
3
- import { isObject } from '../../utils.js';
4
- const debug = debuglog('@eggjs/i18n/app/extend/application');
5
- export const I18N_RESOURCES = Symbol('Application i18n resources');
6
- export default class I18nApplication extends EggCore {
7
- isSupportLocale(locale) {
8
- return !!this[I18N_RESOURCES][locale];
9
- }
10
- gettext(locale, key, value, ...args) {
11
- if (!locale || !key) {
12
- // __()
13
- // __('en')
14
- return '';
15
- }
16
- const resource = this[I18N_RESOURCES][locale] || {};
17
- let text = resource[key];
18
- if (text === undefined) {
19
- text = key;
20
- }
21
- debug('%s: %j => %j', locale, key, text);
22
- if (!text) {
23
- return '';
24
- }
25
- if (value === undefined) {
26
- // __(locale, key)
27
- return text;
28
- }
29
- if (args.length === 0) {
30
- if (isObject(value)) {
31
- // __(locale, key, object)
32
- // __('zh', '{a} {b} {b} {a}', {a: 'foo', b: 'bar'})
33
- // =>
34
- // foo bar bar foo
35
- return formatWithObject(text, value);
36
- }
37
- if (Array.isArray(value)) {
38
- // __(locale, key, array)
39
- // __('zh', '{0} {1} {1} {0}', ['foo', 'bar'])
40
- // =>
41
- // foo bar bar foo
42
- return formatWithArray(text, value);
43
- }
44
- // __(locale, key, value)
45
- return format(text, value);
46
- }
47
- // __(locale, key, value1, ...)
48
- return format(text, value, ...args);
49
- }
50
- __(locale, key, value, ...args) {
51
- return this.gettext(locale, key, value, ...args);
52
- }
53
- }
54
- const ARRAY_INDEX_RE = /\{(\d+)\}/g;
55
- function formatWithArray(text, values) {
56
- return text.replace(ARRAY_INDEX_RE, (original, matched) => {
57
- const index = parseInt(matched);
58
- if (index < values.length) {
59
- return values[index];
60
- }
61
- // not match index, return original text
62
- return original;
63
- });
64
- }
65
- const Object_INDEX_RE = /\{(.+?)\}/g;
66
- function formatWithObject(text, values) {
67
- return text.replace(Object_INDEX_RE, (original, matched) => {
68
- const value = values[matched];
69
- if (value) {
70
- return value;
71
- }
72
- // not match index, return original text
73
- return original;
74
- });
75
- }
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hcHBsaWNhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM3QyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3RDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUxQyxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsb0NBQW9DLENBQUMsQ0FBQztBQUU3RCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDLDRCQUE0QixDQUFDLENBQUM7QUFFbkUsTUFBTSxDQUFDLE9BQU8sT0FBTyxlQUFnQixTQUFRLE9BQU87SUFHbEQsZUFBZSxDQUFDLE1BQWM7UUFDNUIsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCxPQUFPLENBQUMsTUFBYyxFQUFFLEdBQVcsRUFBRSxLQUFXLEVBQUUsR0FBRyxJQUFXO1FBQzlELElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNwQixPQUFPO1lBQ1AsV0FBVztZQUNYLE9BQU8sRUFBRSxDQUFDO1FBQ1osQ0FBQztRQUVELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7UUFFcEQsSUFBSSxJQUFJLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3pCLElBQUksSUFBSSxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ3ZCLElBQUksR0FBRyxHQUFHLENBQUM7UUFDYixDQUFDO1FBRUQsS0FBSyxDQUFDLGNBQWMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNWLE9BQU8sRUFBRSxDQUFDO1FBQ1osQ0FBQztRQUVELElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ3hCLGtCQUFrQjtZQUNsQixPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdEIsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztnQkFDcEIsMEJBQTBCO2dCQUMxQixvREFBb0Q7Z0JBQ3BELEtBQUs7Z0JBQ0wsa0JBQWtCO2dCQUNsQixPQUFPLGdCQUFnQixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztZQUN2QyxDQUFDO1lBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQ3pCLHlCQUF5QjtnQkFDekIsOENBQThDO2dCQUM5QyxLQUFLO2dCQUNMLGtCQUFrQjtnQkFDbEIsT0FBTyxlQUFlLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3RDLENBQUM7WUFFRCx5QkFBeUI7WUFDekIsT0FBTyxNQUFNLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzdCLENBQUM7UUFFRCwrQkFBK0I7UUFDL0IsT0FBTyxNQUFNLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxFQUFFLENBQUMsTUFBYyxFQUFFLEdBQVcsRUFBRSxLQUFXLEVBQUUsR0FBRyxJQUFXO1FBQ3pELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFDO0lBQ25ELENBQUM7Q0FDRjtBQUVELE1BQU0sY0FBYyxHQUFHLFlBQVksQ0FBQztBQUNwQyxTQUFTLGVBQWUsQ0FBQyxJQUFZLEVBQUUsTUFBYTtJQUNsRCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUMsUUFBUSxFQUFFLE9BQU8sRUFBRSxFQUFFO1FBQ3hELE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNoQyxJQUFJLEtBQUssR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDMUIsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkIsQ0FBQztRQUNELHdDQUF3QztRQUN4QyxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUM7QUFDckMsU0FBUyxnQkFBZ0IsQ0FBQyxJQUFZLEVBQUUsTUFBMkI7SUFDakUsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRSxDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUsRUFBRTtRQUN6RCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDOUIsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUNELHdDQUF3QztRQUN4QyxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMifQ==
@@ -1,72 +0,0 @@
1
- import { Context } from '@eggjs/core';
2
- export default class I18nContext extends Context {
3
- /**
4
- * get current request locale
5
- * @member Context#locale
6
- * @return {String} lower case locale string, e.g.: 'zh-cn', 'en-us'
7
- */
8
- get locale(): string;
9
- set locale(l: string);
10
- /**
11
- * `ctx.__` 的别名。
12
- * @see {@link Context#__}
13
- * @function Context#gettext
14
- */
15
- gettext(key: string, value?: any, ...args: any[]): string;
16
- /**
17
- * 如果开启了 I18n 多语言功能,那么会出现此 API,通过它可以获取到当前请求对应的本地化数据。
18
- *
19
- * 详细使用说明,请查看 {@link I18n}
20
- * - `ctx.__ = function (key, value[, value2, ...])`: 类似 `util.format` 接口
21
- * - `ctx.__ = function (key, values)`: 支持数组下标占位符方式,如
22
- * - `__` 的别名是 `gettext(key, value)`
23
- *
24
- * > NOTE: __ 是两个下划线哦!
25
- * @function Context#__
26
- * @example
27
- * ```js
28
- * ctx.__('{0} {0} {1} {1}'), ['foo', 'bar'])
29
- * ctx.gettext('{0} {0} {1} {1}'), ['foo', 'bar'])
30
- * =>
31
- * foo foo bar bar
32
- * ```
33
- * ##### Controller 下的使用示例
34
- *
35
- * ```js
36
- * module.exports = function* () {
37
- * this.body = {
38
- * message: this.__('Welcome back, %s!', this.user.name),
39
- * // 或者使用 gettext,如果觉得 __ 不好看的话
40
- * // message: this.gettext('Welcome back, %s!', this.user.name),
41
- * user: this.user,
42
- * };
43
- * };
44
- * ```
45
- *
46
- * ##### View 文件下的使用示例
47
- *
48
- * ```html
49
- * <li>{{ __('Email') }}: {{ user.email }}</li>
50
- * <li>
51
- * {{ __('Hello %s, how are you today?', user.name) }}
52
- * </li>
53
- * <li>
54
- * {{ __('{0} {0} {1} {1}'), ['foo', 'bar']) }}
55
- * </li>
56
- * ```
57
- *
58
- * ##### locale 参数获取途径
59
- *
60
- * 优先级从上到下:
61
- *
62
- * - query: `/?locale=en-US`
63
- * - cookie: `locale=zh-TW`
64
- * - header: `Accept-Language: zh-CN,zh;q=0.5`
65
- */
66
- __(key: string, value?: any, ...args: any[]): string;
67
- __locale: string;
68
- __getLocale(): string;
69
- __localeOrigin: string;
70
- __getLocaleOrigin(): string;
71
- __setLocale(locale: string): void;
72
- }
@@ -1,174 +0,0 @@
1
- import { debuglog } from 'node:util';
2
- import { Context } from '@eggjs/core';
3
- import { formatLocale } from '../../utils.js';
4
- const debug = debuglog('@eggjs/i18n/app/extend/context');
5
- export default class I18nContext extends Context {
6
- /**
7
- * get current request locale
8
- * @member Context#locale
9
- * @return {String} lower case locale string, e.g.: 'zh-cn', 'en-us'
10
- */
11
- get locale() {
12
- return this.__getLocale();
13
- }
14
- set locale(l) {
15
- this.__setLocale(l);
16
- }
17
- /**
18
- * `ctx.__` 的别名。
19
- * @see {@link Context#__}
20
- * @function Context#gettext
21
- */
22
- gettext(key, value, ...args) {
23
- return this.app.gettext(this.locale, key, value, ...args);
24
- }
25
- /**
26
- * 如果开启了 I18n 多语言功能,那么会出现此 API,通过它可以获取到当前请求对应的本地化数据。
27
- *
28
- * 详细使用说明,请查看 {@link I18n}
29
- * - `ctx.__ = function (key, value[, value2, ...])`: 类似 `util.format` 接口
30
- * - `ctx.__ = function (key, values)`: 支持数组下标占位符方式,如
31
- * - `__` 的别名是 `gettext(key, value)`
32
- *
33
- * > NOTE: __ 是两个下划线哦!
34
- * @function Context#__
35
- * @example
36
- * ```js
37
- * ctx.__('{0} {0} {1} {1}'), ['foo', 'bar'])
38
- * ctx.gettext('{0} {0} {1} {1}'), ['foo', 'bar'])
39
- * =>
40
- * foo foo bar bar
41
- * ```
42
- * ##### Controller 下的使用示例
43
- *
44
- * ```js
45
- * module.exports = function* () {
46
- * this.body = {
47
- * message: this.__('Welcome back, %s!', this.user.name),
48
- * // 或者使用 gettext,如果觉得 __ 不好看的话
49
- * // message: this.gettext('Welcome back, %s!', this.user.name),
50
- * user: this.user,
51
- * };
52
- * };
53
- * ```
54
- *
55
- * ##### View 文件下的使用示例
56
- *
57
- * ```html
58
- * <li>{{ __('Email') }}: {{ user.email }}</li>
59
- * <li>
60
- * {{ __('Hello %s, how are you today?', user.name) }}
61
- * </li>
62
- * <li>
63
- * {{ __('{0} {0} {1} {1}'), ['foo', 'bar']) }}
64
- * </li>
65
- * ```
66
- *
67
- * ##### locale 参数获取途径
68
- *
69
- * 优先级从上到下:
70
- *
71
- * - query: `/?locale=en-US`
72
- * - cookie: `locale=zh-TW`
73
- * - header: `Accept-Language: zh-CN,zh;q=0.5`
74
- */
75
- __(key, value, ...args) {
76
- return this.gettext(key, value, ...args);
77
- }
78
- // 1. query: /?locale=en-US
79
- // 2. cookie: locale=zh-TW
80
- // 3. header: Accept-Language: zh-CN,zh;q=0.5
81
- __getLocale() {
82
- if (this.__locale) {
83
- return this.__locale;
84
- }
85
- const { localeAlias, defaultLocale, cookieField, queryField, writeCookie } = this.app.config.i18n;
86
- const cookieLocale = this.cookies.get(cookieField, { signed: false });
87
- // 1. Query
88
- let locale = this.query[queryField];
89
- let localeOrigin = 'query';
90
- // 2. Cookie
91
- if (!locale) {
92
- locale = cookieLocale;
93
- localeOrigin = 'cookie';
94
- }
95
- // 3. Header
96
- if (!locale) {
97
- // Accept-Language: zh-CN,zh;q=0.5
98
- // Accept-Language: zh-CN
99
- let languages = this.acceptsLanguages();
100
- if (languages) {
101
- if (Array.isArray(languages)) {
102
- if (languages[0] === '*') {
103
- languages = languages.slice(1);
104
- }
105
- if (languages.length > 0) {
106
- for (const l of languages) {
107
- const lang = formatLocale(l);
108
- if (this.app.isSupportLocale(lang) || localeAlias[lang]) {
109
- locale = lang;
110
- localeOrigin = 'header';
111
- break;
112
- }
113
- }
114
- }
115
- }
116
- else {
117
- locale = languages;
118
- localeOrigin = 'header';
119
- }
120
- }
121
- // all missing, set it to defaultLocale
122
- if (!locale) {
123
- locale = defaultLocale;
124
- localeOrigin = 'default';
125
- }
126
- }
127
- // cookie alias
128
- if (locale in localeAlias) {
129
- const originalLocale = locale;
130
- locale = localeAlias[locale];
131
- debug('Used alias, received %s but using %s', originalLocale, locale);
132
- }
133
- locale = formatLocale(locale);
134
- // validate locale
135
- if (!this.app.isSupportLocale(locale)) {
136
- debug('Locale %s is not supported. Using default (%s)', locale, defaultLocale);
137
- locale = defaultLocale;
138
- }
139
- // if header not send, set the locale cookie
140
- if (writeCookie && cookieLocale !== locale && !this.headerSent) {
141
- updateCookie(this, locale);
142
- }
143
- debug('Locale: %s from %s', locale, localeOrigin);
144
- this.__locale = locale;
145
- this.__localeOrigin = localeOrigin;
146
- return locale;
147
- }
148
- __getLocaleOrigin() {
149
- if (this.__localeOrigin) {
150
- return this.__localeOrigin;
151
- }
152
- this.__getLocale();
153
- return this.__localeOrigin;
154
- }
155
- __setLocale(locale) {
156
- this.__locale = locale;
157
- this.__localeOrigin = 'set';
158
- updateCookie(this, locale);
159
- }
160
- }
161
- function updateCookie(ctx, locale) {
162
- const { cookieMaxAge, cookieField, cookieDomain } = ctx.app.config.i18n;
163
- const cookieOptions = {
164
- // make sure browser javascript can read the cookie
165
- httpOnly: false,
166
- maxAge: cookieMaxAge,
167
- signed: false,
168
- domain: cookieDomain,
169
- overwrite: true,
170
- };
171
- ctx.cookies.set(cookieField, locale, cookieOptions);
172
- debug('Saved cookie with locale %s, options: %j', locale, cookieOptions);
173
- }
174
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcHAvZXh0ZW5kL2NvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUNyQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3RDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU5QyxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztBQUV6RCxNQUFNLENBQUMsT0FBTyxPQUFPLFdBQVksU0FBUSxPQUFPO0lBQzlDOzs7O09BSUc7SUFDSCxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsSUFBSSxNQUFNLENBQUMsQ0FBUztRQUNsQixJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsT0FBTyxDQUFDLEdBQVcsRUFBRSxLQUFXLEVBQUUsR0FBRyxJQUFXO1FBQzlDLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsS0FBSyxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O09BaURHO0lBQ0gsRUFBRSxDQUFDLEdBQVcsRUFBRSxLQUFXLEVBQUUsR0FBRyxJQUFXO1FBQ3pDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUdELDJCQUEyQjtJQUMzQiwwQkFBMEI7SUFDMUIsNkNBQTZDO0lBQzdDLFdBQVc7UUFDVCxJ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
package/dist/esm/app.d.ts DELETED
@@ -1,56 +0,0 @@
1
- import type { ILifecycleBoot } from '@eggjs/core';
2
- import type I18nApplication from './app/extend/application.js';
3
- /**
4
- * I18n 国际化
5
- *
6
- * 通过设置 Plugin 配置 `i18n: true`,开启多语言支持。
7
- *
8
- * #### 语言文件存储路径
9
- *
10
- * 统一存放在 `config/locale/*.js` 下( 兼容`config/locales/*.js` ),如包含英文,简体中文,繁体中文的语言文件:
11
- *
12
- * ```
13
- * - config/locale/
14
- * - en-US.js
15
- * - zh-CN.js
16
- * - zh-TW.js
17
- * ```
18
- * @class I18n
19
- * @param {App} app Application object.
20
- * @example
21
- *
22
- * #### I18n 文件内容
23
- *
24
- * ```js
25
- * // config/locale/zh-CN.js
26
- * module.exports = {
27
- * "Email": "邮箱",
28
- * "Welcome back, %s!": "欢迎回来, %s!",
29
- * "Hello %s, how are you today?": "你好 %s, 今天过得咋样?",
30
- * };
31
- * ```
32
- *
33
- * ```js
34
- * // config/locale/en-US.js
35
- * module.exports = {
36
- * "Email": "Email",
37
- * };
38
- * ```
39
- * 或者也可以用 JSON 格式的文件:
40
- *
41
- * ```js
42
- * // config/locale/zh-CN.json
43
- * {
44
- * "email": "邮箱",
45
- * "login": "帐号",
46
- * "createdAt": "注册时间"
47
- * }
48
- * ```
49
- */
50
- export default class I18n implements ILifecycleBoot {
51
- private readonly app;
52
- constructor(app: I18nApplication & {
53
- locals: Record<string, any>;
54
- });
55
- didLoad(): Promise<void>;
56
- }
package/dist/esm/app.js DELETED
@@ -1,89 +0,0 @@
1
- import path from 'node:path';
2
- import { debuglog } from 'node:util';
3
- import { loadLocaleResources } from './locales.js';
4
- import { exists } from 'utility';
5
- import { ms } from 'humanize-ms';
6
- import { formatLocale } from './utils.js';
7
- const debug = debuglog('@eggjs/i18n/app');
8
- /**
9
- * I18n 国际化
10
- *
11
- * 通过设置 Plugin 配置 `i18n: true`,开启多语言支持。
12
- *
13
- * #### 语言文件存储路径
14
- *
15
- * 统一存放在 `config/locale/*.js` 下( 兼容`config/locales/*.js` ),如包含英文,简体中文,繁体中文的语言文件:
16
- *
17
- * ```
18
- * - config/locale/
19
- * - en-US.js
20
- * - zh-CN.js
21
- * - zh-TW.js
22
- * ```
23
- * @class I18n
24
- * @param {App} app Application object.
25
- * @example
26
- *
27
- * #### I18n 文件内容
28
- *
29
- * ```js
30
- * // config/locale/zh-CN.js
31
- * module.exports = {
32
- * "Email": "邮箱",
33
- * "Welcome back, %s!": "欢迎回来, %s!",
34
- * "Hello %s, how are you today?": "你好 %s, 今天过得咋样?",
35
- * };
36
- * ```
37
- *
38
- * ```js
39
- * // config/locale/en-US.js
40
- * module.exports = {
41
- * "Email": "Email",
42
- * };
43
- * ```
44
- * 或者也可以用 JSON 格式的文件:
45
- *
46
- * ```js
47
- * // config/locale/zh-CN.json
48
- * {
49
- * "email": "邮箱",
50
- * "login": "帐号",
51
- * "createdAt": "注册时间"
52
- * }
53
- * ```
54
- */
55
- export default class I18n {
56
- app;
57
- constructor(app) {
58
- this.app = app;
59
- }
60
- async didLoad() {
61
- const i18nConfig = this.app.config.i18n;
62
- i18nConfig.defaultLocale = formatLocale(i18nConfig.defaultLocale);
63
- i18nConfig.cookieMaxAge = ms(i18nConfig.cookieMaxAge);
64
- i18nConfig.dirs = Array.isArray(i18nConfig.dirs) ? i18nConfig.dirs : [];
65
- // 按 egg > 插件 > 框架 > 应用的顺序遍历 config/locale(config/locales) 目录,加载所有配置文件
66
- for (const unit of this.app.loader.getLoadUnits()) {
67
- let localePath = path.join(unit.path, 'config/locale');
68
- /**
69
- * 优先选择 `config/locale` 目录下的多语言文件,不存在时再选择 `config/locales` 目录
70
- * 避免 2 个目录同时存在时可能导致的冲突
71
- */
72
- if (!(await exists(localePath))) {
73
- localePath = path.join(unit.path, 'config/locales');
74
- }
75
- i18nConfig.dirs.push(localePath);
76
- }
77
- debug('app.config.i18n.dirs:', i18nConfig.dirs);
78
- await loadLocaleResources(this.app, i18nConfig);
79
- const app = this.app;
80
- function gettextInContext(key, ...args) {
81
- const ctx = app.ctxStorage.getStore();
82
- return ctx.gettext(key, ...args);
83
- }
84
- // 在 view 中使用 `__(key, value, ...args)`
85
- this.app.locals.gettext = gettextInContext;
86
- this.app.locals.__ = gettextInContext;
87
- }
88
- }
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLElBQUksTUFBTSxXQUFXLENBQUM7QUFDN0IsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUNyQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbkQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUNqQyxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBR2pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFFMUMsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFFMUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E4Q0c7QUFFSCxNQUFNLENBQUMsT0FBTyxPQUFPLElBQUk7SUFDTixHQUFHLENBQUM7SUFFckIsWUFBWSxHQUFzRDtRQUNoRSxJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztJQUNqQixDQUFDO0lBRUQsS0FBSyxDQUFDLE9BQU87UUFDWCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFDeEMsVUFBVSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2xFLFVBQVUsQ0FBQyxZQUFZLEdBQUcsRUFBRSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUV0RCxVQUFVLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDeEUsc0VBQXNFO1FBQ3RFLEtBQUssTUFBTSxJQUFJLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsWUFBWSxFQUFFLEVBQUUsQ0FBQztZQUNsRCxJQUFJLFVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsZUFBZSxDQUFDLENBQUM7WUFDdkQ7OztlQUdHO1lBQ0gsSUFBSSxDQUFDLENBQUMsTUFBTSxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUNoQyxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLGdCQUFnQixDQUFDLENBQUM7WUFDdEQsQ0FBQztZQUNELFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ25DLENBQUM7UUFFRCxLQUFLLENBQUMsdUJBQXVCLEVBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRWhELE1BQU0sbUJBQW1CLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUVoRCxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDO1FBQ3JCLFNBQVMsZ0JBQWdCLENBQUMsR0FBVyxFQUFFLEdBQUcsSUFBVztZQUNuRCxNQUFNLEdBQUcsR0FBRyxHQUFHLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRyxDQUFDO1lBQ3ZDLE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztRQUNuQyxDQUFDO1FBQ0QsdUNBQXVDO1FBQ3ZDLElBQUksQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLE9BQU8sR0FBRyxnQkFBZ0IsQ0FBQztRQUMzQyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLEdBQUcsZ0JBQWdCLENBQUM7SUFDeEMsQ0FBQztDQUNGIn0=