@modern-js/plugin-i18n 1.1.1 → 1.1.2-beta.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.
@@ -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/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "modern",
12
12
  "modern.js"
13
13
  ],
14
- "version": "1.1.1",
14
+ "version": "1.1.2-beta.0",
15
15
  "jsnext:source": "./src/index.ts",
16
16
  "types": "./dist/types/index.d.ts",
17
17
  "main": "./dist/js/node/index.js",
@@ -35,8 +35,8 @@
35
35
  "@types/lodash": "^4.14.126",
36
36
  "@types/node": "^14",
37
37
  "typescript": "^4",
38
- "@modern-js/plugin-testing": "^1.1.0",
39
- "@modern-js/module-tools": "^1.1.0"
38
+ "@modern-js/plugin-testing": "^1.1.1",
39
+ "@modern-js/module-tools": "^1.1.1"
40
40
  },
41
41
  "sideEffects": false,
42
42
  "modernConfig": {},
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;