nfx-ui 0.6.2 → 0.7.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/animations.cjs +2 -2
- package/dist/animations.d.ts +0 -101
- package/dist/animations.mjs +9 -11
- package/dist/apis.cjs +2 -2
- package/dist/apis.cjs.map +1 -1
- package/dist/apis.d.ts +0 -6
- package/dist/apis.mjs +8 -9
- package/dist/apis.mjs.map +1 -1
- package/dist/{chunk-BounceLoading-B54QEw0n.mjs → chunk-BounceLoading-C5XE8DKc.mjs} +62 -65
- package/dist/{chunk-BounceLoading-B54QEw0n.mjs.map → chunk-BounceLoading-C5XE8DKc.mjs.map} +1 -1
- package/dist/chunk-BounceLoading-CwvDT5HF.cjs +11 -0
- package/dist/{chunk-BounceLoading-C6n4BZVJ.cjs.map → chunk-BounceLoading-CwvDT5HF.cjs.map} +1 -1
- package/dist/chunk-animations-CEZ01ALd.mjs +740 -0
- package/dist/chunk-animations-CEZ01ALd.mjs.map +1 -0
- package/dist/chunk-animations-CO7zKbti.cjs +3 -0
- package/dist/chunk-animations-CO7zKbti.cjs.map +1 -0
- package/dist/chunk-i18n-BCDF-skF.cjs +3 -0
- package/dist/{chunk-i18n-daHSL0Nm.cjs.map → chunk-i18n-BCDF-skF.cjs.map} +1 -1
- package/dist/{chunk-i18n-BBPhh6MT.mjs → chunk-i18n-BsyWvA9c.mjs} +44 -69
- package/dist/{chunk-i18n-BBPhh6MT.mjs.map → chunk-i18n-BsyWvA9c.mjs.map} +1 -1
- package/dist/{chunk-types-SD4MzUGp.mjs → chunk-language-B8sfGadQ.mjs} +2 -2
- package/dist/chunk-language-B8sfGadQ.mjs.map +1 -0
- package/dist/{chunk-types-BE3JCLff.cjs → chunk-language-Bqmpuf2W.cjs} +1 -1
- package/dist/chunk-language-Bqmpuf2W.cjs.map +1 -0
- package/dist/{chunk-types-DNPBKfmx.mjs → chunk-layout-C2uqDEMJ.mjs} +2 -2
- package/dist/chunk-layout-C2uqDEMJ.mjs.map +1 -0
- package/dist/{chunk-types-C_opkZGr.cjs → chunk-layout-D728gccQ.cjs} +1 -1
- package/dist/chunk-layout-D728gccQ.cjs.map +1 -0
- package/dist/{chunk-lucide-BhgnmTNo.mjs → chunk-lucide-C54WenI6.mjs} +2 -2
- package/dist/{chunk-lucide-BhgnmTNo.mjs.map → chunk-lucide-C54WenI6.mjs.map} +1 -1
- package/dist/chunk-preference-BWEpbZgC.mjs +50 -0
- package/dist/{chunk-preference-By58ZcJ_.mjs.map → chunk-preference-BWEpbZgC.mjs.map} +1 -1
- package/dist/chunk-preference-Dbugm0iQ.cjs +3 -0
- package/dist/{chunk-preference-C144GkCD.cjs.map → chunk-preference-Dbugm0iQ.cjs.map} +1 -1
- package/dist/chunk-theme-9dcwRKw8.mjs +17 -0
- package/dist/chunk-theme-9dcwRKw8.mjs.map +1 -0
- package/dist/chunk-theme-BFvDRCYS.cjs +3 -0
- package/dist/chunk-theme-BFvDRCYS.cjs.map +1 -0
- package/dist/components.cjs +3 -3
- package/dist/components.cjs.map +1 -1
- package/dist/components.d.ts +0 -412
- package/dist/components.mjs +628 -642
- package/dist/components.mjs.map +1 -1
- package/dist/constants.cjs +1 -1
- package/dist/constants.d.ts +0 -129
- package/dist/constants.mjs +1 -1
- package/dist/events.cjs +1 -1
- package/dist/events.d.ts +0 -60
- package/dist/events.mjs +1 -1
- package/dist/hooks.cjs +1 -1
- package/dist/hooks.d.ts +0 -315
- package/dist/hooks.mjs +1 -1
- package/dist/icons.cjs +2 -2
- package/dist/icons.d.ts +0 -217
- package/dist/icons.mjs +2 -2
- package/dist/languages.cjs +2 -2
- package/dist/languages.cjs.map +1 -1
- package/dist/languages.d.ts +0 -178
- package/dist/languages.mjs +4 -4
- package/dist/languages.mjs.map +1 -1
- package/dist/layouts.cjs +2 -2
- package/dist/layouts.cjs.map +1 -1
- package/dist/layouts.d.ts +0 -208
- package/dist/layouts.mjs +201 -210
- package/dist/layouts.mjs.map +1 -1
- package/dist/navigations.cjs +1 -1
- package/dist/navigations.d.ts +0 -71
- package/dist/navigations.mjs +1 -1
- package/dist/pixel-blast.cjs +192 -0
- package/dist/pixel-blast.cjs.map +1 -0
- package/dist/pixel-blast.d.ts +1 -0
- package/dist/pixel-blast.mjs +506 -0
- package/dist/pixel-blast.mjs.map +1 -0
- package/dist/preference.cjs +2 -2
- package/dist/preference.d.ts +0 -95
- package/dist/preference.mjs +8 -11
- package/dist/services.cjs +2 -2
- package/dist/services.cjs.map +1 -1
- package/dist/services.d.ts +0 -7
- package/dist/services.mjs +9 -10
- package/dist/services.mjs.map +1 -1
- package/dist/stores.cjs +2 -2
- package/dist/stores.cjs.map +1 -1
- package/dist/stores.d.ts +1 -101
- package/dist/stores.mjs +53 -53
- package/dist/stores.mjs.map +1 -1
- package/dist/themes.cjs +2 -2
- package/dist/themes.cjs.map +1 -1
- package/dist/themes.d.ts +0 -232
- package/dist/themes.mjs +888 -721
- package/dist/themes.mjs.map +1 -1
- package/dist/types.cjs +1 -1
- package/dist/types.d.ts +0 -180
- package/dist/types.mjs +1 -1
- package/dist/utils.cjs +2 -2
- package/dist/utils.cjs.map +1 -1
- package/dist/utils.d.ts +0 -485
- package/dist/utils.mjs +143 -156
- package/dist/utils.mjs.map +1 -1
- package/package.json +45 -29
- package/dist/chunk-BounceLoading-C6n4BZVJ.cjs +0 -11
- package/dist/chunk-animations-Brp-bsaE.mjs +0 -1243
- package/dist/chunk-animations-Brp-bsaE.mjs.map +0 -1
- package/dist/chunk-animations-e2F3zuP9.cjs +0 -190
- package/dist/chunk-animations-e2F3zuP9.cjs.map +0 -1
- package/dist/chunk-i18n-daHSL0Nm.cjs +0 -3
- package/dist/chunk-preference-By58ZcJ_.mjs +0 -51
- package/dist/chunk-preference-C144GkCD.cjs +0 -3
- package/dist/chunk-types-BE3JCLff.cjs.map +0 -1
- package/dist/chunk-types-BNUlgEkq.cjs +0 -3
- package/dist/chunk-types-BNUlgEkq.cjs.map +0 -1
- package/dist/chunk-types-BudGuDCK.mjs +0 -20
- package/dist/chunk-types-BudGuDCK.mjs.map +0 -1
- package/dist/chunk-types-C_opkZGr.cjs.map +0 -1
- package/dist/chunk-types-DNPBKfmx.mjs.map +0 -1
- package/dist/chunk-types-SD4MzUGp.mjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-i18n-
|
|
1
|
+
{"version":3,"file":"chunk-i18n-BsyWvA9c.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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BYsBa,IAAiB;AAAA,EAAC;AAAA,EAAS;AAAA,EAAY;AAAA,EAAU;GACjD,IAAoC;AAAA,EAC/C,OAAO;AAAA,EACP,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,YAAY;GAGR,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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var A = (function(r) {
|
|
1
|
+
var A = /* @__PURE__ */ (function(r) {
|
|
2
2
|
return r.EN = "en", r.ZH = "zh", r.FR = "fr", r;
|
|
3
3
|
})(A || {}), a = A.ZH, G = Object.values(A), s = "language-storage";
|
|
4
4
|
export {
|
|
@@ -8,4 +8,4 @@ export {
|
|
|
8
8
|
a as t
|
|
9
9
|
};
|
|
10
10
|
|
|
11
|
-
//# sourceMappingURL=chunk-
|
|
11
|
+
//# sourceMappingURL=chunk-language-B8sfGadQ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-language-B8sfGadQ.mjs","names":[],"sources":["../src/languages/types/language.ts"],"sourcesContent":["/**\n * 语言枚举与常量,不引用任何 JSON,供需要轻量引用的模块使用。\n * Language enum and constants; no JSON deps for lightweight usage.\n */\nenum LanguageEnum {\n EN = \"en\",\n ZH = \"zh\",\n FR = \"fr\",\n}\n\nconst DEFAULT_LANGUAGE = LanguageEnum.ZH;\nconst LANGUAGE_VALUES = Object.values(LanguageEnum);\nconst LANGUAGE_STORAGE_KEY = \"language-storage\";\n\nexport { LanguageEnum, DEFAULT_LANGUAGE, LANGUAGE_VALUES, LANGUAGE_STORAGE_KEY };\n"],"mappings":"AAIA,IAAK,IAAL,0BAAA,GAAA;AACE,SAAA,EAAA,KAAA,MACA,EAAA,KAAA,MACA,EAAA,KAAA;GAHG,KAAA,CAAA,CAAA,GAMC,IAAmB,EAAa,IAChC,IAAkB,OAAO,OAAO,CAAA,GAChC,IAAuB"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
var r=(function(e){return e.EN="en",e.ZH="zh",e.FR="fr",e})(r||{}),t=r.ZH,n=Object.values(r),u="language-storage";Object.defineProperty(exports,"DEFAULT_LANGUAGE",{enumerable:!0,get:function(){return t}});Object.defineProperty(exports,"LANGUAGE_STORAGE_KEY",{enumerable:!0,get:function(){return u}});Object.defineProperty(exports,"LANGUAGE_VALUES",{enumerable:!0,get:function(){return n}});Object.defineProperty(exports,"LanguageEnum",{enumerable:!0,get:function(){return r}});
|
|
2
2
|
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
3
|
+
//# sourceMappingURL=chunk-language-Bqmpuf2W.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-language-Bqmpuf2W.cjs","names":[],"sources":["../src/languages/types/language.ts"],"sourcesContent":["/**\n * 语言枚举与常量,不引用任何 JSON,供需要轻量引用的模块使用。\n * Language enum and constants; no JSON deps for lightweight usage.\n */\nenum LanguageEnum {\n EN = \"en\",\n ZH = \"zh\",\n FR = \"fr\",\n}\n\nconst DEFAULT_LANGUAGE = LanguageEnum.ZH;\nconst LANGUAGE_VALUES = Object.values(LanguageEnum);\nconst LANGUAGE_STORAGE_KEY = \"language-storage\";\n\nexport { LanguageEnum, DEFAULT_LANGUAGE, LANGUAGE_VALUES, LANGUAGE_STORAGE_KEY };\n"],"mappings":"AAIA,IAAK,GAAL,SAAA,EAAA,CACE,OAAA,EAAA,GAAA,KACA,EAAA,GAAA,KACA,EAAA,GAAA,SAHG,GAAA,CAAA,CAAA,EAMC,EAAmB,EAAa,GAChC,EAAkB,OAAO,OAAO,CAAA,EAChC,EAAuB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var r = (function(a) {
|
|
1
|
+
var r = /* @__PURE__ */ (function(a) {
|
|
2
2
|
return a.SHOW = "show", a.HIDE = "hide", a;
|
|
3
3
|
})(r || {}), O = r.SHOW, s = Object.values(r), t = "layout-storage";
|
|
4
4
|
export {
|
|
@@ -8,4 +8,4 @@ export {
|
|
|
8
8
|
O as t
|
|
9
9
|
};
|
|
10
10
|
|
|
11
|
-
//# sourceMappingURL=chunk-
|
|
11
|
+
//# sourceMappingURL=chunk-layout-C2uqDEMJ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-layout-C2uqDEMJ.mjs","names":[],"sources":["../src/designs/layouts/types/layout.ts"],"sourcesContent":["/**\n * 布局模式枚举与常量。Layout mode enum and constants.\n */\nenum LayoutModeEnum {\n SHOW = \"show\",\n HIDE = \"hide\",\n}\n\nconst DEFAULT_LAYOUT_MODE = LayoutModeEnum.SHOW;\nconst LAYOUT_MODE_VALUES = Object.values(LayoutModeEnum);\nconst LAYOUT_STORAGE_KEY = \"layout-storage\";\n\nexport { LayoutModeEnum, DEFAULT_LAYOUT_MODE, LAYOUT_MODE_VALUES, LAYOUT_STORAGE_KEY };\n"],"mappings":"AAGA,IAAK,IAAL,0BAAA,GAAA;AACE,SAAA,EAAA,OAAA,QACA,EAAA,OAAA;GAFG,KAAA,CAAA,CAAA,GAKC,IAAsB,EAAe,MACrC,IAAqB,OAAO,OAAO,CAAA,GACnC,IAAqB"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
var e=(function(r){return r.SHOW="show",r.HIDE="hide",r})(e||{}),t=e.SHOW,n=Object.values(e),u="layout-storage";Object.defineProperty(exports,"DEFAULT_LAYOUT_MODE",{enumerable:!0,get:function(){return t}});Object.defineProperty(exports,"LAYOUT_MODE_VALUES",{enumerable:!0,get:function(){return n}});Object.defineProperty(exports,"LAYOUT_STORAGE_KEY",{enumerable:!0,get:function(){return u}});Object.defineProperty(exports,"LayoutModeEnum",{enumerable:!0,get:function(){return e}});
|
|
2
2
|
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
3
|
+
//# sourceMappingURL=chunk-layout-D728gccQ.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-layout-D728gccQ.cjs","names":[],"sources":["../src/designs/layouts/types/layout.ts"],"sourcesContent":["/**\n * 布局模式枚举与常量。Layout mode enum and constants.\n */\nenum LayoutModeEnum {\n SHOW = \"show\",\n HIDE = \"hide\",\n}\n\nconst DEFAULT_LAYOUT_MODE = LayoutModeEnum.SHOW;\nconst LAYOUT_MODE_VALUES = Object.values(LayoutModeEnum);\nconst LAYOUT_STORAGE_KEY = \"layout-storage\";\n\nexport { LayoutModeEnum, DEFAULT_LAYOUT_MODE, LAYOUT_MODE_VALUES, LAYOUT_STORAGE_KEY };\n"],"mappings":"AAGA,IAAK,GAAL,SAAA,EAAA,CACE,OAAA,EAAA,KAAA,OACA,EAAA,KAAA,WAFG,GAAA,CAAA,CAAA,EAKC,EAAsB,EAAe,KACrC,EAAqB,OAAO,OAAO,CAAA,EACnC,EAAqB"}
|
|
@@ -7,7 +7,7 @@ var r = Object.defineProperty, Pa = (e, o) => {
|
|
|
7
7
|
enumerable: !0
|
|
8
8
|
});
|
|
9
9
|
return o || r(a, Symbol.toStringTag, { value: "Module" }), a;
|
|
10
|
-
}, Sa = Pa({
|
|
10
|
+
}, Sa = /* @__PURE__ */ Pa({
|
|
11
11
|
AlertCircle: () => t,
|
|
12
12
|
ArrowLeft: () => l,
|
|
13
13
|
ArrowRight: () => i,
|
|
@@ -155,4 +155,4 @@ export {
|
|
|
155
155
|
V as z
|
|
156
156
|
};
|
|
157
157
|
|
|
158
|
-
//# sourceMappingURL=chunk-lucide-
|
|
158
|
+
//# sourceMappingURL=chunk-lucide-C54WenI6.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-lucide-
|
|
1
|
+
{"version":3,"file":"chunk-lucide-C54WenI6.mjs","names":[],"sources":["../src/icons/lucide.ts"],"sourcesContent":["export type { LucideIcon } from \"lucide-react\";\n\nexport {\n AlertCircle,\n ArrowLeft,\n ArrowRight,\n Ban,\n Bell,\n Box,\n Briefcase,\n Calendar,\n Camera,\n Check,\n CheckCircle,\n ChevronDown,\n ChevronLeft,\n ChevronRight,\n ChevronUp,\n Clock,\n Coffee,\n CreditCard,\n DollarSign,\n Edit,\n ExternalLink,\n Eye,\n EyeOff,\n FileText,\n Filter,\n FolderOpen,\n FolderPlus,\n FolderTree,\n Folders,\n Globe,\n GraduationCap,\n GripVertical,\n Hash,\n History,\n Home,\n Image,\n Info,\n Languages,\n LayoutGrid,\n LayoutList,\n Leaf,\n Layers,\n List,\n Loader,\n Loader2,\n Lock,\n LockKeyhole,\n LogOut,\n Mail,\n Menu,\n MessageCircle,\n Package,\n Pencil,\n Phone,\n Plus,\n Search,\n Settings,\n Shield,\n Tag,\n Trash2,\n TrendingUp,\n Upload,\n User,\n UserCheck,\n UserPlus,\n UserRound,\n UserRoundSearch,\n UserX,\n Wand2,\n X,\n XCircle,\n} from \"lucide-react\";\n"],"mappings":""}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { c as o, n as l, r as s, s as h } from "./chunk-theme-9dcwRKw8.mjs";
|
|
2
|
+
import { i as t } from "./chunk-layout-C2uqDEMJ.mjs";
|
|
3
|
+
import { i as E, r as c } from "./chunk-language-B8sfGadQ.mjs";
|
|
4
|
+
var r = /* @__PURE__ */ (function(e) {
|
|
5
|
+
return e.NONE = "none", e.WAVES = "waves", e.SQUARES = "squares", e.LETTER_GLITCH = "letterGlitch", e.PIXEL_BLAST = "pixelBlast", e;
|
|
6
|
+
})({}), n = r.NONE, A = Object.values(r);
|
|
7
|
+
function b(e) {
|
|
8
|
+
if (!e || typeof e != "string") return null;
|
|
9
|
+
try {
|
|
10
|
+
const a = JSON.parse(e), u = a.layoutMode === t.HIDE ? t.HIDE : t.SHOW, d = typeof a.other?.dashboardBackground == "string" && A.includes(a.other.dashboardBackground) ? a.other.dashboardBackground : n, i = typeof a.base == "string" && l.includes(a.base) ? a.base : s.DEFAULT, g = typeof a.language == "string" && c.includes(a.language) ? a.language : "zh";
|
|
11
|
+
return {
|
|
12
|
+
theme: typeof a.theme == "string" && h.includes(a.theme) ? a.theme : o.DEFAULT,
|
|
13
|
+
base: i,
|
|
14
|
+
language: g,
|
|
15
|
+
layoutMode: u,
|
|
16
|
+
other: { dashboardBackground: d }
|
|
17
|
+
};
|
|
18
|
+
} catch {
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
function f(e) {
|
|
23
|
+
const a = {
|
|
24
|
+
theme: e.theme || void 0,
|
|
25
|
+
base: e.base || void 0,
|
|
26
|
+
language: e.language || void 0,
|
|
27
|
+
layoutMode: e.layoutMode,
|
|
28
|
+
other: e.other ? { dashboardBackground: e.other.dashboardBackground } : void 0
|
|
29
|
+
};
|
|
30
|
+
return JSON.stringify(a);
|
|
31
|
+
}
|
|
32
|
+
function y() {
|
|
33
|
+
return {
|
|
34
|
+
theme: o.DEFAULT,
|
|
35
|
+
base: s.DEFAULT,
|
|
36
|
+
language: E.ZH,
|
|
37
|
+
layoutMode: t.SHOW,
|
|
38
|
+
other: { dashboardBackground: n }
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
export {
|
|
42
|
+
n as a,
|
|
43
|
+
A as i,
|
|
44
|
+
b as n,
|
|
45
|
+
r as o,
|
|
46
|
+
f as r,
|
|
47
|
+
y as t
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
//# sourceMappingURL=chunk-preference-BWEpbZgC.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-preference-
|
|
1
|
+
{"version":3,"file":"chunk-preference-BWEpbZgC.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,IAAL,0BAAA,GAAA;AACL,SAAA,EAAA,OAAA,QACA,EAAA,QAAA,SACA,EAAA,UAAA,WACA,EAAA,gBAAA,gBACA,EAAA,cAAA;QAGW,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"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
const r=require("./chunk-theme-BFvDRCYS.cjs"),n=require("./chunk-layout-D728gccQ.cjs"),a=require("./chunk-language-Bqmpuf2W.cjs");var u=(function(e){return e.NONE="none",e.WAVES="waves",e.SQUARES="squares",e.LETTER_GLITCH="letterGlitch",e.PIXEL_BLAST="pixelBlast",e})({}),o=u.NONE,s=Object.values(u);function l(e){if(!e||typeof e!="string")return null;try{const t=JSON.parse(e),d=t.layoutMode===n.LayoutModeEnum.HIDE?n.LayoutModeEnum.HIDE:n.LayoutModeEnum.SHOW,i=typeof t.other?.dashboardBackground=="string"&&s.includes(t.other.dashboardBackground)?t.other.dashboardBackground:o,c=typeof t.base=="string"&&r.BASE_VALUES.includes(t.base)?t.base:r.BaseEnum.DEFAULT,g=typeof t.language=="string"&&a.LANGUAGE_VALUES.includes(t.language)?t.language:"zh";return{theme:typeof t.theme=="string"&&r.THEME_VALUES.includes(t.theme)?t.theme:r.ThemeEnum.DEFAULT,base:c,language:g,layoutMode:d,other:{dashboardBackground:i}}}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:r.ThemeEnum.DEFAULT,base:r.BaseEnum.DEFAULT,language:a.LanguageEnum.ZH,layoutMode:n.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
|
+
|
|
3
|
+
//# sourceMappingURL=chunk-preference-Dbugm0iQ.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-preference-
|
|
1
|
+
{"version":3,"file":"chunk-preference-Dbugm0iQ.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":"kIAQA,IAAY,GAAL,SAAA,EAAA,CACL,OAAA,EAAA,KAAA,OACA,EAAA,MAAA,QACA,EAAA,QAAA,UACA,EAAA,cAAA,eACA,EAAA,YAAA,qBAGW,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,17 @@
|
|
|
1
|
+
var r = /* @__PURE__ */ (function(a) {
|
|
2
|
+
return a.DEFAULT = "default", a.LIGHT = "light", a.CORPORATE = "corporate", a.FOREST = "forest", a.DARK = "dark", a.COSMIC = "cosmic", a.COFFEE = "coffee", a.WINE = "wine", a.WHEAT = "wheat", a;
|
|
3
|
+
})({}), t = r.DEFAULT, o = Object.values(r), A = /* @__PURE__ */ (function(a) {
|
|
4
|
+
return a.DEFAULT = "default", a.IOS = "ios", a.ANDROID = "android", a.WINDOWS = "windows", a.LINUX = "linux", a;
|
|
5
|
+
})({}), O = A.DEFAULT, E = Object.values(A), s = "theme-color", L = "theme-base";
|
|
6
|
+
export {
|
|
7
|
+
O as a,
|
|
8
|
+
r as c,
|
|
9
|
+
s as i,
|
|
10
|
+
E as n,
|
|
11
|
+
t as o,
|
|
12
|
+
A as r,
|
|
13
|
+
o as s,
|
|
14
|
+
L as t
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
//# sourceMappingURL=chunk-theme-9dcwRKw8.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-theme-9dcwRKw8.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 ───────────────────────────────────────────────\n\n /** 主品牌色 — 按钮、链接、激活态 | `--color-primary` */\n primary: string;\n /** 主色悬停 — 按钮 hover / ShowFilter active | `--color-primary-hover` */\n primaryHover: string;\n /** 主色浅色 — 标签底色、浅色按钮、选中态背景 | `--color-primary-light` */\n primaryLight: string;\n /** 主色极浅底 — Input/SearchInput focus 发光底、选中行底 | `--color-primary-bg` */\n primaryBg: string;\n /** 主色 RGB 三元组 — 用于 `rgba(var(--color-primary-rgb), α)` 计算 | `--color-primary-rgb` */\n primaryRgb: string;\n /** 主色半透明 — focus ring 外环、Dropdown 聚焦阴影 | `--color-primary-transparent` `--color-primary-alpha` */\n primaryTransparent: string;\n /** 主色上的前景文字 — 按钮白字 / 深色背景字 | `--color-primary-fg` */\n primaryFg: string;\n\n // ─── 语义色 Semantic ─────────────────────────────────────────────\n\n /** 成功色 — Toast 成功、状态徽标 | `--color-success` */\n success: string;\n /** 成功色浅底 — 成功 Alert 背景 | `--color-success-light` */\n successLight: string;\n /** 成功色 RGB — `rgba(var(--color-success-rgb), α)` | `--color-success-rgb` */\n successRgb: string;\n /** 信息色 — 提示 Alert、Badge | `--color-info` */\n info: string;\n /** 信息色浅底 — 信息 Alert 背景 | `--color-info-light` */\n infoLight: string;\n /** 信息色 RGB — `rgba(var(--color-info-rgb), α)` | `--color-info-rgb` */\n infoRgb: string;\n /** 警告色 — 警告 Toast、图标 | `--color-warning` */\n warning: string;\n /** 警告色浅底 — 警告 Alert 背景 | `--color-warning-light` */\n warningLight: string;\n /** 警告色 RGB — `rgba(var(--color-warning-rgb), α)` | `--color-warning-rgb` */\n warningRgb: string;\n /** 危险色 — 删除按钮、表单错误边框 | `--color-danger` `--color-error` */\n danger: string;\n /** 危险色浅底 — 危险按钮 hover、错误 Alert 底 | `--color-danger-light` */\n dangerLight: string;\n /** 危险色 RGB — Input/Textarea 错误 focus ring | `--color-danger-rgb` `--color-error-rgb` */\n dangerRgb: string;\n\n // ─── 背景 Background ────────────────────────────────────────────\n\n /** 页面底色 — html body、最外层容器 | `--color-bg` `--color-bg-1` */\n bg: string;\n /** 二级背景 — Sidebar、Footer、卡片 | `--color-bg-2` */\n bg2: string;\n /** 三级背景 — 菜单 hover、条纹行 | `--color-bg-3` */\n bg3: string;\n /** 四级背景 — 深层嵌套面板 | `--color-bg-4` */\n bg4: string;\n /** 辅助背景 — Suspense fallback 面板 | `--color-bg-secondary` */\n bgSecondary: string;\n\n // ─── 边框 Border ─────────────────────────────────────────────────\n\n /** 最浅边框 — 容器默认边框 | `--color-border` */\n border: string;\n /** 二级边框 — 分隔线 | `--color-border-2` */\n border2: string;\n /** 三级边框 — Input 非激活边、列表分隔 | `--color-border-3` */\n border3: string;\n /** 四级边框 — Input/Button 默认边框 | `--color-border-4` */\n border4: string;\n /** 五级边框(最深) — disabled Input 边框 | `--color-border-5` */\n border5: string;\n /** 悬停边框 — Suspense retry hover、ShowFilter hover | `--color-border-hover` */\n borderHover: string;\n\n // ─── 前景 / 文字 Foreground ──────────────────────────────────────\n\n /** 辅助图标色 — icon placeholder、ShowFilter 默认色 | `--color-fg` */\n fg: string;\n /** 正文文字 — 段落、表格内容 | `--color-fg-text` */\n fgText: string;\n /** 标题文字 — h1-h6、Input label | `--color-fg-heading` */\n fgHeading: string;\n /** 高亮文字 — 链接、Dropdown 选中项 | `--color-fg-highlight` */\n fgHighlight: string;\n /** 次要文字 — placeholder、hint、辅助说明 | `--color-fg-muted` */\n fgMuted: string;\n /** 主色上的文字 — primary 按钮/Badge 内文字 | `--color-fg-on-primary` */\n fgOnPrimary: string;\n /** 分隔线 — Sidebar 底部分隔、Dropdown 选项间隔 | `--color-separator` */\n separator: string;\n\n // ─── 全局效果 Effects ────────────────────────────────────────────\n\n /** 遮罩层 — Modal/Drawer 背景蒙版 | `--color-overlay` */\n overlay: string;\n /** 阴影色 — 卡片/弹出层 box-shadow 基色 | `--color-shadow` */\n shadow: string;\n /** 焦点环 — 键盘 Tab 导航 focus outline | `--color-ring` */\n ring: string;\n\n // ─── 通用图表系列 Chart Series ───────────────────────────────────\n\n /** 图表系列 1(通常=主色) — 多系列折线/柱状图第 1 组 | `--color-chart-1` */\n chart1: string;\n /** 图表系列 2 — 第 2 组数据线 | `--color-chart-2` */\n chart2: string;\n /** 图表系列 3 — 第 3 组数据线 | `--color-chart-3` */\n chart3: string;\n /** 图表系列 4 — 第 4 组数据线 | `--color-chart-4` */\n chart4: string;\n /** 图表系列 5 — 第 5 组数据线 | `--color-chart-5` */\n chart5: string;\n\n // ─── 专用图表 Specific Charts ────────────────────────────────────\n\n /** 温度计仪表盘 — 圆弧填充渐变(5 色由浅到深)、空弧、滑块 */\n temperature: {\n arcFill: string[];\n arcEmpty: string;\n thumbBg: string;\n thumbBorder: string;\n };\n\n /** 太阳能面板图 — 渐变、阴影、第二系列 */\n solar: {\n gradientLeft: string;\n gradientRight: string;\n shadowColor: string;\n secondSeriesFill: string;\n };\n\n /** 流量图 — tooltip、坐标轴、数据点、渐变 */\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 /** 电力图 — tooltip、坐标轴、折线渐变、面积渐变 */\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 全局 — 画布底色、文字、坐标轴、tooltip */\n echarts: {\n bg: string;\n textColor: string;\n axisLineColor: string;\n splitLineColor: string;\n itemHoverShadowColor: string;\n tooltipBackgroundColor: string;\n };\n\n /** Chart.js 全局 — 坐标轴、文字 */\n chartjs: {\n axisLineColor: string;\n textColor: string;\n };\n}\n\n/** 非颜色变量(圆角等,可随平台不同:iOS 24 / Android|Windows 6 / Linux 4) */\nexport interface BaseVariables {\n /** 按钮圆角(px) | `--radius-button` */\n buttonRadius: number;\n /** 卡片圆角(px) | `--radius-card` */\n cardRadius: number;\n /** 输入框圆角(px) | `--radius-input` */\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 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":"AA0NA,IAAY,IAAL,0BAAA,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,QACA,EAAA,QAAA;QAGW,IAAgB,EAAU,SAC1B,IAAe,OAAO,OAAO,CAAA,GAG9B,IAAL,0BAAA,GAAA;AACL,SAAA,EAAA,UAAA,WACA,EAAA,MAAA,OACA,EAAA,UAAA,WACA,EAAA,UAAA,WACA,EAAA,QAAA;QAGW,IAAe,EAAS,SACxB,IAAc,OAAO,OAAO,CAAA,GAE5B,IAAoB,eACpB,IAAmB"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
var r=(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})({}),n=r.DEFAULT,u=Object.values(r),t=(function(e){return e.DEFAULT="default",e.IOS="ios",e.ANDROID="android",e.WINDOWS="windows",e.LINUX="linux",e})({}),E=t.DEFAULT,o=Object.values(t),A="theme-color",O="theme-base";Object.defineProperty(exports,"BASE_STORAGE_KEY",{enumerable:!0,get:function(){return O}});Object.defineProperty(exports,"BASE_VALUES",{enumerable:!0,get:function(){return o}});Object.defineProperty(exports,"BaseEnum",{enumerable:!0,get:function(){return t}});Object.defineProperty(exports,"COLOR_STORAGE_KEY",{enumerable:!0,get:function(){return A}});Object.defineProperty(exports,"DEFAULT_BASE",{enumerable:!0,get:function(){return E}});Object.defineProperty(exports,"DEFAULT_THEME",{enumerable:!0,get:function(){return n}});Object.defineProperty(exports,"THEME_VALUES",{enumerable:!0,get:function(){return u}});Object.defineProperty(exports,"ThemeEnum",{enumerable:!0,get:function(){return r}});
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=chunk-theme-BFvDRCYS.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-theme-BFvDRCYS.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 ───────────────────────────────────────────────\n\n /** 主品牌色 — 按钮、链接、激活态 | `--color-primary` */\n primary: string;\n /** 主色悬停 — 按钮 hover / ShowFilter active | `--color-primary-hover` */\n primaryHover: string;\n /** 主色浅色 — 标签底色、浅色按钮、选中态背景 | `--color-primary-light` */\n primaryLight: string;\n /** 主色极浅底 — Input/SearchInput focus 发光底、选中行底 | `--color-primary-bg` */\n primaryBg: string;\n /** 主色 RGB 三元组 — 用于 `rgba(var(--color-primary-rgb), α)` 计算 | `--color-primary-rgb` */\n primaryRgb: string;\n /** 主色半透明 — focus ring 外环、Dropdown 聚焦阴影 | `--color-primary-transparent` `--color-primary-alpha` */\n primaryTransparent: string;\n /** 主色上的前景文字 — 按钮白字 / 深色背景字 | `--color-primary-fg` */\n primaryFg: string;\n\n // ─── 语义色 Semantic ─────────────────────────────────────────────\n\n /** 成功色 — Toast 成功、状态徽标 | `--color-success` */\n success: string;\n /** 成功色浅底 — 成功 Alert 背景 | `--color-success-light` */\n successLight: string;\n /** 成功色 RGB — `rgba(var(--color-success-rgb), α)` | `--color-success-rgb` */\n successRgb: string;\n /** 信息色 — 提示 Alert、Badge | `--color-info` */\n info: string;\n /** 信息色浅底 — 信息 Alert 背景 | `--color-info-light` */\n infoLight: string;\n /** 信息色 RGB — `rgba(var(--color-info-rgb), α)` | `--color-info-rgb` */\n infoRgb: string;\n /** 警告色 — 警告 Toast、图标 | `--color-warning` */\n warning: string;\n /** 警告色浅底 — 警告 Alert 背景 | `--color-warning-light` */\n warningLight: string;\n /** 警告色 RGB — `rgba(var(--color-warning-rgb), α)` | `--color-warning-rgb` */\n warningRgb: string;\n /** 危险色 — 删除按钮、表单错误边框 | `--color-danger` `--color-error` */\n danger: string;\n /** 危险色浅底 — 危险按钮 hover、错误 Alert 底 | `--color-danger-light` */\n dangerLight: string;\n /** 危险色 RGB — Input/Textarea 错误 focus ring | `--color-danger-rgb` `--color-error-rgb` */\n dangerRgb: string;\n\n // ─── 背景 Background ────────────────────────────────────────────\n\n /** 页面底色 — html body、最外层容器 | `--color-bg` `--color-bg-1` */\n bg: string;\n /** 二级背景 — Sidebar、Footer、卡片 | `--color-bg-2` */\n bg2: string;\n /** 三级背景 — 菜单 hover、条纹行 | `--color-bg-3` */\n bg3: string;\n /** 四级背景 — 深层嵌套面板 | `--color-bg-4` */\n bg4: string;\n /** 辅助背景 — Suspense fallback 面板 | `--color-bg-secondary` */\n bgSecondary: string;\n\n // ─── 边框 Border ─────────────────────────────────────────────────\n\n /** 最浅边框 — 容器默认边框 | `--color-border` */\n border: string;\n /** 二级边框 — 分隔线 | `--color-border-2` */\n border2: string;\n /** 三级边框 — Input 非激活边、列表分隔 | `--color-border-3` */\n border3: string;\n /** 四级边框 — Input/Button 默认边框 | `--color-border-4` */\n border4: string;\n /** 五级边框(最深) — disabled Input 边框 | `--color-border-5` */\n border5: string;\n /** 悬停边框 — Suspense retry hover、ShowFilter hover | `--color-border-hover` */\n borderHover: string;\n\n // ─── 前景 / 文字 Foreground ──────────────────────────────────────\n\n /** 辅助图标色 — icon placeholder、ShowFilter 默认色 | `--color-fg` */\n fg: string;\n /** 正文文字 — 段落、表格内容 | `--color-fg-text` */\n fgText: string;\n /** 标题文字 — h1-h6、Input label | `--color-fg-heading` */\n fgHeading: string;\n /** 高亮文字 — 链接、Dropdown 选中项 | `--color-fg-highlight` */\n fgHighlight: string;\n /** 次要文字 — placeholder、hint、辅助说明 | `--color-fg-muted` */\n fgMuted: string;\n /** 主色上的文字 — primary 按钮/Badge 内文字 | `--color-fg-on-primary` */\n fgOnPrimary: string;\n /** 分隔线 — Sidebar 底部分隔、Dropdown 选项间隔 | `--color-separator` */\n separator: string;\n\n // ─── 全局效果 Effects ────────────────────────────────────────────\n\n /** 遮罩层 — Modal/Drawer 背景蒙版 | `--color-overlay` */\n overlay: string;\n /** 阴影色 — 卡片/弹出层 box-shadow 基色 | `--color-shadow` */\n shadow: string;\n /** 焦点环 — 键盘 Tab 导航 focus outline | `--color-ring` */\n ring: string;\n\n // ─── 通用图表系列 Chart Series ───────────────────────────────────\n\n /** 图表系列 1(通常=主色) — 多系列折线/柱状图第 1 组 | `--color-chart-1` */\n chart1: string;\n /** 图表系列 2 — 第 2 组数据线 | `--color-chart-2` */\n chart2: string;\n /** 图表系列 3 — 第 3 组数据线 | `--color-chart-3` */\n chart3: string;\n /** 图表系列 4 — 第 4 组数据线 | `--color-chart-4` */\n chart4: string;\n /** 图表系列 5 — 第 5 组数据线 | `--color-chart-5` */\n chart5: string;\n\n // ─── 专用图表 Specific Charts ────────────────────────────────────\n\n /** 温度计仪表盘 — 圆弧填充渐变(5 色由浅到深)、空弧、滑块 */\n temperature: {\n arcFill: string[];\n arcEmpty: string;\n thumbBg: string;\n thumbBorder: string;\n };\n\n /** 太阳能面板图 — 渐变、阴影、第二系列 */\n solar: {\n gradientLeft: string;\n gradientRight: string;\n shadowColor: string;\n secondSeriesFill: string;\n };\n\n /** 流量图 — tooltip、坐标轴、数据点、渐变 */\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 /** 电力图 — tooltip、坐标轴、折线渐变、面积渐变 */\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 全局 — 画布底色、文字、坐标轴、tooltip */\n echarts: {\n bg: string;\n textColor: string;\n axisLineColor: string;\n splitLineColor: string;\n itemHoverShadowColor: string;\n tooltipBackgroundColor: string;\n };\n\n /** Chart.js 全局 — 坐标轴、文字 */\n chartjs: {\n axisLineColor: string;\n textColor: string;\n };\n}\n\n/** 非颜色变量(圆角等,可随平台不同:iOS 24 / Android|Windows 6 / Linux 4) */\nexport interface BaseVariables {\n /** 按钮圆角(px) | `--radius-button` */\n buttonRadius: number;\n /** 卡片圆角(px) | `--radius-card` */\n cardRadius: number;\n /** 输入框圆角(px) | `--radius-input` */\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 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":"AA0NA,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,OACA,EAAA,MAAA,gBAGW,EAAgB,EAAU,QAC1B,EAAe,OAAO,OAAO,CAAA,EAG9B,GAAL,SAAA,EAAA,CACL,OAAA,EAAA,QAAA,UACA,EAAA,IAAA,MACA,EAAA,QAAA,UACA,EAAA,QAAA,UACA,EAAA,MAAA,gBAGW,EAAe,EAAS,QACxB,EAAc,OAAO,OAAO,CAAA,EAE5B,EAAoB,cACpB,EAAmB"}
|