xto-fronted 0.4.91 → 0.4.92

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/dist/App.vue.d.ts +2 -0
  2. package/dist/api/auth.d.ts +8 -0
  3. package/dist/api/system.d.ts +16 -0
  4. package/dist/api/user.d.ts +13 -0
  5. package/dist/components/Layout/Footer.vue.d.ts +2 -0
  6. package/dist/components/Layout/Header.vue.d.ts +5 -0
  7. package/dist/components/Layout/MixTopMenu.vue.d.ts +5 -0
  8. package/dist/components/Layout/Sidebar.vue.d.ts +11 -0
  9. package/dist/components/Layout/SidebarMenuItem.vue.d.ts +5 -0
  10. package/dist/components/Layout/Tabs.vue.d.ts +2 -0
  11. package/dist/components/Layout/TopMenu.vue.d.ts +5 -0
  12. package/dist/components/Layout/index.vue.d.ts +2 -0
  13. package/dist/composables/useApp.d.ts +29 -0
  14. package/dist/composables/useAuth.d.ts +6 -0
  15. package/dist/composables/useForm.d.ts +20 -0
  16. package/dist/composables/useI18n.d.ts +30 -0
  17. package/dist/composables/useTable.d.ts +29 -0
  18. package/dist/directives/permission.d.ts +4 -0
  19. package/dist/enums/index.d.ts +32 -0
  20. package/dist/index--qRfsJ32.js +4267 -0
  21. package/dist/index-CsjBlLrl.js +479 -0
  22. package/dist/index-CvYIvRSW.js +515 -0
  23. package/dist/index-DAPLMrmP.js +189 -0
  24. package/dist/index-DjkSMw-x.js +641 -0
  25. package/dist/index.d.ts +59 -0
  26. package/dist/index.es.js +95 -0
  27. package/dist/index.umd.js +8 -0
  28. package/dist/main.d.ts +0 -0
  29. package/dist/router/dynamicRoutes.d.ts +30 -0
  30. package/dist/router/guards.d.ts +17 -0
  31. package/dist/router/index.d.ts +6 -0
  32. package/dist/router/layoutRoute.d.ts +22 -0
  33. package/dist/router/staticRoutes.d.ts +2 -0
  34. package/dist/stores/app.d.ts +93 -0
  35. package/dist/stores/auth.d.ts +41 -0
  36. package/dist/stores/index.d.ts +10 -0
  37. package/dist/stores/locale.d.ts +42 -0
  38. package/dist/stores/menu.d.ts +83 -0
  39. package/dist/stores/user.d.ts +92 -0
  40. package/dist/style.css +1 -0
  41. package/dist/utils/auth.d.ts +27 -0
  42. package/dist/utils/config.d.ts +30 -0
  43. package/dist/utils/permission.d.ts +17 -0
  44. package/dist/utils/request.d.ts +29 -0
  45. package/dist/utils/storage.d.ts +24 -0
  46. package/dist/views/dashboard/index.vue.d.ts +2 -0
  47. package/dist/views/error/403.vue.d.ts +2 -0
  48. package/dist/views/error/404.vue.d.ts +2 -0
  49. package/dist/views/login/index.vue.d.ts +4 -0
  50. package/dist/views/system/menu/index.vue.d.ts +4 -0
  51. package/dist/views/system/role/index.vue.d.ts +4 -0
  52. package/dist/views/system/user/index.vue.d.ts +4 -0
  53. package/package.json +1 -1
  54. package/dist/assets/404-Bq0LY5Cd.js +0 -1
  55. package/dist/assets/404-Cw_4ZCL6.css +0 -1
  56. package/dist/assets/_plugin-vue_export-helper-DlAUqK2U.js +0 -1
  57. package/dist/assets/index-7ZZxpSfk.js +0 -1
  58. package/dist/assets/index-BJUe8VUp.js +0 -1
  59. package/dist/assets/index-BRR97dc6.js +0 -1
  60. package/dist/assets/index-BlOR_ICg.js +0 -1
  61. package/dist/assets/index-BlRslYYI.css +0 -1
  62. package/dist/assets/index-BudArKxR.css +0 -1
  63. package/dist/assets/index-BzbOWBCV.js +0 -1
  64. package/dist/assets/index-CFhWBbxk.css +0 -1
  65. package/dist/assets/index-CH6aTfYg.css +0 -1
  66. package/dist/assets/index-CT5f37nN.js +0 -1
  67. package/dist/assets/index-Ce-kjtEM.js +0 -2
  68. package/dist/assets/index-Cpew6d-v.css +0 -1
  69. package/dist/assets/index-DkkuYBgT.css +0 -1
  70. package/dist/assets/index-vfvEFrCH.css +0 -1
  71. package/dist/assets/index-wVLLAoVp.js +0 -1
  72. package/dist/assets/vendor-DZmPBJ9d.js +0 -16
  73. package/dist/assets/vue-vendor-DjmFuEnG.js +0 -29
  74. package/dist/assets/xto-base-B5HYOo6i.js +0 -1
  75. package/dist/assets/xto-base-CL2NKZJJ.css +0 -1
  76. package/dist/assets/xto-business--V1F5Gwb.css +0 -1
  77. package/dist/assets/xto-core-DZYp_YAR.js +0 -1
  78. package/dist/assets/xto-data-MxZsiJgi.css +0 -1
  79. package/dist/assets/xto-data-ogck6x_i.js +0 -1
  80. package/dist/assets/xto-feedback-Bxx38c3P.css +0 -1
  81. package/dist/assets/xto-feedback-C0-6cAL6.js +0 -1
  82. package/dist/assets/xto-form-Cu6q3VLG.css +0 -1
  83. package/dist/assets/xto-form-IDg_78Vf.js +0 -1
  84. package/dist/assets/xto-layout-BDD6sSlM.css +0 -1
  85. package/dist/assets/xto-navigation-CPYLzfu7.js +0 -1
  86. package/dist/assets/xto-navigation-XfpyMpEo.css +0 -1
  87. package/dist/index.html +0 -28
