@zwa73/utils 1.0.142 → 1.0.144
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/dist/UtilI18n.d.ts +2 -2
- package/dist/UtilI18n.js +10 -4
- package/package.json +1 -1
- package/src/UtilI18n.ts +10 -6
package/dist/UtilI18n.d.ts
CHANGED
|
@@ -74,7 +74,7 @@ export declare class SI18n {
|
|
|
74
74
|
* @param i18nDataDir - 国际化数据的路径。
|
|
75
75
|
* @param lang - 要设置的语言。
|
|
76
76
|
*/
|
|
77
|
-
static init(i18nDataDir: string, lang?: LangFlag): Promise<void>;
|
|
77
|
+
static init(i18nDataDir: string, lang?: LangFlag | '*'): Promise<void>;
|
|
78
78
|
/**根据提供的字符串,返回对应的国际化字符串
|
|
79
79
|
* @param text - 字符串数组
|
|
80
80
|
* @param markStr - 特殊标记文本
|
|
@@ -97,7 +97,7 @@ export declare class SI18n {
|
|
|
97
97
|
* @param lang - 要查找的语言。
|
|
98
98
|
* @returns 对应的国际化字符串。
|
|
99
99
|
*/
|
|
100
|
-
static getI18n(key: string, lang
|
|
100
|
+
static getI18n(key: string, lang?: LangFlag): string;
|
|
101
101
|
/**尝试获取指定语言的翻译,如果没有找到,将回滚到其他可用的语言。
|
|
102
102
|
* @param lang - 要查找的语言。
|
|
103
103
|
* @param dat - 包含翻译的数据对象。
|
package/dist/UtilI18n.js
CHANGED
|
@@ -17,6 +17,10 @@ const I18nFlagTable = {
|
|
|
17
17
|
const LangFlagList = Object.entries(I18nFlagTable)
|
|
18
18
|
.map(([k, v]) => `${k}-${v}`)
|
|
19
19
|
.concat(Object.keys(I18nFlagTable));
|
|
20
|
+
const parseLangFlag = (lf) => {
|
|
21
|
+
const match = lf.match(/^([^-]+)(.+)/);
|
|
22
|
+
return { 1: match[1], 2: match[2] != '' ? match[2] : undefined };
|
|
23
|
+
};
|
|
20
24
|
const MarkRegex = /%%%([^%]+)%%%$/;
|
|
21
25
|
const BaseFile = 'base_lang.json';
|
|
22
26
|
const TemplateFile = 'template.json';
|
|
@@ -53,7 +57,7 @@ class SI18n {
|
|
|
53
57
|
* @param i18nDataDir - 国际化数据的路径。
|
|
54
58
|
* @param lang - 要设置的语言。
|
|
55
59
|
*/
|
|
56
|
-
static async init(i18nDataDir, lang) {
|
|
60
|
+
static async init(i18nDataDir, lang = '*') {
|
|
57
61
|
const date = new Date().toISOString();
|
|
58
62
|
const mergePath = pathe_1.default.join(i18nDataDir, BaseFile);
|
|
59
63
|
const table = await UtilFileTools_1.UtilFT.loadJSONFile(mergePath, { default: {
|
|
@@ -68,7 +72,7 @@ class SI18n {
|
|
|
68
72
|
SI18n._vaildLang = ['template'];
|
|
69
73
|
//覆盖入单语言文件
|
|
70
74
|
const singleDir = pathe_1.default.join(i18nDataDir, LangDir);
|
|
71
|
-
(await Promise.all((await UtilFileTools_1.UtilFT.fileSearchGlob(singleDir, `**/${lang}*.json`))
|
|
75
|
+
(await Promise.all((await UtilFileTools_1.UtilFT.fileSearchGlob(singleDir, `**/${parseLangFlag(lang)[1]}*.json`))
|
|
72
76
|
.map(async (p) => await UtilFileTools_1.UtilFT.loadJSONFile(p))))
|
|
73
77
|
.forEach(t => {
|
|
74
78
|
SI18n._vaildLang?.push(t.target_lang);
|
|
@@ -87,9 +91,9 @@ class SI18n {
|
|
|
87
91
|
ltable[t.target_lang] ??= v;
|
|
88
92
|
});
|
|
89
93
|
});
|
|
90
|
-
if (lang != undefined && !SI18n._vaildLang.includes(lang))
|
|
94
|
+
if (lang != undefined && lang != '*' && !SI18n._vaildLang.includes(lang))
|
|
91
95
|
SI18n._vaildLang.push(lang);
|
|
92
|
-
SI18n._lang = lang;
|
|
96
|
+
SI18n._lang = lang == "*" ? undefined : lang;
|
|
93
97
|
SI18n._dataDir = i18nDataDir;
|
|
94
98
|
}
|
|
95
99
|
static t(strings, ...values) {
|
|
@@ -134,6 +138,8 @@ class SI18n {
|
|
|
134
138
|
source: 'Runtime'
|
|
135
139
|
});
|
|
136
140
|
}
|
|
141
|
+
if (lang == undefined)
|
|
142
|
+
return obj.original;
|
|
137
143
|
if (obj.invalid === true)
|
|
138
144
|
return obj.original;
|
|
139
145
|
return SI18n.tryAndRollback(lang, obj);
|
package/package.json
CHANGED
package/src/UtilI18n.ts
CHANGED
|
@@ -64,7 +64,10 @@ export type I18nTextData = I18nOrigTextData&{lang_table:PRecord<LangFlag,string>
|
|
|
64
64
|
export type I18nTable = Omit<I18nOrigTable,'texts'>&{
|
|
65
65
|
text_table:Record<string,I18nTextData>;
|
|
66
66
|
}
|
|
67
|
-
|
|
67
|
+
const parseLangFlag = (lf:LangFlag|'*')=>{
|
|
68
|
+
const match = lf.match(/^([^-]+)(.+)/)!
|
|
69
|
+
return {1:match[1],2:match[2]!='' ? match[2]:undefined};
|
|
70
|
+
}
|
|
68
71
|
|
|
69
72
|
const MarkRegex = /%%%([^%]+)%%%$/;
|
|
70
73
|
const BaseFile = 'base_lang.json';
|
|
@@ -102,7 +105,7 @@ export class SI18n {
|
|
|
102
105
|
* @param i18nDataDir - 国际化数据的路径。
|
|
103
106
|
* @param lang - 要设置的语言。
|
|
104
107
|
*/
|
|
105
|
-
static async init(i18nDataDir:string,lang
|
|
108
|
+
static async init(i18nDataDir:string,lang:LangFlag|'*'='*'){
|
|
106
109
|
const date = new Date().toISOString();
|
|
107
110
|
const mergePath = path.join(i18nDataDir,BaseFile);
|
|
108
111
|
const table = await UtilFT.loadJSONFile<I18nOrigTable>(mergePath,{default:{
|
|
@@ -119,7 +122,7 @@ export class SI18n {
|
|
|
119
122
|
SI18n._vaildLang=['template'];
|
|
120
123
|
//覆盖入单语言文件
|
|
121
124
|
const singleDir = path.join(i18nDataDir,LangDir);
|
|
122
|
-
(await Promise.all((await UtilFT.fileSearchGlob(singleDir,`**/${lang}*.json`))
|
|
125
|
+
(await Promise.all((await UtilFT.fileSearchGlob(singleDir,`**/${parseLangFlag(lang)[1]}*.json`))
|
|
123
126
|
.map(async p=>await UtilFT.loadJSONFile(p) as I18nSingleTable)))
|
|
124
127
|
.forEach(t=>{
|
|
125
128
|
SI18n._vaildLang?.push(t.target_lang);
|
|
@@ -138,10 +141,10 @@ export class SI18n {
|
|
|
138
141
|
})
|
|
139
142
|
});
|
|
140
143
|
|
|
141
|
-
if(lang!=undefined && !SI18n._vaildLang.includes(lang))
|
|
144
|
+
if(lang!=undefined && lang!='*' && !SI18n._vaildLang.includes(lang))
|
|
142
145
|
SI18n._vaildLang.push(lang);
|
|
143
146
|
|
|
144
|
-
SI18n._lang = lang;
|
|
147
|
+
SI18n._lang = lang=="*" ? undefined : lang;
|
|
145
148
|
SI18n._dataDir = i18nDataDir;
|
|
146
149
|
}
|
|
147
150
|
/**根据提供的字符串,返回对应的国际化字符串
|
|
@@ -190,7 +193,7 @@ export class SI18n {
|
|
|
190
193
|
* @param lang - 要查找的语言。
|
|
191
194
|
* @returns 对应的国际化字符串。
|
|
192
195
|
*/
|
|
193
|
-
static getI18n(key:string,lang
|
|
196
|
+
static getI18n(key:string,lang?:LangFlag){
|
|
194
197
|
if(SI18n._table==undefined) UtilFunc.throwError('SI18n 未初始化');
|
|
195
198
|
let obj = SI18n._table.text_table[key];
|
|
196
199
|
if(obj==undefined){
|
|
@@ -204,6 +207,7 @@ export class SI18n {
|
|
|
204
207
|
source:'Runtime'
|
|
205
208
|
});
|
|
206
209
|
}
|
|
210
|
+
if(lang==undefined) return obj.original;
|
|
207
211
|
if(obj.invalid===true) return obj.original;
|
|
208
212
|
return SI18n.tryAndRollback(lang,obj);
|
|
209
213
|
}
|