nfx-ui 0.4.0 → 0.5.1
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/{chunk-i18n-Bp6pPM9n.mjs → chunk-i18n-BBPhh6MT.mjs} +22 -19
- package/dist/chunk-i18n-BBPhh6MT.mjs.map +1 -0
- package/dist/chunk-i18n-daHSL0Nm.cjs +3 -0
- package/dist/chunk-i18n-daHSL0Nm.cjs.map +1 -0
- package/dist/{chunk-preference-DImtu5jI.mjs → chunk-preference-By58ZcJ_.mjs} +2 -2
- package/dist/{chunk-preference-DImtu5jI.mjs.map → chunk-preference-By58ZcJ_.mjs.map} +1 -1
- package/dist/{chunk-preference-CYl68oeU.cjs → chunk-preference-C144GkCD.cjs} +2 -2
- package/dist/{chunk-preference-CYl68oeU.cjs.map → chunk-preference-C144GkCD.cjs.map} +1 -1
- package/dist/chunk-types-BNUlgEkq.cjs +3 -0
- package/dist/{chunk-types-BkFxelHl.mjs.map → chunk-types-BNUlgEkq.cjs.map} +1 -1
- package/dist/{chunk-types-BkFxelHl.mjs → chunk-types-BudGuDCK.mjs} +8 -8
- package/dist/{chunk-types-CkbZrFqZ.cjs.map → chunk-types-BudGuDCK.mjs.map} +1 -1
- package/dist/components.d.ts +3 -1
- package/dist/events.cjs.map +1 -1
- package/dist/events.d.ts +7 -14
- package/dist/events.mjs.map +1 -1
- package/dist/languages.cjs +1 -1
- package/dist/languages.d.ts +3 -1
- package/dist/languages.mjs +1 -1
- package/dist/layouts.cjs +1 -1
- package/dist/layouts.mjs +2 -2
- package/dist/preference.cjs +1 -1
- package/dist/preference.d.ts +3 -1
- package/dist/preference.mjs +2 -2
- package/dist/themes.cjs +1 -1
- package/dist/themes.cjs.map +1 -1
- package/dist/themes.d.ts +3 -1
- package/dist/themes.mjs +164 -70
- package/dist/themes.mjs.map +1 -1
- package/dist/utils.cjs +1 -1
- package/dist/utils.mjs +1 -1
- package/package.json +1 -1
- package/dist/chunk-i18n-Bp6pPM9n.mjs.map +0 -1
- package/dist/chunk-i18n-_7W7guSV.cjs +0 -3
- package/dist/chunk-i18n-_7W7guSV.cjs.map +0 -1
- package/dist/chunk-types-CkbZrFqZ.cjs +0 -3
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { i as n } from "./chunk-types-SD4MzUGp.mjs";
|
|
2
2
|
import t from "i18next";
|
|
3
3
|
import g from "i18next-browser-languagedetector";
|
|
4
|
-
import { initReactI18next as
|
|
5
|
-
const
|
|
4
|
+
import { initReactI18next as w } from "react-i18next";
|
|
5
|
+
const m = {
|
|
6
6
|
show: "Show Sidebar",
|
|
7
7
|
hide: "Hide Sidebar"
|
|
8
8
|
};
|
|
9
|
-
var p = { layoutSwitcher:
|
|
9
|
+
var p = { layoutSwitcher: m };
|
|
10
10
|
const E = {
|
|
11
11
|
en: "English",
|
|
12
12
|
zh: "Chinese",
|
|
@@ -37,7 +37,8 @@ const $ = {
|
|
|
37
37
|
corporate: "Corporate",
|
|
38
38
|
forest: "Forest",
|
|
39
39
|
coffee: "Coffee",
|
|
40
|
-
wine: "Wine"
|
|
40
|
+
wine: "Wine",
|
|
41
|
+
wheat: "Wheat"
|
|
41
42
|
};
|
|
42
43
|
var b = { themeSwitcher: $ };
|
|
43
44
|
const v = {
|
|
@@ -75,7 +76,8 @@ const F = {
|
|
|
75
76
|
corporate: "Entreprise",
|
|
76
77
|
forest: "Forêt",
|
|
77
78
|
coffee: "Coffee",
|
|
78
|
-
wine: "Vin"
|
|
79
|
+
wine: "Vin",
|
|
80
|
+
wheat: "Blé"
|
|
79
81
|
};
|
|
80
82
|
var O = { themeSwitcher: F };
|
|
81
83
|
const k = {
|
|
@@ -88,22 +90,22 @@ const U = {
|
|
|
88
90
|
zh: "中文",
|
|
89
91
|
fr: "法语"
|
|
90
92
|
};
|
|
91
|
-
var
|
|
92
|
-
const
|
|
93
|
+
var W = { languageSwitcher: U };
|
|
94
|
+
const z = {
|
|
93
95
|
default: "默认",
|
|
94
96
|
ios: "iOS",
|
|
95
97
|
android: "Android",
|
|
96
98
|
windows: "Windows",
|
|
97
99
|
linux: "Linux"
|
|
98
|
-
},
|
|
100
|
+
}, B = {
|
|
99
101
|
theme: "主题",
|
|
100
102
|
language: "语言",
|
|
101
103
|
layout: "布局",
|
|
102
104
|
preferences: "偏好设置"
|
|
103
105
|
};
|
|
104
|
-
var
|
|
105
|
-
baseSwitcher:
|
|
106
|
-
preference:
|
|
106
|
+
var T = {
|
|
107
|
+
baseSwitcher: z,
|
|
108
|
+
preference: B
|
|
107
109
|
};
|
|
108
110
|
const H = {
|
|
109
111
|
default: "默认",
|
|
@@ -113,7 +115,8 @@ const H = {
|
|
|
113
115
|
corporate: "企业",
|
|
114
116
|
forest: "森林",
|
|
115
117
|
coffee: "咖啡",
|
|
116
|
-
wine: "酒红"
|
|
118
|
+
wine: "酒红",
|
|
119
|
+
wheat: "麦田"
|
|
117
120
|
};
|
|
118
121
|
var X = { themeSwitcher: H };
|
|
119
122
|
const q = [
|
|
@@ -136,9 +139,9 @@ var V = {
|
|
|
136
139
|
},
|
|
137
140
|
zh: {
|
|
138
141
|
theme: X,
|
|
139
|
-
language:
|
|
142
|
+
language: W,
|
|
140
143
|
layout: D,
|
|
141
|
-
preference:
|
|
144
|
+
preference: T
|
|
142
145
|
},
|
|
143
146
|
fr: {
|
|
144
147
|
theme: O,
|
|
@@ -155,7 +158,7 @@ function Z() {
|
|
|
155
158
|
};
|
|
156
159
|
}
|
|
157
160
|
function Q(o) {
|
|
158
|
-
const l = Z(), i = o.bundles, c = o.fallbackLng ?? n.ZH,
|
|
161
|
+
const l = Z(), i = o.bundles, c = o.fallbackLng ?? n.ZH, d = [
|
|
159
162
|
n.EN,
|
|
160
163
|
n.ZH,
|
|
161
164
|
n.FR
|
|
@@ -166,9 +169,9 @@ function Q(o) {
|
|
|
166
169
|
...i.RESOURCES[e] ?? {}
|
|
167
170
|
}
|
|
168
171
|
}), {}), s = [...i.NAME_SPACES, ...l.NAME_SPACES.filter((a) => !i.NAME_SPACES.includes(a))];
|
|
169
|
-
t.use(g).use(
|
|
172
|
+
t.use(g).use(w).init({
|
|
170
173
|
compatibilityJSON: "v4",
|
|
171
|
-
resources:
|
|
174
|
+
resources: d,
|
|
172
175
|
lng: c,
|
|
173
176
|
fallbackLng: c,
|
|
174
177
|
ns: s,
|
|
@@ -188,7 +191,7 @@ function Q(o) {
|
|
|
188
191
|
const r = await f(e);
|
|
189
192
|
if (r == null) return;
|
|
190
193
|
const S = Array.isArray(r) ? r : [r];
|
|
191
|
-
for (const { namespace:
|
|
194
|
+
for (const { namespace: h, bundle: u } of S) h && u && typeof u == "object" && t.addResourceBundle(e, h, u, !0, !0);
|
|
192
195
|
};
|
|
193
196
|
a(t.language || c), t.on("languageChanged", (e) => {
|
|
194
197
|
a(e);
|
|
@@ -204,4 +207,4 @@ export {
|
|
|
204
207
|
Y as t
|
|
205
208
|
};
|
|
206
209
|
|
|
207
|
-
//# sourceMappingURL=chunk-i18n-
|
|
210
|
+
//# sourceMappingURL=chunk-i18n-BBPhh6MT.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-i18n-BBPhh6MT.mjs","names":[],"sources":["../src/languages/resources/en/layout.json","../src/languages/resources/en/language.json","../src/languages/resources/en/preference.json","../src/languages/resources/en/theme.json","../src/languages/resources/fr/layout.json","../src/languages/resources/fr/language.json","../src/languages/resources/fr/preference.json","../src/languages/resources/fr/theme.json","../src/languages/resources/zh/layout.json","../src/languages/resources/zh/language.json","../src/languages/resources/zh/preference.json","../src/languages/resources/zh/theme.json","../src/languages/resources/index.ts","../src/languages/languages/i18n.ts"],"sourcesContent":["{\n \"layoutSwitcher\": {\n \"show\": \"Show Sidebar\",\n \"hide\": \"Hide Sidebar\"\n }\n}\n","{\n \"languageSwitcher\": {\n \"en\": \"English\",\n \"zh\": \"Chinese\",\n \"fr\": \"French\"\n }\n}\n","{\n \"baseSwitcher\": {\n \"default\": \"Default\",\n \"ios\": \"iOS\",\n \"android\": \"Android\",\n \"windows\": \"Windows\",\n \"linux\": \"Linux\"\n },\n \"preference\": {\n \"theme\": \"Theme\",\n \"language\": \"Language\",\n \"layout\": \"Layout\",\n \"preferences\": \"Preferences\"\n }\n}\n","{\n \"themeSwitcher\": {\n \"default\": \"Default\",\n \"light\": \"Light\",\n \"dark\": \"Dark\",\n \"cosmic\": \"Cosmic\",\n \"corporate\": \"Corporate\",\n \"forest\": \"Forest\",\n \"coffee\": \"Coffee\",\n \"wine\": \"Wine\",\n \"wheat\": \"Wheat\"\n }\n}\n","{\n \"layoutSwitcher\": {\n \"show\": \"Afficher la barre latérale\",\n \"hide\": \"Masquer la barre latérale\"\n }\n}\n","{\n \"languageSwitcher\": {\n \"en\": \"Anglais\",\n \"zh\": \"Chinois\",\n \"fr\": \"Français\"\n }\n}\n","{\n \"baseSwitcher\": {\n \"default\": \"Par défaut\",\n \"ios\": \"iOS\",\n \"android\": \"Android\",\n \"windows\": \"Windows\",\n \"linux\": \"Linux\"\n },\n \"preference\": {\n \"theme\": \"Thème\",\n \"language\": \"Langue\",\n \"layout\": \"Disposition\",\n \"preferences\": \"Préférences\"\n }\n}\n","{\n \"themeSwitcher\": {\n \"default\": \"Par défaut\",\n \"light\": \"Clair\",\n \"dark\": \"Sombre\",\n \"cosmic\": \"Cosmique\",\n \"corporate\": \"Entreprise\",\n \"forest\": \"Forêt\",\n \"coffee\": \"Coffee\",\n \"wine\": \"Vin\",\n \"wheat\": \"Blé\"\n }\n}\n","{\n \"layoutSwitcher\": {\n \"show\": \"显示侧边栏\",\n \"hide\": \"隐藏侧边栏\"\n }\n}\n","{\n \"languageSwitcher\": {\n \"en\": \"英语\",\n \"zh\": \"中文\",\n \"fr\": \"法语\"\n }\n}\n","{\n \"baseSwitcher\": {\n \"default\": \"默认\",\n \"ios\": \"iOS\",\n \"android\": \"Android\",\n \"windows\": \"Windows\",\n \"linux\": \"Linux\"\n },\n \"preference\": {\n \"theme\": \"主题\",\n \"language\": \"语言\",\n \"layout\": \"布局\",\n \"preferences\": \"偏好设置\"\n }\n}\n","{\n \"themeSwitcher\": {\n \"default\": \"默认\",\n \"light\": \"浅色\",\n \"dark\": \"深色\",\n \"cosmic\": \"宇宙\",\n \"corporate\": \"企业\",\n \"forest\": \"森林\",\n \"coffee\": \"咖啡\",\n \"wine\": \"酒红\",\n \"wheat\": \"麦田\"\n }\n}\n","/**\n * NFX-UI 内置多语言资源:theme / language / layout / preference 四个命名空间,en / zh / fr 三种语言。\n * Built-in i18n resources: namespaces theme, language, layout, preference; languages en, zh, fr.\n *\n * 使用方可在 createI18nResources 时合并此资源,使 ThemeSwitcher / LanguageSwitcher / LayoutSwitcher 使用默认翻译。\n * Consumers can merge these resources in createI18nResources so switchers use default labels.\n */\nimport type { CreateI18nResourcesResult, NameSpacesMap, Resources } from \"../types\";\n\nimport enLayout from \"./en/layout.json\";\nimport enLanguage from \"./en/language.json\";\nimport enPreference from \"./en/preference.json\";\nimport enTheme from \"./en/theme.json\";\nimport frLayout from \"./fr/layout.json\";\nimport frLanguage from \"./fr/language.json\";\nimport frPreference from \"./fr/preference.json\";\nimport frTheme from \"./fr/theme.json\";\nimport zhLayout from \"./zh/layout.json\";\nimport zhLanguage from \"./zh/language.json\";\nimport zhPreference from \"./zh/preference.json\";\nimport zhTheme from \"./zh/theme.json\";\n\nexport const NFX_NAMESPACES = [\"theme\", \"language\", \"layout\", \"preference\"] as const;\nexport const NFX_NAMESPACES_MAP: NameSpacesMap = {\n theme: \"theme\",\n language: \"language\",\n layout: \"layout\",\n preference: \"preference\",\n};\n\nconst DEFAULT_NFX_RESOURCES: Resources = {\n en: {\n theme: enTheme as Record<string, unknown>,\n language: enLanguage as Record<string, unknown>,\n layout: enLayout as Record<string, unknown>,\n preference: enPreference as Record<string, unknown>,\n },\n zh: {\n theme: zhTheme as Record<string, unknown>,\n language: zhLanguage as Record<string, unknown>,\n layout: zhLayout as Record<string, unknown>,\n preference: zhPreference as Record<string, unknown>,\n },\n fr: {\n theme: frTheme as Record<string, unknown>,\n language: frLanguage as Record<string, unknown>,\n layout: frLayout as Record<string, unknown>,\n preference: frPreference as Record<string, unknown>,\n },\n};\n\n/**\n * 返回 NFX-UI 默认文案包,可与使用方自建 resources 合并后传入 createI18nResources。\n * Returns default NFX bundles; merge with your resources and pass to createI18nResources.\n */\nexport function getDefaultNfxBundles(): CreateI18nResourcesResult {\n return {\n RESOURCES: DEFAULT_NFX_RESOURCES,\n NAME_SPACES_MAP: NFX_NAMESPACES_MAP,\n NAME_SPACES: [...NFX_NAMESPACES],\n };\n}\n","/**\n * i18n 初始化与实例:initI18n 由 LanguageProvider 调用,changeLanguage 供外部切换语言。\n * 默认会合并 NFX-UI 自带的 theme / language / layout / preference 四个命名空间,使用方只需传入自己的 bundles。\n * i18n init and instance: initI18n called by LanguageProvider. Merges built-in theme/language/layout/preference by default.\n */\nimport type { InitI18nOptions } from \"../types\";\n\nimport i18n from \"i18next\";\nimport LanguageDetector from \"i18next-browser-languagedetector\";\nimport { initReactI18next } from \"react-i18next\";\n\nimport { getDefaultNfxBundles } from \"../resources\";\nimport { LanguageEnum } from \"../types\";\n\n/**\n * 初始化 i18n。会先合并 NFX-UI 自带的四类 JSON(theme/language/layout/preference),再与用户传入的 bundles 合并(用户可覆盖)。\n * Init i18n. Merges built-in NFX bundles (theme, language, layout, preference) with user bundles (user overrides).\n */\nexport function initI18n(options: InitI18nOptions): void {\n const nfx = getDefaultNfxBundles();\n const user = options.bundles;\n const fallbackLng = options.fallbackLng ?? LanguageEnum.ZH;\n\n const RESOURCES = ([LanguageEnum.EN, LanguageEnum.ZH, LanguageEnum.FR] as const).reduce(\n (acc, lang) => ({\n ...acc,\n [lang]: {\n ...(nfx.RESOURCES[lang] ?? {}),\n ...(user.RESOURCES[lang] ?? {}),\n },\n }),\n {} as typeof user.RESOURCES,\n );\n const NAME_SPACES = [...user.NAME_SPACES, ...nfx.NAME_SPACES.filter((n) => !user.NAME_SPACES.includes(n))];\n\n i18n\n .use(LanguageDetector)\n .use(initReactI18next)\n .init({\n compatibilityJSON: \"v4\",\n resources: RESOURCES,\n lng: fallbackLng,\n fallbackLng,\n ns: NAME_SPACES,\n defaultNS: NAME_SPACES[0],\n interpolation: { escapeValue: false },\n keySeparator: \".\",\n detection: { order: [\"navigator\", \"htmlTag\", \"path\", \"subdomain\"] },\n });\n\n const onLoad = options.onLoadExtraBundles;\n if (onLoad) {\n const apply = async (lng: LanguageEnum) => {\n const result = await onLoad(lng);\n if (result == null) return;\n const items = Array.isArray(result) ? result : [result];\n for (const { namespace, bundle } of items) {\n if (namespace && bundle && typeof bundle === \"object\") {\n i18n.addResourceBundle(lng, namespace, bundle, true, true);\n }\n }\n };\n void apply((i18n.language as LanguageEnum) || fallbackLng);\n i18n.on(\"languageChanged\", (lng) => void apply(lng as LanguageEnum));\n }\n}\n\nexport default i18n;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AYsBA,MAAa,IAAiB;AAAA,EAAC;AAAA,EAAS;AAAA,EAAY;AAAA,EAAU;GACjD,IAAoC;AAAA,EAC/C,OAAO;AAAA,EACP,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,YAAY;;AAGd,IAAM,IAAmC;AAAA,EACvC,IAAI;AAAA,IACF,OAAO;AAAA,IACP,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,YAAY;AAAA;EAEd,IAAI;AAAA,IACF,OAAO;AAAA,IACP,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,YAAY;AAAA;EAEd,IAAI;AAAA,IACF,OAAO;AAAA,IACP,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,YAAY;AAAA;;AAQhB,SAAgB,IAAkD;AAChE,SAAO;AAAA,IACL,WAAW;AAAA,IACX,iBAAiB;AAAA,IACjB,aAAa,CAAC,GAAG,CAAA;AAAA;;ACzCrB,SAAgB,EAAS,GAAgC;AACvD,QAAM,IAAM,EAAA,GACN,IAAO,EAAQ,SACf,IAAc,EAAQ,eAAe,EAAa,IAElD,IAAa;AAAA,IAAC,EAAa;AAAA,IAAI,EAAa;AAAA,IAAI,EAAa;AAAA,IAAc,OAAA,CAC9E,GAAK,OAAU;AAAA,IACd,GAAG;AAAA,KACF,CAAA,GAAO;AAAA,MACN,GAAI,EAAI,UAAU,CAAA,KAAS,CAAA;AAAA,MAC3B,GAAI,EAAK,UAAU,CAAA,KAAS,CAAA;AAAA;MAGhC,CAAA,CAAE,GAEE,IAAc,CAAC,GAAG,EAAK,aAAa,GAAG,EAAI,YAAY,OAAA,CAAQ,MAAM,CAAC,EAAK,YAAY,SAAS,CAAA,CAAE,CAAC;AAEzG,EAAA,EACG,IAAI,CAAA,EACJ,IAAI,CAAA,EACJ,KAAK;AAAA,IACJ,mBAAmB;AAAA,IACnB,WAAW;AAAA,IACX,KAAK;AAAA,IACL,aAAA;AAAA,IACA,IAAI;AAAA,IACJ,WAAW,EAAY,CAAA;AAAA,IACvB,eAAe,EAAE,aAAa,GAAA;AAAA,IAC9B,cAAc;AAAA,IACd,WAAW,EAAE,OAAO;AAAA,MAAC;AAAA,MAAa;AAAA,MAAW;AAAA,MAAQ;AAAA,MAAY;AAAA,GAClE;AAEH,QAAM,IAAS,EAAQ;AACvB,MAAI,GAAQ;AACV,UAAM,IAAQ,OAAO,MAAsB;AACzC,YAAM,IAAS,MAAM,EAAO,CAAA;AAC5B,UAAI,KAAU,KAAM;AACpB,YAAM,IAAQ,MAAM,QAAQ,CAAA,IAAU,IAAS,CAAC,CAAA;AAChD,iBAAW,EAAE,WAAA,GAAW,QAAA,EAAA,KAAY,EAClC,CAAI,KAAa,KAAU,OAAO,KAAW,YAC3C,EAAK,kBAAkB,GAAK,GAAW,GAAQ,IAAM,EAAA;AAAA;AAItD,IAAA,EAAO,EAAK,YAA6B,CAAA,GAC9C,EAAK,GAAG,mBAAA,CAAoB,MAAA;AAAQ,MAAK,EAAM,CAAA;AAAA,KAAoB;AAAA;;AAIvE,IAAA,IAAe"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
const h=require("./chunk-chunk-BFrxaqQT.cjs"),n=require("./chunk-types-BE3JCLff.cjs");let t=require("i18next");t=h.__toESM(t);let l=require("i18next-browser-languagedetector");l=h.__toESM(l);let p=require("react-i18next");const y={show:"Show Sidebar",hide:"Hide Sidebar"};var A={layoutSwitcher:y};const b={en:"English",zh:"Chinese",fr:"French"};var C={languageSwitcher:b};const P={default:"Default",ios:"iOS",android:"Android",windows:"Windows",linux:"Linux"},N={theme:"Theme",language:"Language",layout:"Layout",preferences:"Preferences"};var $={baseSwitcher:P,preference:N};const v={default:"Default",light:"Light",dark:"Dark",cosmic:"Cosmic",corporate:"Corporate",forest:"Forest",coffee:"Coffee",wine:"Wine",wheat:"Wheat"};var L={themeSwitcher:v};const M={show:"Afficher la barre latérale",hide:"Masquer la barre latérale"};var x={layoutSwitcher:M};const O={en:"Anglais",zh:"Chinois",fr:"Français"};var R={languageSwitcher:O};const F={default:"Par défaut",ios:"iOS",android:"Android",windows:"Windows",linux:"Linux"},q={theme:"Thème",language:"Langue",layout:"Disposition",preferences:"Préférences"};var k={baseSwitcher:F,preference:q};const D={default:"Par défaut",light:"Clair",dark:"Sombre",cosmic:"Cosmique",corporate:"Entreprise",forest:"Forêt",coffee:"Coffee",wine:"Vin",wheat:"Blé"};var j={themeSwitcher:D};const U={show:"显示侧边栏",hide:"隐藏侧边栏"};var B={layoutSwitcher:U};const W={en:"英语",zh:"中文",fr:"法语"};var X={languageSwitcher:W};const z={default:"默认",ios:"iOS",android:"Android",windows:"Windows",linux:"Linux"},T={theme:"主题",language:"语言",layout:"布局",preferences:"偏好设置"};var H={baseSwitcher:z,preference:T};const I={default:"默认",light:"浅色",dark:"深色",cosmic:"宇宙",corporate:"企业",forest:"森林",coffee:"咖啡",wine:"酒红",wheat:"麦田"};var V={themeSwitcher:I};const S=["theme","language","layout","preference"],w={theme:"theme",language:"language",layout:"layout",preference:"preference"};var Z={en:{theme:L,language:C,layout:A,preference:$},zh:{theme:V,language:X,layout:B,preference:H},fr:{theme:j,language:R,layout:x,preference:k}};function E(){return{RESOURCES:Z,NAME_SPACES_MAP:w,NAME_SPACES:[...S]}}function J(u){const f=E(),o=u.bundles,i=u.fallbackLng??n.LanguageEnum.ZH,m=[n.LanguageEnum.EN,n.LanguageEnum.ZH,n.LanguageEnum.FR].reduce((r,e)=>({...r,[e]:{...f.RESOURCES[e]??{},...o.RESOURCES[e]??{}}}),{}),s=[...o.NAME_SPACES,...f.NAME_SPACES.filter(r=>!o.NAME_SPACES.includes(r))];t.default.use(l.default).use(p.initReactI18next).init({compatibilityJSON:"v4",resources:m,lng:i,fallbackLng:i,ns:s,defaultNS:s[0],interpolation:{escapeValue:!1},keySeparator:".",detection:{order:["navigator","htmlTag","path","subdomain"]}});const d=u.onLoadExtraBundles;if(d){const r=async e=>{const a=await d(e);if(a==null)return;const _=Array.isArray(a)?a:[a];for(const{namespace:g,bundle:c}of _)g&&c&&typeof c=="object"&&t.default.addResourceBundle(e,g,c,!0,!0)};r(t.default.language||i),t.default.on("languageChanged",e=>{r(e)})}}var G=t.default;Object.defineProperty(exports,"NFX_NAMESPACES",{enumerable:!0,get:function(){return S}});Object.defineProperty(exports,"NFX_NAMESPACES_MAP",{enumerable:!0,get:function(){return w}});Object.defineProperty(exports,"getDefaultNfxBundles",{enumerable:!0,get:function(){return E}});Object.defineProperty(exports,"i18n_default",{enumerable:!0,get:function(){return G}});Object.defineProperty(exports,"initI18n",{enumerable:!0,get:function(){return J}});
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=chunk-i18n-daHSL0Nm.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-i18n-daHSL0Nm.cjs","names":[],"sources":["../src/languages/resources/en/layout.json","../src/languages/resources/en/language.json","../src/languages/resources/en/preference.json","../src/languages/resources/en/theme.json","../src/languages/resources/fr/layout.json","../src/languages/resources/fr/language.json","../src/languages/resources/fr/preference.json","../src/languages/resources/fr/theme.json","../src/languages/resources/zh/layout.json","../src/languages/resources/zh/language.json","../src/languages/resources/zh/preference.json","../src/languages/resources/zh/theme.json","../src/languages/resources/index.ts","../src/languages/languages/i18n.ts"],"sourcesContent":["{\n \"layoutSwitcher\": {\n \"show\": \"Show Sidebar\",\n \"hide\": \"Hide Sidebar\"\n }\n}\n","{\n \"languageSwitcher\": {\n \"en\": \"English\",\n \"zh\": \"Chinese\",\n \"fr\": \"French\"\n }\n}\n","{\n \"baseSwitcher\": {\n \"default\": \"Default\",\n \"ios\": \"iOS\",\n \"android\": \"Android\",\n \"windows\": \"Windows\",\n \"linux\": \"Linux\"\n },\n \"preference\": {\n \"theme\": \"Theme\",\n \"language\": \"Language\",\n \"layout\": \"Layout\",\n \"preferences\": \"Preferences\"\n }\n}\n","{\n \"themeSwitcher\": {\n \"default\": \"Default\",\n \"light\": \"Light\",\n \"dark\": \"Dark\",\n \"cosmic\": \"Cosmic\",\n \"corporate\": \"Corporate\",\n \"forest\": \"Forest\",\n \"coffee\": \"Coffee\",\n \"wine\": \"Wine\",\n \"wheat\": \"Wheat\"\n }\n}\n","{\n \"layoutSwitcher\": {\n \"show\": \"Afficher la barre latérale\",\n \"hide\": \"Masquer la barre latérale\"\n }\n}\n","{\n \"languageSwitcher\": {\n \"en\": \"Anglais\",\n \"zh\": \"Chinois\",\n \"fr\": \"Français\"\n }\n}\n","{\n \"baseSwitcher\": {\n \"default\": \"Par défaut\",\n \"ios\": \"iOS\",\n \"android\": \"Android\",\n \"windows\": \"Windows\",\n \"linux\": \"Linux\"\n },\n \"preference\": {\n \"theme\": \"Thème\",\n \"language\": \"Langue\",\n \"layout\": \"Disposition\",\n \"preferences\": \"Préférences\"\n }\n}\n","{\n \"themeSwitcher\": {\n \"default\": \"Par défaut\",\n \"light\": \"Clair\",\n \"dark\": \"Sombre\",\n \"cosmic\": \"Cosmique\",\n \"corporate\": \"Entreprise\",\n \"forest\": \"Forêt\",\n \"coffee\": \"Coffee\",\n \"wine\": \"Vin\",\n \"wheat\": \"Blé\"\n }\n}\n","{\n \"layoutSwitcher\": {\n \"show\": \"显示侧边栏\",\n \"hide\": \"隐藏侧边栏\"\n }\n}\n","{\n \"languageSwitcher\": {\n \"en\": \"英语\",\n \"zh\": \"中文\",\n \"fr\": \"法语\"\n }\n}\n","{\n \"baseSwitcher\": {\n \"default\": \"默认\",\n \"ios\": \"iOS\",\n \"android\": \"Android\",\n \"windows\": \"Windows\",\n \"linux\": \"Linux\"\n },\n \"preference\": {\n \"theme\": \"主题\",\n \"language\": \"语言\",\n \"layout\": \"布局\",\n \"preferences\": \"偏好设置\"\n }\n}\n","{\n \"themeSwitcher\": {\n \"default\": \"默认\",\n \"light\": \"浅色\",\n \"dark\": \"深色\",\n \"cosmic\": \"宇宙\",\n \"corporate\": \"企业\",\n \"forest\": \"森林\",\n \"coffee\": \"咖啡\",\n \"wine\": \"酒红\",\n \"wheat\": \"麦田\"\n }\n}\n","/**\n * NFX-UI 内置多语言资源:theme / language / layout / preference 四个命名空间,en / zh / fr 三种语言。\n * Built-in i18n resources: namespaces theme, language, layout, preference; languages en, zh, fr.\n *\n * 使用方可在 createI18nResources 时合并此资源,使 ThemeSwitcher / LanguageSwitcher / LayoutSwitcher 使用默认翻译。\n * Consumers can merge these resources in createI18nResources so switchers use default labels.\n */\nimport type { CreateI18nResourcesResult, NameSpacesMap, Resources } from \"../types\";\n\nimport enLayout from \"./en/layout.json\";\nimport enLanguage from \"./en/language.json\";\nimport enPreference from \"./en/preference.json\";\nimport enTheme from \"./en/theme.json\";\nimport frLayout from \"./fr/layout.json\";\nimport frLanguage from \"./fr/language.json\";\nimport frPreference from \"./fr/preference.json\";\nimport frTheme from \"./fr/theme.json\";\nimport zhLayout from \"./zh/layout.json\";\nimport zhLanguage from \"./zh/language.json\";\nimport zhPreference from \"./zh/preference.json\";\nimport zhTheme from \"./zh/theme.json\";\n\nexport const NFX_NAMESPACES = [\"theme\", \"language\", \"layout\", \"preference\"] as const;\nexport const NFX_NAMESPACES_MAP: NameSpacesMap = {\n theme: \"theme\",\n language: \"language\",\n layout: \"layout\",\n preference: \"preference\",\n};\n\nconst DEFAULT_NFX_RESOURCES: Resources = {\n en: {\n theme: enTheme as Record<string, unknown>,\n language: enLanguage as Record<string, unknown>,\n layout: enLayout as Record<string, unknown>,\n preference: enPreference as Record<string, unknown>,\n },\n zh: {\n theme: zhTheme as Record<string, unknown>,\n language: zhLanguage as Record<string, unknown>,\n layout: zhLayout as Record<string, unknown>,\n preference: zhPreference as Record<string, unknown>,\n },\n fr: {\n theme: frTheme as Record<string, unknown>,\n language: frLanguage as Record<string, unknown>,\n layout: frLayout as Record<string, unknown>,\n preference: frPreference as Record<string, unknown>,\n },\n};\n\n/**\n * 返回 NFX-UI 默认文案包,可与使用方自建 resources 合并后传入 createI18nResources。\n * Returns default NFX bundles; merge with your resources and pass to createI18nResources.\n */\nexport function getDefaultNfxBundles(): CreateI18nResourcesResult {\n return {\n RESOURCES: DEFAULT_NFX_RESOURCES,\n NAME_SPACES_MAP: NFX_NAMESPACES_MAP,\n NAME_SPACES: [...NFX_NAMESPACES],\n };\n}\n","/**\n * i18n 初始化与实例:initI18n 由 LanguageProvider 调用,changeLanguage 供外部切换语言。\n * 默认会合并 NFX-UI 自带的 theme / language / layout / preference 四个命名空间,使用方只需传入自己的 bundles。\n * i18n init and instance: initI18n called by LanguageProvider. Merges built-in theme/language/layout/preference by default.\n */\nimport type { InitI18nOptions } from \"../types\";\n\nimport i18n from \"i18next\";\nimport LanguageDetector from \"i18next-browser-languagedetector\";\nimport { initReactI18next } from \"react-i18next\";\n\nimport { getDefaultNfxBundles } from \"../resources\";\nimport { LanguageEnum } from \"../types\";\n\n/**\n * 初始化 i18n。会先合并 NFX-UI 自带的四类 JSON(theme/language/layout/preference),再与用户传入的 bundles 合并(用户可覆盖)。\n * Init i18n. Merges built-in NFX bundles (theme, language, layout, preference) with user bundles (user overrides).\n */\nexport function initI18n(options: InitI18nOptions): void {\n const nfx = getDefaultNfxBundles();\n const user = options.bundles;\n const fallbackLng = options.fallbackLng ?? LanguageEnum.ZH;\n\n const RESOURCES = ([LanguageEnum.EN, LanguageEnum.ZH, LanguageEnum.FR] as const).reduce(\n (acc, lang) => ({\n ...acc,\n [lang]: {\n ...(nfx.RESOURCES[lang] ?? {}),\n ...(user.RESOURCES[lang] ?? {}),\n },\n }),\n {} as typeof user.RESOURCES,\n );\n const NAME_SPACES = [...user.NAME_SPACES, ...nfx.NAME_SPACES.filter((n) => !user.NAME_SPACES.includes(n))];\n\n i18n\n .use(LanguageDetector)\n .use(initReactI18next)\n .init({\n compatibilityJSON: \"v4\",\n resources: RESOURCES,\n lng: fallbackLng,\n fallbackLng,\n ns: NAME_SPACES,\n defaultNS: NAME_SPACES[0],\n interpolation: { escapeValue: false },\n keySeparator: \".\",\n detection: { order: [\"navigator\", \"htmlTag\", \"path\", \"subdomain\"] },\n });\n\n const onLoad = options.onLoadExtraBundles;\n if (onLoad) {\n const apply = async (lng: LanguageEnum) => {\n const result = await onLoad(lng);\n if (result == null) return;\n const items = Array.isArray(result) ? result : [result];\n for (const { namespace, bundle } of items) {\n if (namespace && bundle && typeof bundle === \"object\") {\n i18n.addResourceBundle(lng, namespace, bundle, true, true);\n }\n }\n };\n void apply((i18n.language as LanguageEnum) || fallbackLng);\n i18n.on(\"languageChanged\", (lng) => void apply(lng as LanguageEnum));\n }\n}\n\nexport default i18n;\n"],"mappings":"8tDYsBA,MAAa,EAAiB,CAAC,QAAS,WAAY,SAAU,cACjD,EAAoC,CAC/C,MAAO,QACP,SAAU,WACV,OAAQ,SACR,WAAY,cAGd,IAAM,EAAmC,CACvC,GAAI,CACF,MAAO,EACP,SAAU,EACV,OAAQ,EACR,WAAY,GAEd,GAAI,CACF,MAAO,EACP,SAAU,EACV,OAAQ,EACR,WAAY,GAEd,GAAI,CACF,MAAO,EACP,SAAU,EACV,OAAQ,EACR,WAAY,IAQhB,SAAgB,GAAkD,CAChE,MAAO,CACL,UAAW,EACX,gBAAiB,EACjB,YAAa,CAAC,GAAG,CAAA,GCzCrB,SAAgB,EAAS,EAAgC,CACvD,MAAM,EAAM,EAAA,EACN,EAAO,EAAQ,QACf,EAAc,EAAQ,aAAe,EAAA,aAAa,GAElD,EAAa,CAAC,EAAA,aAAa,GAAI,EAAA,aAAa,GAAI,EAAA,aAAa,IAAc,OAAA,CAC9E,EAAK,KAAU,CACd,GAAG,GACF,CAAA,EAAO,CACN,GAAI,EAAI,UAAU,CAAA,GAAS,CAAA,EAC3B,GAAI,EAAK,UAAU,CAAA,GAAS,CAAA,KAGhC,CAAA,CAAE,EAEE,EAAc,CAAC,GAAG,EAAK,YAAa,GAAG,EAAI,YAAY,OAAQ,GAAM,CAAC,EAAK,YAAY,SAAS,CAAA,CAAE,CAAC,EAEzG,EAAA,QACG,IAAI,EAAA,OAAA,EACJ,IAAI,EAAA,gBAAA,EACJ,KAAK,CACJ,kBAAmB,KACnB,UAAW,EACX,IAAK,EACL,YAAA,EACA,GAAI,EACJ,UAAW,EAAY,CAAA,EACvB,cAAe,CAAE,YAAa,EAAA,EAC9B,aAAc,IACd,UAAW,CAAE,MAAO,CAAC,YAAa,UAAW,OAAQ,YAAY,EAClE,EAEH,MAAM,EAAS,EAAQ,mBACvB,GAAI,EAAQ,CACV,MAAM,EAAQ,MAAO,GAAsB,CACzC,MAAM,EAAS,MAAM,EAAO,CAAA,EAC5B,GAAI,GAAU,KAAM,OACpB,MAAM,EAAQ,MAAM,QAAQ,CAAA,EAAU,EAAS,CAAC,CAAA,EAChD,SAAW,CAAE,UAAA,EAAW,OAAA,CAAA,IAAY,EAC9B,GAAa,GAAU,OAAO,GAAW,UAC3C,EAAA,QAAK,kBAAkB,EAAK,EAAW,EAAQ,GAAM,EAAA,GAItD,EAAO,EAAA,QAAK,UAA6B,CAAA,EAC9C,EAAA,QAAK,GAAG,kBAAoB,GAAA,CAAa,EAAM,CAAA,EAAoB,GAIvE,IAAA,EAAe,EAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { c as o, n as g, r as s, s as c } from "./chunk-types-
|
|
1
|
+
import { c as o, n as g, r as s, s as c } from "./chunk-types-BudGuDCK.mjs";
|
|
2
2
|
import { i as a } from "./chunk-types-DNPBKfmx.mjs";
|
|
3
3
|
import { i as h, r as E } from "./chunk-types-SD4MzUGp.mjs";
|
|
4
4
|
let n = (function(e) {
|
|
@@ -48,4 +48,4 @@ export {
|
|
|
48
48
|
y as t
|
|
49
49
|
};
|
|
50
50
|
|
|
51
|
-
//# sourceMappingURL=chunk-preference-
|
|
51
|
+
//# sourceMappingURL=chunk-preference-By58ZcJ_.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-preference-
|
|
1
|
+
{"version":3,"file":"chunk-preference-By58ZcJ_.mjs","names":[],"sources":["../src/preference/constants.ts","../src/preference/index.ts"],"sourcesContent":["/**\n * 用户偏好相关常量:仪表盘背景等\n * Preference-related constants: dashboard background, etc.\n */\n\nimport type { Array } from \"@/types\";\n\n/** 仪表盘背景枚举。Dashboard background enum. */\nexport enum DashboardBackgroundEnum {\n NONE = \"none\",\n WAVES = \"waves\",\n SQUARES = \"squares\",\n LETTER_GLITCH = \"letterGlitch\",\n PIXEL_BLAST = \"pixelBlast\",\n}\n\nexport const DEFAULT_DASHBOARD_BACKGROUND = DashboardBackgroundEnum.NONE;\n\n/** 仪表盘背景可选值列表。Dashboard background values list. */\nexport const DASHBOARD_BACKGROUND_VALUES: Array<DashboardBackgroundEnum> = Object.values(DashboardBackgroundEnum);\n","/**\n * 用户偏好模块:类型、解析/序列化、默认值(与后端 profile.preference JSON 约定)\n * User preference: types, parse/serialize, defaults (backend profile.preference JSON contract).\n */\nimport { LayoutModeEnum } from \"@/designs/layouts/types\";\nimport { LANGUAGE_VALUES, LanguageEnum } from \"@/languages/types\";\nimport { BASE_VALUES, BaseEnum, THEME_VALUES, ThemeEnum } from \"@/themes/types\";\n\nimport { DASHBOARD_BACKGROUND_VALUES, DashboardBackgroundEnum, DEFAULT_DASHBOARD_BACKGROUND } from \"./constants\";\n\nexport { DashboardBackgroundEnum, DEFAULT_DASHBOARD_BACKGROUND, DASHBOARD_BACKGROUND_VALUES } from \"./constants\";\n\n/** 前端统一的偏好结构;后端存为 JSON:theme, base, language, layoutMode, other.dashboardBackground */\nexport type Preference = {\n theme: ThemeEnum;\n base: BaseEnum;\n language: LanguageEnum;\n layoutMode: LayoutModeEnum;\n other?: {\n dashboardBackground: DashboardBackgroundEnum;\n };\n};\n\n/** 后端 JSON 形状(profile.preference 字符串解析后)。Internal backend shape. */\ntype PreferenceBackendShape = {\n theme?: ThemeEnum;\n base?: BaseEnum;\n language?: LanguageEnum;\n layoutMode: LayoutModeEnum;\n other?: Record<string, unknown>;\n};\n\n/**\n * 从后端 preference JSON 解析为前端 Preference,解析失败或空返回 null\n * Parse backend preference JSON to Preference; returns null on empty or parse error.\n * @param json - 后端存的 JSON 字符串\n * @returns Preference 或 null\n */\nexport function parsePreferenceJson(json: string | null | undefined): Preference | null {\n if (!json || typeof json !== \"string\") return null;\n try {\n const raw = JSON.parse(json) as PreferenceBackendShape;\n const layoutMode = raw.layoutMode === LayoutModeEnum.HIDE ? LayoutModeEnum.HIDE : LayoutModeEnum.SHOW;\n const db =\n typeof raw.other?.dashboardBackground === \"string\" && DASHBOARD_BACKGROUND_VALUES.includes(raw.other.dashboardBackground as DashboardBackgroundEnum)\n ? (raw.other.dashboardBackground as DashboardBackgroundEnum)\n : DEFAULT_DASHBOARD_BACKGROUND;\n const base = typeof raw.base === \"string\" && BASE_VALUES.includes(raw.base as BaseEnum) ? (raw.base as BaseEnum) : BaseEnum.DEFAULT;\n const language =\n typeof raw.language === \"string\" && (LANGUAGE_VALUES as string[]).includes(raw.language) ? (raw.language as LanguageEnum) : (\"zh\" as LanguageEnum);\n return {\n theme: typeof raw.theme === \"string\" && THEME_VALUES.includes(raw.theme as ThemeEnum) ? (raw.theme as ThemeEnum) : ThemeEnum.DEFAULT,\n base,\n language,\n layoutMode,\n other: { dashboardBackground: db },\n };\n } catch {\n return null;\n }\n}\n\n/**\n * 将前端 Preference 序列化为后端存的完整 JSON 字符串(每次更新都传完整 JSON)\n * Serialize Preference to backend JSON string (full payload on each update).\n * @param preference - 前端偏好对象\n * @returns JSON 字符串\n */\nexport function preferenceToJson(preference: Preference): string {\n const backend: PreferenceBackendShape = {\n theme: preference.theme || undefined,\n base: preference.base || undefined,\n language: preference.language || undefined,\n layoutMode: preference.layoutMode,\n other: preference.other ? { dashboardBackground: preference.other.dashboardBackground } : undefined,\n };\n return JSON.stringify(backend);\n}\n\n/**\n * 默认偏好(解析不到或同步时兜底):默认中文、default 主题、default base\n * Default preference (fallback when parse fails or for initial sync).\n * @returns 默认 Preference\n */\nexport function getDefaultPreference(): Preference {\n return {\n theme: ThemeEnum.DEFAULT,\n base: BaseEnum.DEFAULT,\n language: LanguageEnum.ZH,\n layoutMode: LayoutModeEnum.SHOW,\n other: { dashboardBackground: DEFAULT_DASHBOARD_BACKGROUND },\n };\n}\n"],"mappings":";;;AAQA,IAAY,KAAL,SAAA,GAAA;AACL,SAAA,EAAA,OAAA,QACA,EAAA,QAAA,SACA,EAAA,UAAA,WACA,EAAA,gBAAA,gBACA,EAAA,cAAA;;AAGF,MAAa,IAA+B,EAAwB,MAGvD,IAA8D,OAAO,OAAO,CAAA;ACmBzF,SAAgB,EAAoB,GAAoD;AACtF,MAAI,CAAC,KAAQ,OAAO,KAAS,SAAU,QAAO;AAC9C,MAAI;AACF,UAAM,IAAM,KAAK,MAAM,CAAA,GACjB,IAAa,EAAI,eAAe,EAAe,OAAO,EAAe,OAAO,EAAe,MAC3F,IACJ,OAAO,EAAI,OAAO,uBAAwB,YAAY,EAA4B,SAAS,EAAI,MAAM,mBAAA,IAChG,EAAI,MAAM,sBACX,GACA,IAAO,OAAO,EAAI,QAAS,YAAY,EAAY,SAAS,EAAI,IAAA,IAAqB,EAAI,OAAoB,EAAS,SACtH,IACJ,OAAO,EAAI,YAAa,YAAa,EAA6B,SAAS,EAAI,QAAA,IAAa,EAAI,WAA6B;AAC/H,WAAO;AAAA,MACL,OAAO,OAAO,EAAI,SAAU,YAAY,EAAa,SAAS,EAAI,KAAA,IAAuB,EAAI,QAAsB,EAAU;AAAA,MAC7H,MAAA;AAAA,MACA,UAAA;AAAA,MACA,YAAA;AAAA,MACA,OAAO,EAAE,qBAAqB,EAAA;AAAA;UAE1B;AACN,WAAO;AAAA;;AAUX,SAAgB,EAAiB,GAAgC;AAC/D,QAAM,IAAkC;AAAA,IACtC,OAAO,EAAW,SAAS;AAAA,IAC3B,MAAM,EAAW,QAAQ;AAAA,IACzB,UAAU,EAAW,YAAY;AAAA,IACjC,YAAY,EAAW;AAAA,IACvB,OAAO,EAAW,QAAQ,EAAE,qBAAqB,EAAW,MAAM,oBAAA,IAAwB;AAAA;AAE5F,SAAO,KAAK,UAAU,CAAA;;AAQxB,SAAgB,IAAmC;AACjD,SAAO;AAAA,IACL,OAAO,EAAU;AAAA,IACjB,MAAM,EAAS;AAAA,IACf,UAAU,EAAa;AAAA,IACvB,YAAY,EAAe;AAAA,IAC3B,OAAO,EAAE,qBAAqB,EAAA;AAAA"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
const n=require("./chunk-types-
|
|
1
|
+
const n=require("./chunk-types-BNUlgEkq.cjs"),r=require("./chunk-types-C_opkZGr.cjs"),a=require("./chunk-types-BE3JCLff.cjs");let u=(function(e){return e.NONE="none",e.WAVES="waves",e.SQUARES="squares",e.LETTER_GLITCH="letterGlitch",e.PIXEL_BLAST="pixelBlast",e})({});const o=u.NONE,s=Object.values(u);function l(e){if(!e||typeof e!="string")return null;try{const t=JSON.parse(e),c=t.layoutMode===r.LayoutModeEnum.HIDE?r.LayoutModeEnum.HIDE:r.LayoutModeEnum.SHOW,d=typeof t.other?.dashboardBackground=="string"&&s.includes(t.other.dashboardBackground)?t.other.dashboardBackground:o,i=typeof t.base=="string"&&n.BASE_VALUES.includes(t.base)?t.base:n.BaseEnum.DEFAULT,g=typeof t.language=="string"&&a.LANGUAGE_VALUES.includes(t.language)?t.language:"zh";return{theme:typeof t.theme=="string"&&n.THEME_VALUES.includes(t.theme)?t.theme:n.ThemeEnum.DEFAULT,base:i,language:g,layoutMode:c,other:{dashboardBackground:d}}}catch{return null}}function E(e){const t={theme:e.theme||void 0,base:e.base||void 0,language:e.language||void 0,layoutMode:e.layoutMode,other:e.other?{dashboardBackground:e.other.dashboardBackground}:void 0};return JSON.stringify(t)}function A(){return{theme:n.ThemeEnum.DEFAULT,base:n.BaseEnum.DEFAULT,language:a.LanguageEnum.ZH,layoutMode:r.LayoutModeEnum.SHOW,other:{dashboardBackground:o}}}Object.defineProperty(exports,"DASHBOARD_BACKGROUND_VALUES",{enumerable:!0,get:function(){return s}});Object.defineProperty(exports,"DEFAULT_DASHBOARD_BACKGROUND",{enumerable:!0,get:function(){return o}});Object.defineProperty(exports,"DashboardBackgroundEnum",{enumerable:!0,get:function(){return u}});Object.defineProperty(exports,"getDefaultPreference",{enumerable:!0,get:function(){return A}});Object.defineProperty(exports,"parsePreferenceJson",{enumerable:!0,get:function(){return l}});Object.defineProperty(exports,"preferenceToJson",{enumerable:!0,get:function(){return E}});
|
|
2
2
|
|
|
3
|
-
//# sourceMappingURL=chunk-preference-
|
|
3
|
+
//# sourceMappingURL=chunk-preference-C144GkCD.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-preference-
|
|
1
|
+
{"version":3,"file":"chunk-preference-C144GkCD.cjs","names":[],"sources":["../src/preference/constants.ts","../src/preference/index.ts"],"sourcesContent":["/**\n * 用户偏好相关常量:仪表盘背景等\n * Preference-related constants: dashboard background, etc.\n */\n\nimport type { Array } from \"@/types\";\n\n/** 仪表盘背景枚举。Dashboard background enum. */\nexport enum DashboardBackgroundEnum {\n NONE = \"none\",\n WAVES = \"waves\",\n SQUARES = \"squares\",\n LETTER_GLITCH = \"letterGlitch\",\n PIXEL_BLAST = \"pixelBlast\",\n}\n\nexport const DEFAULT_DASHBOARD_BACKGROUND = DashboardBackgroundEnum.NONE;\n\n/** 仪表盘背景可选值列表。Dashboard background values list. */\nexport const DASHBOARD_BACKGROUND_VALUES: Array<DashboardBackgroundEnum> = Object.values(DashboardBackgroundEnum);\n","/**\n * 用户偏好模块:类型、解析/序列化、默认值(与后端 profile.preference JSON 约定)\n * User preference: types, parse/serialize, defaults (backend profile.preference JSON contract).\n */\nimport { LayoutModeEnum } from \"@/designs/layouts/types\";\nimport { LANGUAGE_VALUES, LanguageEnum } from \"@/languages/types\";\nimport { BASE_VALUES, BaseEnum, THEME_VALUES, ThemeEnum } from \"@/themes/types\";\n\nimport { DASHBOARD_BACKGROUND_VALUES, DashboardBackgroundEnum, DEFAULT_DASHBOARD_BACKGROUND } from \"./constants\";\n\nexport { DashboardBackgroundEnum, DEFAULT_DASHBOARD_BACKGROUND, DASHBOARD_BACKGROUND_VALUES } from \"./constants\";\n\n/** 前端统一的偏好结构;后端存为 JSON:theme, base, language, layoutMode, other.dashboardBackground */\nexport type Preference = {\n theme: ThemeEnum;\n base: BaseEnum;\n language: LanguageEnum;\n layoutMode: LayoutModeEnum;\n other?: {\n dashboardBackground: DashboardBackgroundEnum;\n };\n};\n\n/** 后端 JSON 形状(profile.preference 字符串解析后)。Internal backend shape. */\ntype PreferenceBackendShape = {\n theme?: ThemeEnum;\n base?: BaseEnum;\n language?: LanguageEnum;\n layoutMode: LayoutModeEnum;\n other?: Record<string, unknown>;\n};\n\n/**\n * 从后端 preference JSON 解析为前端 Preference,解析失败或空返回 null\n * Parse backend preference JSON to Preference; returns null on empty or parse error.\n * @param json - 后端存的 JSON 字符串\n * @returns Preference 或 null\n */\nexport function parsePreferenceJson(json: string | null | undefined): Preference | null {\n if (!json || typeof json !== \"string\") return null;\n try {\n const raw = JSON.parse(json) as PreferenceBackendShape;\n const layoutMode = raw.layoutMode === LayoutModeEnum.HIDE ? LayoutModeEnum.HIDE : LayoutModeEnum.SHOW;\n const db =\n typeof raw.other?.dashboardBackground === \"string\" && DASHBOARD_BACKGROUND_VALUES.includes(raw.other.dashboardBackground as DashboardBackgroundEnum)\n ? (raw.other.dashboardBackground as DashboardBackgroundEnum)\n : DEFAULT_DASHBOARD_BACKGROUND;\n const base = typeof raw.base === \"string\" && BASE_VALUES.includes(raw.base as BaseEnum) ? (raw.base as BaseEnum) : BaseEnum.DEFAULT;\n const language =\n typeof raw.language === \"string\" && (LANGUAGE_VALUES as string[]).includes(raw.language) ? (raw.language as LanguageEnum) : (\"zh\" as LanguageEnum);\n return {\n theme: typeof raw.theme === \"string\" && THEME_VALUES.includes(raw.theme as ThemeEnum) ? (raw.theme as ThemeEnum) : ThemeEnum.DEFAULT,\n base,\n language,\n layoutMode,\n other: { dashboardBackground: db },\n };\n } catch {\n return null;\n }\n}\n\n/**\n * 将前端 Preference 序列化为后端存的完整 JSON 字符串(每次更新都传完整 JSON)\n * Serialize Preference to backend JSON string (full payload on each update).\n * @param preference - 前端偏好对象\n * @returns JSON 字符串\n */\nexport function preferenceToJson(preference: Preference): string {\n const backend: PreferenceBackendShape = {\n theme: preference.theme || undefined,\n base: preference.base || undefined,\n language: preference.language || undefined,\n layoutMode: preference.layoutMode,\n other: preference.other ? { dashboardBackground: preference.other.dashboardBackground } : undefined,\n };\n return JSON.stringify(backend);\n}\n\n/**\n * 默认偏好(解析不到或同步时兜底):默认中文、default 主题、default base\n * Default preference (fallback when parse fails or for initial sync).\n * @returns 默认 Preference\n */\nexport function getDefaultPreference(): Preference {\n return {\n theme: ThemeEnum.DEFAULT,\n base: BaseEnum.DEFAULT,\n language: LanguageEnum.ZH,\n layoutMode: LayoutModeEnum.SHOW,\n other: { dashboardBackground: DEFAULT_DASHBOARD_BACKGROUND },\n };\n}\n"],"mappings":"8HAQA,IAAY,GAAL,SAAA,EAAA,CACL,OAAA,EAAA,KAAA,OACA,EAAA,MAAA,QACA,EAAA,QAAA,UACA,EAAA,cAAA,eACA,EAAA,YAAA,qBAGF,MAAa,EAA+B,EAAwB,KAGvD,EAA8D,OAAO,OAAO,CAAA,ECmBzF,SAAgB,EAAoB,EAAoD,CACtF,GAAI,CAAC,GAAQ,OAAO,GAAS,SAAU,OAAO,KAC9C,GAAI,CACF,MAAM,EAAM,KAAK,MAAM,CAAA,EACjB,EAAa,EAAI,aAAe,EAAA,eAAe,KAAO,EAAA,eAAe,KAAO,EAAA,eAAe,KAC3F,EACJ,OAAO,EAAI,OAAO,qBAAwB,UAAY,EAA4B,SAAS,EAAI,MAAM,mBAAA,EAChG,EAAI,MAAM,oBACX,EACA,EAAO,OAAO,EAAI,MAAS,UAAY,EAAA,YAAY,SAAS,EAAI,IAAA,EAAqB,EAAI,KAAoB,EAAA,SAAS,QACtH,EACJ,OAAO,EAAI,UAAa,UAAa,EAAA,gBAA6B,SAAS,EAAI,QAAA,EAAa,EAAI,SAA6B,KAC/H,MAAO,CACL,MAAO,OAAO,EAAI,OAAU,UAAY,EAAA,aAAa,SAAS,EAAI,KAAA,EAAuB,EAAI,MAAsB,EAAA,UAAU,QAC7H,KAAA,EACA,SAAA,EACA,WAAA,EACA,MAAO,CAAE,oBAAqB,CAAA,QAE1B,CACN,OAAO,MAUX,SAAgB,EAAiB,EAAgC,CAC/D,MAAM,EAAkC,CACtC,MAAO,EAAW,OAAS,OAC3B,KAAM,EAAW,MAAQ,OACzB,SAAU,EAAW,UAAY,OACjC,WAAY,EAAW,WACvB,MAAO,EAAW,MAAQ,CAAE,oBAAqB,EAAW,MAAM,mBAAA,EAAwB,QAE5F,OAAO,KAAK,UAAU,CAAA,EAQxB,SAAgB,GAAmC,CACjD,MAAO,CACL,MAAO,EAAA,UAAU,QACjB,KAAM,EAAA,SAAS,QACf,SAAU,EAAA,aAAa,GACvB,WAAY,EAAA,eAAe,KAC3B,MAAO,CAAE,oBAAqB,CAAA"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
let t=(function(e){return e.DEFAULT="default",e.LIGHT="light",e.CORPORATE="corporate",e.FOREST="forest",e.DARK="dark",e.COSMIC="cosmic",e.COFFEE="coffee",e.WINE="wine",e.WHEAT="wheat",e})({});const n=t.DEFAULT,o=Object.values(t);let r=(function(e){return e.DEFAULT="default",e.IOS="ios",e.ANDROID="android",e.WINDOWS="windows",e.LINUX="linux",e})({});const c=r.DEFAULT,u=Object.values(r),E="theme-color",A="theme-base";Object.defineProperty(exports,"BASE_STORAGE_KEY",{enumerable:!0,get:function(){return A}});Object.defineProperty(exports,"BASE_VALUES",{enumerable:!0,get:function(){return u}});Object.defineProperty(exports,"BaseEnum",{enumerable:!0,get:function(){return r}});Object.defineProperty(exports,"COLOR_STORAGE_KEY",{enumerable:!0,get:function(){return E}});Object.defineProperty(exports,"DEFAULT_BASE",{enumerable:!0,get:function(){return c}});Object.defineProperty(exports,"DEFAULT_THEME",{enumerable:!0,get:function(){return n}});Object.defineProperty(exports,"THEME_VALUES",{enumerable:!0,get:function(){return o}});Object.defineProperty(exports,"ThemeEnum",{enumerable:!0,get:function(){return t}});
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=chunk-types-BNUlgEkq.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-types-
|
|
1
|
+
{"version":3,"file":"chunk-types-BNUlgEkq.cjs","names":[],"sources":["../src/themes/types/theme.ts"],"sourcesContent":["/**\n * 主题相关类型:颜色变量、基础变量、主题枚举与常量。\n * Theme types: color/base variables, theme enums and constants.\n */\n\n/** 颜色变量(主题色、背景、边框、文字、图表等一切与颜色相关) */\nexport interface ColorVariables {\n primary: string;\n primaryLight: string;\n primaryFg: string;\n success: string;\n successLight: string;\n info: string;\n infoLight: string;\n warning: string;\n warningLight: string;\n danger: string;\n dangerLight: string;\n\n bg: string;\n bg2: string;\n bg3: string;\n bg4: string;\n\n border: string;\n border2: string;\n border3: string;\n border4: string;\n border5: string;\n\n fg: string;\n fgText: string;\n fgHeading: string;\n fgHighlight: string;\n separator: string;\n\n temperature: {\n arcFill: string[];\n arcEmpty: string;\n thumbBg: string;\n thumbBorder: string;\n };\n\n solar: {\n gradientLeft: string;\n gradientRight: string;\n shadowColor: string;\n secondSeriesFill: string;\n };\n\n traffic: {\n tooltipBg: string;\n tooltipBorderColor: string;\n tooltipTextColor: string;\n yAxisSplitLine: string;\n lineBg: string;\n itemColor: string;\n itemBorderColor: string;\n itemEmphasisBorderColor: string;\n shadowLineDarkBg: string;\n shadowLineShadow: string;\n gradFrom: string;\n gradTo: string;\n };\n\n electricity: {\n tooltipBg: string;\n tooltipLineColor: string;\n tooltipBorderColor: string;\n tooltipTextColor: string;\n axisLineColor: string;\n xAxisTextColor: string;\n yAxisSplitLine: string;\n itemBorderColor: string;\n lineGradFrom: string;\n lineGradTo: string;\n lineShadow: string;\n areaGradFrom: string;\n areaGradTo: string;\n shadowLineDarkBg: string;\n };\n\n echarts: {\n bg: string;\n textColor: string;\n axisLineColor: string;\n splitLineColor: string;\n itemHoverShadowColor: string;\n tooltipBackgroundColor: string;\n };\n\n chartjs: {\n axisLineColor: string;\n textColor: string;\n };\n}\n\n/** 非颜色变量(圆角等,可随平台不同:iOS 24 / Android|Windows 6 / Linux 4) */\nexport interface BaseVariables {\n buttonRadius: number;\n cardRadius: number;\n inputRadius: number;\n}\n\n/** 颜色主题:name/displayName 表示这套配色是谁 */\nexport interface ColorTheme {\n name: string;\n displayName: string;\n variables: ColorVariables;\n}\n\n/** 基础主题:name/displayName 表示这套基础规范是谁(如 iOS / Android / 默认) */\nexport interface BaseTheme {\n name: string;\n displayName: string;\n variables: BaseVariables;\n}\n\n/** 完整主题 = 颜色主题 + 基础主题 */\nexport interface Theme {\n colors: ColorTheme;\n base: BaseTheme;\n}\n\n/** 颜色主题枚举 */\nexport enum ThemeEnum {\n DEFAULT = \"default\",\n LIGHT = \"light\",\n CORPORATE = \"corporate\",\n FOREST = \"forest\",\n DARK = \"dark\",\n COSMIC = \"cosmic\",\n COFFEE = \"coffee\",\n WINE = \"wine\",\n /** 麦田:default 基础上白红色改为金黄色 */\n WHEAT = \"wheat\",\n}\n\nexport const DEFAULT_THEME = ThemeEnum.DEFAULT;\nexport const THEME_VALUES = Object.values(ThemeEnum);\n\n/** 基础主题枚举(平台/圆角等,如 iOS 24 / Android|Windows 6 / Linux 4) */\nexport enum BaseEnum {\n DEFAULT = \"default\",\n IOS = \"ios\",\n ANDROID = \"android\",\n WINDOWS = \"windows\",\n LINUX = \"linux\",\n}\n\nexport const DEFAULT_BASE = BaseEnum.DEFAULT;\nexport const BASE_VALUES = Object.values(BaseEnum);\n\nexport const COLOR_STORAGE_KEY = \"theme-color\";\nexport const BASE_STORAGE_KEY = \"theme-base\";\n"],"mappings":"AA6HA,IAAY,GAAL,SAAA,EAAA,CACL,OAAA,EAAA,QAAA,UACA,EAAA,MAAA,QACA,EAAA,UAAA,YACA,EAAA,OAAA,SACA,EAAA,KAAA,OACA,EAAA,OAAA,SACA,EAAA,OAAA,SACA,EAAA,KAAA,OAEA,EAAA,MAAA,gBAGF,MAAa,EAAgB,EAAU,QAC1B,EAAe,OAAO,OAAO,CAAA,EAG1C,IAAY,GAAL,SAAA,EAAA,CACL,OAAA,EAAA,QAAA,UACA,EAAA,IAAA,MACA,EAAA,QAAA,UACA,EAAA,QAAA,UACA,EAAA,MAAA,gBAGF,MAAa,EAAe,EAAS,QACxB,EAAc,OAAO,OAAO,CAAA,EAE5B,EAAoB,cACpB,EAAmB"}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
let o = (function(t) {
|
|
2
|
-
return t.DEFAULT = "default", t.LIGHT = "light", t.CORPORATE = "corporate", t.FOREST = "forest", t.DARK = "dark", t.COSMIC = "cosmic", t.COFFEE = "coffee", t.WINE = "wine", t;
|
|
2
|
+
return t.DEFAULT = "default", t.LIGHT = "light", t.CORPORATE = "corporate", t.FOREST = "forest", t.DARK = "dark", t.COSMIC = "cosmic", t.COFFEE = "coffee", t.WINE = "wine", t.WHEAT = "wheat", t;
|
|
3
3
|
})({});
|
|
4
|
-
const
|
|
4
|
+
const A = o.DEFAULT, c = Object.values(o);
|
|
5
5
|
let s = (function(t) {
|
|
6
6
|
return t.DEFAULT = "default", t.IOS = "ios", t.ANDROID = "android", t.WINDOWS = "windows", t.LINUX = "linux", t;
|
|
7
7
|
})({});
|
|
8
|
-
const
|
|
8
|
+
const a = s.DEFAULT, O = Object.values(s), E = "theme-color", r = "theme-base";
|
|
9
9
|
export {
|
|
10
|
-
|
|
10
|
+
a,
|
|
11
11
|
o as c,
|
|
12
12
|
E as i,
|
|
13
|
-
|
|
14
|
-
|
|
13
|
+
O as n,
|
|
14
|
+
A as o,
|
|
15
15
|
s as r,
|
|
16
|
-
|
|
16
|
+
c as s,
|
|
17
17
|
r as t
|
|
18
18
|
};
|
|
19
19
|
|
|
20
|
-
//# sourceMappingURL=chunk-types-
|
|
20
|
+
//# sourceMappingURL=chunk-types-BudGuDCK.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-types-
|
|
1
|
+
{"version":3,"file":"chunk-types-BudGuDCK.mjs","names":[],"sources":["../src/themes/types/theme.ts"],"sourcesContent":["/**\n * 主题相关类型:颜色变量、基础变量、主题枚举与常量。\n * Theme types: color/base variables, theme enums and constants.\n */\n\n/** 颜色变量(主题色、背景、边框、文字、图表等一切与颜色相关) */\nexport interface ColorVariables {\n primary: string;\n primaryLight: string;\n primaryFg: string;\n success: string;\n successLight: string;\n info: string;\n infoLight: string;\n warning: string;\n warningLight: string;\n danger: string;\n dangerLight: string;\n\n bg: string;\n bg2: string;\n bg3: string;\n bg4: string;\n\n border: string;\n border2: string;\n border3: string;\n border4: string;\n border5: string;\n\n fg: string;\n fgText: string;\n fgHeading: string;\n fgHighlight: string;\n separator: string;\n\n temperature: {\n arcFill: string[];\n arcEmpty: string;\n thumbBg: string;\n thumbBorder: string;\n };\n\n solar: {\n gradientLeft: string;\n gradientRight: string;\n shadowColor: string;\n secondSeriesFill: string;\n };\n\n traffic: {\n tooltipBg: string;\n tooltipBorderColor: string;\n tooltipTextColor: string;\n yAxisSplitLine: string;\n lineBg: string;\n itemColor: string;\n itemBorderColor: string;\n itemEmphasisBorderColor: string;\n shadowLineDarkBg: string;\n shadowLineShadow: string;\n gradFrom: string;\n gradTo: string;\n };\n\n electricity: {\n tooltipBg: string;\n tooltipLineColor: string;\n tooltipBorderColor: string;\n tooltipTextColor: string;\n axisLineColor: string;\n xAxisTextColor: string;\n yAxisSplitLine: string;\n itemBorderColor: string;\n lineGradFrom: string;\n lineGradTo: string;\n lineShadow: string;\n areaGradFrom: string;\n areaGradTo: string;\n shadowLineDarkBg: string;\n };\n\n echarts: {\n bg: string;\n textColor: string;\n axisLineColor: string;\n splitLineColor: string;\n itemHoverShadowColor: string;\n tooltipBackgroundColor: string;\n };\n\n chartjs: {\n axisLineColor: string;\n textColor: string;\n };\n}\n\n/** 非颜色变量(圆角等,可随平台不同:iOS 24 / Android|Windows 6 / Linux 4) */\nexport interface BaseVariables {\n buttonRadius: number;\n cardRadius: number;\n inputRadius: number;\n}\n\n/** 颜色主题:name/displayName 表示这套配色是谁 */\nexport interface ColorTheme {\n name: string;\n displayName: string;\n variables: ColorVariables;\n}\n\n/** 基础主题:name/displayName 表示这套基础规范是谁(如 iOS / Android / 默认) */\nexport interface BaseTheme {\n name: string;\n displayName: string;\n variables: BaseVariables;\n}\n\n/** 完整主题 = 颜色主题 + 基础主题 */\nexport interface Theme {\n colors: ColorTheme;\n base: BaseTheme;\n}\n\n/** 颜色主题枚举 */\nexport enum ThemeEnum {\n DEFAULT = \"default\",\n LIGHT = \"light\",\n CORPORATE = \"corporate\",\n FOREST = \"forest\",\n DARK = \"dark\",\n COSMIC = \"cosmic\",\n COFFEE = \"coffee\",\n WINE = \"wine\",\n /** 麦田:default 基础上白红色改为金黄色 */\n WHEAT = \"wheat\",\n}\n\nexport const DEFAULT_THEME = ThemeEnum.DEFAULT;\nexport const THEME_VALUES = Object.values(ThemeEnum);\n\n/** 基础主题枚举(平台/圆角等,如 iOS 24 / Android|Windows 6 / Linux 4) */\nexport enum BaseEnum {\n DEFAULT = \"default\",\n IOS = \"ios\",\n ANDROID = \"android\",\n WINDOWS = \"windows\",\n LINUX = \"linux\",\n}\n\nexport const DEFAULT_BASE = BaseEnum.DEFAULT;\nexport const BASE_VALUES = Object.values(BaseEnum);\n\nexport const COLOR_STORAGE_KEY = \"theme-color\";\nexport const BASE_STORAGE_KEY = \"theme-base\";\n"],"mappings":"AA6HA,IAAY,KAAL,SAAA,GAAA;AACL,SAAA,EAAA,UAAA,WACA,EAAA,QAAA,SACA,EAAA,YAAA,aACA,EAAA,SAAA,UACA,EAAA,OAAA,QACA,EAAA,SAAA,UACA,EAAA,SAAA,UACA,EAAA,OAAA,QAEA,EAAA,QAAA;;AAGF,MAAa,IAAgB,EAAU,SAC1B,IAAe,OAAO,OAAO,CAAA;AAG1C,IAAY,KAAL,SAAA,GAAA;AACL,SAAA,EAAA,UAAA,WACA,EAAA,MAAA,OACA,EAAA,UAAA,WACA,EAAA,UAAA,WACA,EAAA,QAAA;;AAGF,MAAa,IAAe,EAAS,SACxB,IAAc,OAAO,OAAO,CAAA,GAE5B,IAAoB,eACpB,IAAmB"}
|
package/dist/components.d.ts
CHANGED
|
@@ -311,7 +311,9 @@ declare enum ThemeEnum {
|
|
|
311
311
|
DARK = "dark",
|
|
312
312
|
COSMIC = "cosmic",
|
|
313
313
|
COFFEE = "coffee",
|
|
314
|
-
WINE = "wine"
|
|
314
|
+
WINE = "wine",
|
|
315
|
+
/** 麦田:default 基础上白红色改为金黄色 */
|
|
316
|
+
WHEAT = "wheat"
|
|
315
317
|
}
|
|
316
318
|
|
|
317
319
|
export declare const ThemeSwitcher: MemoExoticComponent<({ status, getThemeDisplayName, handleChangeTheme }: ThemeSwitcherProps) => JSX.Element>;
|
package/dist/events.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"events.cjs","names":[],"sources":["../src/events/EventEmitter.ts"],"sourcesContent":["/**\n * 通用事件发射器(按事件名注册/注销/触发)\n * Generic event emitter: subscribe, unsubscribe, and emit by event name.\n *\n * 不传 PayloadMap 时默认 PayloadMap = Record<E, unknown>,每个事件可无参或单参 (unknown),通用。\n * 传 PayloadMap 时可精确到:void(无参)、单类型(单参)、元组(多参)。\n *\n * @example 不传 PayloadMap(通用:无参或单参均可)\n * ```ts\n * const events = defineEvents({ A: \"a\", B: \"b\" });\n * class Em extends EventEmitter<EventNamesOf<typeof events>> { constructor() { super(events); } }\n * const em = new Em();\n * em.on(events.A, () => {}); em.emit(events.A);\n * em.on(events.B, (x) => console.log(x)); em.emit(events.B, data);\n * ```\n * @example 传 PayloadMap(严格单参/多参)\n * ```ts\n * type Map = { FOO: string; LOG: [string, number] };\n * class Em extends EventEmitter<\"FOO\"|\"LOG\", Map> { ... }\n * em.on(events.FOO, (x) => {}); em.emit(events.FOO, \"hi\");\n * em.on(events.LOG, (msg, level) => {}); em.emit(events.LOG, \"ok\", 1);\n * ```\n */\n\nimport type { Defined } from \"@/types\";\n\n/**
|
|
1
|
+
{"version":3,"file":"events.cjs","names":[],"sources":["../src/events/EventEmitter.ts"],"sourcesContent":["/**\n * 通用事件发射器(按事件名注册/注销/触发)\n * Generic event emitter: subscribe, unsubscribe, and emit by event name.\n *\n * 不传 PayloadMap 时默认 PayloadMap = Record<E, unknown>,每个事件可无参或单参 (unknown),通用。\n * 传 PayloadMap 时可精确到:void(无参)、单类型(单参)、元组(多参)。\n *\n * @example 不传 PayloadMap(通用:无参或单参均可)\n * ```ts\n * const events = defineEvents({ A: \"a\", B: \"b\" });\n * class Em extends EventEmitter<EventNamesOf<typeof events>> { constructor() { super(events); } }\n * const em = new Em();\n * em.on(events.A, () => {}); em.emit(events.A);\n * em.on(events.B, (x) => console.log(x)); em.emit(events.B, data);\n * ```\n * @example 传 PayloadMap(严格单参/多参)\n * ```ts\n * type Map = { FOO: string; LOG: [string, number] };\n * class Em extends EventEmitter<\"FOO\"|\"LOG\", Map> { ... }\n * em.on(events.FOO, (x) => {}); em.emit(events.FOO, \"hi\");\n * em.on(events.LOG, (msg, level) => {}); em.emit(events.LOG, \"ok\", 1);\n * ```\n */\n\nimport type { Defined } from \"@/types\";\n\n/** 回调类型:内部存储与 on/off 默认(unknown)时均用此,任意函数即可,无需 as 断言。 */\ntype EventCallback = (...args: any[]) => void;\n\n/**\n * 将 PayloadMap[K] 规范为参数元组。\n * void→[];unknown(默认)→ [] | [unknown];单类型 T→[T];元组→不变。\n */\ntype ToArgs<P> = P extends void\n ? []\n : unknown extends P\n ? [] | [P]\n : P extends unknown[]\n ? P\n : [P];\n\n/** 由 defineEvents 返回的「已规范事件名对象」类型;constructor 只接受此类型。 */\ntype DefinedEvents<T extends Record<string, string>> = Defined<T, \"events\">;\n\n/** 从 events 对象推导出事件名联合类型。Event name union from an events key-value object. */\ntype EventNamesOf<T> = T extends Defined<infer O, \"events\"> ? O[keyof O] : T extends Record<string, string> ? T[keyof T] : never;\n\n/**\n * 规范创建「一级 key-value」事件名对象:仅允许 key → 字符串 value,禁止嵌套(类型约束)。\n * 返回 DefinedEvents<T>,供 EventEmitter 构造使用。\n * Define events object: one-level key-value (string values), no nested objects (type-only). Returns DefinedEvents<T> for EventEmitter.\n *\n * @param events - 事件名 key-value 对象。Event name key-value object (e.g. { FOO: \"DOMAIN:FOO\" }).\n * @returns DefinedEvents<E>,仅此类型可传入 EventEmitter 构造。DefinedEvents<E>; only this type is accepted by EventEmitter constructor.\n * @example\n * ```ts\n * const routerEvents = defineEvents({ NAVIGATE: \"ROUTER:NAVIGATE\", NAVIGATE_BACK: \"ROUTER:NAVIGATE_BACK\" });\n * class RouterEmitter extends EventEmitter<EventNamesOf<typeof routerEvents>> { constructor() { super(routerEvents); } }\n * ```\n */\nfunction defineEvents<E extends Record<string, string>>(events: E): DefinedEvents<E> {\n return events as DefinedEvents<E>;\n}\n\nfunction createListenersMap<E extends string>(eventNames: readonly E[]): Record<E, Set<EventCallback>> {\n const map = {} as Record<E, Set<EventCallback>>;\n for (const e of eventNames) {\n map[e] = new Set();\n }\n return map;\n}\n\n/**\n * 泛型 EventEmitter:构造函数仅接受 defineEvents 返回的 DefinedEvents 类型,提供 on / off / emit。\n * PayloadMap[K] 可为 void(无参)、单类型 T(单参)、或元组 [A, B, ...](多参),统一规范为参数列表。\n * PayloadMap[K] can be void (no args), single type T (one arg), or tuple [A, B, ...] (multi arg).\n *\n * @param events - 须为 defineEvents(...) 的返回值(DefinedEvents)。Must be the return value of defineEvents(...) (DefinedEvents).\n */\nclass EventEmitter<E extends string, PayloadMap extends Record<E, unknown> = Record<E, unknown>> {\n private listeners: Record<E, Set<EventCallback>>;\n\n constructor(events: DefinedEvents<Record<string, E>>) {\n this.listeners = createListenersMap(Object.values(events as Record<string, E>));\n }\n\n /** 注册事件监听;回调为任意函数,由 emit 时传入的参数决定实际类型。 */\n on<K extends E>(event: K, callback: EventCallback): void {\n this.listeners[event].add(callback);\n }\n\n /** 移除事件监听(需与 on 时同一引用)。 */\n off<K extends E>(event: K, callback: EventCallback): void {\n this.listeners[event].delete(callback);\n }\n\n /**\n * 触发事件;参数与 PayloadMap[K] 一致:void 无参,T 单参,[A,B] 多参。\n * Emit an event; args match PayloadMap[K]: void → no args, T → one arg, [A,B] → spread.\n */\n emit<K extends E>(event: K, ...args: ToArgs<PayloadMap[K]>): void {\n this.listeners[event].forEach((cb) => cb(...args));\n }\n}\n\nexport { EventEmitter, defineEvents };\nexport type { EventCallback, DefinedEvents, EventNamesOf };\n"],"mappings":"mEA4DA,SAAS,EAA+C,EAA6B,CACnF,OAAO,EAGT,SAAS,EAAqC,EAAyD,CACrG,MAAM,EAAM,CAAA,EACZ,UAAW,KAAK,EACd,EAAI,CAAA,EAAK,IAAI,IAEf,OAAO,EAUT,IAAM,EAAN,KAAiG,CAC/F,UAEA,YAAY,EAA0C,CACpD,KAAK,UAAY,EAAmB,OAAO,OAAO,CAAA,CAA4B,EAIhF,GAAgB,EAAU,EAA+B,CACvD,KAAK,UAAU,CAAA,EAAO,IAAI,CAAA,EAI5B,IAAiB,EAAU,EAA+B,CACxD,KAAK,UAAU,CAAA,EAAO,OAAO,CAAA,EAO/B,KAAkB,KAAa,EAAmC,CAChE,KAAK,UAAU,CAAA,EAAO,QAAS,GAAO,EAAG,GAAG,CAAA,CAAK"}
|
package/dist/events.d.ts
CHANGED
|
@@ -25,8 +25,8 @@ export declare type DefinedEvents<T extends Record<string, string>> = Defined<T,
|
|
|
25
25
|
*/
|
|
26
26
|
export declare function defineEvents<E extends Record<string, string>>(events: E): DefinedEvents<E>;
|
|
27
27
|
|
|
28
|
-
/**
|
|
29
|
-
export declare type EventCallback
|
|
28
|
+
/** 回调类型:内部存储与 on/off 默认(unknown)时均用此,任意函数即可,无需 as 断言。 */
|
|
29
|
+
export declare type EventCallback = (...args: any[]) => void;
|
|
30
30
|
|
|
31
31
|
/**
|
|
32
32
|
* 泛型 EventEmitter:构造函数仅接受 defineEvents 返回的 DefinedEvents 类型,提供 on / off / emit。
|
|
@@ -38,16 +38,10 @@ export declare type EventCallback<Args extends unknown[] = unknown[]> = (...args
|
|
|
38
38
|
export declare class EventEmitter<E extends string, PayloadMap extends Record<E, unknown> = Record<E, unknown>> {
|
|
39
39
|
private listeners;
|
|
40
40
|
constructor(events: DefinedEvents<Record<string, E>>);
|
|
41
|
-
/**
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
on<K extends E>(event: K, callback: (...args: ToArgs<PayloadMap[K]>) => void): void;
|
|
46
|
-
/**
|
|
47
|
-
* 移除事件监听(需与 on 时同一引用)。
|
|
48
|
-
* Remove a listener (same reference as passed to on).
|
|
49
|
-
*/
|
|
50
|
-
off<K extends E>(event: K, callback: (...args: ToArgs<PayloadMap[K]>) => void): void;
|
|
41
|
+
/** 注册事件监听;回调为任意函数,由 emit 时传入的参数决定实际类型。 */
|
|
42
|
+
on<K extends E>(event: K, callback: EventCallback): void;
|
|
43
|
+
/** 移除事件监听(需与 on 时同一引用)。 */
|
|
44
|
+
off<K extends E>(event: K, callback: EventCallback): void;
|
|
51
45
|
/**
|
|
52
46
|
* 触发事件;参数与 PayloadMap[K] 一致:void 无参,T 单参,[A,B] 多参。
|
|
53
47
|
* Emit an event; args match PayloadMap[K]: void → no args, T → one arg, [A,B] → spread.
|
|
@@ -60,8 +54,7 @@ export declare type EventNamesOf<T> = T extends Defined<infer O, "events"> ? O[k
|
|
|
60
54
|
|
|
61
55
|
/**
|
|
62
56
|
* 将 PayloadMap[K] 规范为参数元组。
|
|
63
|
-
* void→[];unknown
|
|
64
|
-
* Normalize payload to args: void→[]; unknown (default)→optional one arg; single T→[T]; tuple→unchanged.
|
|
57
|
+
* void→[];unknown(默认)→ [] | [unknown];单类型 T→[T];元组→不变。
|
|
65
58
|
*/
|
|
66
59
|
declare type ToArgs<P> = P extends void ? [] : unknown extends P ? [] | [P] : P extends unknown[] ? P : [P];
|
|
67
60
|
|
package/dist/events.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"events.mjs","names":[],"sources":["../src/events/EventEmitter.ts"],"sourcesContent":["/**\n * 通用事件发射器(按事件名注册/注销/触发)\n * Generic event emitter: subscribe, unsubscribe, and emit by event name.\n *\n * 不传 PayloadMap 时默认 PayloadMap = Record<E, unknown>,每个事件可无参或单参 (unknown),通用。\n * 传 PayloadMap 时可精确到:void(无参)、单类型(单参)、元组(多参)。\n *\n * @example 不传 PayloadMap(通用:无参或单参均可)\n * ```ts\n * const events = defineEvents({ A: \"a\", B: \"b\" });\n * class Em extends EventEmitter<EventNamesOf<typeof events>> { constructor() { super(events); } }\n * const em = new Em();\n * em.on(events.A, () => {}); em.emit(events.A);\n * em.on(events.B, (x) => console.log(x)); em.emit(events.B, data);\n * ```\n * @example 传 PayloadMap(严格单参/多参)\n * ```ts\n * type Map = { FOO: string; LOG: [string, number] };\n * class Em extends EventEmitter<\"FOO\"|\"LOG\", Map> { ... }\n * em.on(events.FOO, (x) => {}); em.emit(events.FOO, \"hi\");\n * em.on(events.LOG, (msg, level) => {}); em.emit(events.LOG, \"ok\", 1);\n * ```\n */\n\nimport type { Defined } from \"@/types\";\n\n/**
|
|
1
|
+
{"version":3,"file":"events.mjs","names":[],"sources":["../src/events/EventEmitter.ts"],"sourcesContent":["/**\n * 通用事件发射器(按事件名注册/注销/触发)\n * Generic event emitter: subscribe, unsubscribe, and emit by event name.\n *\n * 不传 PayloadMap 时默认 PayloadMap = Record<E, unknown>,每个事件可无参或单参 (unknown),通用。\n * 传 PayloadMap 时可精确到:void(无参)、单类型(单参)、元组(多参)。\n *\n * @example 不传 PayloadMap(通用:无参或单参均可)\n * ```ts\n * const events = defineEvents({ A: \"a\", B: \"b\" });\n * class Em extends EventEmitter<EventNamesOf<typeof events>> { constructor() { super(events); } }\n * const em = new Em();\n * em.on(events.A, () => {}); em.emit(events.A);\n * em.on(events.B, (x) => console.log(x)); em.emit(events.B, data);\n * ```\n * @example 传 PayloadMap(严格单参/多参)\n * ```ts\n * type Map = { FOO: string; LOG: [string, number] };\n * class Em extends EventEmitter<\"FOO\"|\"LOG\", Map> { ... }\n * em.on(events.FOO, (x) => {}); em.emit(events.FOO, \"hi\");\n * em.on(events.LOG, (msg, level) => {}); em.emit(events.LOG, \"ok\", 1);\n * ```\n */\n\nimport type { Defined } from \"@/types\";\n\n/** 回调类型:内部存储与 on/off 默认(unknown)时均用此,任意函数即可,无需 as 断言。 */\ntype EventCallback = (...args: any[]) => void;\n\n/**\n * 将 PayloadMap[K] 规范为参数元组。\n * void→[];unknown(默认)→ [] | [unknown];单类型 T→[T];元组→不变。\n */\ntype ToArgs<P> = P extends void\n ? []\n : unknown extends P\n ? [] | [P]\n : P extends unknown[]\n ? P\n : [P];\n\n/** 由 defineEvents 返回的「已规范事件名对象」类型;constructor 只接受此类型。 */\ntype DefinedEvents<T extends Record<string, string>> = Defined<T, \"events\">;\n\n/** 从 events 对象推导出事件名联合类型。Event name union from an events key-value object. */\ntype EventNamesOf<T> = T extends Defined<infer O, \"events\"> ? O[keyof O] : T extends Record<string, string> ? T[keyof T] : never;\n\n/**\n * 规范创建「一级 key-value」事件名对象:仅允许 key → 字符串 value,禁止嵌套(类型约束)。\n * 返回 DefinedEvents<T>,供 EventEmitter 构造使用。\n * Define events object: one-level key-value (string values), no nested objects (type-only). Returns DefinedEvents<T> for EventEmitter.\n *\n * @param events - 事件名 key-value 对象。Event name key-value object (e.g. { FOO: \"DOMAIN:FOO\" }).\n * @returns DefinedEvents<E>,仅此类型可传入 EventEmitter 构造。DefinedEvents<E>; only this type is accepted by EventEmitter constructor.\n * @example\n * ```ts\n * const routerEvents = defineEvents({ NAVIGATE: \"ROUTER:NAVIGATE\", NAVIGATE_BACK: \"ROUTER:NAVIGATE_BACK\" });\n * class RouterEmitter extends EventEmitter<EventNamesOf<typeof routerEvents>> { constructor() { super(routerEvents); } }\n * ```\n */\nfunction defineEvents<E extends Record<string, string>>(events: E): DefinedEvents<E> {\n return events as DefinedEvents<E>;\n}\n\nfunction createListenersMap<E extends string>(eventNames: readonly E[]): Record<E, Set<EventCallback>> {\n const map = {} as Record<E, Set<EventCallback>>;\n for (const e of eventNames) {\n map[e] = new Set();\n }\n return map;\n}\n\n/**\n * 泛型 EventEmitter:构造函数仅接受 defineEvents 返回的 DefinedEvents 类型,提供 on / off / emit。\n * PayloadMap[K] 可为 void(无参)、单类型 T(单参)、或元组 [A, B, ...](多参),统一规范为参数列表。\n * PayloadMap[K] can be void (no args), single type T (one arg), or tuple [A, B, ...] (multi arg).\n *\n * @param events - 须为 defineEvents(...) 的返回值(DefinedEvents)。Must be the return value of defineEvents(...) (DefinedEvents).\n */\nclass EventEmitter<E extends string, PayloadMap extends Record<E, unknown> = Record<E, unknown>> {\n private listeners: Record<E, Set<EventCallback>>;\n\n constructor(events: DefinedEvents<Record<string, E>>) {\n this.listeners = createListenersMap(Object.values(events as Record<string, E>));\n }\n\n /** 注册事件监听;回调为任意函数,由 emit 时传入的参数决定实际类型。 */\n on<K extends E>(event: K, callback: EventCallback): void {\n this.listeners[event].add(callback);\n }\n\n /** 移除事件监听(需与 on 时同一引用)。 */\n off<K extends E>(event: K, callback: EventCallback): void {\n this.listeners[event].delete(callback);\n }\n\n /**\n * 触发事件;参数与 PayloadMap[K] 一致:void 无参,T 单参,[A,B] 多参。\n * Emit an event; args match PayloadMap[K]: void → no args, T → one arg, [A,B] → spread.\n */\n emit<K extends E>(event: K, ...args: ToArgs<PayloadMap[K]>): void {\n this.listeners[event].forEach((cb) => cb(...args));\n }\n}\n\nexport { EventEmitter, defineEvents };\nexport type { EventCallback, DefinedEvents, EventNamesOf };\n"],"mappings":"AA4DA,SAAS,EAA+C,GAA6B;AACnF,SAAO;;AAGT,SAAS,EAAqC,GAAyD;AACrG,QAAM,IAAM,CAAA;AACZ,aAAW,KAAK,EACd,CAAA,EAAI,CAAA,IAAK,oBAAI,IAAA;AAEf,SAAO;;AAUT,IAAM,IAAN,MAAiG;AAAA,EAC/F;AAAA,EAEA,YAAY,GAA0C;AACpD,SAAK,YAAY,EAAmB,OAAO,OAAO,CAAA,CAA4B;AAAA;EAIhF,GAAgB,GAAU,GAA+B;AACvD,SAAK,UAAU,CAAA,EAAO,IAAI,CAAA;AAAA;EAI5B,IAAiB,GAAU,GAA+B;AACxD,SAAK,UAAU,CAAA,EAAO,OAAO,CAAA;AAAA;EAO/B,KAAkB,MAAa,GAAmC;AAChE,SAAK,UAAU,CAAA,EAAO,QAAA,CAAS,MAAO,EAAG,GAAG,CAAA,CAAK;AAAA"}
|