@vlian/framework 1.2.55 → 1.2.56
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/analytics.umd.js +1 -1
- package/dist/core/initialization/initialization.cjs.map +1 -1
- package/dist/core/initialization/initialization.js +3 -3
- package/dist/core/initialization/initialization.js.map +1 -1
- package/dist/core/router/validation/RouterConfigValidator.d.ts +2 -2
- package/dist/core/router/validation/schema.d.ts +3 -3
- package/dist/index.umd.js +291 -228
- package/dist/index.umd.js.map +1 -1
- package/dist/kernel/manager/i18n/I18nManager.cjs +93 -0
- package/dist/kernel/manager/i18n/I18nManager.cjs.map +1 -0
- package/dist/kernel/manager/i18n/I18nManager.d.ts +15 -0
- package/dist/kernel/manager/i18n/I18nManager.js +83 -0
- package/dist/kernel/manager/i18n/I18nManager.js.map +1 -0
- package/dist/kernel/manager/i18n/i18n.persistence.cjs +59 -0
- package/dist/kernel/manager/i18n/i18n.persistence.cjs.map +1 -0
- package/dist/kernel/manager/i18n/i18n.persistence.d.ts +5 -0
- package/dist/kernel/manager/i18n/i18n.persistence.js +38 -0
- package/dist/kernel/manager/i18n/i18n.persistence.js.map +1 -0
- package/dist/kernel/manager/i18n/i18n.schema.cjs +88 -0
- package/dist/kernel/manager/i18n/i18n.schema.cjs.map +1 -0
- package/dist/kernel/manager/i18n/i18n.schema.d.ts +6 -0
- package/dist/kernel/manager/i18n/i18n.schema.js +64 -0
- package/dist/kernel/manager/i18n/i18n.schema.js.map +1 -0
- package/dist/kernel/manager/i18n/index.cjs +13 -0
- package/dist/kernel/manager/i18n/index.cjs.map +1 -0
- package/dist/kernel/manager/i18n/index.d.ts +1 -0
- package/dist/kernel/manager/i18n/index.js +3 -0
- package/dist/kernel/manager/i18n/index.js.map +1 -0
- package/dist/kernel/manager/i18nManager.cjs +2 -77
- package/dist/kernel/manager/i18nManager.cjs.map +1 -1
- package/dist/kernel/manager/i18nManager.d.ts +1 -13
- package/dist/kernel/manager/i18nManager.js +1 -76
- package/dist/kernel/manager/i18nManager.js.map +1 -1
- package/dist/kernel/manager/logger/LoggerManager.cjs +109 -0
- package/dist/kernel/manager/logger/LoggerManager.cjs.map +1 -0
- package/dist/kernel/manager/logger/LoggerManager.d.ts +21 -0
- package/dist/kernel/manager/logger/LoggerManager.js +99 -0
- package/dist/kernel/manager/logger/LoggerManager.js.map +1 -0
- package/dist/kernel/manager/logger/index.cjs +13 -0
- package/dist/kernel/manager/logger/index.cjs.map +1 -0
- package/dist/kernel/manager/logger/index.d.ts +1 -0
- package/dist/kernel/manager/logger/index.js +3 -0
- package/dist/kernel/manager/logger/index.js.map +1 -0
- package/dist/kernel/manager/logger/logger.persistence.cjs +64 -0
- package/dist/kernel/manager/logger/logger.persistence.cjs.map +1 -0
- package/dist/kernel/manager/logger/logger.persistence.d.ts +6 -0
- package/dist/kernel/manager/logger/logger.persistence.js +43 -0
- package/dist/kernel/manager/logger/logger.persistence.js.map +1 -0
- package/dist/kernel/manager/logger/logger.schema.cjs +76 -0
- package/dist/kernel/manager/logger/logger.schema.cjs.map +1 -0
- package/dist/kernel/manager/logger/logger.schema.d.ts +8 -0
- package/dist/kernel/manager/logger/logger.schema.js +55 -0
- package/dist/kernel/manager/logger/logger.schema.js.map +1 -0
- package/dist/kernel/manager/loggerManager.cjs +2 -103
- package/dist/kernel/manager/loggerManager.cjs.map +1 -1
- package/dist/kernel/manager/loggerManager.d.ts +1 -18
- package/dist/kernel/manager/loggerManager.js +1 -102
- package/dist/kernel/manager/loggerManager.js.map +1 -1
- package/dist/kernel/types.d.ts +3 -3
- package/dist/kernel/types.js.map +1 -1
- package/dist/library/locale/index.cjs +8 -34
- package/dist/library/locale/index.cjs.map +1 -1
- package/dist/library/locale/index.d.ts +4 -4
- package/dist/library/locale/index.js +5 -34
- package/dist/library/locale/index.js.map +1 -1
- package/dist/state.umd.js +1 -1
- package/package.json +3 -1
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { LogLevel } from "@vlian/logger";
|
|
2
|
+
export function normalizeLogLevel(value, fallback) {
|
|
3
|
+
if (typeof value === 'number' && Number.isInteger(value)) {
|
|
4
|
+
switch(value){
|
|
5
|
+
case LogLevel.DEBUG:
|
|
6
|
+
case LogLevel.INFO:
|
|
7
|
+
case LogLevel.WARN:
|
|
8
|
+
case LogLevel.ERROR:
|
|
9
|
+
case LogLevel.NONE:
|
|
10
|
+
return value;
|
|
11
|
+
default:
|
|
12
|
+
return fallback;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
if (typeof value !== 'string') {
|
|
16
|
+
return fallback;
|
|
17
|
+
}
|
|
18
|
+
const normalized = value.trim();
|
|
19
|
+
if (!normalized) {
|
|
20
|
+
return fallback;
|
|
21
|
+
}
|
|
22
|
+
if (/^\d+$/.test(normalized)) {
|
|
23
|
+
return normalizeLogLevel(Number(normalized), fallback);
|
|
24
|
+
}
|
|
25
|
+
switch(normalized.toUpperCase()){
|
|
26
|
+
case 'DEBUG':
|
|
27
|
+
return LogLevel.DEBUG;
|
|
28
|
+
case 'INFO':
|
|
29
|
+
return LogLevel.INFO;
|
|
30
|
+
case 'WARN':
|
|
31
|
+
return LogLevel.WARN;
|
|
32
|
+
case 'ERROR':
|
|
33
|
+
return LogLevel.ERROR;
|
|
34
|
+
case 'NONE':
|
|
35
|
+
return LogLevel.NONE;
|
|
36
|
+
default:
|
|
37
|
+
return fallback;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
export function normalizeLoggerSnapshot(value, fallback) {
|
|
41
|
+
if (typeof value === 'number' || typeof value === 'string') {
|
|
42
|
+
return {
|
|
43
|
+
level: normalizeLogLevel(value, fallback.level)
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
const source = value && typeof value === 'object' ? value : {};
|
|
47
|
+
return {
|
|
48
|
+
level: normalizeLogLevel(source.level, fallback.level)
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
export function isLoggerEqual(left, right) {
|
|
52
|
+
return left.level === right.level;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
//# sourceMappingURL=logger.schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/kernel/manager/logger/logger.schema.ts"],"sourcesContent":["import { LogLevel } from '@vlian/logger';\n\nexport type LoggerSnapshot = {\n level: LogLevel;\n};\n\nexport type LoggerListener = (next: LoggerSnapshot, prev: LoggerSnapshot) => void;\n\nexport function normalizeLogLevel(value: unknown, fallback: LogLevel): LogLevel {\n if (typeof value === 'number' && Number.isInteger(value)) {\n switch (value) {\n case LogLevel.DEBUG:\n case LogLevel.INFO:\n case LogLevel.WARN:\n case LogLevel.ERROR:\n case LogLevel.NONE:\n return value;\n default:\n return fallback;\n }\n }\n\n if (typeof value !== 'string') {\n return fallback;\n }\n\n const normalized = value.trim();\n if (!normalized) {\n return fallback;\n }\n\n if (/^\\d+$/.test(normalized)) {\n return normalizeLogLevel(Number(normalized), fallback);\n }\n\n switch (normalized.toUpperCase()) {\n case 'DEBUG':\n return LogLevel.DEBUG;\n case 'INFO':\n return LogLevel.INFO;\n case 'WARN':\n return LogLevel.WARN;\n case 'ERROR':\n return LogLevel.ERROR;\n case 'NONE':\n return LogLevel.NONE;\n default:\n return fallback;\n }\n}\n\nexport function normalizeLoggerSnapshot(\n value: unknown,\n fallback: LoggerSnapshot\n): LoggerSnapshot {\n if (typeof value === 'number' || typeof value === 'string') {\n return {\n level: normalizeLogLevel(value, fallback.level),\n };\n }\n\n const source = value && typeof value === 'object' ? (value as Partial<LoggerSnapshot>) : {};\n\n return {\n level: normalizeLogLevel(source.level, fallback.level),\n };\n}\n\nexport function isLoggerEqual(left: LoggerSnapshot, right: LoggerSnapshot): boolean {\n return left.level === right.level;\n}\n"],"names":["LogLevel","normalizeLogLevel","value","fallback","Number","isInteger","DEBUG","INFO","WARN","ERROR","NONE","normalized","trim","test","toUpperCase","normalizeLoggerSnapshot","level","source","isLoggerEqual","left","right"],"mappings":"AAAA,SAASA,QAAQ,QAAQ,gBAAgB;AAQzC,OAAO,SAASC,kBAAkBC,KAAc,EAAEC,QAAkB;IAClE,IAAI,OAAOD,UAAU,YAAYE,OAAOC,SAAS,CAACH,QAAQ;QACxD,OAAQA;YACN,KAAKF,SAASM,KAAK;YACnB,KAAKN,SAASO,IAAI;YAClB,KAAKP,SAASQ,IAAI;YAClB,KAAKR,SAASS,KAAK;YACnB,KAAKT,SAASU,IAAI;gBAChB,OAAOR;YACT;gBACE,OAAOC;QACX;IACF;IAEA,IAAI,OAAOD,UAAU,UAAU;QAC7B,OAAOC;IACT;IAEA,MAAMQ,aAAaT,MAAMU,IAAI;IAC7B,IAAI,CAACD,YAAY;QACf,OAAOR;IACT;IAEA,IAAI,QAAQU,IAAI,CAACF,aAAa;QAC5B,OAAOV,kBAAkBG,OAAOO,aAAaR;IAC/C;IAEA,OAAQQ,WAAWG,WAAW;QAC5B,KAAK;YACH,OAAOd,SAASM,KAAK;QACvB,KAAK;YACH,OAAON,SAASO,IAAI;QACtB,KAAK;YACH,OAAOP,SAASQ,IAAI;QACtB,KAAK;YACH,OAAOR,SAASS,KAAK;QACvB,KAAK;YACH,OAAOT,SAASU,IAAI;QACtB;YACE,OAAOP;IACX;AACF;AAEA,OAAO,SAASY,wBACdb,KAAc,EACdC,QAAwB;IAExB,IAAI,OAAOD,UAAU,YAAY,OAAOA,UAAU,UAAU;QAC1D,OAAO;YACLc,OAAOf,kBAAkBC,OAAOC,SAASa,KAAK;QAChD;IACF;IAEA,MAAMC,SAASf,SAAS,OAAOA,UAAU,WAAYA,QAAoC,CAAC;IAE1F,OAAO;QACLc,OAAOf,kBAAkBgB,OAAOD,KAAK,EAAEb,SAASa,KAAK;IACvD;AACF;AAEA,OAAO,SAASE,cAAcC,IAAoB,EAAEC,KAAqB;IACvE,OAAOD,KAAKH,KAAK,KAAKI,MAAMJ,KAAK;AACnC"}
|
|
@@ -5,110 +5,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
Object.defineProperty(exports, "LoggerManager", {
|
|
6
6
|
enumerable: true,
|
|
7
7
|
get: function() {
|
|
8
|
-
return LoggerManager;
|
|
8
|
+
return _logger.LoggerManager;
|
|
9
9
|
}
|
|
10
10
|
});
|
|
11
|
-
const _logger = require("
|
|
12
|
-
const _constants = require("../constants");
|
|
13
|
-
const _persistence = require("./persistence");
|
|
14
|
-
function _define_property(obj, key, value) {
|
|
15
|
-
if (key in obj) {
|
|
16
|
-
Object.defineProperty(obj, key, {
|
|
17
|
-
value: value,
|
|
18
|
-
enumerable: true,
|
|
19
|
-
configurable: true,
|
|
20
|
-
writable: true
|
|
21
|
-
});
|
|
22
|
-
} else {
|
|
23
|
-
obj[key] = value;
|
|
24
|
-
}
|
|
25
|
-
return obj;
|
|
26
|
-
}
|
|
27
|
-
function normalizeLogLevel(value, fallback) {
|
|
28
|
-
if (typeof value === 'number' && Number.isInteger(value)) {
|
|
29
|
-
switch(value){
|
|
30
|
-
case _logger.LogLevel.DEBUG:
|
|
31
|
-
case _logger.LogLevel.INFO:
|
|
32
|
-
case _logger.LogLevel.WARN:
|
|
33
|
-
case _logger.LogLevel.ERROR:
|
|
34
|
-
case _logger.LogLevel.NONE:
|
|
35
|
-
return value;
|
|
36
|
-
default:
|
|
37
|
-
return fallback;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
if (typeof value !== 'string') {
|
|
41
|
-
return fallback;
|
|
42
|
-
}
|
|
43
|
-
const normalized = value.trim();
|
|
44
|
-
if (!normalized) {
|
|
45
|
-
return fallback;
|
|
46
|
-
}
|
|
47
|
-
if (/^\d+$/.test(normalized)) {
|
|
48
|
-
return normalizeLogLevel(Number(normalized), fallback);
|
|
49
|
-
}
|
|
50
|
-
switch(normalized.toUpperCase()){
|
|
51
|
-
case 'DEBUG':
|
|
52
|
-
return _logger.LogLevel.DEBUG;
|
|
53
|
-
case 'INFO':
|
|
54
|
-
return _logger.LogLevel.INFO;
|
|
55
|
-
case 'WARN':
|
|
56
|
-
return _logger.LogLevel.WARN;
|
|
57
|
-
case 'ERROR':
|
|
58
|
-
return _logger.LogLevel.ERROR;
|
|
59
|
-
case 'NONE':
|
|
60
|
-
return _logger.LogLevel.NONE;
|
|
61
|
-
default:
|
|
62
|
-
return fallback;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
let LoggerManager = class LoggerManager {
|
|
66
|
-
async initialize(context) {
|
|
67
|
-
this.config = context.config.logger;
|
|
68
|
-
const hasConfiguredLevel = this.config.level !== undefined && this.config.level !== null;
|
|
69
|
-
const configuredLevel = normalizeLogLevel(this.config.level, _logger.LogLevel.INFO);
|
|
70
|
-
if (hasConfiguredLevel) {
|
|
71
|
-
this.level = configuredLevel;
|
|
72
|
-
_logger.logger.setLevel(this.level);
|
|
73
|
-
await (0, _persistence.writePersistedValue)(this.config.persistence, String(this.level));
|
|
74
|
-
return;
|
|
75
|
-
}
|
|
76
|
-
const persisted = await (0, _persistence.readPersistedValue)(this.config.persistence);
|
|
77
|
-
if (persisted !== null) {
|
|
78
|
-
this.level = normalizeLogLevel(persisted, configuredLevel);
|
|
79
|
-
_logger.logger.setLevel(this.level);
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
this.level = configuredLevel;
|
|
83
|
-
_logger.logger.setLevel(this.level);
|
|
84
|
-
await (0, _persistence.writePersistedValue)(this.config.persistence, String(this.level));
|
|
85
|
-
}
|
|
86
|
-
debug(...args) {
|
|
87
|
-
_logger.logger.debug(...args);
|
|
88
|
-
}
|
|
89
|
-
info(...args) {
|
|
90
|
-
_logger.logger.info(...args);
|
|
91
|
-
}
|
|
92
|
-
warn(...args) {
|
|
93
|
-
_logger.logger.warn(...args);
|
|
94
|
-
}
|
|
95
|
-
error(...args) {
|
|
96
|
-
_logger.logger.error(...args);
|
|
97
|
-
}
|
|
98
|
-
async setLevel(level) {
|
|
99
|
-
this.level = level;
|
|
100
|
-
_logger.logger.setLevel(level);
|
|
101
|
-
await (0, _persistence.writePersistedValue)(this.config.persistence, String(level));
|
|
102
|
-
}
|
|
103
|
-
getSnapshot() {
|
|
104
|
-
return {
|
|
105
|
-
level: this.level
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
|
-
constructor(){
|
|
109
|
-
_define_property(this, "level", _logger.LogLevel.INFO);
|
|
110
|
-
_define_property(this, "config", _constants.DEFAULT_CONFIG.logger);
|
|
111
|
-
}
|
|
112
|
-
};
|
|
11
|
+
const _logger = require("./logger");
|
|
113
12
|
|
|
114
13
|
//# sourceMappingURL=loggerManager.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/kernel/manager/loggerManager.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"sources":["../../../src/kernel/manager/loggerManager.ts"],"sourcesContent":["export { LoggerManager } from './logger';\n"],"names":["LoggerManager"],"mappings":";;;;+BAASA;;;eAAAA,qBAAa;;;wBAAQ"}
|
|
@@ -1,18 +1 @@
|
|
|
1
|
-
|
|
2
|
-
import type { Logger } from '@vlian/logger';
|
|
3
|
-
import type { KernelManager, KernelManagerContext } from '../types';
|
|
4
|
-
export declare class LoggerManager implements KernelManager<{
|
|
5
|
-
level: LogLevel;
|
|
6
|
-
}> {
|
|
7
|
-
private level;
|
|
8
|
-
private config;
|
|
9
|
-
initialize(context: KernelManagerContext): Promise<void>;
|
|
10
|
-
debug(...args: Parameters<Logger['debug']>): void;
|
|
11
|
-
info(...args: Parameters<Logger['info']>): void;
|
|
12
|
-
warn(...args: Parameters<Logger['warn']>): void;
|
|
13
|
-
error(...args: Parameters<Logger['error']>): void;
|
|
14
|
-
setLevel(level: LogLevel): Promise<void>;
|
|
15
|
-
getSnapshot(): {
|
|
16
|
-
level: LogLevel;
|
|
17
|
-
};
|
|
18
|
-
}
|
|
1
|
+
export { LoggerManager } from './logger';
|
|
@@ -1,104 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
if (key in obj) {
|
|
3
|
-
Object.defineProperty(obj, key, {
|
|
4
|
-
value: value,
|
|
5
|
-
enumerable: true,
|
|
6
|
-
configurable: true,
|
|
7
|
-
writable: true
|
|
8
|
-
});
|
|
9
|
-
} else {
|
|
10
|
-
obj[key] = value;
|
|
11
|
-
}
|
|
12
|
-
return obj;
|
|
13
|
-
}
|
|
14
|
-
import { logger, LogLevel } from "@vlian/logger";
|
|
15
|
-
import { DEFAULT_CONFIG } from "../constants";
|
|
16
|
-
import { readPersistedValue, writePersistedValue } from "./persistence";
|
|
17
|
-
function normalizeLogLevel(value, fallback) {
|
|
18
|
-
if (typeof value === 'number' && Number.isInteger(value)) {
|
|
19
|
-
switch(value){
|
|
20
|
-
case LogLevel.DEBUG:
|
|
21
|
-
case LogLevel.INFO:
|
|
22
|
-
case LogLevel.WARN:
|
|
23
|
-
case LogLevel.ERROR:
|
|
24
|
-
case LogLevel.NONE:
|
|
25
|
-
return value;
|
|
26
|
-
default:
|
|
27
|
-
return fallback;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
if (typeof value !== 'string') {
|
|
31
|
-
return fallback;
|
|
32
|
-
}
|
|
33
|
-
const normalized = value.trim();
|
|
34
|
-
if (!normalized) {
|
|
35
|
-
return fallback;
|
|
36
|
-
}
|
|
37
|
-
if (/^\d+$/.test(normalized)) {
|
|
38
|
-
return normalizeLogLevel(Number(normalized), fallback);
|
|
39
|
-
}
|
|
40
|
-
switch(normalized.toUpperCase()){
|
|
41
|
-
case 'DEBUG':
|
|
42
|
-
return LogLevel.DEBUG;
|
|
43
|
-
case 'INFO':
|
|
44
|
-
return LogLevel.INFO;
|
|
45
|
-
case 'WARN':
|
|
46
|
-
return LogLevel.WARN;
|
|
47
|
-
case 'ERROR':
|
|
48
|
-
return LogLevel.ERROR;
|
|
49
|
-
case 'NONE':
|
|
50
|
-
return LogLevel.NONE;
|
|
51
|
-
default:
|
|
52
|
-
return fallback;
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
export class LoggerManager {
|
|
56
|
-
async initialize(context) {
|
|
57
|
-
this.config = context.config.logger;
|
|
58
|
-
const hasConfiguredLevel = this.config.level !== undefined && this.config.level !== null;
|
|
59
|
-
const configuredLevel = normalizeLogLevel(this.config.level, LogLevel.INFO);
|
|
60
|
-
if (hasConfiguredLevel) {
|
|
61
|
-
this.level = configuredLevel;
|
|
62
|
-
logger.setLevel(this.level);
|
|
63
|
-
await writePersistedValue(this.config.persistence, String(this.level));
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
const persisted = await readPersistedValue(this.config.persistence);
|
|
67
|
-
if (persisted !== null) {
|
|
68
|
-
this.level = normalizeLogLevel(persisted, configuredLevel);
|
|
69
|
-
logger.setLevel(this.level);
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
this.level = configuredLevel;
|
|
73
|
-
logger.setLevel(this.level);
|
|
74
|
-
await writePersistedValue(this.config.persistence, String(this.level));
|
|
75
|
-
}
|
|
76
|
-
debug(...args) {
|
|
77
|
-
logger.debug(...args);
|
|
78
|
-
}
|
|
79
|
-
info(...args) {
|
|
80
|
-
logger.info(...args);
|
|
81
|
-
}
|
|
82
|
-
warn(...args) {
|
|
83
|
-
logger.warn(...args);
|
|
84
|
-
}
|
|
85
|
-
error(...args) {
|
|
86
|
-
logger.error(...args);
|
|
87
|
-
}
|
|
88
|
-
async setLevel(level) {
|
|
89
|
-
this.level = level;
|
|
90
|
-
logger.setLevel(level);
|
|
91
|
-
await writePersistedValue(this.config.persistence, String(level));
|
|
92
|
-
}
|
|
93
|
-
getSnapshot() {
|
|
94
|
-
return {
|
|
95
|
-
level: this.level
|
|
96
|
-
};
|
|
97
|
-
}
|
|
98
|
-
constructor(){
|
|
99
|
-
_define_property(this, "level", LogLevel.INFO);
|
|
100
|
-
_define_property(this, "config", DEFAULT_CONFIG.logger);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
1
|
+
export { LoggerManager } from "./logger";
|
|
103
2
|
|
|
104
3
|
//# sourceMappingURL=loggerManager.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/kernel/manager/loggerManager.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"sources":["../../../src/kernel/manager/loggerManager.ts"],"sourcesContent":["export { LoggerManager } from './logger';\n"],"names":["LoggerManager"],"mappings":"AAAA,SAASA,aAAa,QAAQ,WAAW"}
|
package/dist/kernel/types.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import type { LogLevel } from '@vlian/logger';
|
|
2
|
-
import type { LangType } from '../library/locale/types';
|
|
3
2
|
import type { StartOptions as CoreStartOptions } from '../core/types';
|
|
4
3
|
import type { StorageOptions } from '../types';
|
|
5
4
|
import type { StorageInstance } from "@vlian/utils";
|
|
5
|
+
import type { Resource } from "i18next";
|
|
6
6
|
export type KernelInstanceId = string;
|
|
7
7
|
export type KernelStorageDriver = 'localStorage' | 'sessionStorage' | 'indexedDB' | 'none';
|
|
8
8
|
export interface ThemeSnapshot {
|
|
@@ -11,8 +11,8 @@ export interface ThemeSnapshot {
|
|
|
11
11
|
tokens?: Record<string, string | number>;
|
|
12
12
|
}
|
|
13
13
|
export interface I18nSnapshot {
|
|
14
|
-
locale:
|
|
15
|
-
resources?:
|
|
14
|
+
locale: string;
|
|
15
|
+
resources?: Resource;
|
|
16
16
|
}
|
|
17
17
|
export interface PersistenceOptions {
|
|
18
18
|
enabled?: boolean;
|
package/dist/kernel/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/kernel/types.ts"],"sourcesContent":["import type { LogLevel } from '@vlian/logger';\nimport type {
|
|
1
|
+
{"version":3,"sources":["../../src/kernel/types.ts"],"sourcesContent":["import type { LogLevel } from '@vlian/logger';\nimport type { StartOptions as CoreStartOptions } from '../core/types';\nimport type { StorageOptions } from '../types';\nimport type {StorageInstance} from \"@vlian/utils\"\nimport type { Resource } from \"i18next\";\n\nexport type KernelInstanceId = string;\nexport type KernelStorageDriver = 'localStorage' | 'sessionStorage' | 'indexedDB' | 'none';\n\nexport interface ThemeSnapshot {\n mode: 'light' | 'dark' | 'system';\n primaryColor?: string;\n tokens?: Record<string, string | number>;\n}\n\nexport interface I18nSnapshot {\n locale: string;\n resources?: Resource;\n}\n\nexport interface PersistenceOptions {\n enabled?: boolean;\n storage?: KernelStorageDriver;\n key?: string;\n}\n\nexport interface LoggerManagerConfig {\n level?: LogLevel;\n persistence?: PersistenceOptions;\n}\n\nexport interface CacheManagerConfig {\n enabled?: boolean;\n storageOptions?: Partial<StorageOptions>;\n}\n\nexport interface ThemeManagerConfig {\n initial?: ThemeSnapshot;\n persistence?: PersistenceOptions;\n}\n\nexport interface I18nManagerConfig {\n initial?: I18nSnapshot;\n persistence?: PersistenceOptions;\n}\n\nexport interface KernelConfig {\n logger: LoggerManagerConfig;\n cache: CacheManagerConfig;\n theme: ThemeManagerConfig;\n i18n: I18nManagerConfig;\n}\n\nexport interface KernelTimingMetric {\n phase: string;\n startTime: number;\n endTime: number;\n duration: number;\n}\n\nexport interface KernelManagerContext {\n instanceId: KernelInstanceId;\n config: KernelConfig;\n cacheManager: StorageInstance;\n}\n\nexport interface KernelManager<TSnapshot = unknown> {\n initialize: (context: KernelManagerContext) => Promise<void> | void;\n getSnapshot?: () => TSnapshot;\n destroy?: () => Promise<void> | void;\n}\n\nexport interface KernelRenderContext {\n instanceId: KernelInstanceId;\n config: KernelConfig;\n}\n\nexport interface StartupHooks {\n initialize?: () => Promise<void> | void;\n}\n\nexport interface StartOptions extends CoreStartOptions {\n config?: Partial<KernelConfig>;\n configLoader?: () => Promise<Partial<KernelConfig> | void> | Partial<KernelConfig> | void;\n render?: (context: KernelRenderContext) => Promise<void> | void;\n customManagers?: Record<string, KernelManager>;\n hooks?: StartupHooks;\n}\n\nexport type KernelStartOptions = StartOptions;\n"],"names":[],"mappings":"AAyFA,WAA8C"}
|
|
@@ -12,6 +12,9 @@ _export(exports, {
|
|
|
12
12
|
get $t () {
|
|
13
13
|
return $t;
|
|
14
14
|
},
|
|
15
|
+
get reactI18nextInstance () {
|
|
16
|
+
return reactI18nextInstance;
|
|
17
|
+
},
|
|
15
18
|
get setLang () {
|
|
16
19
|
return setLang;
|
|
17
20
|
},
|
|
@@ -21,47 +24,18 @@ _export(exports, {
|
|
|
21
24
|
});
|
|
22
25
|
const _i18next = /*#__PURE__*/ _interop_require_default(require("i18next"));
|
|
23
26
|
const _reacti18next = require("react-i18next");
|
|
24
|
-
const _enus = /*#__PURE__*/ _interop_require_default(require("./langs/en-us"));
|
|
25
|
-
const _zhcn = /*#__PURE__*/ _interop_require_default(require("./langs/zh-cn"));
|
|
26
27
|
function _interop_require_default(obj) {
|
|
27
28
|
return obj && obj.__esModule ? obj : {
|
|
28
29
|
default: obj
|
|
29
30
|
};
|
|
30
31
|
}
|
|
31
|
-
|
|
32
|
-
function setupI18n(
|
|
33
|
-
|
|
34
|
-
'zh-CN': {}
|
|
35
|
-
}) {
|
|
36
|
-
const locales = {
|
|
37
|
-
'en-US': {
|
|
38
|
-
translation: Object.assign({}, _enus.default, otherLocales['en-US'])
|
|
39
|
-
},
|
|
40
|
-
'zh-CN': {
|
|
41
|
-
translation: Object.assign({}, _zhcn.default, otherLocales['zh-CN'])
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
if (_i18next.default.isInitialized) {
|
|
45
|
-
_i18next.default.addResourceBundle('en-US', 'translation', locales['en-US'].translation, true, true);
|
|
46
|
-
_i18next.default.addResourceBundle('zh-CN', 'translation', locales['zh-CN'].translation, true, true);
|
|
47
|
-
return Promise.resolve(_i18next.default);
|
|
48
|
-
}
|
|
49
|
-
if (setupPromise) {
|
|
50
|
-
return setupPromise;
|
|
51
|
-
}
|
|
52
|
-
const initPromise = _i18next.default.use(_reacti18next.initReactI18next).init({
|
|
53
|
-
interpolation: {
|
|
54
|
-
escapeValue: false
|
|
55
|
-
},
|
|
56
|
-
lng: 'zh-CN',
|
|
57
|
-
resources: locales
|
|
58
|
-
}).then(()=>_i18next.default);
|
|
59
|
-
setupPromise = initPromise;
|
|
60
|
-
return initPromise;
|
|
32
|
+
const reactI18nextInstance = _i18next.default.use(_reacti18next.initReactI18next);
|
|
33
|
+
async function setupI18n(options, callback) {
|
|
34
|
+
await reactI18nextInstance.init(options, callback);
|
|
61
35
|
}
|
|
62
36
|
const $t = _i18next.default.t;
|
|
63
|
-
function setLang(locale) {
|
|
64
|
-
_i18next.default.changeLanguage(locale);
|
|
37
|
+
async function setLang(locale, callback) {
|
|
38
|
+
await _i18next.default.changeLanguage(locale, callback);
|
|
65
39
|
}
|
|
66
40
|
|
|
67
41
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/library/locale/index.ts"],"sourcesContent":["import i18n from 'i18next';\nimport { initReactI18next } from 'react-i18next';\nimport
|
|
1
|
+
{"version":3,"sources":["../../../src/library/locale/index.ts"],"sourcesContent":["import i18n from 'i18next';\nimport { initReactI18next } from 'react-i18next';\nimport type { Callback, InitOptions } from \"i18next\";\nexport const reactI18nextInstance = i18n.use(initReactI18next);\n\n\n/** Setup plugin i18n */\nexport async function setupI18n <T = unknown>(options: InitOptions<T>, callback?: Callback): Promise<void> {\n await reactI18nextInstance.init(options, callback);\n}\n\nexport const $t = i18n.t;\n\nexport async function setLang(locale: string, callback?: Callback) {\n await i18n.changeLanguage(locale, callback);\n}\n"],"names":["$t","reactI18nextInstance","setLang","setupI18n","i18n","use","initReactI18next","options","callback","init","t","locale","changeLanguage"],"mappings":";;;;;;;;;;;QAWaA;eAAAA;;QARAC;eAAAA;;QAUSC;eAAAA;;QANAC;eAAAA;;;gEAPL;8BACgB;;;;;;AAE1B,MAAMF,uBAAuBG,gBAAI,CAACC,GAAG,CAACC,8BAAgB;AAItD,eAAeH,UAAwBI,OAAuB,EAAEC,QAAmB;IACtF,MAAMP,qBAAqBQ,IAAI,CAACF,SAASC;AAC7C;AAEO,MAAMR,KAAKI,gBAAI,CAACM,CAAC;AAEjB,eAAeR,QAAQS,MAAc,EAAEH,QAAmB;IAC7D,MAAMJ,gBAAI,CAACQ,cAAc,CAACD,QAAQH;AACtC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
1
|
+
import type { Callback, InitOptions } from "i18next";
|
|
2
|
+
export declare const reactI18nextInstance: import("i18next").i18n;
|
|
3
3
|
/** Setup plugin i18n */
|
|
4
|
-
export declare function setupI18n(
|
|
4
|
+
export declare function setupI18n<T = unknown>(options: InitOptions<T>, callback?: Callback): Promise<void>;
|
|
5
5
|
export declare const $t: import("i18next").TFunction<["translation", ...string[]], undefined>;
|
|
6
|
-
export declare function setLang(locale:
|
|
6
|
+
export declare function setLang(locale: string, callback?: Callback): Promise<void>;
|
|
@@ -1,41 +1,12 @@
|
|
|
1
1
|
import i18n from "i18next";
|
|
2
2
|
import { initReactI18next } from "react-i18next";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
/** Setup plugin i18n */ export function setupI18n(otherLocales = {
|
|
7
|
-
'en-US': {},
|
|
8
|
-
'zh-CN': {}
|
|
9
|
-
}) {
|
|
10
|
-
const locales = {
|
|
11
|
-
'en-US': {
|
|
12
|
-
translation: Object.assign({}, enUS, otherLocales['en-US'])
|
|
13
|
-
},
|
|
14
|
-
'zh-CN': {
|
|
15
|
-
translation: Object.assign({}, zhCN, otherLocales['zh-CN'])
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
if (i18n.isInitialized) {
|
|
19
|
-
i18n.addResourceBundle('en-US', 'translation', locales['en-US'].translation, true, true);
|
|
20
|
-
i18n.addResourceBundle('zh-CN', 'translation', locales['zh-CN'].translation, true, true);
|
|
21
|
-
return Promise.resolve(i18n);
|
|
22
|
-
}
|
|
23
|
-
if (setupPromise) {
|
|
24
|
-
return setupPromise;
|
|
25
|
-
}
|
|
26
|
-
const initPromise = i18n.use(initReactI18next).init({
|
|
27
|
-
interpolation: {
|
|
28
|
-
escapeValue: false
|
|
29
|
-
},
|
|
30
|
-
lng: 'zh-CN',
|
|
31
|
-
resources: locales
|
|
32
|
-
}).then(()=>i18n);
|
|
33
|
-
setupPromise = initPromise;
|
|
34
|
-
return initPromise;
|
|
3
|
+
export const reactI18nextInstance = i18n.use(initReactI18next);
|
|
4
|
+
/** Setup plugin i18n */ export async function setupI18n(options, callback) {
|
|
5
|
+
await reactI18nextInstance.init(options, callback);
|
|
35
6
|
}
|
|
36
7
|
export const $t = i18n.t;
|
|
37
|
-
export function setLang(locale) {
|
|
38
|
-
i18n.changeLanguage(locale);
|
|
8
|
+
export async function setLang(locale, callback) {
|
|
9
|
+
await i18n.changeLanguage(locale, callback);
|
|
39
10
|
}
|
|
40
11
|
|
|
41
12
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/library/locale/index.ts"],"sourcesContent":["import i18n from 'i18next';\nimport { initReactI18next } from 'react-i18next';\nimport
|
|
1
|
+
{"version":3,"sources":["../../../src/library/locale/index.ts"],"sourcesContent":["import i18n from 'i18next';\nimport { initReactI18next } from 'react-i18next';\nimport type { Callback, InitOptions } from \"i18next\";\nexport const reactI18nextInstance = i18n.use(initReactI18next);\n\n\n/** Setup plugin i18n */\nexport async function setupI18n <T = unknown>(options: InitOptions<T>, callback?: Callback): Promise<void> {\n await reactI18nextInstance.init(options, callback);\n}\n\nexport const $t = i18n.t;\n\nexport async function setLang(locale: string, callback?: Callback) {\n await i18n.changeLanguage(locale, callback);\n}\n"],"names":["i18n","initReactI18next","reactI18nextInstance","use","setupI18n","options","callback","init","$t","t","setLang","locale","changeLanguage"],"mappings":"AAAA,OAAOA,UAAU,UAAU;AAC3B,SAASC,gBAAgB,QAAQ,gBAAgB;AAEjD,OAAO,MAAMC,uBAAuBF,KAAKG,GAAG,CAACF,kBAAkB;AAG/D,sBAAsB,GACtB,OAAO,eAAeG,UAAwBC,OAAuB,EAAEC,QAAmB;IACtF,MAAMJ,qBAAqBK,IAAI,CAACF,SAASC;AAC7C;AAEA,OAAO,MAAME,KAAKR,KAAKS,CAAC,CAAC;AAEzB,OAAO,eAAeC,QAAQC,MAAc,EAAEL,QAAmB;IAC7D,MAAMN,KAAKY,cAAc,CAACD,QAAQL;AACtC"}
|
package/dist/state.umd.js
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vlian/framework",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.56",
|
|
4
4
|
"private": false,
|
|
5
5
|
"packageManager": "pnpm@10.27.0",
|
|
6
6
|
"description": "Secra Framework - 一个现代化的低代码框架",
|
|
@@ -192,9 +192,11 @@
|
|
|
192
192
|
"antd": "^5.29.2",
|
|
193
193
|
"dumi": "^2.4.21",
|
|
194
194
|
"happy-dom": "^20.1.0",
|
|
195
|
+
"i18next": "^25.8.18",
|
|
195
196
|
"jsdom": "^27.4.0",
|
|
196
197
|
"react": "^19.2.3",
|
|
197
198
|
"react-dom": "^19.2.3",
|
|
199
|
+
"react-i18next": "^16.5.8",
|
|
198
200
|
"react-router-dom": "^7.12.0",
|
|
199
201
|
"rollup": "^4.55.1",
|
|
200
202
|
"rollup-plugin-peer-deps-external": "^2.2.4",
|