nfx-ui 0.16.0 → 0.16.2
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 -3
- package/dist/animations.mjs +3 -4
- package/dist/apis.cjs +1 -2
- package/dist/apis.cjs.map +1 -1
- package/dist/apis.mjs +1 -2
- package/dist/apis.mjs.map +1 -1
- package/dist/{chunk-BounceLoading-C5XE8DKc.mjs → chunk-BounceLoading-C-gq-XVr.mjs} +1 -1
- package/dist/{chunk-BounceLoading-C5XE8DKc.mjs.map → chunk-BounceLoading-C-gq-XVr.mjs.map} +1 -1
- package/dist/chunk-BounceLoading-CkxvzNz8.cjs +11 -0
- package/dist/{chunk-BounceLoading-CwvDT5HF.cjs.map → chunk-BounceLoading-CkxvzNz8.cjs.map} +1 -1
- package/dist/{chunk-animations-Do1xZdGL.mjs → chunk-animations-CiJbVYGC.mjs} +2 -2
- package/dist/{chunk-animations-Do1xZdGL.mjs.map → chunk-animations-CiJbVYGC.mjs.map} +1 -1
- package/dist/{chunk-animations-DOdfS0n5.cjs → chunk-animations-i85rn79V.cjs} +2 -2
- package/dist/{chunk-animations-DOdfS0n5.cjs.map → chunk-animations-i85rn79V.cjs.map} +1 -1
- package/dist/{chunk-i18n--XStRXog.cjs → chunk-i18n-2-xL4pEi.cjs} +2 -2
- package/dist/{chunk-i18n--XStRXog.cjs.map → chunk-i18n-2-xL4pEi.cjs.map} +1 -1
- package/dist/{chunk-i18n-ly0gkdrE.mjs → chunk-i18n-DgaoEbGL.mjs} +3 -3
- package/dist/{chunk-i18n-ly0gkdrE.mjs.map → chunk-i18n-DgaoEbGL.mjs.map} +1 -1
- package/dist/{chunk-language-b-WaFsLY.cjs → chunk-language-2r4uKROB.cjs} +2 -2
- package/dist/{chunk-language-b-WaFsLY.cjs.map → chunk-language-2r4uKROB.cjs.map} +1 -1
- package/dist/{chunk-language-BKIy1ot4.mjs → chunk-language-JRs5UIa2.mjs} +2 -2
- package/dist/{chunk-language-BKIy1ot4.mjs.map → chunk-language-JRs5UIa2.mjs.map} +1 -1
- package/dist/chunk-layout-BEAgFhif.mjs +11 -0
- package/dist/{chunk-layout-C2uqDEMJ.mjs.map → chunk-layout-BEAgFhif.mjs.map} +1 -1
- package/dist/{chunk-layout-D728gccQ.cjs → chunk-layout-mMQXuBLE.cjs} +2 -2
- package/dist/{chunk-layout-D728gccQ.cjs.map → chunk-layout-mMQXuBLE.cjs.map} +1 -1
- package/dist/{chunk-lstorage-BVCD00Ow.mjs → chunk-lstorage-WwyI7gQN.mjs} +1 -1
- package/dist/{chunk-lstorage-BVCD00Ow.mjs.map → chunk-lstorage-WwyI7gQN.mjs.map} +1 -1
- package/dist/{chunk-lstorage-BnxLXHgH.cjs → chunk-lstorage-_yGQsIQ9.cjs} +1 -1
- package/dist/{chunk-lstorage-BnxLXHgH.cjs.map → chunk-lstorage-_yGQsIQ9.cjs.map} +1 -1
- package/dist/{chunk-lucide-C54WenI6.mjs → chunk-lucide-B99NZWfa.mjs} +1 -1
- package/dist/{chunk-lucide-C54WenI6.mjs.map → chunk-lucide-B99NZWfa.mjs.map} +1 -1
- package/dist/{chunk-lucide-CP2lvOPY.cjs → chunk-lucide-XL6d5__j.cjs} +2 -2
- package/dist/{chunk-lucide-CP2lvOPY.cjs.map → chunk-lucide-XL6d5__j.cjs.map} +1 -1
- package/dist/{chunk-preference-Bs5zQSRc.mjs → chunk-preference-DMhhY1Pl.mjs} +15 -15
- package/dist/{chunk-preference-Bs5zQSRc.mjs.map → chunk-preference-DMhhY1Pl.mjs.map} +1 -1
- package/dist/{chunk-preference-DE8Jp2f5.cjs → chunk-preference-DbNgeGhx.cjs} +2 -2
- package/dist/{chunk-preference-DE8Jp2f5.cjs.map → chunk-preference-DbNgeGhx.cjs.map} +1 -1
- package/dist/{chunk-theme-9dcwRKw8.mjs → chunk-theme-CINVDd47.mjs} +8 -8
- package/dist/{chunk-theme-9dcwRKw8.mjs.map → chunk-theme-CINVDd47.mjs.map} +1 -1
- package/dist/{chunk-theme-BFvDRCYS.cjs → chunk-theme-D49XQfXe.cjs} +2 -2
- package/dist/{chunk-theme-BFvDRCYS.cjs.map → chunk-theme-D49XQfXe.cjs.map} +1 -1
- package/dist/chunk-useLayout-BAIFfydj.cjs +3 -0
- package/dist/{chunk-useLayout-BAJHOIL3.cjs.map → chunk-useLayout-BAIFfydj.cjs.map} +1 -1
- package/dist/{chunk-useLayout-DPxlynT-.mjs → chunk-useLayout-BXsJlpcb.mjs} +1 -1
- package/dist/{chunk-useLayout-DPxlynT-.mjs.map → chunk-useLayout-BXsJlpcb.mjs.map} +1 -1
- package/dist/{chunk-useTheme-oHcq3d0o.mjs → chunk-useTheme-BY1_pW9y.mjs} +1 -1
- package/dist/{chunk-useTheme-oHcq3d0o.mjs.map → chunk-useTheme-BY1_pW9y.mjs.map} +1 -1
- package/dist/chunk-useTheme-Tw_7_cQf.cjs +3 -0
- package/dist/{chunk-useTheme-DgleVMMh.cjs.map → chunk-useTheme-Tw_7_cQf.cjs.map} +1 -1
- package/dist/components.cjs +3 -4
- package/dist/components.cjs.map +1 -1
- package/dist/components.mjs +1299 -1094
- package/dist/components.mjs.map +1 -1
- package/dist/constants.cjs +1 -2
- package/dist/constants.cjs.map +1 -1
- package/dist/constants.mjs +1 -2
- package/dist/constants.mjs.map +1 -1
- package/dist/events.cjs +1 -2
- package/dist/events.cjs.map +1 -1
- package/dist/events.mjs +1 -2
- package/dist/events.mjs.map +1 -1
- package/dist/hooks.cjs +2 -3
- package/dist/hooks.cjs.map +1 -1
- package/dist/hooks.mjs +1 -2
- package/dist/hooks.mjs.map +1 -1
- package/dist/icons.cjs +2 -3
- package/dist/icons.mjs +2 -3
- package/dist/languages.cjs +2 -3
- package/dist/languages.cjs.map +1 -1
- package/dist/languages.mjs +35 -36
- package/dist/languages.mjs.map +1 -1
- package/dist/layouts.cjs +2 -3
- package/dist/layouts.cjs.map +1 -1
- package/dist/layouts.mjs +7 -8
- package/dist/layouts.mjs.map +1 -1
- package/dist/navigations.cjs +1 -2
- package/dist/navigations.cjs.map +1 -1
- package/dist/navigations.mjs +1 -2
- package/dist/navigations.mjs.map +1 -1
- package/dist/pixel-blast.cjs +2 -3
- package/dist/pixel-blast.cjs.map +1 -1
- package/dist/pixel-blast.mjs +2 -3
- package/dist/pixel-blast.mjs.map +1 -1
- package/dist/preference.cjs +2 -3
- package/dist/preference.mjs +2 -3
- package/dist/services.cjs +1 -2
- package/dist/services.cjs.map +1 -1
- package/dist/services.mjs +1 -2
- package/dist/services.mjs.map +1 -1
- package/dist/src/designs/animations/BounceLoading/index.d.ts +1 -1
- package/dist/src/designs/animations/BounceLoading/index.d.ts.map +1 -1
- package/dist/src/designs/animations/ECGLoading/index.d.ts +1 -1
- package/dist/src/designs/animations/ECGLoading/index.d.ts.map +1 -1
- package/dist/src/designs/animations/TruckLoading/index.d.ts +1 -1
- package/dist/src/designs/animations/TruckLoading/index.d.ts.map +1 -1
- package/dist/src/designs/components/Icon/index.d.ts +1 -1
- package/dist/src/designs/components/Icon/index.d.ts.map +1 -1
- package/dist/src/designs/components/KeyValueEditor/index.d.ts +1 -1
- package/dist/src/designs/components/KeyValueEditor/index.d.ts.map +1 -1
- package/dist/src/designs/components/LayoutSwitcher/index.d.ts +1 -1
- package/dist/src/designs/components/LayoutSwitcher/index.d.ts.map +1 -1
- package/dist/src/designs/components/SearchInput/index.d.ts +1 -1
- package/dist/src/designs/components/SearchInput/index.d.ts.map +1 -1
- package/dist/src/designs/components/ShowFilter/index.d.ts +1 -1
- package/dist/src/designs/components/ShowFilter/index.d.ts.map +1 -1
- package/dist/src/designs/components/SlideDownSwitcher/index.d.ts +1 -1
- package/dist/src/designs/components/SlideDownSwitcher/index.d.ts.map +1 -1
- package/dist/src/designs/components/Suspense/index.d.ts +1 -1
- package/dist/src/designs/components/Suspense/index.d.ts.map +1 -1
- package/dist/src/designs/components/ThemeSwitcher/index.d.ts +1 -1
- package/dist/src/designs/components/ThemeSwitcher/index.d.ts.map +1 -1
- package/dist/src/designs/components/VirtualList/index.d.ts +1 -1
- package/dist/src/designs/components/VirtualList/index.d.ts.map +1 -1
- package/dist/src/designs/components/VirtualWindowList/index.d.ts +1 -1
- package/dist/src/designs/components/VirtualWindowList/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/Background/index.d.ts +1 -1
- package/dist/src/designs/layouts/components/Background/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/Footer/index.d.ts +2 -2
- package/dist/src/designs/layouts/components/Footer/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/Header/index.d.ts +1 -1
- package/dist/src/designs/layouts/components/Header/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/LayoutFrame/index.d.ts +1 -1
- package/dist/src/designs/layouts/components/LayoutFrame/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/MainWrapper/index.d.ts +1 -1
- package/dist/src/designs/layouts/components/MainWrapper/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/SideHideLayout/index.d.ts +1 -1
- package/dist/src/designs/layouts/components/SideHideLayout/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/SideShowLayout/index.d.ts +1 -1
- package/dist/src/designs/layouts/components/SideShowLayout/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/components/Sidebar/index.d.ts +1 -1
- package/dist/src/designs/layouts/components/Sidebar/index.d.ts.map +1 -1
- package/dist/src/designs/layouts/providers/index.d.ts +1 -1
- package/dist/src/designs/layouts/providers/index.d.ts.map +1 -1
- package/dist/src/languages/providers/index.d.ts +1 -1
- package/dist/src/languages/providers/index.d.ts.map +1 -1
- package/dist/src/themes/providers/index.d.ts +1 -1
- package/dist/src/themes/providers/index.d.ts.map +1 -1
- package/dist/stores.cjs +2 -3
- package/dist/stores.cjs.map +1 -1
- package/dist/stores.mjs +1 -2
- package/dist/stores.mjs.map +1 -1
- package/dist/themes.cjs +2 -3
- package/dist/themes.cjs.map +1 -1
- package/dist/themes.mjs +4 -5
- package/dist/themes.mjs.map +1 -1
- package/dist/types.cjs +1 -2
- package/dist/types.mjs +1 -2
- package/dist/utils.cjs +2 -3
- package/dist/utils.cjs.map +1 -1
- package/dist/utils.mjs +3 -4
- package/dist/utils.mjs.map +1 -1
- package/package.json +21 -21
- package/dist/chunk-BounceLoading-CwvDT5HF.cjs +0 -11
- package/dist/chunk-layout-C2uqDEMJ.mjs +0 -11
- package/dist/chunk-useLayout-BAJHOIL3.cjs +0 -3
- package/dist/chunk-useTheme-DgleVMMh.cjs +0 -3
- /package/dist/{chunk-chunk-BFrxaqQT.cjs → chunk-chunk-D-Fg7nx1.cjs} +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
const r=require("./chunk-chunk-
|
|
1
|
+
const r=require("./chunk-chunk-D-Fg7nx1.cjs");let e=require("lucide-react");var o=r.__exportAll({AlertCircle:()=>e.AlertCircle,ArrowLeft:()=>e.ArrowLeft,ArrowRight:()=>e.ArrowRight,Ban:()=>e.Ban,Bell:()=>e.Bell,Box:()=>e.Box,Briefcase:()=>e.Briefcase,Calendar:()=>e.Calendar,Camera:()=>e.Camera,Check:()=>e.Check,CheckCircle:()=>e.CheckCircle,ChevronDown:()=>e.ChevronDown,ChevronLeft:()=>e.ChevronLeft,ChevronRight:()=>e.ChevronRight,ChevronUp:()=>e.ChevronUp,Clock:()=>e.Clock,Coffee:()=>e.Coffee,CreditCard:()=>e.CreditCard,DollarSign:()=>e.DollarSign,Edit:()=>e.Edit,ExternalLink:()=>e.ExternalLink,Eye:()=>e.Eye,EyeOff:()=>e.EyeOff,FileText:()=>e.FileText,Filter:()=>e.Filter,FolderOpen:()=>e.FolderOpen,FolderPlus:()=>e.FolderPlus,FolderTree:()=>e.FolderTree,Folders:()=>e.Folders,Globe:()=>e.Globe,GraduationCap:()=>e.GraduationCap,GripVertical:()=>e.GripVertical,Hash:()=>e.Hash,History:()=>e.History,Home:()=>e.Home,Image:()=>e.Image,Info:()=>e.Info,Languages:()=>e.Languages,Layers:()=>e.Layers,LayoutGrid:()=>e.LayoutGrid,LayoutList:()=>e.LayoutList,Leaf:()=>e.Leaf,List:()=>e.List,Loader:()=>e.Loader,Loader2:()=>e.Loader2,Lock:()=>e.Lock,LockKeyhole:()=>e.LockKeyhole,LogOut:()=>e.LogOut,Mail:()=>e.Mail,Menu:()=>e.Menu,MessageCircle:()=>e.MessageCircle,Package:()=>e.Package,Pencil:()=>e.Pencil,Phone:()=>e.Phone,Plus:()=>e.Plus,Search:()=>e.Search,Settings:()=>e.Settings,Shield:()=>e.Shield,Tag:()=>e.Tag,Trash2:()=>e.Trash2,TrendingUp:()=>e.TrendingUp,Upload:()=>e.Upload,User:()=>e.User,UserCheck:()=>e.UserCheck,UserPlus:()=>e.UserPlus,UserRound:()=>e.UserRound,UserRoundSearch:()=>e.UserRoundSearch,UserX:()=>e.UserX,Wand2:()=>e.Wand2,X:()=>e.X,XCircle:()=>e.XCircle});Object.defineProperty(exports,"lucide_exports",{enumerable:!0,get:function(){return o}});
|
|
2
2
|
|
|
3
|
-
//# sourceMappingURL=chunk-lucide-
|
|
3
|
+
//# sourceMappingURL=chunk-lucide-XL6d5__j.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-lucide-
|
|
1
|
+
{"version":3,"file":"chunk-lucide-XL6d5__j.cjs","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":""}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { c
|
|
2
|
-
import { i as a } from "./chunk-layout-
|
|
3
|
-
import { i as
|
|
4
|
-
var
|
|
1
|
+
import { c, n as i, r as l, s as d } from "./chunk-theme-CINVDd47.mjs";
|
|
2
|
+
import { i as a } from "./chunk-layout-BEAgFhif.mjs";
|
|
3
|
+
import { i as f, r as g } from "./chunk-language-JRs5UIa2.mjs";
|
|
4
|
+
var E = /* @__PURE__ */ (function(e) {
|
|
5
5
|
return e.NONE = "none", e.WAVES = "waves", e.SQUARES = "squares", e.LETTER_GLITCH = "letterGlitch", e.PIXEL_BLAST = "pixelBlast", e;
|
|
6
|
-
})({}), A =
|
|
6
|
+
})({}), A = "none", S = Object.values(E);
|
|
7
7
|
function u(e) {
|
|
8
8
|
return e !== null && typeof e == "object" && !Array.isArray(e);
|
|
9
9
|
}
|
|
10
10
|
function y(e) {
|
|
11
|
-
const n = e.layoutMode === a.HIDE ? a.HIDE : a.SHOW, t = typeof e.base == "string" &&
|
|
11
|
+
const n = e.layoutMode === a.HIDE ? a.HIDE : a.SHOW, t = typeof e.base == "string" && i.includes(e.base) ? e.base : l.DEFAULT, o = typeof e.language == "string" && g.includes(e.language) ? e.language : f.ZH, s = typeof e.dashboardBackground == "string" && S.includes(e.dashboardBackground) ? e.dashboardBackground : A;
|
|
12
12
|
return {
|
|
13
|
-
theme: typeof e.theme == "string" &&
|
|
13
|
+
theme: typeof e.theme == "string" && d.includes(e.theme) ? e.theme : c.DEFAULT,
|
|
14
14
|
base: t,
|
|
15
15
|
language: o,
|
|
16
16
|
layoutMode: n,
|
|
@@ -26,8 +26,8 @@ function p(e) {
|
|
|
26
26
|
dashboardBackground: e.dashboardBackground
|
|
27
27
|
};
|
|
28
28
|
}
|
|
29
|
-
var
|
|
30
|
-
function
|
|
29
|
+
var T = "nfx";
|
|
30
|
+
function _(e, n) {
|
|
31
31
|
if (!e || typeof e != "string") return null;
|
|
32
32
|
try {
|
|
33
33
|
const t = JSON.parse(e);
|
|
@@ -41,7 +41,7 @@ function O(e, n) {
|
|
|
41
41
|
return null;
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
|
-
function
|
|
44
|
+
function h(e, n) {
|
|
45
45
|
const { nfx: t, ...o } = e, s = n ? n(o) : o;
|
|
46
46
|
return JSON.stringify({
|
|
47
47
|
nfx: p(t),
|
|
@@ -51,10 +51,10 @@ function T(e, n) {
|
|
|
51
51
|
export {
|
|
52
52
|
A as a,
|
|
53
53
|
S as i,
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
54
|
+
h as n,
|
|
55
|
+
E as o,
|
|
56
|
+
T as r,
|
|
57
|
+
_ as t
|
|
58
58
|
};
|
|
59
59
|
|
|
60
|
-
//# sourceMappingURL=chunk-preference-
|
|
60
|
+
//# sourceMappingURL=chunk-preference-DMhhY1Pl.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-preference-
|
|
1
|
+
{"version":3,"file":"chunk-preference-DMhhY1Pl.mjs","names":[],"sources":["../src/preference/constants.ts","../src/preference/nfx_slice.ts","../src/preference/types.ts","../src/preference/core.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","import { 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\";\nimport type { NfxPreferenceSlice } from \"./types\";\n\n/** 后端 `nfx` 对象允许的 JSON 形状(字段均可选)。 */\nexport type NfxBackendShape = {\n theme?: ThemeEnum;\n base?: BaseEnum;\n language?: LanguageEnum;\n layoutMode?: LayoutModeEnum;\n dashboardBackground?: DashboardBackgroundEnum;\n};\n\n/** 判断值是否为「普通对象」(非 null、非数组)。 */\nexport function isPlainRecord(v: unknown): v is Record<string, unknown> {\n return v !== null && typeof v === \"object\" && !Array.isArray(v);\n}\n\n/**\n * 将后端 `nfx` 对象的原始字段规范化为前端 `NfxPreferenceSlice`(非法或缺失字段用 NFX 默认值)。\n */\nexport function parseNfxFields(raw: NfxBackendShape): NfxPreferenceSlice {\n const layoutMode = raw.layoutMode === LayoutModeEnum.HIDE ? LayoutModeEnum.HIDE : LayoutModeEnum.SHOW;\n const base = typeof raw.base === \"string\" && BASE_VALUES.includes(raw.base) ? raw.base : BaseEnum.DEFAULT;\n const language =\n typeof raw.language === \"string\" && LANGUAGE_VALUES.includes(raw.language) ? raw.language : LanguageEnum.ZH;\n const dashboardBackground =\n typeof raw.dashboardBackground === \"string\" && DASHBOARD_BACKGROUND_VALUES.includes(raw.dashboardBackground)\n ? raw.dashboardBackground\n : DEFAULT_DASHBOARD_BACKGROUND;\n const theme = typeof raw.theme === \"string\" && THEME_VALUES.includes(raw.theme) ? raw.theme : ThemeEnum.DEFAULT;\n return {\n theme,\n base,\n language,\n layoutMode,\n dashboardBackground,\n };\n}\n\n/**\n * 将前端 `NfxPreferenceSlice` 转为写入 JSON 的 `nfx` 对象(与 `theme`/`base`/`language` 的省略规则一致)。\n */\nexport function nfxSliceToBackend(nfx: NfxPreferenceSlice): NfxBackendShape {\n return {\n theme: nfx.theme || undefined,\n base: nfx.base || undefined,\n language: nfx.language || undefined,\n layoutMode: nfx.layoutMode,\n dashboardBackground: nfx.dashboardBackground,\n };\n}\n","import type { LayoutModeEnum } from \"@/designs/layouts/types\";\nimport type { LanguageEnum } from \"@/languages/types\";\nimport type { BaseEnum, ThemeEnum } from \"@/themes/types\";\n\nimport type { DashboardBackgroundEnum } from \"./constants\";\n\n/**\n * 根对象上 NFX 内置块使用的键名(字面量 `\"nfx\"`)。\n * Literal key name for the NFX slice on the preference JSON root.\n */\nexport const NFX_PREFERENCE_ROOT_KEY = \"nfx\" as const;\n\n/**\n * NFX 负责的内置字段(存于 JSON 的 `nfx` 对象内)。\n * Built-in fields owned by NFX (nested under the `nfx` object in JSON).\n */\nexport type NfxPreferenceSlice = {\n theme: ThemeEnum;\n base: BaseEnum;\n language: LanguageEnum;\n layoutMode: LayoutModeEnum;\n dashboardBackground: DashboardBackgroundEnum;\n};\n\n/**\n * 完整偏好:必有 `nfx`;`TExtra` 为与 `nfx` 平级的其它顶层键。\n * 默认 `TExtra` 为 `Record<string, unknown>`(**勿用** `Record<string, never>`:会与 `nfx` 索引冲突导致无法赋值)。\n */\nexport type Preference<TExtra extends Record<string, unknown> = Record<string, unknown>> = {\n nfx: NfxPreferenceSlice;\n} & TExtra;\n","import type { Nilable, Nullable } from \"@/types\";\n\nimport { isPlainRecord, nfxSliceToBackend, parseNfxFields, type NfxBackendShape } from \"./nfx_slice\";\nimport { NFX_PREFERENCE_ROOT_KEY, type NfxPreferenceSlice, type Preference } from \"./types\";\n\n/**\n * 解析后端 preference 字符串:`nfx` 由本包规范化(缺省或非对象则按 `{}` → 默认值);\n * `parseExtra(rest)` 的 `rest` 为根对象去掉 `nfx` 后的键值(宿主扩展,线 snake / 内存 camel 在函数内自行处理)。\n */\nexport function parsePreferenceJson<TExtra extends Record<string, unknown> = Record<string, unknown>>(\n json: Nilable<string>,\n parseExtra?: (raw: Record<string, unknown>) => TExtra,\n): Nullable<Preference<TExtra>> {\n if (!json || typeof json !== \"string\") return null;\n try {\n const data = JSON.parse(json) as unknown;\n if (!isPlainRecord(data)) return null;\n const nfxSource = data[NFX_PREFERENCE_ROOT_KEY];\n const nfxRaw = isPlainRecord(nfxSource) ? nfxSource : {};\n const nfx = parseNfxFields(nfxRaw as NfxBackendShape);\n const rest = { ...data };\n delete rest[NFX_PREFERENCE_ROOT_KEY];\n const extra = parseExtra ? parseExtra(rest) : ({} as TExtra);\n return { nfx, ...extra };\n } catch {\n return null;\n }\n}\n\n/**\n * 序列化:`serializeExtra` 把内存中的扩展部分写成根上要合并的顶层键;省略则对扩展做浅拷贝(键名原样写入 JSON)。\n */\nexport function preferenceToJson<TExtra extends Record<string, unknown> = Record<string, unknown>>(\n preference: Preference<TExtra>,\n serializeExtra?: (extra: TExtra) => Record<string, unknown>,\n): string {\n const { nfx, ...extra } = preference as { nfx: NfxPreferenceSlice } & Record<string, unknown>;\n const extraBag = serializeExtra ? serializeExtra(extra as unknown as TExtra) : extra;\n return JSON.stringify({\n [NFX_PREFERENCE_ROOT_KEY]: nfxSliceToBackend(nfx),\n ...extraBag,\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;AACF,GAAA,CAAA,CAAA,GAEa,IAAA,QAGA,IAA8D,OAAO,OAAO,CAAuB;ACFhH,SAAgB,EAAc,GAA0C;AACtE,SAAO,MAAM,QAAQ,OAAO,KAAM,YAAY,CAAC,MAAM,QAAQ,CAAC;AAChE;AAKA,SAAgB,EAAe,GAA0C;AACvE,QAAM,IAAa,EAAI,eAAe,EAAe,OAAO,EAAe,OAAO,EAAe,MAC3F,IAAO,OAAO,EAAI,QAAS,YAAY,EAAY,SAAS,EAAI,IAAI,IAAI,EAAI,OAAO,EAAS,SAC5F,IACJ,OAAO,EAAI,YAAa,YAAY,EAAgB,SAAS,EAAI,QAAQ,IAAI,EAAI,WAAW,EAAa,IACrG,IACJ,OAAO,EAAI,uBAAwB,YAAY,EAA4B,SAAS,EAAI,mBAAmB,IACvG,EAAI,sBACJ;AAEN,SAAO;AAAA,IACL,OAFY,OAAO,EAAI,SAAU,YAAY,EAAa,SAAS,EAAI,KAAK,IAAI,EAAI,QAAQ,EAAU;AAAA,IAGtG,MAAA;AAAA,IACA,UAAA;AAAA,IACA,YAAA;AAAA,IACA,qBAAA;AAAA,EACF;AACF;AAKA,SAAgB,EAAkB,GAA0C;AAC1E,SAAO;AAAA,IACL,OAAO,EAAI,SAAS;AAAA,IACpB,MAAM,EAAI,QAAQ;AAAA,IAClB,UAAU,EAAI,YAAY;AAAA,IAC1B,YAAY,EAAI;AAAA,IAChB,qBAAqB,EAAI;AAAA,EAC3B;AACF;AC5CA,IAAa,IAA0B;ACDvC,SAAgB,EACd,GACA,GAC8B;AAC9B,MAAI,CAAC,KAAQ,OAAO,KAAS,SAAU,QAAO;AAC9C,MAAI;AACF,UAAM,IAAO,KAAK,MAAM,CAAI;AAC5B,QAAI,CAAC,EAAc,CAAI,EAAG,QAAO;AACjC,UAAM,IAAY,EAAA,KAEZ,IAAM,EADG,EAAc,CAAS,IAAI,IAAY,CAAC,CACH,GAC9C,IAAO,EAAE,GAAG,EAAK;AACvB,kBAAO,EAAA,KAEA;AAAA,MAAE,KAAA;AAAA,MAAK,GADA,IAAa,EAAW,CAAI,IAAK,CAAC;AAAA,IACzB;AAAA,EACzB,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAKA,SAAgB,EACd,GACA,GACQ;AACR,QAAM,EAAE,KAAA,GAAK,GAAG,EAAA,IAAU,GACpB,IAAW,IAAiB,EAAe,CAA0B,IAAI;AAC/E,SAAO,KAAK,UAAU;AAAA,SACO,EAAkB,CAAG;AAAA,IAChD,GAAG;AAAA,EACL,CAAC;AACH"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
const o=require("./chunk-theme-
|
|
1
|
+
const o=require("./chunk-theme-D49XQfXe.cjs"),a=require("./chunk-layout-mMQXuBLE.cjs"),s=require("./chunk-language-2r4uKROB.cjs");var l=(function(e){return e.NONE="none",e.WAVES="waves",e.SQUARES="squares",e.LETTER_GLITCH="letterGlitch",e.PIXEL_BLAST="pixelBlast",e})({}),d="none",f=Object.values(l);function i(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}function g(e){const n=e.layoutMode===a.LayoutModeEnum.HIDE?a.LayoutModeEnum.HIDE:a.LayoutModeEnum.SHOW,t=typeof e.base=="string"&&o.BASE_VALUES.includes(e.base)?e.base:o.BaseEnum.DEFAULT,r=typeof e.language=="string"&&s.LANGUAGE_VALUES.includes(e.language)?e.language:s.LanguageEnum.ZH,u=typeof e.dashboardBackground=="string"&&f.includes(e.dashboardBackground)?e.dashboardBackground:d;return{theme:typeof e.theme=="string"&&o.THEME_VALUES.includes(e.theme)?e.theme:o.ThemeEnum.DEFAULT,base:t,language:r,layoutMode:n,dashboardBackground:u}}function E(e){return{theme:e.theme||void 0,base:e.base||void 0,language:e.language||void 0,layoutMode:e.layoutMode,dashboardBackground:e.dashboardBackground}}var A="nfx";function y(e,n){if(!e||typeof e!="string")return null;try{const t=JSON.parse(e);if(!i(t))return null;const r=t.nfx,u=g(i(r)?r:{}),c={...t};return delete c.nfx,{nfx:u,...n?n(c):{}}}catch{return null}}function b(e,n){const{nfx:t,...r}=e,u=n?n(r):r;return JSON.stringify({nfx:E(t),...u})}Object.defineProperty(exports,"DASHBOARD_BACKGROUND_VALUES",{enumerable:!0,get:function(){return f}});Object.defineProperty(exports,"DEFAULT_DASHBOARD_BACKGROUND",{enumerable:!0,get:function(){return d}});Object.defineProperty(exports,"DashboardBackgroundEnum",{enumerable:!0,get:function(){return l}});Object.defineProperty(exports,"NFX_PREFERENCE_ROOT_KEY",{enumerable:!0,get:function(){return A}});Object.defineProperty(exports,"parsePreferenceJson",{enumerable:!0,get:function(){return y}});Object.defineProperty(exports,"preferenceToJson",{enumerable:!0,get:function(){return b}});
|
|
2
2
|
|
|
3
|
-
//# sourceMappingURL=chunk-preference-
|
|
3
|
+
//# sourceMappingURL=chunk-preference-DbNgeGhx.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-preference-
|
|
1
|
+
{"version":3,"file":"chunk-preference-DbNgeGhx.cjs","names":[],"sources":["../src/preference/constants.ts","../src/preference/nfx_slice.ts","../src/preference/types.ts","../src/preference/core.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","import { 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\";\nimport type { NfxPreferenceSlice } from \"./types\";\n\n/** 后端 `nfx` 对象允许的 JSON 形状(字段均可选)。 */\nexport type NfxBackendShape = {\n theme?: ThemeEnum;\n base?: BaseEnum;\n language?: LanguageEnum;\n layoutMode?: LayoutModeEnum;\n dashboardBackground?: DashboardBackgroundEnum;\n};\n\n/** 判断值是否为「普通对象」(非 null、非数组)。 */\nexport function isPlainRecord(v: unknown): v is Record<string, unknown> {\n return v !== null && typeof v === \"object\" && !Array.isArray(v);\n}\n\n/**\n * 将后端 `nfx` 对象的原始字段规范化为前端 `NfxPreferenceSlice`(非法或缺失字段用 NFX 默认值)。\n */\nexport function parseNfxFields(raw: NfxBackendShape): NfxPreferenceSlice {\n const layoutMode = raw.layoutMode === LayoutModeEnum.HIDE ? LayoutModeEnum.HIDE : LayoutModeEnum.SHOW;\n const base = typeof raw.base === \"string\" && BASE_VALUES.includes(raw.base) ? raw.base : BaseEnum.DEFAULT;\n const language =\n typeof raw.language === \"string\" && LANGUAGE_VALUES.includes(raw.language) ? raw.language : LanguageEnum.ZH;\n const dashboardBackground =\n typeof raw.dashboardBackground === \"string\" && DASHBOARD_BACKGROUND_VALUES.includes(raw.dashboardBackground)\n ? raw.dashboardBackground\n : DEFAULT_DASHBOARD_BACKGROUND;\n const theme = typeof raw.theme === \"string\" && THEME_VALUES.includes(raw.theme) ? raw.theme : ThemeEnum.DEFAULT;\n return {\n theme,\n base,\n language,\n layoutMode,\n dashboardBackground,\n };\n}\n\n/**\n * 将前端 `NfxPreferenceSlice` 转为写入 JSON 的 `nfx` 对象(与 `theme`/`base`/`language` 的省略规则一致)。\n */\nexport function nfxSliceToBackend(nfx: NfxPreferenceSlice): NfxBackendShape {\n return {\n theme: nfx.theme || undefined,\n base: nfx.base || undefined,\n language: nfx.language || undefined,\n layoutMode: nfx.layoutMode,\n dashboardBackground: nfx.dashboardBackground,\n };\n}\n","import type { LayoutModeEnum } from \"@/designs/layouts/types\";\nimport type { LanguageEnum } from \"@/languages/types\";\nimport type { BaseEnum, ThemeEnum } from \"@/themes/types\";\n\nimport type { DashboardBackgroundEnum } from \"./constants\";\n\n/**\n * 根对象上 NFX 内置块使用的键名(字面量 `\"nfx\"`)。\n * Literal key name for the NFX slice on the preference JSON root.\n */\nexport const NFX_PREFERENCE_ROOT_KEY = \"nfx\" as const;\n\n/**\n * NFX 负责的内置字段(存于 JSON 的 `nfx` 对象内)。\n * Built-in fields owned by NFX (nested under the `nfx` object in JSON).\n */\nexport type NfxPreferenceSlice = {\n theme: ThemeEnum;\n base: BaseEnum;\n language: LanguageEnum;\n layoutMode: LayoutModeEnum;\n dashboardBackground: DashboardBackgroundEnum;\n};\n\n/**\n * 完整偏好:必有 `nfx`;`TExtra` 为与 `nfx` 平级的其它顶层键。\n * 默认 `TExtra` 为 `Record<string, unknown>`(**勿用** `Record<string, never>`:会与 `nfx` 索引冲突导致无法赋值)。\n */\nexport type Preference<TExtra extends Record<string, unknown> = Record<string, unknown>> = {\n nfx: NfxPreferenceSlice;\n} & TExtra;\n","import type { Nilable, Nullable } from \"@/types\";\n\nimport { isPlainRecord, nfxSliceToBackend, parseNfxFields, type NfxBackendShape } from \"./nfx_slice\";\nimport { NFX_PREFERENCE_ROOT_KEY, type NfxPreferenceSlice, type Preference } from \"./types\";\n\n/**\n * 解析后端 preference 字符串:`nfx` 由本包规范化(缺省或非对象则按 `{}` → 默认值);\n * `parseExtra(rest)` 的 `rest` 为根对象去掉 `nfx` 后的键值(宿主扩展,线 snake / 内存 camel 在函数内自行处理)。\n */\nexport function parsePreferenceJson<TExtra extends Record<string, unknown> = Record<string, unknown>>(\n json: Nilable<string>,\n parseExtra?: (raw: Record<string, unknown>) => TExtra,\n): Nullable<Preference<TExtra>> {\n if (!json || typeof json !== \"string\") return null;\n try {\n const data = JSON.parse(json) as unknown;\n if (!isPlainRecord(data)) return null;\n const nfxSource = data[NFX_PREFERENCE_ROOT_KEY];\n const nfxRaw = isPlainRecord(nfxSource) ? nfxSource : {};\n const nfx = parseNfxFields(nfxRaw as NfxBackendShape);\n const rest = { ...data };\n delete rest[NFX_PREFERENCE_ROOT_KEY];\n const extra = parseExtra ? parseExtra(rest) : ({} as TExtra);\n return { nfx, ...extra };\n } catch {\n return null;\n }\n}\n\n/**\n * 序列化:`serializeExtra` 把内存中的扩展部分写成根上要合并的顶层键;省略则对扩展做浅拷贝(键名原样写入 JSON)。\n */\nexport function preferenceToJson<TExtra extends Record<string, unknown> = Record<string, unknown>>(\n preference: Preference<TExtra>,\n serializeExtra?: (extra: TExtra) => Record<string, unknown>,\n): string {\n const { nfx, ...extra } = preference as { nfx: NfxPreferenceSlice } & Record<string, unknown>;\n const extraBag = serializeExtra ? serializeExtra(extra as unknown as TExtra) : extra;\n return JSON.stringify({\n [NFX_PREFERENCE_ROOT_KEY]: nfxSliceToBackend(nfx),\n ...extraBag,\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,cACF,GAAA,CAAA,CAAA,EAEa,EAAA,OAGA,EAA8D,OAAO,OAAO,CAAuB,ECFhH,SAAgB,EAAc,EAA0C,CACtE,OAAO,IAAM,MAAQ,OAAO,GAAM,UAAY,CAAC,MAAM,QAAQ,CAAC,CAChE,CAKA,SAAgB,EAAe,EAA0C,CACvE,MAAM,EAAa,EAAI,aAAe,EAAA,eAAe,KAAO,EAAA,eAAe,KAAO,EAAA,eAAe,KAC3F,EAAO,OAAO,EAAI,MAAS,UAAY,EAAA,YAAY,SAAS,EAAI,IAAI,EAAI,EAAI,KAAO,EAAA,SAAS,QAC5F,EACJ,OAAO,EAAI,UAAa,UAAY,EAAA,gBAAgB,SAAS,EAAI,QAAQ,EAAI,EAAI,SAAW,EAAA,aAAa,GACrG,EACJ,OAAO,EAAI,qBAAwB,UAAY,EAA4B,SAAS,EAAI,mBAAmB,EACvG,EAAI,oBACJ,EAEN,MAAO,CACL,MAFY,OAAO,EAAI,OAAU,UAAY,EAAA,aAAa,SAAS,EAAI,KAAK,EAAI,EAAI,MAAQ,EAAA,UAAU,QAGtG,KAAA,EACA,SAAA,EACA,WAAA,EACA,oBAAA,CACF,CACF,CAKA,SAAgB,EAAkB,EAA0C,CAC1E,MAAO,CACL,MAAO,EAAI,OAAS,OACpB,KAAM,EAAI,MAAQ,OAClB,SAAU,EAAI,UAAY,OAC1B,WAAY,EAAI,WAChB,oBAAqB,EAAI,mBAC3B,CACF,CC5CA,IAAa,EAA0B,MCDvC,SAAgB,EACd,EACA,EAC8B,CAC9B,GAAI,CAAC,GAAQ,OAAO,GAAS,SAAU,OAAO,KAC9C,GAAI,CACF,MAAM,EAAO,KAAK,MAAM,CAAI,EAC5B,GAAI,CAAC,EAAc,CAAI,EAAG,OAAO,KACjC,MAAM,EAAY,EAAA,IAEZ,EAAM,EADG,EAAc,CAAS,EAAI,EAAY,CAAC,CACH,EAC9C,EAAO,CAAE,GAAG,CAAK,EACvB,cAAO,EAAA,IAEA,CAAE,IAAA,EAAK,GADA,EAAa,EAAW,CAAI,EAAK,CAAC,CACzB,CACzB,MAAQ,CACN,OAAO,IACT,CACF,CAKA,SAAgB,EACd,EACA,EACQ,CACR,KAAM,CAAE,IAAA,EAAK,GAAG,CAAA,EAAU,EACpB,EAAW,EAAiB,EAAe,CAA0B,EAAI,EAC/E,OAAO,KAAK,UAAU,KACO,EAAkB,CAAG,EAChD,GAAG,CACL,CAAC,CACH"}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
var r = /* @__PURE__ */ (function(a) {
|
|
2
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
|
-
})({}),
|
|
3
|
+
})({}), A = "default", o = Object.values(r), t = /* @__PURE__ */ (function(a) {
|
|
4
4
|
return a.DEFAULT = "default", a.IOS = "ios", a.ANDROID = "android", a.WINDOWS = "windows", a.LINUX = "linux", a;
|
|
5
|
-
})({}), O =
|
|
5
|
+
})({}), O = "default", s = Object.values(t), E = "theme-color", S = "theme-base";
|
|
6
6
|
export {
|
|
7
7
|
O as a,
|
|
8
8
|
r as c,
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
9
|
+
E as i,
|
|
10
|
+
s as n,
|
|
11
|
+
A as o,
|
|
12
|
+
t as r,
|
|
13
13
|
o as s,
|
|
14
|
-
|
|
14
|
+
S as t
|
|
15
15
|
};
|
|
16
16
|
|
|
17
|
-
//# sourceMappingURL=chunk-theme-
|
|
17
|
+
//# sourceMappingURL=chunk-theme-CINVDd47.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-theme-
|
|
1
|
+
{"version":3,"file":"chunk-theme-CINVDd47.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 radius: {\n button: number;\n card: number;\n input: number;\n modal: number;\n badge: number;\n avatar: number;\n };\n\n spacing: {\n xs: number;\n sm: number;\n md: number;\n lg: number;\n xl: number;\n page: number;\n card: number;\n sectionGap: number;\n gridGap: number;\n };\n\n border: {\n thin: number;\n base: number;\n thick: number;\n focusRing: number;\n };\n\n size: {\n buttonSm: number;\n buttonMd: number;\n buttonLg: number;\n inputSm: number;\n inputMd: number;\n inputLg: number;\n navbarHeight: number;\n sidebarWidth: number;\n };\n\n typography: {\n fontFamilyBase: string;\n fontFamilyHeading: string;\n fontSizeXs: number;\n fontSizeSm: number;\n fontSizeMd: number;\n fontSizeLg: number;\n fontSizeXl: number;\n fontWeightNormal: number;\n fontWeightMedium: number;\n fontWeightBold: number;\n lineHeightBase: number;\n };\n\n motion: {\n fast: number;\n base: number;\n slow: number;\n easingStandard: string;\n };\n\n zIndex: {\n dropdown: number;\n sticky: number;\n modal: number;\n toast: number;\n tooltip: number;\n };\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":"AAuRA,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;AACF,GAAA,CAAA,CAAA,GAEa,IAAA,WACA,IAAe,OAAO,OAAO,CAAS,GAGvC,IAAL,0BAAA,GAAA;AACL,SAAA,EAAA,UAAA,WACA,EAAA,MAAA,OACA,EAAA,UAAA,WACA,EAAA,UAAA,WACA,EAAA,QAAA;AACF,GAAA,CAAA,CAAA,GAEa,IAAA,WACA,IAAc,OAAO,OAAO,CAAQ,GAEpC,IAAoB,eACpB,IAAmB"}
|
|
@@ -1,3 +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=
|
|
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="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})({}),o="default",E=Object.values(t),O="theme-color",c="theme-base";Object.defineProperty(exports,"BASE_STORAGE_KEY",{enumerable:!0,get:function(){return c}});Object.defineProperty(exports,"BASE_VALUES",{enumerable:!0,get:function(){return E}});Object.defineProperty(exports,"BaseEnum",{enumerable:!0,get:function(){return t}});Object.defineProperty(exports,"COLOR_STORAGE_KEY",{enumerable:!0,get:function(){return O}});Object.defineProperty(exports,"DEFAULT_BASE",{enumerable:!0,get:function(){return o}});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
2
|
|
|
3
|
-
//# sourceMappingURL=chunk-theme-
|
|
3
|
+
//# sourceMappingURL=chunk-theme-D49XQfXe.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-theme-
|
|
1
|
+
{"version":3,"file":"chunk-theme-D49XQfXe.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 radius: {\n button: number;\n card: number;\n input: number;\n modal: number;\n badge: number;\n avatar: number;\n };\n\n spacing: {\n xs: number;\n sm: number;\n md: number;\n lg: number;\n xl: number;\n page: number;\n card: number;\n sectionGap: number;\n gridGap: number;\n };\n\n border: {\n thin: number;\n base: number;\n thick: number;\n focusRing: number;\n };\n\n size: {\n buttonSm: number;\n buttonMd: number;\n buttonLg: number;\n inputSm: number;\n inputMd: number;\n inputLg: number;\n navbarHeight: number;\n sidebarWidth: number;\n };\n\n typography: {\n fontFamilyBase: string;\n fontFamilyHeading: string;\n fontSizeXs: number;\n fontSizeSm: number;\n fontSizeMd: number;\n fontSizeLg: number;\n fontSizeXl: number;\n fontWeightNormal: number;\n fontWeightMedium: number;\n fontWeightBold: number;\n lineHeightBase: number;\n };\n\n motion: {\n fast: number;\n base: number;\n slow: number;\n easingStandard: string;\n };\n\n zIndex: {\n dropdown: number;\n sticky: number;\n modal: number;\n toast: number;\n tooltip: number;\n };\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":"AAuRA,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,SACF,GAAA,CAAA,CAAA,EAEa,EAAA,UACA,EAAe,OAAO,OAAO,CAAS,EAGvC,GAAL,SAAA,EAAA,CACL,OAAA,EAAA,QAAA,UACA,EAAA,IAAA,MACA,EAAA,QAAA,UACA,EAAA,QAAA,UACA,EAAA,MAAA,SACF,GAAA,CAAA,CAAA,EAEa,EAAA,UACA,EAAc,OAAO,OAAO,CAAQ,EAEpC,EAAoB,cACpB,EAAmB"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
let t=require("react");var r=(0,t.createContext)(void 0),u=()=>{const e=(0,t.useContext)(r);if(e===void 0)throw new Error("useLayout must be used within a LayoutProvider");return e};Object.defineProperty(exports,"LayoutContext",{enumerable:!0,get:function(){return r}});Object.defineProperty(exports,"useLayout",{enumerable:!0,get:function(){return u}});
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=chunk-useLayout-BAIFfydj.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-useLayout-
|
|
1
|
+
{"version":3,"file":"chunk-useLayout-BAIFfydj.cjs","names":[],"sources":["../src/designs/layouts/hooks/useLayout.ts"],"sourcesContent":["/**\n * 布局上下文与 useLayout:供子组件消费侧栏状态与 setLayoutMode。\n * Layout context and useLayout: for consuming sidebar state and setLayoutMode.\n */\nimport type { LayoutContextType } from \"../types\";\n\nimport { createContext, useContext } from \"react\";\n\nconst LayoutContext = createContext<LayoutContextType | undefined>(undefined);\n\nconst useLayout = () => {\n const context = useContext(LayoutContext);\n if (context === undefined) {\n throw new Error(\"useLayout must be used within a LayoutProvider\");\n }\n return context;\n};\n\nexport default useLayout;\nexport { LayoutContext, useLayout };\n"],"mappings":"uBAQA,IAAM,KAAA,EAAA,eAA6D,MAAS,EAEtE,EAAA,IAAkB,CACtB,MAAM,KAAA,EAAA,YAAqB,CAAa,EACxC,GAAI,IAAY,OACd,MAAM,IAAI,MAAM,gDAAgD,EAElE,OAAO,CACT"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-useLayout-
|
|
1
|
+
{"version":3,"file":"chunk-useLayout-BXsJlpcb.mjs","names":[],"sources":["../src/designs/layouts/hooks/useLayout.ts"],"sourcesContent":["/**\n * 布局上下文与 useLayout:供子组件消费侧栏状态与 setLayoutMode。\n * Layout context and useLayout: for consuming sidebar state and setLayoutMode.\n */\nimport type { LayoutContextType } from \"../types\";\n\nimport { createContext, useContext } from \"react\";\n\nconst LayoutContext = createContext<LayoutContextType | undefined>(undefined);\n\nconst useLayout = () => {\n const context = useContext(LayoutContext);\n if (context === undefined) {\n throw new Error(\"useLayout must be used within a LayoutProvider\");\n }\n return context;\n};\n\nexport default useLayout;\nexport { LayoutContext, useLayout };\n"],"mappings":";AAQA,IAAM,IAAgB,EAA6C,MAAS,GAEtE,IAAA,MAAkB;AACtB,QAAM,IAAU,EAAW,CAAa;AACxC,MAAI,MAAY,OACd,OAAM,IAAI,MAAM,gDAAgD;AAElE,SAAO;AACT"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-useTheme-
|
|
1
|
+
{"version":3,"file":"chunk-useTheme-BY1_pW9y.mjs","names":[],"sources":["../src/themes/hooks/useTheme.ts"],"sourcesContent":["/**\n * 主题上下文与 useTheme:供子组件消费当前主题与 setTheme/setBase。\n * Theme context and useTheme: for consuming current theme and setTheme/setBase.\n */\nimport type { ThemeContextType } from \"../types\";\n\nimport { createContext, useContext } from \"react\";\n\nconst ThemeContext = createContext<ThemeContextType | undefined>(undefined);\n\nfunction useTheme(): ThemeContextType {\n const context = useContext(ThemeContext);\n if (context === undefined) {\n throw new Error(\"useTheme must be used within a ThemeProvider\");\n }\n return context;\n}\n\nexport { ThemeContext, useTheme };\nexport type { ThemeContextType } from \"../types\";\n"],"mappings":";AAQA,IAAM,IAAe,EAA4C,MAAS;AAE1E,SAAS,IAA6B;AACpC,QAAM,IAAU,EAAW,CAAY;AACvC,MAAI,MAAY,OACd,OAAM,IAAI,MAAM,8CAA8C;AAEhE,SAAO;AACT"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
let t=require("react");var r=(0,t.createContext)(void 0);function n(){const e=(0,t.useContext)(r);if(e===void 0)throw new Error("useTheme must be used within a ThemeProvider");return e}Object.defineProperty(exports,"ThemeContext",{enumerable:!0,get:function(){return r}});Object.defineProperty(exports,"useTheme",{enumerable:!0,get:function(){return n}});
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=chunk-useTheme-Tw_7_cQf.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunk-useTheme-
|
|
1
|
+
{"version":3,"file":"chunk-useTheme-Tw_7_cQf.cjs","names":[],"sources":["../src/themes/hooks/useTheme.ts"],"sourcesContent":["/**\n * 主题上下文与 useTheme:供子组件消费当前主题与 setTheme/setBase。\n * Theme context and useTheme: for consuming current theme and setTheme/setBase.\n */\nimport type { ThemeContextType } from \"../types\";\n\nimport { createContext, useContext } from \"react\";\n\nconst ThemeContext = createContext<ThemeContextType | undefined>(undefined);\n\nfunction useTheme(): ThemeContextType {\n const context = useContext(ThemeContext);\n if (context === undefined) {\n throw new Error(\"useTheme must be used within a ThemeProvider\");\n }\n return context;\n}\n\nexport { ThemeContext, useTheme };\nexport type { ThemeContextType } from \"../types\";\n"],"mappings":"uBAQA,IAAM,KAAA,EAAA,eAA2D,MAAS,EAE1E,SAAS,GAA6B,CACpC,MAAM,KAAA,EAAA,YAAqB,CAAY,EACvC,GAAI,IAAY,OACd,MAAM,IAAI,MAAM,8CAA8C,EAEhE,OAAO,CACT"}
|