@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.
Files changed (67) hide show
  1. package/dist/analytics.umd.js +1 -1
  2. package/dist/core/initialization/initialization.cjs.map +1 -1
  3. package/dist/core/initialization/initialization.js +3 -3
  4. package/dist/core/initialization/initialization.js.map +1 -1
  5. package/dist/core/router/validation/RouterConfigValidator.d.ts +2 -2
  6. package/dist/core/router/validation/schema.d.ts +3 -3
  7. package/dist/index.umd.js +291 -228
  8. package/dist/index.umd.js.map +1 -1
  9. package/dist/kernel/manager/i18n/I18nManager.cjs +93 -0
  10. package/dist/kernel/manager/i18n/I18nManager.cjs.map +1 -0
  11. package/dist/kernel/manager/i18n/I18nManager.d.ts +15 -0
  12. package/dist/kernel/manager/i18n/I18nManager.js +83 -0
  13. package/dist/kernel/manager/i18n/I18nManager.js.map +1 -0
  14. package/dist/kernel/manager/i18n/i18n.persistence.cjs +59 -0
  15. package/dist/kernel/manager/i18n/i18n.persistence.cjs.map +1 -0
  16. package/dist/kernel/manager/i18n/i18n.persistence.d.ts +5 -0
  17. package/dist/kernel/manager/i18n/i18n.persistence.js +38 -0
  18. package/dist/kernel/manager/i18n/i18n.persistence.js.map +1 -0
  19. package/dist/kernel/manager/i18n/i18n.schema.cjs +88 -0
  20. package/dist/kernel/manager/i18n/i18n.schema.cjs.map +1 -0
  21. package/dist/kernel/manager/i18n/i18n.schema.d.ts +6 -0
  22. package/dist/kernel/manager/i18n/i18n.schema.js +64 -0
  23. package/dist/kernel/manager/i18n/i18n.schema.js.map +1 -0
  24. package/dist/kernel/manager/i18n/index.cjs +13 -0
  25. package/dist/kernel/manager/i18n/index.cjs.map +1 -0
  26. package/dist/kernel/manager/i18n/index.d.ts +1 -0
  27. package/dist/kernel/manager/i18n/index.js +3 -0
  28. package/dist/kernel/manager/i18n/index.js.map +1 -0
  29. package/dist/kernel/manager/i18nManager.cjs +2 -77
  30. package/dist/kernel/manager/i18nManager.cjs.map +1 -1
  31. package/dist/kernel/manager/i18nManager.d.ts +1 -13
  32. package/dist/kernel/manager/i18nManager.js +1 -76
  33. package/dist/kernel/manager/i18nManager.js.map +1 -1
  34. package/dist/kernel/manager/logger/LoggerManager.cjs +109 -0
  35. package/dist/kernel/manager/logger/LoggerManager.cjs.map +1 -0
  36. package/dist/kernel/manager/logger/LoggerManager.d.ts +21 -0
  37. package/dist/kernel/manager/logger/LoggerManager.js +99 -0
  38. package/dist/kernel/manager/logger/LoggerManager.js.map +1 -0
  39. package/dist/kernel/manager/logger/index.cjs +13 -0
  40. package/dist/kernel/manager/logger/index.cjs.map +1 -0
  41. package/dist/kernel/manager/logger/index.d.ts +1 -0
  42. package/dist/kernel/manager/logger/index.js +3 -0
  43. package/dist/kernel/manager/logger/index.js.map +1 -0
  44. package/dist/kernel/manager/logger/logger.persistence.cjs +64 -0
  45. package/dist/kernel/manager/logger/logger.persistence.cjs.map +1 -0
  46. package/dist/kernel/manager/logger/logger.persistence.d.ts +6 -0
  47. package/dist/kernel/manager/logger/logger.persistence.js +43 -0
  48. package/dist/kernel/manager/logger/logger.persistence.js.map +1 -0
  49. package/dist/kernel/manager/logger/logger.schema.cjs +76 -0
  50. package/dist/kernel/manager/logger/logger.schema.cjs.map +1 -0
  51. package/dist/kernel/manager/logger/logger.schema.d.ts +8 -0
  52. package/dist/kernel/manager/logger/logger.schema.js +55 -0
  53. package/dist/kernel/manager/logger/logger.schema.js.map +1 -0
  54. package/dist/kernel/manager/loggerManager.cjs +2 -103
  55. package/dist/kernel/manager/loggerManager.cjs.map +1 -1
  56. package/dist/kernel/manager/loggerManager.d.ts +1 -18
  57. package/dist/kernel/manager/loggerManager.js +1 -102
  58. package/dist/kernel/manager/loggerManager.js.map +1 -1
  59. package/dist/kernel/types.d.ts +3 -3
  60. package/dist/kernel/types.js.map +1 -1
  61. package/dist/library/locale/index.cjs +8 -34
  62. package/dist/library/locale/index.cjs.map +1 -1
  63. package/dist/library/locale/index.d.ts +4 -4
  64. package/dist/library/locale/index.js +5 -34
  65. package/dist/library/locale/index.js.map +1 -1
  66. package/dist/state.umd.js +1 -1
  67. 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("@vlian/logger");
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":["import { logger, LogLevel } from '@vlian/logger';\nimport type { Logger } from '@vlian/logger';\nimport type { KernelConfig, KernelManager, KernelManagerContext } from '../types';\nimport { DEFAULT_CONFIG } from '../constants';\nimport { readPersistedValue, writePersistedValue } from './persistence';\n\nfunction 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 class LoggerManager implements KernelManager<{ level: LogLevel }> {\n private level: LogLevel = LogLevel.INFO;\n private config: KernelConfig['logger'] = DEFAULT_CONFIG.logger;\n\n public async initialize(context: KernelManagerContext): Promise<void> {\n this.config = context.config.logger;\n const hasConfiguredLevel = this.config.level !== undefined && this.config.level !== null;\n const configuredLevel = normalizeLogLevel(this.config.level, LogLevel.INFO);\n\n if (hasConfiguredLevel) {\n this.level = configuredLevel;\n logger.setLevel(this.level);\n await writePersistedValue(this.config.persistence, String(this.level));\n return;\n }\n\n const persisted = await readPersistedValue(this.config.persistence);\n\n if (persisted !== null) {\n this.level = normalizeLogLevel(persisted, configuredLevel);\n logger.setLevel(this.level);\n return;\n }\n\n this.level = configuredLevel;\n logger.setLevel(this.level);\n await writePersistedValue(this.config.persistence, String(this.level));\n }\n\n public debug(...args: Parameters<Logger['debug']>): void {\n logger.debug(...args);\n }\n\n public info(...args: Parameters<Logger['info']>): void {\n logger.info(...args);\n }\n\n public warn(...args: Parameters<Logger['warn']>): void {\n logger.warn(...args);\n }\n\n public error(...args: Parameters<Logger['error']>): void {\n logger.error(...args);\n }\n\n public async setLevel(level: LogLevel): Promise<void> {\n this.level = level;\n logger.setLevel(level);\n await writePersistedValue(this.config.persistence, String(level));\n }\n\n public getSnapshot(): { level: LogLevel } {\n return { level: this.level };\n }\n}\n"],"names":["LoggerManager","normalizeLogLevel","value","fallback","Number","isInteger","LogLevel","DEBUG","INFO","WARN","ERROR","NONE","normalized","trim","test","toUpperCase","initialize","context","config","logger","hasConfiguredLevel","level","undefined","configuredLevel","setLevel","writePersistedValue","persistence","String","persisted","readPersistedValue","debug","args","info","warn","error","getSnapshot","DEFAULT_CONFIG"],"mappings":"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"}
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
- import { LogLevel } from '@vlian/logger';
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
- function _define_property(obj, key, value) {
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":["import { logger, LogLevel } from '@vlian/logger';\nimport type { Logger } from '@vlian/logger';\nimport type { KernelConfig, KernelManager, KernelManagerContext } from '../types';\nimport { DEFAULT_CONFIG } from '../constants';\nimport { readPersistedValue, writePersistedValue } from './persistence';\n\nfunction 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 class LoggerManager implements KernelManager<{ level: LogLevel }> {\n private level: LogLevel = LogLevel.INFO;\n private config: KernelConfig['logger'] = DEFAULT_CONFIG.logger;\n\n public async initialize(context: KernelManagerContext): Promise<void> {\n this.config = context.config.logger;\n const hasConfiguredLevel = this.config.level !== undefined && this.config.level !== null;\n const configuredLevel = normalizeLogLevel(this.config.level, LogLevel.INFO);\n\n if (hasConfiguredLevel) {\n this.level = configuredLevel;\n logger.setLevel(this.level);\n await writePersistedValue(this.config.persistence, String(this.level));\n return;\n }\n\n const persisted = await readPersistedValue(this.config.persistence);\n\n if (persisted !== null) {\n this.level = normalizeLogLevel(persisted, configuredLevel);\n logger.setLevel(this.level);\n return;\n }\n\n this.level = configuredLevel;\n logger.setLevel(this.level);\n await writePersistedValue(this.config.persistence, String(this.level));\n }\n\n public debug(...args: Parameters<Logger['debug']>): void {\n logger.debug(...args);\n }\n\n public info(...args: Parameters<Logger['info']>): void {\n logger.info(...args);\n }\n\n public warn(...args: Parameters<Logger['warn']>): void {\n logger.warn(...args);\n }\n\n public error(...args: Parameters<Logger['error']>): void {\n logger.error(...args);\n }\n\n public async setLevel(level: LogLevel): Promise<void> {\n this.level = level;\n logger.setLevel(level);\n await writePersistedValue(this.config.persistence, String(level));\n }\n\n public getSnapshot(): { level: LogLevel } {\n return { level: this.level };\n }\n}\n"],"names":["logger","LogLevel","DEFAULT_CONFIG","readPersistedValue","writePersistedValue","normalizeLogLevel","value","fallback","Number","isInteger","DEBUG","INFO","WARN","ERROR","NONE","normalized","trim","test","toUpperCase","LoggerManager","initialize","context","config","hasConfiguredLevel","level","undefined","configuredLevel","setLevel","persistence","String","persisted","debug","args","info","warn","error","getSnapshot"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/kernel/manager/loggerManager.ts"],"sourcesContent":["export { LoggerManager } from './logger';\n"],"names":["LoggerManager"],"mappings":"AAAA,SAASA,aAAa,QAAQ,WAAW"}
@@ -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: LangType;
15
- resources?: Record<LangType, Record<string, unknown>>;
14
+ locale: string;
15
+ resources?: Resource;
16
16
  }