@@ -0,0 +1,22 @@
1
+ import { RouteRecordRaw, Router } from 'vue-router';
2
+ interface LayoutRouteOptions {
3
+ indexPath?: string;
4
+ }
5
+ interface CreateRouterOptions {
6
+ base?: string;
7
+ }
8
+ /**
9
+ * 创建布局路由
10
+ * @param children 子路由配置
11
+ * @param options 配置选项
12
+ * @returns 布局路由配置
13
+ */
14
+ export declare function createLayoutRoute(children: RouteRecordRaw[], options?: LayoutRouteOptions): RouteRecordRaw;
15
+ /**
16
+ * 创建路由实例
17
+ * @param routes 路由配置数组
18
+ * @param options 配置选项
19
+ * @returns 路由实例
20
+ */
21
+ export declare function createRouter(routes: RouteRecordRaw[], options?: CreateRouterOptions): Router;
22
+ export {};
@@ -0,0 +1,2 @@
1
+ import { RouteRecordRaw } from 'vue-router';
2
+ export declare const staticRoutes: RouteRecordRaw[];
@@ -0,0 +1,93 @@
1
+ /**
2
+ * 应用状态
3
+ */
4
+ export type ThemeMode = 'light' | 'dark';
5
+ export type LayoutMode = 'sidebar' | 'top' | 'mix';
6
+ export declare const useAppStore: import('pinia').StoreDefinition<"app", Pick<{
7
+ appName: import('vue').Ref<string, string>;
8
+ indexPath: import('vue').Ref<string, string>;
9
+ isDark: import('vue').Ref<boolean, boolean>;
10
+ theme: import('vue').Ref<ThemeMode, ThemeMode>;
11
+ layout: import('vue').Ref<LayoutMode, LayoutMode>;
12
+ isCollapsed: import('vue').Ref<boolean, boolean>;
13
+ showTabs: import('vue').Ref<boolean, boolean>;
14
+ showFooter: import('vue').Ref<boolean, boolean>;
15
+ showBreadcrumb: import('vue').Ref<boolean, boolean>;
16
+ primaryColor: import('vue').Ref<string, string>;
17
+ cachedViews: import('vue').Ref<string[], string[]>;
18
+ mixSubMenus: import('vue').Ref<any[], any[]>;
19
+ themeClass: import('vue').ComputedRef<"light" | "dark">;
20
+ setAppName: (name: string) => void;
21
+ setIndexPath: (path: string) => void;
22
+ toggleTheme: () => void;
23
+ toggleCollapse: () => void;
24
+ setTheme: (mode: ThemeMode) => void;
25
+ setLayout: (mode: LayoutMode) => void;
26
+ toggleTabs: () => void;
27
+ toggleFooter: () => void;
28
+ toggleBreadcrumb: () => void;
29
+ setPrimaryColor: (color: string) => void;
30
+ addCachedView: (name: string) => void;
31
+ removeCachedView: (name: string) => void;
32
+ clearCachedViews: () => void;
33
+ setMixSubMenus: (menus: any[]) => void;
34
+ initTheme: () => void;
35
+ }, "appName" | "indexPath" | "isDark" | "theme" | "layout" | "isCollapsed" | "showTabs" | "showFooter" | "showBreadcrumb" | "primaryColor" | "cachedViews" | "mixSubMenus">, Pick<{
36
+ appName: import('vue').Ref<string, string>;
37
+ indexPath: import('vue').Ref<string, string>;
38
+ isDark: import('vue').Ref<boolean, boolean>;
39
+ theme: import('vue').Ref<ThemeMode, ThemeMode>;
40
+ layout: import('vue').Ref<LayoutMode, LayoutMode>;
41
+ isCollapsed: import('vue').Ref<boolean, boolean>;
42
+ showTabs: import('vue').Ref<boolean, boolean>;
43
+ showFooter: import('vue').Ref<boolean, boolean>;
44
+ showBreadcrumb: import('vue').Ref<boolean, boolean>;
45
+ primaryColor: import('vue').Ref<string, string>;
46
+ cachedViews: import('vue').Ref<string[], string[]>;
47
+ mixSubMenus: import('vue').Ref<any[], any[]>;
48
+ themeClass: import('vue').ComputedRef<"light" | "dark">;
49
+ setAppName: (name: string) => void;
50
+ setIndexPath: (path: string) => void;
51
+ toggleTheme: () => void;
52
+ toggleCollapse: () => void;
53
+ setTheme: (mode: ThemeMode) => void;
54
+ setLayout: (mode: LayoutMode) => void;
55
+ toggleTabs: () => void;
56
+ toggleFooter: () => void;
57
+ toggleBreadcrumb: () => void;
58
+ setPrimaryColor: (color: string) => void;
59
+ addCachedView: (name: string) => void;
60
+ removeCachedView: (name: string) => void;
61
+ clearCachedViews: () => void;
62
+ setMixSubMenus: (menus: any[]) => void;
63
+ initTheme: () => void;
64
+ }, "themeClass">, Pick<{
65
+ appName: import('vue').Ref<string, string>;
66
+ indexPath: import('vue').Ref<string, string>;
67
+ isDark: import('vue').Ref<boolean, boolean>;
68
+ theme: import('vue').Ref<ThemeMode, ThemeMode>;
69
+ layout: import('vue').Ref<LayoutMode, LayoutMode>;
70
+ isCollapsed: import('vue').Ref<boolean, boolean>;
71
+ showTabs: import('vue').Ref<boolean, boolean>;
72
+ showFooter: import('vue').Ref<boolean, boolean>;
73
+ showBreadcrumb: import('vue').Ref<boolean, boolean>;
74
+ primaryColor: import('vue').Ref<string, string>;
75
+ cachedViews: import('vue').Ref<string[], string[]>;
76
+ mixSubMenus: import('vue').Ref<any[], any[]>;
77
+ themeClass: import('vue').ComputedRef<"light" | "dark">;
78
+ setAppName: (name: string) => void;
79
+ setIndexPath: (path: string) => void;
80
+ toggleTheme: () => void;
81
+ toggleCollapse: () => void;
82
+ setTheme: (mode: ThemeMode) => void;
83
+ setLayout: (mode: LayoutMode) => void;
84
+ toggleTabs: () => void;
85
+ toggleFooter: () => void;
86
+ toggleBreadcrumb: () => void;
87
+ setPrimaryColor: (color: string) => void;
88
+ addCachedView: (name: string) => void;
89
+ removeCachedView: (name: string) => void;
90
+ clearCachedViews: () => void;
91
+ setMixSubMenus: (menus: any[]) => void;
92
+ initTheme: () => void;
93
+ }, "setAppName" | "setIndexPath" | "toggleTheme" | "toggleCollapse" | "setTheme" | "setLayout" | "toggleTabs" | "toggleFooter" | "toggleBreadcrumb" | "setPrimaryColor" | "addCachedView" | "removeCachedView" | "clearCachedViews" | "setMixSubMenus" | "initTheme">>;
@@ -0,0 +1,41 @@
1
+ import { TokenInfo } from '../utils/auth';
2
+ export declare const useAuthStore: import('pinia').StoreDefinition<"auth", Pick<{
3
+ token: import('vue').Ref<string | null, string | null>;
4
+ isLoggedIn: import('vue').ComputedRef<boolean>;
5
+ baseUrl: import('vue').Ref<string, string>;
6
+ appId: import('vue').Ref<string, string>;
7
+ clientId: import('vue').Ref<string, string>;
8
+ loginPath: import('vue').Ref<string, string>;
9
+ login: (tokenInfo: TokenInfo) => void;
10
+ logout: () => void;
11
+ setBaseUrl: (url: string) => void;
12
+ setAppId: (id: string) => void;
13
+ setClientId: (id: string) => void;
14
+ setLoginPath: (path: string) => void;
15
+ }, "appId" | "token" | "baseUrl" | "clientId" | "loginPath">, Pick<{
16
+ token: import('vue').Ref<string | null, string | null>;
17
+ isLoggedIn: import('vue').ComputedRef<boolean>;
18
+ baseUrl: import('vue').Ref<string, string>;
19
+ appId: import('vue').Ref<string, string>;
20
+ clientId: import('vue').Ref<string, string>;
21
+ loginPath: import('vue').Ref<string, string>;
22
+ login: (tokenInfo: TokenInfo) => void;
23
+ logout: () => void;
24
+ setBaseUrl: (url: string) => void;
25
+ setAppId: (id: string) => void;
26
+ setClientId: (id: string) => void;
27
+ setLoginPath: (path: string) => void;
28
+ }, "isLoggedIn">, Pick<{
29
+ token: import('vue').Ref<string | null, string | null>;
30
+ isLoggedIn: import('vue').ComputedRef<boolean>;
31
+ baseUrl: import('vue').Ref<string, string>;
32
+ appId: import('vue').Ref<string, string>;
33
+ clientId: import('vue').Ref<string, string>;
34
+ loginPath: import('vue').Ref<string, string>;
35
+ login: (tokenInfo: TokenInfo) => void;
36
+ logout: () => void;
37
+ setBaseUrl: (url: string) => void;
38
+ setAppId: (id: string) => void;
39
+ setClientId: (id: string) => void;
40
+ setLoginPath: (path: string) => void;
41
+ }, "login" | "logout" | "setBaseUrl" | "setAppId" | "setClientId" | "setLoginPath">>;
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Pinia Store 入口
3
+ */
4
+ declare const pinia: import('pinia').Pinia;
5
+ export default pinia;
6
+ export * from './user';
7
+ export * from './auth';
8
+ export * from './menu';
9
+ export * from './app';
10
+ export * from './locale';
@@ -0,0 +1,42 @@
1
+ import { LocaleCode, LocaleMessages } from '@xto/core/locale';
2
+ export type { LocaleCode, LocaleMessages };
3
+ export declare const useLocaleStore: import('pinia').StoreDefinition<"locale", Pick<{
4
+ locale: import('vue').Ref<LocaleCode, LocaleCode>;
5
+ localeName: import('vue').ComputedRef<string>;
6
+ locales: {
7
+ code: LocaleCode;
8
+ name: string;
9
+ }[];
10
+ messages: import('vue').ComputedRef<LocaleMessages>;
11
+ t: (key: string, ...args: (string | number)[]) => string;
12
+ changeLocale: (code: LocaleCode) => void;
13
+ addMessages: (msgs: LocaleMessages) => void;
14
+ initLocale: () => void;
15
+ provider: any;
16
+ }, "locale" | "locales" | "provider">, Pick<{
17
+ locale: import('vue').Ref<LocaleCode, LocaleCode>;
18
+ localeName: import('vue').ComputedRef<string>;
19
+ locales: {
20
+ code: LocaleCode;
21
+ name: string;
22
+ }[];
23
+ messages: import('vue').ComputedRef<LocaleMessages>;
24
+ t: (key: string, ...args: (string | number)[]) => string;
25
+ changeLocale: (code: LocaleCode) => void;
26
+ addMessages: (msgs: LocaleMessages) => void;
27
+ initLocale: () => void;
28
+ provider: any;
29
+ }, "messages" | "localeName" | "provider">, Pick<{
30
+ locale: import('vue').Ref<LocaleCode, LocaleCode>;
31
+ localeName: import('vue').ComputedRef<string>;
32
+ locales: {
33
+ code: LocaleCode;
34
+ name: string;
35
+ }[];
36
+ messages: import('vue').ComputedRef<LocaleMessages>;
37
+ t: (key: string, ...args: (string | number)[]) => string;
38
+ changeLocale: (code: LocaleCode) => void;
39
+ addMessages: (msgs: LocaleMessages) => void;
40
+ initLocale: () => void;
41
+ provider: any;
42
+ }, "t" | "changeLocale" | "addMessages" | "initLocale" | "provider">>;
@@ -0,0 +1,83 @@
1
+ import { MenuItem } from '../types/api';
2
+ export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<{
3
+ menuList: import('vue').Ref<{
4
+ menuCode: string;
5
+ menuName: string;
6
+ menuUrl: string;
7
+ icon?: string | undefined;
8
+ closable?: boolean | undefined;
9
+ isDefault?: boolean | undefined;
10
+ isOut?: boolean | undefined;
11
+ type?: number | undefined;
12
+ children?: /*elided*/ any[] | undefined;
13
+ }[], MenuItem[] | {
14
+ menuCode: string;
15
+ menuName: string;
16
+ menuUrl: string;
17
+ icon?: string | undefined;
18
+ closable?: boolean | undefined;
19
+ isDefault?: boolean | undefined;
20
+ isOut?: boolean | undefined;
21
+ type?: number | undefined;
22
+ children?: /*elided*/ any[] | undefined;
23
+ }[]>;
24
+ permissions: import('vue').Ref<string[], string[]>;
25
+ hasMenu: import('vue').ComputedRef<boolean>;
26
+ setMenuList: (menus: MenuItem[]) => void;
27
+ clearMenu: () => void;
28
+ hasPermission: (permission: string | string[]) => boolean;
29
+ }, "menuList" | "permissions">, Pick<{
30
+ menuList: import('vue').Ref<{
31
+ menuCode: string;
32
+ menuName: string;
33
+ menuUrl: string;
34
+ icon?: string | undefined;
35
+ closable?: boolean | undefined;
36
+ isDefault?: boolean | undefined;
37
+ isOut?: boolean | undefined;
38
+ type?: number | undefined;
39
+ children?: /*elided*/ any[] | undefined;
40
+ }[], MenuItem[] | {
41
+ menuCode: string;
42
+ menuName: string;
43
+ menuUrl: string;
44
+ icon?: string | undefined;
45
+ closable?: boolean | undefined;
46
+ isDefault?: boolean | undefined;
47
+ isOut?: boolean | undefined;
48
+ type?: number | undefined;
49
+ children?: /*elided*/ any[] | undefined;
50
+ }[]>;
51
+ permissions: import('vue').Ref<string[], string[]>;
52
+ hasMenu: import('vue').ComputedRef<boolean>;
53
+ setMenuList: (menus: MenuItem[]) => void;
54
+ clearMenu: () => void;
55
+ hasPermission: (permission: string | string[]) => boolean;
56
+ }, "hasMenu">, Pick<{
57
+ menuList: import('vue').Ref<{
58
+ menuCode: string;
59
+ menuName: string;
60
+ menuUrl: string;
61
+ icon?: string | undefined;
62
+ closable?: boolean | undefined;
63
+ isDefault?: boolean | undefined;
64
+ isOut?: boolean | undefined;
65
+ type?: number | undefined;
66
+ children?: /*elided*/ any[] | undefined;
67
+ }[], MenuItem[] | {
68
+ menuCode: string;
69
+ menuName: string;
70
+ menuUrl: string;
71
+ icon?: string | undefined;
72
+ closable?: boolean | undefined;
73
+ isDefault?: boolean | undefined;
74
+ isOut?: boolean | undefined;
75
+ type?: number | undefined;
76
+ children?: /*elided*/ any[] | undefined;
77
+ }[]>;
78
+ permissions: import('vue').Ref<string[], string[]>;
79
+ hasMenu: import('vue').ComputedRef<boolean>;
80
+ setMenuList: (menus: MenuItem[]) => void;
81
+ clearMenu: () => void;
82
+ hasPermission: (permission: string | string[]) => boolean;
83
+ }, "setMenuList" | "clearMenu" | "hasPermission">>;
@@ -0,0 +1,92 @@
1
+ import { UserInfo } from '../types/api';
2
+ export declare const useUserStore: import('pinia').StoreDefinition<"user", Pick<{
3
+ userInfo: import('vue').Ref<{
4
+ appId: string;
5
+ userId: string;
6
+ userName: string;
7
+ departmentName?: string | undefined;
8
+ email?: string | undefined;
9
+ mobilePhone?: string | undefined;
10
+ positionName?: string | undefined;
11
+ avatar?: string | undefined;
12
+ } | null, UserInfo | {
13
+ appId: string;
14
+ userId: string;
15
+ userName: string;
16
+ departmentName?: string | undefined;
17
+ email?: string | undefined;
18
+ mobilePhone?: string | undefined;
19
+ positionName?: string | undefined;
20
+ avatar?: string | undefined;
21
+ } | null>;
22
+ isLoggedIn: import('vue').ComputedRef<boolean>;
23
+ userId: import('vue').ComputedRef<string>;
24
+ userName: import('vue').ComputedRef<string>;
25
+ departmentName: import('vue').ComputedRef<string>;
26
+ email: import('vue').ComputedRef<string>;
27
+ mobilePhone: import('vue').ComputedRef<string>;
28
+ positionName: import('vue').ComputedRef<string>;
29
+ avatar: import('vue').ComputedRef<string>;
30
+ setUserInfo: (info: UserInfo) => void;
31
+ clearUserInfo: () => void;
32
+ }, "userInfo">, Pick<{
33
+ userInfo: import('vue').Ref<{
34
+ appId: string;
35
+ userId: string;
36
+ userName: string;
37
+ departmentName?: string | undefined;
38
+ email?: string | undefined;
39
+ mobilePhone?: string | undefined;
40
+ positionName?: string | undefined;
41
+ avatar?: string | undefined;
42
+ } | null, UserInfo | {
43
+ appId: string;
44
+ userId: string;
45
+ userName: string;
46
+ departmentName?: string | undefined;
47
+ email?: string | undefined;
48
+ mobilePhone?: string | undefined;
49
+ positionName?: string | undefined;
50
+ avatar?: string | undefined;
51
+ } | null>;
52
+ isLoggedIn: import('vue').ComputedRef<boolean>;
53
+ userId: import('vue').ComputedRef<string>;
54
+ userName: import('vue').ComputedRef<string>;
55
+ departmentName: import('vue').ComputedRef<string>;
56
+ email: import('vue').ComputedRef<string>;
57
+ mobilePhone: import('vue').ComputedRef<string>;
58
+ positionName: import('vue').ComputedRef<string>;
59
+ avatar: import('vue').ComputedRef<string>;
60
+ setUserInfo: (info: UserInfo) => void;
61
+ clearUserInfo: () => void;
62
+ }, "userId" | "userName" | "departmentName" | "email" | "mobilePhone" | "positionName" | "avatar" | "isLoggedIn">, Pick<{
63
+ userInfo: import('vue').Ref<{
64
+ appId: string;
65
+ userId: string;
66
+ userName: string;
67
+ departmentName?: string | undefined;
68
+ email?: string | undefined;
69
+ mobilePhone?: string | undefined;
70
+ positionName?: string | undefined;
71
+ avatar?: string | undefined;
72
+ } | null, UserInfo | {
73
+ appId: string;
74
+ userId: string;
75
+ userName: string;
76
+ departmentName?: string | undefined;
77
+ email?: string | undefined;
78
+ mobilePhone?: string | undefined;
79
+ positionName?: string | undefined;
80
+ avatar?: string | undefined;
81
+ } | null>;
82
+ isLoggedIn: import('vue').ComputedRef<boolean>;
83
+ userId: import('vue').ComputedRef<string>;
84
+ userName: import('vue').ComputedRef<string>;
85
+ departmentName: import('vue').ComputedRef<string>;
86
+ email: import('vue').ComputedRef<string>;
87
+ mobilePhone: import('vue').ComputedRef<string>;
88
+ positionName: import('vue').ComputedRef<string>;
89
+ avatar: import('vue').ComputedRef<string>;
90
+ setUserInfo: (info: UserInfo) => void;
91
+ clearUserInfo: () => void;
92
+ }, "setUserInfo" | "clearUserInfo">>;
package/dist/style.css ADDED
@@ -0,0 +1 @@
1
+ @charset "UTF-8";:root{--color-primary: #1677ff;--color-primary-light-1: #4096ff;--color-primary-light-2: #69b1ff;--color-primary-light-3: #91caff;--color-primary-light-4: #bae0ff;--color-primary-light-5: #e6f4ff;--color-primary-light-6: #f0f8ff;--color-primary-dark-1: #0958d9;--color-primary-dark-2: #003eb3;--color-primary-dark-3: #002c8c;--color-success: #52c41a;--color-success-light: #b7eb8f;--color-success-lighter: #f6ffed;--color-success-dark: #389e0d;--color-warning: #faad14;--color-warning-light: #ffe58f;--color-warning-lighter: #fffbe6;--color-warning-dark: #d48806;--color-danger: #ff4d4f;--color-danger-light: #ffa39e;--color-danger-lighter: #fff2f0;--color-danger-dark: #cf1322;--color-info: #1677ff;--color-info-light: #91caff;--color-info-lighter: #e6f4ff;--color-info-dark: #0958d9;--color-text-primary: #1f1f1f;--color-text-regular: #424242;--color-text-secondary: #757575;--color-text-placeholder: #9e9e9e;--color-text-disabled: #bdbdbd;--color-border: #d9d9d9;--color-border-light: #e8e8e8;--color-border-lighter: #f0f0f0;--color-border-extra-light: #f5f5f5;--color-border-dark: #bfbfbf;--color-fill: #f5f5f5;--color-fill-light: #fafafa;--color-fill-lighter: #ffffff;--color-fill-blank: #ffffff;--color-fill-dark: #e8e8e8;--bg-color: #ffffff;--bg-color-page: #f0f2f5;--bg-color-component: #ffffff;--bg-color-overlay: #ffffff;--bg-color-spotlight: #e6f4ff;--box-shadow: 0 6px 16px 0 rgba(0, 0, 0, .08), 0 3px 6px -4px rgba(0, 0, 0, .12), 0 9px 28px 8px rgba(0, 0, 0, .05);--box-shadow-light: 0 1px 2px 0 rgba(0, 0, 0, .03), 0 1px 6px -1px rgba(0, 0, 0, .02), 0 2px 4px 0 rgba(0, 0, 0, .02);--box-shadow-lighter: 0 1px 4px rgba(0, 0, 0, .04);--box-shadow-dark: 0 6px 16px -8px rgba(0, 0, 0, .08), 0 9px 28px 8px rgba(0, 0, 0, .05), 0 12px 48px 16px rgba(0, 0, 0, .03);--box-shadow-card: 0 1px 10px -6px rgba(0, 0, 0, .1);--box-shadow-card-hover: 0 6px 16px -8px rgba(0, 0, 0, .12);--font-family: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--font-family-code: "IBM Plex Mono", "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-size-base: 14px;--font-size-small: 12px;--font-size-large: 16px;--font-size-extra-large: 20px;--font-size-title: 24px;--font-size-hero: 38px;--font-line-height: 1.5714285714285714;--border-radius-base: 6px;--border-radius-small: 4px;--border-radius-large: 8px;--border-radius-extra-large: 12px;--border-radius-round: 24px;--border-radius-circle: 50%;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--component-size-large: 40px;--component-size-default: 32px;--component-size-small: 24px;--transition-duration: .2s;--transition-duration-fast: .1s;--transition-duration-slow: .3s;--transition-easing: cubic-bezier(.645, .045, .355, 1);--transition-easing-bounce: cubic-bezier(.68, -.55, .265, 1.55);--z-index-dropdown: 1000;--z-index-sticky: 1020;--z-index-fixed: 1030;--z-index-modal-backdrop: 1040;--z-index-modal: 1050;--z-index-popover: 1060;--z-index-tooltip: 1070;--sidebar-width: 220px;--sidebar-collapsed-width: 64px;--header-height: 56px;--tabs-height: 40px;--footer-height: 32px;--gradient-primary: linear-gradient(135deg, #1677ff 0%, #4096ff 100%);--gradient-hero: linear-gradient(135deg, #002c8c 0%, #1677ff 50%, #4096ff 100%);--gradient-card: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .8) 100%);--gradient-mask: linear-gradient(180deg, rgba(0, 44, 140, .03) 0%, rgba(0, 0, 0, 0) 100%)}.dark{--color-text-primary: #ffffff;--color-text-regular: #e0e0e0;--color-text-secondary: #a6a6a6;--color-text-placeholder: #737373;--color-text-disabled: #5c5c5c;--color-border: #434343;--color-border-light: #363636;--color-border-lighter: #2a2a2a;--color-border-extra-light: #1f1f1f;--color-border-dark: #5c5c5c;--color-fill: #262626;--color-fill-light: #1f1f1f;--color-fill-lighter: #141414;--color-fill-blank: #141414;--color-fill-dark: #363636;--bg-color: #141414;--bg-color-page: #0a0a0a;--bg-color-component: #1f1f1f;--bg-color-overlay: #1f1f1f;--bg-color-spotlight: #111d2c;--box-shadow: 0 6px 16px 0 rgba(0, 0, 0, .32), 0 3px 6px -4px rgba(0, 0, 0, .48), 0 9px 28px 8px rgba(0, 0, 0, .2);--box-shadow-light: 0 1px 2px 0 rgba(0, 0, 0, .16), 0 1px 6px -1px rgba(0, 0, 0, .12), 0 2px 4px 0 rgba(0, 0, 0, .08);--box-shadow-card: 0 1px 10px -6px rgba(0, 0, 0, .32);--box-shadow-card-hover: 0 6px 16px -8px rgba(0, 0, 0, .48);--gradient-primary: linear-gradient(135deg, #1677ff 0%, #4096ff 100%);--gradient-hero: linear-gradient(135deg, #002c8c 0%, #0958d9 50%, #1677ff 100%);--gradient-card: linear-gradient(180deg, rgba(20, 20, 20, 0) 0%, rgba(20, 20, 20, .8) 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{width:100%;height:100%;font-size:var(--font-size-base);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{width:100%;height:100%;font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-primary);background-color:var(--bg-color-page)}#app{width:100%;height:100%}a{color:var(--color-primary);text-decoration:none;cursor:pointer;transition:color var(--transition-duration-fast)}a:hover{color:var(--color-primary-light-3)}ul,ol{list-style:none}img{max-width:100%;height:auto;vertical-align:middle}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none;outline:none}button:disabled{cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{margin:0;font-weight:500;color:var(--color-text-primary)}p{margin:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background-color:var(--color-fill-light);border-radius:3px}::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-secondary)}::selection{background-color:var(--color-primary-light-8);color:var(--color-primary)}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-duration)}.fade-enter-from,.fade-leave-to{opacity:0}.fade-scale-enter-active,.fade-scale-leave-active{transition:all var(--transition-duration)}.fade-scale-enter-from,.fade-scale-leave-to{opacity:0;transform:scale(.9)}.fade-transform-enter-active,.fade-transform-leave-active{transition:all var(--transition-duration-fast)}.fade-transform-enter-from{opacity:0;transform:translate(-10px)}.fade-transform-leave-to{opacity:0;transform:translate(10px)}.slide-down-enter-active,.slide-down-leave-active{transition:all var(--transition-duration)}.slide-down-enter-from,.slide-down-leave-to{opacity:0;transform:translateY(-20px)}.slide-up-enter-active,.slide-up-leave-active{transition:all var(--transition-duration)}.slide-up-enter-from,.slide-up-leave-to{opacity:0;transform:translateY(20px)}.slide-left-enter-active,.slide-left-leave-active{transition:all var(--transition-duration)}.slide-left-enter-from,.slide-left-leave-to{opacity:0;transform:translate(20px)}.slide-right-enter-active,.slide-right-leave-active{transition:all var(--transition-duration)}.slide-right-enter-from,.slide-right-leave-to{opacity:0;transform:translate(-20px)}.zoom-enter-active,.zoom-leave-active{transition:all var(--transition-duration)}.zoom-enter-from,.zoom-leave-to{opacity:0;transform:scale(.5)}.list-enter-active,.list-leave-active{transition:all var(--transition-duration)}.list-enter-from,.list-leave-to{opacity:0;transform:translateY(30px)}.collapse-transition{transition:width var(--transition-duration),padding var(--transition-duration)}.dark .sidebar,.dark .layout__aside{background-color:#1d1e1f}.dark .sidebar{border-right:1px solid #363637}.dark .sidebar__search-results{background-color:#1d1e1f;border-color:#363637}.dark .sidebar__search-item:hover{background-color:#262727}.dark .sidebar__search-item-title{color:#cfd3dc}.dark .sidebar__search-item-parent{color:#a3a6ad}.dark .sidebar__logo{border-bottom-color:#363637}.dark .sidebar__user{border-top-color:#363637}.dark .sidebar__user-name{color:#cfd3dc}.dark .sidebar__user-role{color:#a3a6ad}.dark .x-menu{background-color:#1d1e1f!important;border-color:#363637;color:#cfd3dc}.dark .x-menu.x-menu--vertical{border-right-color:#363637}.dark .x-menu.x-menu--horizontal{border-bottom-color:#363637;background-color:#1d1e1f!important}.dark .x-menu-item{color:#cfd3dc!important;background-color:transparent!important}.dark .x-menu-item:hover{background-color:#262727!important}.dark .x-menu-item.is-active{color:#409eff!important;background-color:#409eff1a!important}.dark .x-menu-item.is-active:before{background-color:#409eff}.dark .x-menu-item.is-horizontal:hover{background-color:transparent!important}.dark .x-menu-item.is-horizontal.is-active{background-color:transparent!important;border-bottom-color:#409eff}.dark .x-sub-menu__title{color:#cfd3dc!important;background-color:transparent!important}.dark .x-sub-menu__title:hover{background-color:#262727!important}.dark .x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .x-sub-menu__menu .x-menu-item{background-color:transparent!important;color:#cfd3dc!important}.dark .x-sub-menu__menu .x-menu-item:hover{background-color:#262727!important}.dark .x-sub-menu__menu .x-menu-item.is-active{color:#409eff!important;background-color:#409eff1a!important}.dark .x-sub-menu__arrow{color:#a3a6ad}.dark .x-sub-menu.is-active>.x-sub-menu__title{color:#409eff!important}.dark .x-sub-menu--horizontal .x-sub-menu__title:hover{background-color:transparent!important}.dark .x-sub-menu--horizontal .x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637}.dark .x-sub-menu.is-collapse>.x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637}.dark .header{background-color:#1d1e1f;border-bottom-color:#363637}.dark .header__collapse{color:#cfd3dc}.dark .header__breadcrumb{color:#a3a6ad}.dark .header__user-name{color:#cfd3dc}.dark .header__user-arrow{color:#a3a6ad}.dark .header__action:hover,.dark .header__user-trigger:hover{background-color:#262727}.dark .header__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .header__dropdown-name{color:#e5eaf3}.dark .header__dropdown-role{color:#a3a6ad}.dark .header__dropdown-divider{background-color:#363637}.dark .header__dropdown-item{color:#cfd3dc}.dark .header__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.dark .top-menu{background-color:#1d1e1f}.dark .top-menu__menu{background-color:#1d1e1f!important}.dark .top-menu__menu-char{background-color:#409eff33;color:#79bbff}.dark .top-menu__action{color:#cfd3dc}.dark .top-menu__action:hover{background-color:#262727;color:#409eff}.dark .top-menu__user-trigger:hover{background-color:#262727}.dark .top-menu__user-name{color:#cfd3dc}.dark .top-menu__user-arrow{color:#a3a6ad}.dark .top-menu__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .top-menu__dropdown-name{color:#e5eaf3}.dark .top-menu__dropdown-role{color:#a3a6ad}.dark .top-menu__dropdown-divider{background-color:#363637}.dark .top-menu__dropdown-item{color:#cfd3dc}.dark .top-menu__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.dark .x-button.x-button--default{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-button.x-button--default:hover{border-color:#409eff;color:#409eff}.dark .x-button.x-button--text{color:#409eff}.dark .x-form-item__label{color:#cfd3dc}.dark .x-form-item__error{color:#f56c6c}.dark .x-input{background-color:#1d1e1f;border-color:#4c4d4f}.dark .x-input.is-focus{border-color:#409eff}.dark .x-input .x-input__inner{background-color:transparent;color:#e5eaf3}.dark .x-input .x-input__inner::placeholder{color:#6c6e72}.dark .x-input .x-input__suffix,.dark .x-input .x-input__prefix{color:#a3a6ad}.dark .x-select{background-color:#1d1e1f;border-color:#4c4d4f}.dark .x-card{background-color:#1d1e1f;border-color:#363637}.dark .x-card__header{border-bottom-color:#363637;color:#e5eaf3}.dark .data-table th{background-color:#262727;color:#cfd3dc;border-bottom-color:#363637}.dark .data-table td{border-bottom-color:#363637;color:#cfd3dc}.dark .data-table tr:hover td{background-color:#262727}.dark .x-modal__wrapper{background-color:#000000b3}.dark .x-modal__container{background-color:#1d1e1f;border:1px solid #363637}.dark .x-modal__header{border-bottom-color:#363637;color:#e5eaf3}.dark .x-modal__footer{border-top-color:#363637}.dark .x-message{background-color:#1d1e1f;border:1px solid #363637}.dark .x-tag.x-tag--primary{background-color:#409eff33;color:#79bbff;border-color:#409eff4d}.dark .x-tag.x-tag--success{background-color:#67c23a33;color:#95d475;border-color:#67c23a4d}.dark .x-tag.x-tag--warning{background-color:#e6a23c33;color:#eebe77;border-color:#e6a23c4d}.dark .x-tag.x-tag--danger{background-color:#f56c6c33;color:#fab6b6;border-color:#f56c6c4d}.dark .x-tag.x-tag--info{background-color:#90939933;color:#c0c4cc;border-color:#9093994d}.dark .x-switch{background-color:#4c4d4f}.dark .x-switch.is-checked{background-color:#409eff}.dark .x-pagination{color:#cfd3dc}.dark .x-pagination__item{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-pagination__item:hover{color:#409eff}.dark .x-pagination__item.is-active{background-color:#409eff;border-color:#409eff;color:#fff}.dark .login{background:linear-gradient(135deg,#1a1a2e,#16213e)}.dark .login__container{background-color:#1d1e1f;border:1px solid #363637}.dark .login__title{color:#409eff}.dark .login__subtitle{color:#a3a6ad}.dark .login__footer{color:#6c6e72}.dark .stat-card__title{color:#a3a6ad}.dark .quick-link{background-color:#262727}.dark .quick-link:hover{background-color:#409eff1a}.dark .quick-link__title{color:#cfd3dc}.dark .activity-item{border-bottom-color:#363637}.dark .activity-item__action{color:#cfd3dc}.dark .search-card,.dark .table-card,.dark .x-popconfirm{background-color:#1d1e1f;border:1px solid #363637}.dark .x-drawer{background-color:#1d1e1f}.dark .x-drawer__header{background-color:#1d1e1f;border-bottom-color:#363637;color:#e5eaf3}.dark .x-drawer__body{background-color:#1d1e1f;color:#cfd3dc}.dark .x-drawer__footer{background-color:#1d1e1f;border-top-color:#363637}.dark .settings-drawer .settings-title{color:#e5eaf3}.dark .settings-drawer .settings-section{background-color:transparent}.dark .settings-drawer .layout-option{border-color:#4c4d4f;background-color:transparent}.dark .settings-drawer .layout-option:hover{border-color:#409eff}.dark .settings-drawer .layout-option.is-active{border-color:#409eff;background-color:#409eff1a}.dark .settings-drawer .layout-option__label,.dark .settings-drawer .settings-switch-item span{color:#cfd3dc}.dark .mix-top-menu{background-color:#1d1e1f;border-bottom-color:#363637}.dark .mix-top-menu__logo-text{color:#409eff}.dark .mix-top-menu__menu{background-color:#1d1e1f!important}.dark .mix-top-menu__menu-char{color:#79bbff;background-color:#409eff33}.dark .mix-top-menu__action{color:#cfd3dc}.dark .mix-top-menu__action:hover{background-color:#262727;color:#409eff}.dark .mix-top-menu__user-trigger:hover{background-color:#262727}.dark .mix-top-menu__user-name{color:#cfd3dc}.dark .mix-top-menu__user-arrow{color:#a3a6ad}.dark .mix-top-menu__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .mix-top-menu__dropdown-name{color:#e5eaf3}.dark .mix-top-menu__dropdown-role{color:#a3a6ad}.dark .mix-top-menu__dropdown-divider{background-color:#363637}.dark .mix-top-menu__dropdown-item{color:#cfd3dc}.dark .mix-top-menu__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-ellipsis-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-ellipsis-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-start{display:flex;align-items:center;justify-content:flex-start}.flex-end{display:flex;align-items:center;justify-content:flex-end}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.flex-col{display:flex;flex-direction:column}.flex-col-center{display:flex;flex-direction:column;align-items:center}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.gap-32{gap:32px}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-info{color:var(--color-info)}.text-secondary{color:var(--color-text-secondary)}.text-placeholder{color:var(--color-text-placeholder)}.bg-primary{background-color:var(--color-primary)}.bg-success{background-color:var(--color-success)}.bg-warning{background-color:var(--color-warning)}.bg-danger{background-color:var(--color-danger)}.bg-page{background-color:var(--bg-color-page)}.bg-card{background-color:var(--bg-color)}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.ml-4{margin-left:4px}.ml-8{margin-left:8px}.ml-12{margin-left:12px}.ml-16{margin-left:16px}.mr-4{margin-right:4px}.mr-8{margin-right:8px}.mr-12{margin-right:12px}.mr-16{margin-right:16px}.p-4{padding:4px}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.p-20{padding:20px}.p-24{padding:24px}.p-32{padding:32px}.px-4{padding-left:4px;padding-right:4px}.px-8{padding-left:8px;padding-right:8px}.px-12{padding-left:12px;padding-right:12px}.px-16{padding-left:16px;padding-right:16px}.px-24{padding-left:24px;padding-right:24px}.py-4{padding-top:4px;padding-bottom:4px}.py-8{padding-top:8px;padding-bottom:8px}.py-12{padding-top:12px;padding-bottom:12px}.py-16{padding-top:16px;padding-bottom:16px}.py-24{padding-top:24px;padding-bottom:24px}.card{background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);padding:var(--spacing-lg);transition:box-shadow .3s ease}.card:hover{box-shadow:var(--box-shadow-card-hover)}.card-flat{background-color:var(--bg-color);border-radius:var(--border-radius-large);padding:var(--spacing-lg);border:1px solid var(--color-border-lighter)}.page-container{padding:12px;min-height:100%;background:var(--bg-color-page)}.search-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:12px;padding:12px;background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card)}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--color-border-lighter)}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.table-container{background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.pagination-container{display:flex;justify-content:flex-end;padding:12px;border-top:1px solid var(--color-border-lighter)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:12px;font-weight:500;border-radius:10px;background:var(--color-fill);color:var(--color-text-secondary)}.badge-primary{background:var(--color-primary-light-6);color:var(--color-primary)}.badge-success{background:var(--color-success-lighter);color:var(--color-success)}.badge-warning{background:var(--color-warning-lighter);color:var(--color-warning)}.badge-danger{background:var(--color-danger-lighter);color:var(--color-danger)}.divider{height:1px;background:var(--color-border-lighter);margin:var(--spacing-md) 0}.divider-vertical{width:1px;height:100%;background:var(--color-border-lighter);margin:0 var(--spacing-md)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-placeholder)}.empty-state .empty-icon{width:64px;height:64px;margin-bottom:16px;opacity:.5}.empty-state .empty-text{font-size:14px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-state .loading-spinner{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-state .loading-text{margin-top:16px;font-size:14px;color:var(--color-text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}.link{color:var(--color-primary);text-decoration:none;transition:color .2s ease}.link:hover{color:var(--color-primary-dark-1)}.link-underline{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px}.link-underline:hover{color:var(--color-primary-dark-1)}.x-menu-item.is-active{color:var(--color-primary)!important;background-color:var(--color-primary-light-9)!important;position:relative}.x-menu-item.is-active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary);border-radius:0 2px 2px 0}.x-sub-menu__menu .x-menu-item.is-active{color:var(--color-primary)!important;background-color:var(--color-primary-light-9)!important;position:relative}.x-sub-menu__menu .x-menu-item.is-active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary);border-radius:0 2px 2px 0}html.grey-mode{filter:grayscale(100%);-webkit-filter:grayscale(100%)}:root{--bg-color: #ffffff;--bg-color-page: #f5f7fa;--color-border-lighter: #e4e7ed}.menu-item__content[data-v-d160ae6a]{display:inline-flex;align-items:center;line-height:1}.menu-item__text[data-v-d160ae6a]{flex:1;line-height:1}.menu-item__icon[data-v-d160ae6a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.menu-item__char[data-v-d160ae6a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.sidebar[data-v-50c184da]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color);border-right:1px solid var(--color-border-lighter)}.sidebar--collapsed .sidebar__logo[data-v-50c184da]{justify-content:center;padding:0}.sidebar__logo[data-v-50c184da]{height:50px;display:flex;align-items:center;padding:0 20px;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-50c184da]{width:32px;height:32px}.sidebar__logo-text[data-v-50c184da]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-50c184da]{flex:1;border-right:none;overflow-y:auto}.sidebar__user[data-v-50c184da]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-50c184da]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-50c184da]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-50c184da]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-89179947]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.header__left[data-v-89179947]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-89179947]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-regular);transition:color .2s}.header__collapse[data-v-89179947]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-89179947]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-89179947]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-89179947]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-89179947]{display:flex;align-items:center;gap:8px}.header__search[data-v-89179947]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.header__search-icon[data-v-89179947]{color:var(--color-text-secondary)}.header__search-input[data-v-89179947]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.header__search-input[data-v-89179947]::placeholder{color:var(--color-text-placeholder)}.header__search-dropdown[data-v-89179947]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.header__search-results[data-v-89179947]{padding:8px 0}.header__search-item[data-v-89179947]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.header__search-item[data-v-89179947]:hover{background-color:var(--color-fill)}.header__search-item-title[data-v-89179947]{font-size:14px;color:var(--color-text-primary)}.header__search-item-parent[data-v-89179947]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.header__search-icon[data-v-89179947]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.header__search-char[data-v-89179947]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.header__search-empty[data-v-89179947]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.header__action[data-v-89179947]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.header__action[data-v-89179947]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-89179947]{position:relative;margin-left:8px}.header__user-trigger[data-v-89179947]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.header__user-trigger[data-v-89179947]:hover{background-color:var(--color-fill)}.header__user-name[data-v-89179947]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-89179947]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-89179947]{transform:rotate(180deg)}.header__avatar[data-v-89179947]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.header__dropdown[data-v-89179947]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.header__dropdown-header[data-v-89179947]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-89179947]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.header__dropdown-info[data-v-89179947]{flex:1}.header__dropdown-name[data-v-89179947]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-89179947]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-89179947]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-89179947]{padding:8px 0}.header__dropdown-item[data-v-89179947]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.header__dropdown-item[data-v-89179947]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-89179947]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-89179947]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-89179947]{margin-bottom:24px}.settings-drawer .settings-title[data-v-89179947]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-89179947]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-89179947]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-89179947]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-89179947]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-89179947]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-89179947]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-89179947]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-89179947]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-89179947]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-89179947]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-89179947]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-89179947]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-89179947]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-89179947]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-89179947]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-89179947]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-89179947]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-89179947]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-89179947]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-89179947]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-89179947]{display:flex;gap:12px}.settings-drawer .color-option[data-v-89179947]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-89179947]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-89179947]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-89179947]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-89179947]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-89179947]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-89179947]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-89179947]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-89179947]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-89179947]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-89179947]:after{left:24px}.dropdown-enter-active[data-v-89179947],.dropdown-leave-active[data-v-89179947]{transition:all .2s ease}.dropdown-enter-from[data-v-89179947],.dropdown-leave-to[data-v-89179947]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-89179947],.search-dropdown-leave-active[data-v-89179947]{transition:all .2s ease}.search-dropdown-enter-from[data-v-89179947],.search-dropdown-leave-to[data-v-89179947]{opacity:0;transform:translateY(-4px)}.top-menu[data-v-5c8f8b91]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__logo[data-v-5c8f8b91]{display:flex;align-items:center;gap:10px;margin-right:20px}.top-menu__logo-img[data-v-5c8f8b91]{width:32px;height:32px}.top-menu__logo-text[data-v-5c8f8b91]{font-size:16px;font-weight:600;color:var(--color-primary)}.top-menu__menu[data-v-5c8f8b91]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.top-menu__menu[data-v-5c8f8b91] .x-menu{height:49px;line-height:49px;border-bottom:none}.top-menu__menu[data-v-5c8f8b91] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.top-menu__menu[data-v-5c8f8b91] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-5c8f8b91] .x-menu-item.is-horizontal{height:49px;line-height:49px}.top-menu__menu[data-v-5c8f8b91] .x-menu-item__content{height:49px}.top-menu__menu[data-v-5c8f8b91] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-5c8f8b91] .x-sub-menu--horizontal{height:49px}.top-menu__menu[data-v-5c8f8b91] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-5c8f8b91] .x-sub-menu__content{height:49px}.top-menu__menu-content[data-v-5c8f8b91]{align-items:center;line-height:1}.top-menu__menu-text[data-v-5c8f8b91]{line-height:1}.top-menu__menu-icon[data-v-5c8f8b91]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.top-menu__menu-char[data-v-5c8f8b91]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__actions[data-v-5c8f8b91]{display:flex;align-items:center;gap:8px}.top-menu__search[data-v-5c8f8b91]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.top-menu__search-icon[data-v-5c8f8b91]{color:var(--color-text-secondary)}.top-menu__search-input[data-v-5c8f8b91]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.top-menu__search-input[data-v-5c8f8b91]::placeholder{color:var(--color-text-placeholder)}.top-menu__search-dropdown[data-v-5c8f8b91]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.top-menu__search-results[data-v-5c8f8b91]{padding:8px 0}.top-menu__search-item[data-v-5c8f8b91]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.top-menu__search-item[data-v-5c8f8b91]:hover{background-color:var(--color-fill)}.top-menu__search-item-title[data-v-5c8f8b91]{font-size:14px;color:var(--color-text-primary)}.top-menu__search-item-parent[data-v-5c8f8b91]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.top-menu__search-icon-item[data-v-5c8f8b91]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.top-menu__search-char[data-v-5c8f8b91]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__search-empty[data-v-5c8f8b91]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.top-menu__action[data-v-5c8f8b91]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.top-menu__action[data-v-5c8f8b91]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-5c8f8b91]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-5c8f8b91]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.top-menu__user-trigger[data-v-5c8f8b91]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-5c8f8b91]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-menu__user-arrow[data-v-5c8f8b91]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-5c8f8b91]{transform:rotate(180deg)}.top-menu__avatar[data-v-5c8f8b91]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.top-menu__dropdown[data-v-5c8f8b91]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.top-menu__dropdown-header[data-v-5c8f8b91]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-5c8f8b91]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.top-menu__dropdown-info[data-v-5c8f8b91]{flex:1}.top-menu__dropdown-name[data-v-5c8f8b91]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-5c8f8b91]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-5c8f8b91]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-5c8f8b91]{padding:8px 0}.top-menu__dropdown-item[data-v-5c8f8b91]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.top-menu__dropdown-item[data-v-5c8f8b91]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-5c8f8b91]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-5c8f8b91]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-5c8f8b91]{margin-bottom:24px}.settings-drawer .settings-title[data-v-5c8f8b91]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-5c8f8b91]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-5c8f8b91]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-5c8f8b91]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-5c8f8b91]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-5c8f8b91]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-5c8f8b91]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-5c8f8b91]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-5c8f8b91]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-5c8f8b91]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-5c8f8b91]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-5c8f8b91]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-5c8f8b91]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-5c8f8b91]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-5c8f8b91]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-5c8f8b91]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-5c8f8b91]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-5c8f8b91]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-5c8f8b91]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-5c8f8b91]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-5c8f8b91]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-5c8f8b91]{display:flex;gap:12px}.settings-drawer .color-option[data-v-5c8f8b91]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-5c8f8b91]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-5c8f8b91]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-5c8f8b91]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-5c8f8b91]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-5c8f8b91]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-5c8f8b91]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-5c8f8b91]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-5c8f8b91]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-5c8f8b91]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-5c8f8b91]:after{left:24px}.dropdown-enter-active[data-v-5c8f8b91],.dropdown-leave-active[data-v-5c8f8b91]{transition:all .2s ease}.dropdown-enter-from[data-v-5c8f8b91],.dropdown-leave-to[data-v-5c8f8b91]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-5c8f8b91],.search-dropdown-leave-active[data-v-5c8f8b91]{transition:all .2s ease}.search-dropdown-enter-from[data-v-5c8f8b91],.search-dropdown-leave-to[data-v-5c8f8b91]{opacity:0;transform:translateY(-4px)}.mix-top-menu[data-v-25806305]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.mix-top-menu__logo[data-v-25806305]{display:flex;align-items:center;gap:10px;margin-right:20px}.mix-top-menu__logo-img[data-v-25806305]{width:32px;height:32px}.mix-top-menu__logo-text[data-v-25806305]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__menu[data-v-25806305]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.mix-top-menu__menu[data-v-25806305] .x-menu{height:49px;line-height:49px;border-bottom:none}.mix-top-menu__menu[data-v-25806305] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.mix-top-menu__menu[data-v-25806305] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-25806305] .x-menu-item.is-horizontal{height:49px;line-height:49px}.mix-top-menu__menu[data-v-25806305] .x-menu-item__content{height:49px}.mix-top-menu__menu[data-v-25806305] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-25806305] .x-sub-menu--horizontal{height:49px}.mix-top-menu__menu[data-v-25806305] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-25806305] .x-sub-menu__content{height:49px}.mix-top-menu__menu-content[data-v-25806305]{align-items:center;line-height:1}.mix-top-menu__menu-text[data-v-25806305]{line-height:1}.mix-top-menu__menu-icon[data-v-25806305]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.mix-top-menu__menu-char[data-v-25806305]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__actions[data-v-25806305]{display:flex;align-items:center;gap:8px}.mix-top-menu__search[data-v-25806305]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.mix-top-menu__search-icon[data-v-25806305]{color:var(--color-text-secondary)}.mix-top-menu__search-input[data-v-25806305]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.mix-top-menu__search-input[data-v-25806305]::placeholder{color:var(--color-text-placeholder)}.mix-top-menu__search-dropdown[data-v-25806305]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.mix-top-menu__search-results[data-v-25806305]{padding:8px 0}.mix-top-menu__search-item[data-v-25806305]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.mix-top-menu__search-item[data-v-25806305]:hover{background-color:var(--color-fill)}.mix-top-menu__search-item-title[data-v-25806305]{font-size:14px;color:var(--color-text-primary)}.mix-top-menu__search-item-parent[data-v-25806305]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.mix-top-menu__search-icon-item[data-v-25806305]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.mix-top-menu__search-char[data-v-25806305]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__search-empty[data-v-25806305]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.mix-top-menu__action[data-v-25806305]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.mix-top-menu__action[data-v-25806305]:hover{background-color:var(--color-fill);color:var(--color-primary)}.mix-top-menu__user[data-v-25806305]{position:relative;margin-left:8px}.mix-top-menu__user-trigger[data-v-25806305]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.mix-top-menu__user-trigger[data-v-25806305]:hover{background-color:var(--color-fill)}.mix-top-menu__user-name[data-v-25806305]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mix-top-menu__user-arrow[data-v-25806305]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.mix-top-menu__user-arrow.is-active[data-v-25806305]{transform:rotate(180deg)}.mix-top-menu__avatar[data-v-25806305]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.mix-top-menu__dropdown[data-v-25806305]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.mix-top-menu__dropdown-header[data-v-25806305]{display:flex;align-items:center;gap:12px;padding:16px}.mix-top-menu__dropdown-avatar[data-v-25806305]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.mix-top-menu__dropdown-info[data-v-25806305]{flex:1}.mix-top-menu__dropdown-name[data-v-25806305]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.mix-top-menu__dropdown-role[data-v-25806305]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.mix-top-menu__dropdown-divider[data-v-25806305]{height:1px;background-color:var(--color-border-lighter)}.mix-top-menu__dropdown-menu[data-v-25806305]{padding:8px 0}.mix-top-menu__dropdown-item[data-v-25806305]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.mix-top-menu__dropdown-item[data-v-25806305]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.mix-top-menu__dropdown-item--danger[data-v-25806305]{color:var(--color-danger)}.mix-top-menu__dropdown-item--danger[data-v-25806305]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-25806305]{margin-bottom:24px}.settings-drawer .settings-title[data-v-25806305]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-25806305]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-25806305]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-25806305]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-25806305]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-25806305]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-25806305]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-25806305]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-25806305]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-25806305]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-25806305]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-25806305]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-25806305]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-25806305]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-25806305]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-25806305]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-25806305]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-25806305]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-25806305]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-25806305]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-25806305]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-25806305]{display:flex;gap:12px}.settings-drawer .color-option[data-v-25806305]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-25806305]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-25806305]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-25806305]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-25806305]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-25806305]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-25806305]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-25806305]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-25806305]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-25806305]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-25806305]:after{left:24px}.dropdown-enter-active[data-v-25806305],.dropdown-leave-active[data-v-25806305]{transition:all .2s ease}.dropdown-enter-from[data-v-25806305],.dropdown-leave-to[data-v-25806305]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-25806305],.search-dropdown-leave-active[data-v-25806305]{transition:all .2s ease}.search-dropdown-enter-from[data-v-25806305],.search-dropdown-leave-to[data-v-25806305]{opacity:0;transform:translateY(-4px)}.layout[data-v-24c73186]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-24c73186]{flex-direction:row}.layout--sidebar .layout__aside[data-v-24c73186]{height:100%}.layout--sidebar .layout__main[data-v-24c73186]{flex:1;display:flex;flex-direction:column;height:100%}.layout--top[data-v-24c73186]{flex-direction:column}.layout--top .layout__main[data-v-24c73186]{flex:1;display:flex;flex-direction:column;height:calc(100% - 50px)}.layout--top .layout__content[data-v-24c73186]{flex:1}.layout--mix[data-v-24c73186]{flex-direction:column}.layout--mix .layout__mix-top-menu[data-v-24c73186]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout--mix .layout__mix-body[data-v-24c73186]{flex:1;display:flex;flex-direction:row;height:calc(100% - 50px)}.layout__aside[data-v-24c73186]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-24c73186]{width:100%;height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__mix-top-menu[data-v-24c73186]{width:100%;height:50px;box-sizing:border-box;flex-shrink:0}.layout__main[data-v-24c73186]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-24c73186]{height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-24c73186]{flex:1;overflow:auto;background-color:var(--bg-color-page);padding:0}.tabs-wrapper[data-v-9156d8cd]{width:100%;height:100%;padding:0 10px}.tabs-wrapper[data-v-9156d8cd] .t-tabs{height:100%}.tabs-wrapper[data-v-9156d8cd] .t-tabs__header{margin:0;border-bottom:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__nav{border:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item{height:32px;line-height:32px;border:1px solid var(--color-border-lighter);margin-right:5px;border-radius:var(--border-radius-base);padding:0 15px}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item.is-active{background-color:var(--color-primary-light-9);border-color:var(--color-primary)}.tab-label[data-v-9156d8cd]{display:flex;align-items:center;gap:5px}.tab-close[data-v-9156d8cd]{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:50%}.tab-close[data-v-9156d8cd]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.footer[data-v-4852826a]{width:100%;text-align:center;font-size:12px;color:var(--color-text-secondary)}.login-page[data-v-102cb5d3]{width:100%;min-height:100vh;display:flex;background:var(--bg-color-page)}.login-brand[data-v-102cb5d3]{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#002c8c,#0958d9,#1677ff);overflow:hidden}@media (max-width: 992px){.login-brand[data-v-102cb5d3]{display:none}}.login-brand .brand-content[data-v-102cb5d3]{position:relative;z-index:2;padding:60px;max-width:520px;color:#fff}.login-brand .brand-logo[data-v-102cb5d3]{display:flex;align-items:center;gap:12px;margin-bottom:48px}.login-brand .brand-logo .logo-icon[data-v-102cb5d3]{width:48px;height:48px;color:#fff}.login-brand .brand-logo .logo-text[data-v-102cb5d3]{font-size:28px;font-weight:700;letter-spacing:2px}.login-brand .brand-slogan[data-v-102cb5d3]{margin-bottom:48px}.login-brand .brand-slogan h1[data-v-102cb5d3]{font-size:32px;font-weight:600;line-height:1.3;margin-bottom:12px}.login-brand .brand-slogan p[data-v-102cb5d3]{font-size:16px;opacity:.8;line-height:1.6}.login-brand .brand-features[data-v-102cb5d3]{display:flex;flex-direction:column;gap:24px}.login-brand .brand-features .feature-item[data-v-102cb5d3]{display:flex;align-items:flex-start;gap:16px;padding:16px;background:#ffffff1a;border-radius:var(--border-radius-large);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.login-brand .brand-features .feature-item[data-v-102cb5d3]:hover{background:#ffffff26;transform:translate(8px)}.login-brand .brand-features .feature-icon[data-v-102cb5d3]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:var(--border-radius-base);flex-shrink:0}.login-brand .brand-features .feature-icon svg[data-v-102cb5d3]{width:20px;height:20px}.login-brand .brand-features .feature-text h4[data-v-102cb5d3]{font-size:15px;font-weight:600;margin-bottom:4px}.login-brand .brand-features .feature-text p[data-v-102cb5d3]{font-size:13px;opacity:.8}.login-brand .brand-decoration[data-v-102cb5d3]{position:absolute;bottom:60px;left:60px;right:60px;display:flex;align-items:center;gap:16px}.login-brand .brand-decoration .decoration-line[data-v-102cb5d3]{flex:1;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.3),transparent)}.login-brand .brand-decoration .decoration-dots[data-v-102cb5d3]{display:flex;gap:8px}.login-brand .brand-decoration .decoration-dots span[data-v-102cb5d3]{width:6px;height:6px;background:#ffffff80;border-radius:50%}.login-brand .brand-bg[data-v-102cb5d3]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.login-brand .brand-bg .bg-grid[data-v-102cb5d3]{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px}.login-brand .brand-bg .bg-glow[data-v-102cb5d3]{position:absolute;top:-20%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:glow-pulse-102cb5d3 8s ease-in-out infinite}.login-brand .brand-bg .bg-pattern[data-v-102cb5d3]{position:absolute;bottom:-10%;left:-10%;width:40%;height:40%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 60%)}@keyframes glow-pulse-102cb5d3{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.login-form-section[data-v-102cb5d3]{width:500px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:60px 80px;background:var(--bg-color)}@media (max-width: 768px){.login-form-section[data-v-102cb5d3]{width:100%;padding:40px 24px}}.login-form-section .form-container[data-v-102cb5d3]{width:100%;max-width:360px;margin:0 auto}.login-form-section .form-header[data-v-102cb5d3]{margin-bottom:40px}.login-form-section .form-header h2[data-v-102cb5d3]{font-size:28px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.login-form-section .form-header p[data-v-102cb5d3]{font-size:14px;color:var(--color-text-secondary)}.login-form-section .login-form .input-wrapper[data-v-102cb5d3]{margin-bottom:4px}.login-form-section .login-form .input-label[data-v-102cb5d3]{display:block;font-size:14px;font-weight:500;color:var(--color-text-regular);margin-bottom:8px}.login-form-section .login-form[data-v-102cb5d3] .x-form-item{margin-bottom:24px}.login-form-section .login-form[data-v-102cb5d3] .x-input{--x-input-border-radius: 8px}.login-form-section .login-form[data-v-102cb5d3] .x-input__prefix{margin-right:12px;color:var(--color-text-placeholder)}.login-form-section .form-options[data-v-102cb5d3]{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.login-form-section .form-options .forgot-link[data-v-102cb5d3]{font-size:14px;color:var(--color-primary);text-decoration:none;transition:color .2s}.login-form-section .form-options .forgot-link[data-v-102cb5d3]:hover{color:var(--color-primary-dark-1)}.login-form-section .login-btn[data-v-102cb5d3]{width:100%;height:44px;font-size:16px;font-weight:500;border-radius:8px;letter-spacing:4px;transition:all .3s ease}.login-form-section .login-btn[data-v-102cb5d3]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1677ff66}.login-form-section .login-btn[data-v-102cb5d3]:active:not(:disabled){transform:translateY(0)}.login-form-section .form-footer[data-v-102cb5d3]{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border-lighter);text-align:center}.login-form-section .form-footer p[data-v-102cb5d3]{font-size:13px;color:var(--color-text-placeholder);margin-bottom:16px}.login-form-section .form-footer .social-login[data-v-102cb5d3]{display:flex;justify-content:center;gap:16px}.login-form-section .form-footer .social-btn[data-v-102cb5d3]{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-fill);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;color:var(--color-text-secondary)}.login-form-section .form-footer .social-btn svg[data-v-102cb5d3]{width:20px;height:20px}.login-form-section .form-footer .social-btn[data-v-102cb5d3]:hover{background:var(--color-primary-light-6);color:var(--color-primary);transform:translateY(-2px)}.login-form-section .copyright[data-v-102cb5d3]{margin-top:48px;text-align:center}.login-form-section .copyright p[data-v-102cb5d3]{font-size:12px;color:var(--color-text-placeholder)}.error-page[data-v-1b083153]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-color-page);position:relative;overflow:hidden}.error-container[data-v-1b083153]{position:relative;z-index:2;max-width:600px;padding:40px}.error-bg[data-v-1b083153]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.error-bg .bg-circle[data-v-1b083153]{position:absolute;border-radius:50%;opacity:.1}.error-bg .bg-circle.circle-1[data-v-1b083153]{width:400px;height:400px;top:-100px;right:-100px;background:var(--color-primary)}.error-bg .bg-circle.circle-2[data-v-1b083153]{width:300px;height:300px;bottom:-50px;left:-50px;background:var(--color-info)}.error-bg .bg-circle.circle-3[data-v-1b083153]{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-primary-light-3)}.error-content[data-v-1b083153]{text-align:center}.error-code[data-v-1b083153]{display:flex;justify-content:center;align-items:center;gap:8px;margin-bottom:32px}.error-code .code-digit[data-v-1b083153]{font-size:80px;font-weight:700;color:var(--color-text-primary);line-height:1}.error-code .code-zero[data-v-1b083153]{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light-1) 100%);border-radius:50%}.error-code .code-zero .zero-inner[data-v-1b083153]{font-size:48px;font-weight:700;color:#fff}.error-illustration[data-v-1b083153]{width:200px;height:120px;margin:0 auto 24px}.error-title[data-v-1b083153]{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.error-desc[data-v-1b083153]{font-size:14px;color:var(--color-text-secondary);margin-bottom:32px}.error-actions[data-v-1b083153]{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.error-actions[data-v-1b083153] .x-button{padding:12px 24px;border-radius:8px}.error-actions[data-v-1b083153] .x-button svg{width:18px;height:18px;margin-right:8px}.error-tip[data-v-1b083153]{padding:20px;background:var(--color-fill-light);border-radius:var(--border-radius-large)}.error-tip p[data-v-1b083153]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.error-tip ul[data-v-1b083153]{list-style:none;padding:0;margin:0}.error-tip ul li[data-v-1b083153]{font-size:13px;color:var(--color-text-secondary);position:relative;padding:4px 0 4px 16px}.error-tip ul li[data-v-1b083153]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--color-primary);border-radius:50%;opacity:.6}.error-page[data-v-d167f981]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-color-page);position:relative;overflow:hidden}.error-container[data-v-d167f981]{position:relative;z-index:2;max-width:600px;padding:40px}.error-bg[data-v-d167f981]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.error-bg .bg-circle[data-v-d167f981]{position:absolute;border-radius:50%;opacity:.1}.error-bg .bg-circle.circle-1[data-v-d167f981]{width:400px;height:400px;top:-100px;right:-100px;background:var(--color-warning)}.error-bg .bg-circle.circle-2[data-v-d167f981]{width:300px;height:300px;bottom:-50px;left:-50px;background:var(--color-warning)}.error-bg .bg-circle.circle-3[data-v-d167f981]{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-warning-light)}.error-content[data-v-d167f981]{text-align:center}.error-code[data-v-d167f981]{display:flex;justify-content:center;align-items:center;gap:8px;margin-bottom:32px}.error-code .code-digit[data-v-d167f981]{font-size:80px;font-weight:700;color:var(--color-text-primary);line-height:1}.error-code .code-zero[data-v-d167f981]{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-warning-light) 100%);border-radius:50%}.error-code .code-zero .zero-inner[data-v-d167f981]{font-size:48px;font-weight:700;color:#fff}.error-illustration[data-v-d167f981]{width:200px;height:120px;margin:0 auto 24px}.error-title[data-v-d167f981]{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.error-desc[data-v-d167f981]{font-size:14px;color:var(--color-text-secondary);margin-bottom:32px}.error-actions[data-v-d167f981]{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.error-actions[data-v-d167f981] .x-button{padding:12px 24px;border-radius:8px}.error-actions[data-v-d167f981] .x-button svg{width:18px;height:18px;margin-right:8px}.error-tip[data-v-d167f981]{padding:20px;background:var(--color-warning-lighter);border-radius:var(--border-radius-large)}.error-tip p[data-v-d167f981]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.error-tip ul[data-v-d167f981]{list-style:none;padding:0;margin:0}.error-tip ul li[data-v-d167f981]{font-size:13px;color:var(--color-text-secondary);position:relative;padding:4px 0 4px 16px}.error-tip ul li[data-v-d167f981]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--color-warning);border-radius:50%;opacity:.6}.dashboard[data-v-545d4c27]{padding:24px;background:var(--bg-color-page);min-height:100%}.stats-section[data-v-545d4c27]{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}@media (max-width: 1200px){.stats-section[data-v-545d4c27]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.stats-section[data-v-545d4c27]{grid-template-columns:1fr}}.stat-card[data-v-545d4c27]{position:relative;display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);transition:all .3s ease;overflow:hidden}.stat-card[data-v-545d4c27]:hover{box-shadow:var(--box-shadow-card-hover);transform:translateY(-4px)}.stat-card:hover .stat-decoration[data-v-545d4c27]{opacity:1}.stat-card .stat-icon[data-v-545d4c27]{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-large);flex-shrink:0}.stat-card .stat-icon span[data-v-545d4c27]{font-size:26px}.stat-card .stat-content[data-v-545d4c27]{flex:1;min-width:0}.stat-card .stat-title[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary);margin-bottom:8px}.stat-card .stat-value[data-v-545d4c27]{font-size:28px;font-weight:600;line-height:1.2;margin-bottom:8px}.stat-card .stat-trend[data-v-545d4c27]{display:inline-flex;align-items:center;gap:4px;font-size:12px;padding:2px 8px;border-radius:12px}.stat-card .stat-trend svg[data-v-545d4c27]{width:14px;height:14px}.stat-card .stat-trend.up[data-v-545d4c27]{color:var(--color-success);background:var(--color-success-lighter)}.stat-card .stat-trend.down[data-v-545d4c27]{color:var(--color-danger);background:var(--color-danger-lighter)}.stat-card .stat-decoration[data-v-545d4c27]{position:absolute;top:0;right:0;width:100px;height:100px;border-radius:50%;opacity:0;transition:opacity .3s ease}.main-section[data-v-545d4c27]{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}@media (max-width: 992px){.main-section[data-v-545d4c27]{grid-template-columns:1fr}}.section-header[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3[data-v-545d4c27]{font-size:16px;font-weight:600;color:var(--color-text-primary)}.section-header .section-badge[data-v-545d4c27]{font-size:12px;color:var(--color-text-placeholder);background:var(--color-fill);padding:4px 10px;border-radius:12px}.section-header .section-link[data-v-545d4c27]{font-size:14px;color:var(--color-primary);text-decoration:none;transition:color .2s}.section-header .section-link[data-v-545d4c27]:hover{color:var(--color-primary-dark-1)}.quick-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.quick-grid[data-v-545d4c27]{display:flex;flex-direction:column;gap:12px}.quick-card[data-v-545d4c27]{display:flex;align-items:center;gap:16px;padding:16px;background:var(--color-fill-light);border-radius:var(--border-radius-base);text-decoration:none;transition:all .2s ease}.quick-card[data-v-545d4c27]:hover{background:var(--color-primary-light-6);transform:translate(4px)}.quick-card:hover .quick-arrow[data-v-545d4c27]{color:var(--color-primary);transform:translate(4px)}.quick-card .quick-icon[data-v-545d4c27]{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-color);border-radius:var(--border-radius-base);font-size:22px;flex-shrink:0}.quick-card .quick-info[data-v-545d4c27]{flex:1;min-width:0}.quick-card .quick-title[data-v-545d4c27]{font-size:15px;font-weight:500;color:var(--color-text-primary);margin-bottom:4px}.quick-card .quick-desc[data-v-545d4c27]{font-size:13px;color:var(--color-text-secondary)}.quick-card .quick-arrow[data-v-545d4c27]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-text-placeholder);transition:all .2s ease}.quick-card .quick-arrow svg[data-v-545d4c27]{width:16px;height:16px}.activity-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.activity-list[data-v-545d4c27]{display:flex;flex-direction:column}.activity-item[data-v-545d4c27]{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--color-border-lighter);position:relative}.activity-item[data-v-545d4c27]:last-child{border-bottom:none}.activity-avatar[data-v-545d4c27]{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;font-weight:500;flex-shrink:0}.activity-avatar.success[data-v-545d4c27]{background:var(--color-success-lighter);color:var(--color-success)}.activity-avatar.warning[data-v-545d4c27]{background:var(--color-warning-lighter);color:var(--color-warning)}.activity-avatar.info[data-v-545d4c27]{background:var(--color-info-lighter);color:var(--color-info)}.activity-avatar.danger[data-v-545d4c27]{background:var(--color-danger-lighter);color:var(--color-danger)}.activity-avatar.primary[data-v-545d4c27]{background:var(--color-primary-light-6);color:var(--color-primary)}.activity-content[data-v-545d4c27]{flex:1;min-width:0}.activity-main[data-v-545d4c27]{margin-bottom:4px}.activity-user[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-right:8px}.activity-action[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.activity-time[data-v-545d4c27]{font-size:12px;color:var(--color-text-placeholder)}.activity-dot[data-v-545d4c27]{position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;opacity:.6}.activity-dot.success[data-v-545d4c27]{background:var(--color-success)}.activity-dot.warning[data-v-545d4c27]{background:var(--color-warning)}.activity-dot.info[data-v-545d4c27]{background:var(--color-info)}.activity-dot.danger[data-v-545d4c27]{background:var(--color-danger)}.activity-dot.primary[data-v-545d4c27]{background:var(--color-primary)}.system-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.system-grid[data-v-545d4c27]{display:grid;grid-template-columns:1fr 1.5fr;gap:24px}@media (max-width: 768px){.system-grid[data-v-545d4c27]{grid-template-columns:1fr}}.system-info-list[data-v-545d4c27]{display:flex;flex-direction:column;gap:12px}.info-item[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-fill-light);border-radius:var(--border-radius-base)}.info-item .info-label[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.info-item .info-value[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.system-status[data-v-545d4c27]{display:flex;flex-direction:column;gap:16px}.status-item .status-header[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.status-item .status-label[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.status-item .status-value[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.user-page[data-v-5d3ed390]{padding:24px;background:var(--bg-color-page);min-height:100%}.search-section[data-v-5d3ed390]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px 24px;margin-bottom:16px;box-shadow:var(--box-shadow-card)}.search-section .search-form[data-v-5d3ed390]{display:flex;flex-wrap:wrap;gap:16px}.search-section .search-form[data-v-5d3ed390] .x-form-item{margin-bottom:0}.search-section .search-form[data-v-5d3ed390] .x-input,.search-section .search-form[data-v-5d3ed390] .x-select{width:200px}.table-section[data-v-5d3ed390]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-5d3ed390]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-5d3ed390]{display:flex;gap:12px}.table-toolbar .table-count[data-v-5d3ed390]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-5d3ed390]{overflow-x:auto}.data-table[data-v-5d3ed390]{width:100%;border-collapse:collapse}.data-table th[data-v-5d3ed390],.data-table td[data-v-5d3ed390]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-5d3ed390]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-5d3ed390]{transition:background-color .2s}.data-table .data-row[data-v-5d3ed390]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-5d3ed390]{vertical-align:middle}.data-table .loading-cell[data-v-5d3ed390],.data-table .empty-cell[data-v-5d3ed390]{padding:60px 20px}.data-table .loading-content[data-v-5d3ed390],.data-table .empty-content[data-v-5d3ed390]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-5d3ed390],.data-table .empty-content svg[data-v-5d3ed390]{width:64px;height:41px}.data-table .loading-spinner[data-v-5d3ed390]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-5d3ed390 .8s linear infinite}@keyframes spin-5d3ed390{to{transform:rotate(360deg)}}.col-id[data-v-5d3ed390]{width:80px}.id-badge[data-v-5d3ed390]{display:inline-block;min-width:32px;padding:4px 10px;background:var(--color-fill);border-radius:12px;font-size:12px;font-weight:500;color:var(--color-text-secondary);text-align:center}.col-user[data-v-5d3ed390]{min-width:180px}.user-info[data-v-5d3ed390]{display:flex;align-items:center;gap:12px}.user-avatar[data-v-5d3ed390]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light-1) 100%);border-radius:50%;font-size:16px;font-weight:500;color:#fff;flex-shrink:0}.user-detail[data-v-5d3ed390]{display:flex;flex-direction:column;gap:2px}.user-nickname[data-v-5d3ed390]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.user-username[data-v-5d3ed390]{font-size:12px;color:var(--color-text-placeholder)}.col-contact[data-v-5d3ed390]{min-width:180px}.contact-info[data-v-5d3ed390]{display:flex;flex-direction:column;gap:4px}.contact-email[data-v-5d3ed390],.contact-phone[data-v-5d3ed390]{font-size:13px;color:var(--color-text-regular)}.contact-phone[data-v-5d3ed390]{color:var(--color-text-secondary)}.col-roles[data-v-5d3ed390]{min-width:100px}.role-tags[data-v-5d3ed390]{display:flex;gap:6px}.col-status[data-v-5d3ed390]{min-width:120px}.status-switch[data-v-5d3ed390]{display:flex;align-items:center;gap:8px}.status-text[data-v-5d3ed390]{font-size:13px;color:var(--color-text-secondary)}.status-text.enabled[data-v-5d3ed390]{color:var(--color-success)}.col-time[data-v-5d3ed390]{min-width:160px}.time-text[data-v-5d3ed390]{font-size:13px;color:var(--color-text-secondary)}.col-actions[data-v-5d3ed390]{min-width:140px}.action-buttons[data-v-5d3ed390] .x-button{padding:4px 8px}.action-buttons[data-v-5d3ed390] .x-button svg{width:14px;height:14px;margin-right:4px}.pagination-wrapper[data-v-5d3ed390]{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--color-border-lighter)}.user-form[data-v-5d3ed390]{padding:16px 0}.user-form .status-field[data-v-5d3ed390]{display:flex;align-items:center;gap:12px}.user-form .status-label[data-v-5d3ed390]{font-size:14px;color:var(--color-text-secondary)}.role-page[data-v-de354764]{padding:24px;background:var(--bg-color-page);min-height:100%}.search-section[data-v-de354764]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px 24px;margin-bottom:16px;box-shadow:var(--box-shadow-card)}.search-section .search-form[data-v-de354764]{display:flex;flex-wrap:wrap;gap:16px}.search-section .search-form[data-v-de354764] .x-form-item{margin-bottom:0}.search-section .search-form[data-v-de354764] .x-input,.search-section .search-form[data-v-de354764] .x-select{width:200px}.table-section[data-v-de354764]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-de354764]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-de354764]{display:flex;gap:12px}.table-toolbar .table-count[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-de354764]{overflow-x:auto}.data-table[data-v-de354764]{width:100%;border-collapse:collapse}.data-table th[data-v-de354764],.data-table td[data-v-de354764]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-de354764]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-de354764]{transition:background-color .2s}.data-table .data-row[data-v-de354764]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-de354764]{vertical-align:middle}.data-table .loading-cell[data-v-de354764],.data-table .empty-cell[data-v-de354764]{padding:60px 20px}.data-table .loading-content[data-v-de354764],.data-table .empty-content[data-v-de354764]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-de354764],.data-table .empty-content svg[data-v-de354764]{width:64px;height:41px}.data-table .loading-spinner[data-v-de354764]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-de354764 .8s linear infinite}@keyframes spin-de354764{to{transform:rotate(360deg)}}.col-id[data-v-de354764]{width:80px}.id-badge[data-v-de354764]{display:inline-block;min-width:32px;padding:4px 10px;background:var(--color-fill);border-radius:12px;font-size:12px;font-weight:500;color:var(--color-text-secondary);text-align:center}.col-name[data-v-de354764]{min-width:120px}.role-name[data-v-de354764]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.col-code[data-v-de354764]{min-width:100px}.col-desc[data-v-de354764]{min-width:150px}.desc-text[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.col-status[data-v-de354764]{min-width:120px}.status-switch[data-v-de354764]{display:flex;align-items:center;gap:8px}.status-text[data-v-de354764]{font-size:13px;color:var(--color-text-secondary)}.status-text.enabled[data-v-de354764]{color:var(--color-success)}.col-time[data-v-de354764]{min-width:160px}.time-text[data-v-de354764]{font-size:13px;color:var(--color-text-secondary)}.col-actions[data-v-de354764]{min-width:140px}.action-buttons[data-v-de354764] .x-button{padding:4px 8px}.action-buttons[data-v-de354764] .x-button svg{width:14px;height:14px;margin-right:4px}.pagination-wrapper[data-v-de354764]{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--color-border-lighter)}.role-form[data-v-de354764]{padding:16px 0}.role-form .status-field[data-v-de354764]{display:flex;align-items:center;gap:12px}.role-form .status-label[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.menu-page[data-v-e7cc9235]{padding:24px;background:var(--bg-color-page);min-height:100%}.table-section[data-v-e7cc9235]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-e7cc9235]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-e7cc9235]{display:flex;gap:12px}.table-toolbar .table-count[data-v-e7cc9235]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-e7cc9235]{overflow-x:auto}.data-table[data-v-e7cc9235]{width:100%;border-collapse:collapse}.data-table th[data-v-e7cc9235],.data-table td[data-v-e7cc9235]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-e7cc9235]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-e7cc9235]{transition:background-color .2s}.data-table .data-row[data-v-e7cc9235]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-e7cc9235]{vertical-align:middle}.data-table .loading-cell[data-v-e7cc9235],.data-table .empty-cell[data-v-e7cc9235]{padding:60px 20px}.data-table .loading-content[data-v-e7cc9235],.data-table .empty-content[data-v-e7cc9235]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-e7cc9235],.data-table .empty-content svg[data-v-e7cc9235]{width:64px;height:41px}.data-table .loading-spinner[data-v-e7cc9235]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-e7cc9235 .8s linear infinite}@keyframes spin-e7cc9235{to{transform:rotate(360deg)}}.tree-row--level-1 .col-name[data-v-e7cc9235]{padding-left:40px}.tree-indent[data-v-e7cc9235]{display:inline-block;width:24px}.tree-line[data-v-e7cc9235]{position:relative;display:inline-block;width:16px;height:1px;background:var(--color-border-light);margin-right:8px;vertical-align:middle}.col-name[data-v-e7cc9235]{min-width:200px}.menu-info[data-v-e7cc9235]{display:flex;align-items:center;gap:8px}.menu-icon-wrapper[data-v-e7cc9235]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-fill-light);border-radius:6px;font-size:14px}.menu-title[data-v-e7cc9235]{font-size:14px;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:color .2s}.menu-title[data-v-e7cc9235]:hover{color:var(--color-primary)}.col-icon[data-v-e7cc9235]{width:80px}.icon-text[data-v-e7cc9235]{font-size:16px}.col-path[data-v-e7cc9235]{min-width:140px}.path-code[data-v-e7cc9235]{font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;padding:4px 8px;background:var(--color-fill-light);border-radius:4px;color:var(--color-text-secondary)}.col-type[data-v-e7cc9235]{width:80px}.col-sort[data-v-e7cc9235]{width:60px}.sort-badge[data-v-e7cc9235]{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--color-fill);border-radius:12px;font-size:12px;color:var(--color-text-secondary)}.col-status[data-v-e7cc9235]{width:80px}.col-actions[data-v-e7cc9235]{min-width:140px}.action-buttons[data-v-e7cc9235] .x-button{padding:4px 8px}.action-buttons[data-v-e7cc9235] .x-button svg{width:14px;height:14px;margin-right:4px}.menu-form[data-v-e7cc9235]{padding:16px 0}.menu-form .form-grid[data-v-e7cc9235]{display:grid;grid-template-columns:repeat(2,1fr);gap:0 24px}.menu-form .form-item-full[data-v-e7cc9235]{grid-column:span 2}.menu-form .status-field[data-v-e7cc9235]{display:flex;align-items:center;gap:12px}.menu-form .status-label[data-v-e7cc9235]{font-size:14px;color:var(--color-text-secondary)}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Token 管理
3
+ */
4
+ export interface TokenInfo {
5
+ access_token: string;
6
+ token_type: string;
7
+ refresh_token: string;
8
+ expires_time: number;
9
+ refresh_time: number;
10
+ code?: string;
11
+ }
12
+ export declare const getToken: () => string | null;
13
+ export declare const setToken: (token: string) => void;
14
+ export declare const getTokenType: () => string | null;
15
+ export declare const setTokenType: (tokenType: string) => void;
16
+ export declare const getRefreshToken: () => string | null;
17
+ export declare const setRefreshToken: (refreshToken: string) => void;
18
+ export declare const getTokenExpire: () => number | null;
19
+ export declare const setTokenExpire: (expireTime: number) => void;
20
+ export declare const getRefreshTime: () => number | null;
21
+ export declare const setRefreshTime: (refreshTime: number) => void;
22
+ export declare const getCode: () => string | null;
23
+ export declare const setCode: (code: string) => void;
24
+ export declare const setTokenInfo: (info: TokenInfo) => void;
25
+ export declare const clearToken: () => void;
26
+ export declare const isTokenExpired: () => boolean;
27
+ export declare const hasToken: () => boolean;