@modern-js/plugin-i18n 1.1.1 → 1.2.0

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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # @modern-js/plugin-i18n
2
2
 
3
+ ## 1.2.0
4
+
5
+ ### Minor Changes
6
+
7
+ - cfe11628: Make Modern.js self bootstraping
8
+
9
+ ## 1.1.2
10
+
11
+ ### Patch Changes
12
+
13
+ - 5e3de7d8: fix: i18n get message error when system language not zh or en
14
+
3
15
  ## 1.1.1
4
16
 
5
17
  ### Patch Changes
@@ -1,5 +1,5 @@
1
1
  import _get from "lodash/get";
2
- import { getObjKeyMap } from "./utils/index";
2
+ import { getObjKeyMap } from "./utils";
3
3
 
4
4
  class I18n {
5
5
  constructor() {
@@ -12,10 +12,18 @@ class I18n {
12
12
  }
13
13
 
14
14
  getMessage(lang, key, vars, fallbackText) {
15
- const model = this.languageMap[lang];
15
+ // 判断语言当前语料库是否存在,不存在使用 en 作为默认语言
16
+ const languages = Object.keys(this.languageMap);
17
+ const resultLang = languages.find(l => l === lang);
18
+
19
+ if (!resultLang && languages.length === 0) {
20
+ return fallbackText || key;
21
+ }
22
+
23
+ const model = this.languageMap[resultLang || 'en' || languages[0]];
16
24
 
17
25
  if (!model) {
18
- throw new Error(`current ${lang} language is not exisit`);
26
+ return fallbackText || key;
19
27
  }
20
28
 
21
29
  const message = _get(model, key);
@@ -7,7 +7,7 @@ exports.I18n = void 0;
7
7
 
8
8
  var _get2 = _interopRequireDefault(require("lodash/get"));
9
9
 
10
- var _index = require("./utils/index");
10
+ var _utils = require("./utils");
11
11
 
12
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
13
 
@@ -22,10 +22,18 @@ class I18n {
22
22
  }
23
23
 
24
24
  getMessage(lang, key, vars, fallbackText) {
25
- const model = this.languageMap[lang];
25
+ // 判断语言当前语料库是否存在,不存在使用 en 作为默认语言
26
+ const languages = Object.keys(this.languageMap);
27
+ const resultLang = languages.find(l => l === lang);
28
+
29
+ if (!resultLang && languages.length === 0) {
30
+ return fallbackText || key;
31
+ }
32
+
33
+ const model = this.languageMap[resultLang || 'en' || languages[0]];
26
34
 
27
35
  if (!model) {
28
- throw new Error(`current ${lang} language is not exisit`);
36
+ return fallbackText || key;
29
37
  }
30
38
 
31
39
  const message = (0, _get2.default)(model, key);
@@ -45,7 +53,7 @@ class I18n {
45
53
  this.languageMap = languageMap;
46
54
  }
47
55
 
48
- return (0, _index.getObjKeyMap)(this.languageMap[this.language]);
56
+ return (0, _utils.getObjKeyMap)(this.languageMap[this.language]);
49
57
  }
50
58
 
51
59
  changeLanguage(config) {
@@ -4,9 +4,9 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
4
4
 
5
5
  function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
6
6
 
7
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
7
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
8
8
 
9
- import { getObjKeyMap } from "./utils/index";
9
+ import { getObjKeyMap } from "./utils";
10
10
 
11
11
  var I18n = /*#__PURE__*/function () {
12
12
  function I18n() {
@@ -26,10 +26,20 @@ var I18n = /*#__PURE__*/function () {
26
26
  }, {
27
27
  key: "getMessage",
28
28
  value: function getMessage(lang, key, vars, fallbackText) {
29
- var model = this.languageMap[lang];
29
+ // 判断语言当前语料库是否存在,不存在使用 en 作为默认语言
30
+ var languages = Object.keys(this.languageMap);
31
+ var resultLang = languages.find(function (l) {
32
+ return l === lang;
33
+ });
34
+
35
+ if (!resultLang && languages.length === 0) {
36
+ return fallbackText || key;
37
+ }
38
+
39
+ var model = this.languageMap[resultLang || 'en' || languages[0]];
30
40
 
31
41
  if (!model) {
32
- throw new Error("current ".concat(lang, " language is not exisit"));
42
+ return fallbackText || key;
33
43
  }
34
44
 
35
45
  var message = _get(model, key);
package/jest.config.js ADDED
@@ -0,0 +1,8 @@
1
+ const sharedConfig = require('@scripts/jest-config');
2
+
3
+ /** @type {import('@jest/types').Config.InitialOptions} */
4
+ module.exports = {
5
+ // eslint-disable-next-line node/no-unsupported-features/es-syntax
6
+ ...sharedConfig,
7
+ rootDir: __dirname,
8
+ };
package/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "modern",
12
12
  "modern.js"
13
13
  ],
14
- "version": "1.1.1",
14
+ "version": "1.2.0",
15
15
  "jsnext:source": "./src/index.ts",
16
16
  "types": "./dist/types/index.d.ts",
17
17
  "main": "./dist/js/node/index.js",
@@ -20,6 +20,7 @@
20
20
  "exports": {
21
21
  ".": {
22
22
  "node": {
23
+ "jsnext:source": "./src/index.ts",
23
24
  "import": "./dist/js/modern/index.js",
24
25
  "require": "./dist/js/node/index.js"
25
26
  },
@@ -35,18 +36,21 @@
35
36
  "@types/lodash": "^4.14.126",
36
37
  "@types/node": "^14",
37
38
  "typescript": "^4",
38
- "@modern-js/plugin-testing": "^1.1.0",
39
- "@modern-js/module-tools": "^1.1.0"
39
+ "@scripts/build": "0.0.0",
40
+ "jest": "^27",
41
+ "@scripts/jest-config": "0.0.0"
40
42
  },
41
43
  "sideEffects": false,
42
44
  "modernConfig": {},
43
45
  "publishConfig": {
44
46
  "registry": "https://registry.npmjs.org/",
45
- "access": "public"
47
+ "access": "public",
48
+ "types": "./dist/types/index.d.ts"
46
49
  },
47
50
  "scripts": {
48
51
  "new": "modern new",
49
52
  "build": "modern build",
50
- "test": "modern test --passWithNoTests"
51
- }
53
+ "test": "jest --passWithNoTests"
54
+ },
55
+ "readme": "\n<p align=\"center\">\n <a href=\"https://modernjs.dev\" target=\"blank\"><img src=\"https://lf3-static.bytednsdoc.com/obj/eden-cn/ylaelkeh7nuhfnuhf/modernjs-cover.png\" width=\"300\" alt=\"Modern.js Logo\" /></a>\n</p>\n<p align=\"center\">\n现代 Web 工程体系\n <br/>\n <a href=\"https://modernjs.dev\" target=\"blank\">\n modernjs.dev\n </a>\n</p>\n<p align=\"center\">\n The meta-framework suite designed from scratch for frontend-focused modern web development\n</p>\n\n# Introduction\n\n> The doc site ([modernjs.dev](https://modernjs.dev)) and articles are only available in Chinese for now, we are planning to add English versions soon.\n\n- [Modern.js: Hello, World!](https://zhuanlan.zhihu.com/p/426707646)\n\n## Getting Started\n\n- [Quick Start](https://modernjs.dev/docs/start)\n- [Guides](https://modernjs.dev/docs/guides)\n- [API References](https://modernjs.dev/docs/apis)\n\n## Contributing\n\n- [Contributing Guide](https://github.com/modern-js-dev/modern.js/blob/main/CONTRIBUTING.md)\n"
52
56
  }
package/src/index.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { get } from 'lodash';
2
- import { getObjKeyMap } from './utils/index';
2
+ import { getObjKeyMap } from './utils';
3
3
 
4
4
  type Language = string;
5
5
 
@@ -43,9 +43,16 @@ class I18n implements TI18n {
43
43
  vars?: { [key: string]: string },
44
44
  fallbackText?: string,
45
45
  ) {
46
- const model: LanguageModel = this.languageMap[lang];
46
+ // 判断语言当前语料库是否存在,不存在使用 en 作为默认语言
47
+ const languages = Object.keys(this.languageMap);
48
+ const resultLang = languages.find(l => l === lang);
49
+ if (!resultLang && languages.length === 0) {
50
+ return fallbackText || key;
51
+ }
52
+ const model: LanguageModel =
53
+ this.languageMap[resultLang || 'en' || languages[0]];
47
54
  if (!model) {
48
- throw new Error(`current ${lang} language is not exisit`);
55
+ return fallbackText || key;
49
56
  }
50
57
  const message = get(model, key);
51
58
  const value = message || fallbackText || key;
@@ -1,4 +1,4 @@
1
- import { I18n } from '@/index';
1
+ import { I18n } from '../src';
2
2
 
3
3
  describe('i18n test', () => {
4
4
  test('Init Default language', () => {
@@ -5,8 +5,6 @@
5
5
  "jsx": "preserve",
6
6
  "baseUrl": "./",
7
7
  "isolatedModules": true,
8
- "paths": {
9
- "@/*": ["../src/*"]
10
- }
8
+ "paths": {}
11
9
  }
12
10
  }
package/tsconfig.json CHANGED
@@ -5,9 +5,7 @@
5
5
  "jsx": "preserve",
6
6
  "baseUrl": "./",
7
7
  "isolatedModules": true,
8
- "paths": {
9
- "@/*": ["./src/*"]
10
- }
8
+ "paths": {}
11
9
  },
12
10
  "include": ["src"]
13
11
  }