17
17
  export interface PersistenceOptions {
18
18
  enabled?: boolean;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/kernel/types.ts"],"sourcesContent":["import type { LogLevel } from '@vlian/logger';\nimport type { LangType } from '../library/locale/types';\nimport type { StartOptions as CoreStartOptions } from '../core/types';\nimport type { StorageOptions } from '../types';\nimport type {StorageInstance} from \"@vlian/utils\"\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: LangType;\n resources?: Record<LangType, Record<string, unknown>>;\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"}
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
- let setupPromise = null;
32
- function setupI18n(otherLocales = {
33
- 'en-US': {},
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 enUS from './langs/en-us';\nimport zhCN from './langs/zh-cn';\n\nimport { LangType, Schema } from \"./types\"\n\nlet setupPromise: Promise<typeof i18n> | null = null;\n\n/** Setup plugin i18n */\nexport function setupI18n(otherLocales: Record<LangType, Record<string, unknown>> = {\n 'en-US': {},\n 'zh-CN': {}\n}): Promise<typeof i18n> {\n const locales: Record<LangType, Schema> = {\n 'en-US': {\n translation: Object.assign({}, enUS, otherLocales['en-US'])\n },\n 'zh-CN': {\n translation: Object.assign({}, zhCN, otherLocales['zh-CN'])\n }\n };\n\n if (i18n.isInitialized) {\n i18n.addResourceBundle('en-US', 'translation', locales['en-US'].translation, true, true);\n i18n.addResourceBundle('zh-CN', 'translation', locales['zh-CN'].translation, true, true);\n return Promise.resolve(i18n);\n }\n\n if (setupPromise) {\n return setupPromise;\n }\n\n const initPromise = i18n.use(initReactI18next).init({\n interpolation: {\n escapeValue: false\n },\n lng: 'zh-CN',\n resources: locales\n }).then(() => i18n);\n\n setupPromise = initPromise;\n\n return initPromise;\n}\n\nexport const $t = i18n.t;\n\nexport function setLang(locale: LangType) {\n i18n.changeLanguage(locale);\n}\n"],"names":["$t","setLang","setupI18n","setupPromise","otherLocales","locales","translation","Object","assign","enUS","zhCN","i18n","isInitialized","addResourceBundle","Promise","resolve","initPromise","use","initReactI18next","init","interpolation","escapeValue","lng","resources","then","t","locale","changeLanguage"],"mappings":";;;;;;;;;;;QA8CaA;eAAAA;;QAEGC;eAAAA;;QAtCAC;eAAAA;;;gEAVC;8BACgB;6DAChB;6DACA;;;;;;AAIjB,IAAIC,eAA4C;AAGzC,SAASD,UAAUE,eAA0D;IAChF,SAAS,CAAC;IACV,SAAS,CAAC;AACd,CAAC;IACG,MAAMC,UAAoC;QACtC,SAAS;YACLC,aAAaC,OAAOC,MAAM,CAAC,CAAC,GAAGC,aAAI,EAAEL,YAAY,CAAC,QAAQ;QAC9D;QACA,SAAS;YACLE,aAAaC,OAAOC,MAAM,CAAC,CAAC,GAAGE,aAAI,EAAEN,YAAY,CAAC,QAAQ;QAC9D;IACJ;IAEA,IAAIO,gBAAI,CAACC,aAAa,EAAE;QACpBD,gBAAI,CAACE,iBAAiB,CAAC,SAAS,eAAeR,OAAO,CAAC,QAAQ,CAACC,WAAW,EAAE,MAAM;QACnFK,gBAAI,CAACE,iBAAiB,CAAC,SAAS,eAAeR,OAAO,CAAC,QAAQ,CAACC,WAAW,EAAE,MAAM;QACnF,OAAOQ,QAAQC,OAAO,CAACJ,gBAAI;IAC/B;IAEA,IAAIR,cAAc;QACd,OAAOA;IACX;IAEA,MAAMa,cAAcL,gBAAI,CAACM,GAAG,CAACC,8BAAgB,EAAEC,IAAI,CAAC;QAChDC,eAAe;YACXC,aAAa;QACjB;QACAC,KAAK;QACLC,WAAWlB;IACf,GAAGmB,IAAI,CAAC,IAAMb,gBAAI;IAElBR,eAAea;IAEf,OAAOA;AACX;AAEO,MAAMhB,KAAKW,gBAAI,CAACc,CAAC;AAEjB,SAASxB,QAAQyB,MAAgB;IACpCf,gBAAI,CAACgB,cAAc,CAACD;AACxB"}
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 i18n from 'i18next';
2
- import { LangType } from "./types";
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(otherLocales?: Record<LangType, Record<string, unknown>>): Promise<typeof i18n>;
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: LangType): void;
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
- import enUS from "./langs/en-us";
4
- import zhCN from "./langs/zh-cn";
5
- let setupPromise = null;
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 enUS from './langs/en-us';\nimport zhCN from './langs/zh-cn';\n\nimport { LangType, Schema } from \"./types\"\n\nlet setupPromise: Promise<typeof i18n> | null = null;\n\n/** Setup plugin i18n */\nexport function setupI18n(otherLocales: Record<LangType, Record<string, unknown>> = {\n 'en-US': {},\n 'zh-CN': {}\n}): Promise<typeof i18n> {\n const locales: Record<LangType, Schema> = {\n 'en-US': {\n translation: Object.assign({}, enUS, otherLocales['en-US'])\n },\n 'zh-CN': {\n translation: Object.assign({}, zhCN, otherLocales['zh-CN'])\n }\n };\n\n if (i18n.isInitialized) {\n i18n.addResourceBundle('en-US', 'translation', locales['en-US'].translation, true, true);\n i18n.addResourceBundle('zh-CN', 'translation', locales['zh-CN'].translation, true, true);\n return Promise.resolve(i18n);\n }\n\n if (setupPromise) {\n return setupPromise;\n }\n\n const initPromise = i18n.use(initReactI18next).init({\n interpolation: {\n escapeValue: false\n },\n lng: 'zh-CN',\n resources: locales\n }).then(() => i18n);\n\n setupPromise = initPromise;\n\n return initPromise;\n}\n\nexport const $t = i18n.t;\n\nexport function setLang(locale: LangType) {\n i18n.changeLanguage(locale);\n}\n"],"names":["i18n","initReactI18next","enUS","zhCN","setupPromise","setupI18n","otherLocales","locales","translation","Object","assign","isInitialized","addResourceBundle","Promise","resolve","initPromise","use","init","interpolation","escapeValue","lng","resources","then","$t","t","setLang","locale","changeLanguage"],"mappings":"AAAA,OAAOA,UAAU,UAAU;AAC3B,SAASC,gBAAgB,QAAQ,gBAAgB;AACjD,OAAOC,UAAU,gBAAgB;AACjC,OAAOC,UAAU,gBAAgB;AAIjC,IAAIC,eAA4C;AAEhD,sBAAsB,GACtB,OAAO,SAASC,UAAUC,eAA0D;IAChF,SAAS,CAAC;IACV,SAAS,CAAC;AACd,CAAC;IACG,MAAMC,UAAoC;QACtC,SAAS;YACLC,aAAaC,OAAOC,MAAM,CAAC,CAAC,GAAGR,MAAMI,YAAY,CAAC,QAAQ;QAC9D;QACA,SAAS;YACLE,aAAaC,OAAOC,MAAM,CAAC,CAAC,GAAGP,MAAMG,YAAY,CAAC,QAAQ;QAC9D;IACJ;IAEA,IAAIN,KAAKW,aAAa,EAAE;QACpBX,KAAKY,iBAAiB,CAAC,SAAS,eAAeL,OAAO,CAAC,QAAQ,CAACC,WAAW,EAAE,MAAM;QACnFR,KAAKY,iBAAiB,CAAC,SAAS,eAAeL,OAAO,CAAC,QAAQ,CAACC,WAAW,EAAE,MAAM;QACnF,OAAOK,QAAQC,OAAO,CAACd;IAC3B;IAEA,IAAII,cAAc;QACd,OAAOA;IACX;IAEA,MAAMW,cAAcf,KAAKgB,GAAG,CAACf,kBAAkBgB,IAAI,CAAC;QAChDC,eAAe;YACXC,aAAa;QACjB;QACAC,KAAK;QACLC,WAAWd;IACf,GAAGe,IAAI,CAAC,IAAMtB;IAEdI,eAAeW;IAEf,OAAOA;AACX;AAEA,OAAO,MAAMQ,KAAKvB,KAAKwB,CAAC,CAAC;AAEzB,OAAO,SAASC,QAAQC,MAAgB;IACpC1B,KAAK2B,cAAc,CAACD;AACxB"}
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
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * @vlian/framework v1.2.54
2
+ * @vlian/framework v1.2.55
3
3
  * Secra Framework - 一个现代化的低代码框架
4
4
  * (c) 2026 Secra Framework Contributors
5
5
  * Licensed under Apache-2.0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vlian/framework",
3
- "version": "1.2.55",
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",