xto-fronted 0.2.5 → 0.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.development +4 -0
- package/.env.production +4 -0
- package/README.md +94 -196
- package/dist/{components/Layout/TopMenu.vue.d.ts → App.vue.d.ts} +1 -1
- package/dist/api/auth.d.ts +8 -10
- package/dist/api/system.d.ts +11 -12
- package/dist/api/user.d.ts +12 -3
- package/dist/components/Layout/Footer.vue.d.ts +1 -1
- package/dist/components/Layout/Header.vue.d.ts +3 -14
- package/dist/components/Layout/Sidebar.vue.d.ts +1 -1
- package/dist/components/Layout/Tabs.vue.d.ts +1 -1
- package/dist/components/Layout/index.vue.d.ts +1 -1
- package/dist/composables/useAuth.d.ts +4 -19
- package/dist/directives/permission.d.ts +0 -1
- package/dist/index-CWRs4WMN.js +372 -0
- package/dist/index-CpxpXTQX.js +1462 -0
- package/dist/index-Cu3Z2-PY.js +345 -0
- package/dist/index-DPEVEyik.js +475 -0
- package/dist/index-DYnXaqYf.js +142 -0
- package/dist/index.d.ts +12 -25
- package/dist/index.es.js +76 -1521
- package/dist/index.umd.js +1 -20
- package/dist/main.d.ts +0 -1
- package/dist/router/dynamicRoutes.d.ts +33 -17
- package/dist/router/index.d.ts +4 -26
- package/dist/router/layoutRoute.d.ts +18 -0
- package/dist/router/staticRoutes.d.ts +2 -18
- package/dist/setup.d.ts +17 -0
- package/dist/stores/app.d.ts +15 -9
- package/dist/stores/auth.d.ts +48 -62
- package/dist/stores/index.d.ts +3 -1
- package/dist/stores/menu.d.ts +29 -47
- package/dist/stores/user.d.ts +84 -64
- package/dist/style.css +1 -1
- package/dist/utils/auth.d.ts +10 -10
- package/dist/utils/permission.d.ts +10 -1
- package/dist/utils/request.d.ts +7 -23
- package/dist/{components/Layout/Breadcrumb.vue.d.ts → views/dashboard/index.vue.d.ts} +1 -1
- package/dist/{components/Error → views/error}/403.vue.d.ts +1 -1
- package/dist/{components/Error → views/error}/404.vue.d.ts +1 -1
- package/dist/views/login/index.vue.d.ts +4 -0
- package/dist/views/system/menu/index.vue.d.ts +4 -0
- package/dist/views/system/role/index.vue.d.ts +4 -0
- package/dist/views/system/user/index.vue.d.ts +4 -0
- package/dist/vite.svg +9 -9
- package/index.html +13 -0
- package/package.json +27 -31
- package/public/vite.svg +10 -0
- package/src/App.vue +20 -0
- package/src/api/auth.ts +26 -0
- package/src/api/system.ts +65 -0
- package/src/api/user.ts +46 -0
- package/src/assets/styles/_dark.scss +407 -0
- package/src/assets/styles/_reset.scss +126 -0
- package/src/assets/styles/_root.scss +140 -0
- package/src/assets/styles/_transition.scss +119 -0
- package/src/assets/styles/_variables.scss +45 -0
- package/src/assets/styles/index.scss +187 -0
- package/src/components/Layout/Footer.vue +17 -0
- package/src/components/Layout/Header.vue +390 -0
- package/src/components/Layout/Sidebar.vue +297 -0
- package/src/components/Layout/Tabs.vue +134 -0
- package/src/components/Layout/index.vue +62 -0
- package/src/composables/useAuth.ts +45 -0
- package/src/composables/useForm.ts +79 -0
- package/src/composables/useTable.ts +97 -0
- package/src/directives/permission.ts +38 -0
- package/src/enums/index.ts +63 -0
- package/src/env.d.ts +17 -0
- package/src/index.ts +48 -0
- package/src/main.ts +34 -0
- package/src/router/dynamicRoutes.ts +163 -0
- package/src/router/index.ts +81 -0
- package/src/router/layoutRoute.ts +45 -0
- package/src/router/staticRoutes.ts +43 -0
- package/src/setup.ts +54 -0
- package/src/stores/app.ts +163 -0
- package/src/stores/auth.ts +66 -0
- package/src/stores/index.ts +15 -0
- package/src/stores/menu.ts +80 -0
- package/src/stores/user.ts +73 -0
- package/src/style.css +11 -0
- package/src/types/api.d.ts +84 -0
- package/src/types/global.d.ts +45 -0
- package/src/types/router.d.ts +48 -0
- package/src/types/xto.d.ts +149 -0
- package/src/utils/auth.ts +62 -0
- package/src/utils/permission.ts +42 -0
- package/src/utils/request.ts +124 -0
- package/src/utils/storage.ts +63 -0
- package/src/views/dashboard/index.vue +284 -0
- package/src/views/error/403.vue +57 -0
- package/src/views/error/404.vue +57 -0
- package/src/views/login/index.vue +248 -0
- package/src/views/system/menu/index.vue +381 -0
- package/src/views/system/role/index.vue +304 -0
- package/src/views/system/user/index.vue +327 -0
- package/tsconfig.json +26 -0
- package/tsconfig.node.json +11 -0
- package/vite.config.ts +140 -0
- package/dist/api/menu.d.ts +0 -4
- package/dist/components/Login/index.vue.d.ts +0 -25
- package/dist/components/SettingDrawer/index.vue.d.ts +0 -19
- package/dist/composables/index.d.ts +0 -8
- package/dist/composables/useApp.d.ts +0 -65
- package/dist/composables/useMenu.d.ts +0 -34
- package/dist/config/index.d.ts +0 -31
package/dist/stores/auth.d.ts
CHANGED
|
@@ -1,69 +1,55 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
/**
|
|
2
|
+
* 认证状态
|
|
3
|
+
*/
|
|
3
4
|
export declare const useAuthStore: import('pinia').StoreDefinition<"auth", Pick<{
|
|
4
|
-
|
|
5
|
-
accessToken: string;
|
|
6
|
-
refreshToken: string;
|
|
7
|
-
expiresTime: string;
|
|
8
|
-
refreshTime: string;
|
|
9
|
-
tokenType: string;
|
|
10
|
-
code: string;
|
|
11
|
-
} | null, LoginInfo | {
|
|
12
|
-
accessToken: string;
|
|
13
|
-
refreshToken: string;
|
|
14
|
-
expiresTime: string;
|
|
15
|
-
refreshTime: string;
|
|
16
|
-
tokenType: string;
|
|
17
|
-
code: string;
|
|
18
|
-
} | null>;
|
|
5
|
+
token: import('vue').Ref<string | null, string | null>;
|
|
19
6
|
isLoggedIn: import('vue').ComputedRef<boolean>;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
loginInfo: import('vue').Ref<{
|
|
27
|
-
accessToken: string;
|
|
7
|
+
baseUrl: import('vue').Ref<string, string>;
|
|
8
|
+
appId: import('vue').Ref<string, string>;
|
|
9
|
+
clientId: import('vue').Ref<string, string>;
|
|
10
|
+
loginPath: import('vue').Ref<string, string>;
|
|
11
|
+
login: (tokenInfo: {
|
|
12
|
+
token: string;
|
|
28
13
|
refreshToken: string;
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
tokenType: string;
|
|
32
|
-
code: string;
|
|
33
|
-
} | null, LoginInfo | {
|
|
34
|
-
accessToken: string;
|
|
35
|
-
refreshToken: string;
|
|
36
|
-
expiresTime: string;
|
|
37
|
-
refreshTime: string;
|
|
38
|
-
tokenType: string;
|
|
39
|
-
code: string;
|
|
40
|
-
} | null>;
|
|
41
|
-
isLoggedIn: import('vue').ComputedRef<boolean>;
|
|
42
|
-
accessToken: import('vue').ComputedRef<string | null>;
|
|
43
|
-
tokenType: import('vue').ComputedRef<string>;
|
|
44
|
-
code: import('vue').ComputedRef<string | null>;
|
|
45
|
-
login: (data: Record<string, unknown>) => void;
|
|
14
|
+
expireTime: number;
|
|
15
|
+
}) => void;
|
|
46
16
|
logout: () => void;
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
17
|
+
setBaseUrl: (url: string) => void;
|
|
18
|
+
setAppId: (id: string) => void;
|
|
19
|
+
setClientId: (id: string) => void;
|
|
20
|
+
setLoginPath: (path: string) => void;
|
|
21
|
+
}, "token" | "baseUrl" | "appId" | "clientId" | "loginPath">, Pick<{
|
|
22
|
+
token: import('vue').Ref<string | null, string | null>;
|
|
23
|
+
isLoggedIn: import('vue').ComputedRef<boolean>;
|
|
24
|
+
baseUrl: import('vue').Ref<string, string>;
|
|
25
|
+
appId: import('vue').Ref<string, string>;
|
|
26
|
+
clientId: import('vue').Ref<string, string>;
|
|
27
|
+
loginPath: import('vue').Ref<string, string>;
|
|
28
|
+
login: (tokenInfo: {
|
|
29
|
+
token: string;
|
|
57
30
|
refreshToken: string;
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
31
|
+
expireTime: number;
|
|
32
|
+
}) => void;
|
|
33
|
+
logout: () => void;
|
|
34
|
+
setBaseUrl: (url: string) => void;
|
|
35
|
+
setAppId: (id: string) => void;
|
|
36
|
+
setClientId: (id: string) => void;
|
|
37
|
+
setLoginPath: (path: string) => void;
|
|
38
|
+
}, "isLoggedIn">, Pick<{
|
|
39
|
+
token: import('vue').Ref<string | null, string | null>;
|
|
63
40
|
isLoggedIn: import('vue').ComputedRef<boolean>;
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
41
|
+
baseUrl: import('vue').Ref<string, string>;
|
|
42
|
+
appId: import('vue').Ref<string, string>;
|
|
43
|
+
clientId: import('vue').Ref<string, string>;
|
|
44
|
+
loginPath: import('vue').Ref<string, string>;
|
|
45
|
+
login: (tokenInfo: {
|
|
46
|
+
token: string;
|
|
47
|
+
refreshToken: string;
|
|
48
|
+
expireTime: number;
|
|
49
|
+
}) => void;
|
|
68
50
|
logout: () => void;
|
|
69
|
-
|
|
51
|
+
setBaseUrl: (url: string) => void;
|
|
52
|
+
setAppId: (id: string) => void;
|
|
53
|
+
setClientId: (id: string) => void;
|
|
54
|
+
setLoginPath: (path: string) => void;
|
|
55
|
+
}, "login" | "logout" | "setBaseUrl" | "setAppId" | "setClientId" | "setLoginPath">>;
|
package/dist/stores/index.d.ts
CHANGED
package/dist/stores/menu.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { AppRoute } from '../types/router';
|
|
2
|
+
import { MenuItem } from '../types/api';
|
|
3
3
|
export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<{
|
|
4
4
|
menuList: import('vue').Ref<{
|
|
5
|
-
|
|
5
|
+
id: number | string;
|
|
6
6
|
name: string;
|
|
7
7
|
path: string;
|
|
8
8
|
component?: string | undefined;
|
|
@@ -12,12 +12,11 @@ export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<
|
|
|
12
12
|
hidden?: boolean | undefined;
|
|
13
13
|
keepAlive?: boolean | undefined;
|
|
14
14
|
affix?: boolean | undefined;
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
closable?: boolean | undefined;
|
|
15
|
+
order?: number | undefined;
|
|
16
|
+
parentId?: number | string | null | undefined;
|
|
18
17
|
children?: /*elided*/ any[] | undefined;
|
|
19
18
|
}[], MenuItem[] | {
|
|
20
|
-
|
|
19
|
+
id: number | string;
|
|
21
20
|
name: string;
|
|
22
21
|
path: string;
|
|
23
22
|
component?: string | undefined;
|
|
@@ -27,23 +26,18 @@ export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<
|
|
|
27
26
|
hidden?: boolean | undefined;
|
|
28
27
|
keepAlive?: boolean | undefined;
|
|
29
28
|
affix?: boolean | undefined;
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
closable?: boolean | undefined;
|
|
29
|
+
order?: number | undefined;
|
|
30
|
+
parentId?: number | string | null | undefined;
|
|
33
31
|
children?: /*elided*/ any[] | undefined;
|
|
34
32
|
}[]>;
|
|
35
|
-
menuBtnListMap: import('vue').Ref<Record<string, MenuItem[]>, Record<string, MenuItem[]>>;
|
|
36
33
|
hasMenu: import('vue').ComputedRef<boolean>;
|
|
37
|
-
index: import('vue').ComputedRef<string>;
|
|
38
34
|
setMenuList: (menus: MenuItem[]) => void;
|
|
39
|
-
setIndexMenu: (menu: MenuItem) => void;
|
|
40
|
-
setMenuFromRemote: (remoteMenus: RemoteMenuItem[], options?: {
|
|
41
|
-
skipIndexMenu?: boolean;
|
|
42
|
-
}) => void;
|
|
43
35
|
clearMenu: () => void;
|
|
44
|
-
|
|
36
|
+
generateRoutes: (menus: MenuItem[]) => AppRoute[];
|
|
37
|
+
addRoutes: (menus: MenuItem[]) => void;
|
|
38
|
+
}, "menuList">, Pick<{
|
|
45
39
|
menuList: import('vue').Ref<{
|
|
46
|
-
|
|
40
|
+
id: number | string;
|
|
47
41
|
name: string;
|
|
48
42
|
path: string;
|
|
49
43
|
component?: string | undefined;
|
|
@@ -53,12 +47,11 @@ export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<
|
|
|
53
47
|
hidden?: boolean | undefined;
|
|
54
48
|
keepAlive?: boolean | undefined;
|
|
55
49
|
affix?: boolean | undefined;
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
closable?: boolean | undefined;
|
|
50
|
+
order?: number | undefined;
|
|
51
|
+
parentId?: number | string | null | undefined;
|
|
59
52
|
children?: /*elided*/ any[] | undefined;
|
|
60
53
|
}[], MenuItem[] | {
|
|
61
|
-
|
|
54
|
+
id: number | string;
|
|
62
55
|
name: string;
|
|
63
56
|
path: string;
|
|
64
57
|
component?: string | undefined;
|
|
@@ -68,23 +61,18 @@ export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<
|
|
|
68
61
|
hidden?: boolean | undefined;
|
|
69
62
|
keepAlive?: boolean | undefined;
|
|
70
63
|
affix?: boolean | undefined;
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
closable?: boolean | undefined;
|
|
64
|
+
order?: number | undefined;
|
|
65
|
+
parentId?: number | string | null | undefined;
|
|
74
66
|
children?: /*elided*/ any[] | undefined;
|
|
75
67
|
}[]>;
|
|
76
|
-
menuBtnListMap: import('vue').Ref<Record<string, MenuItem[]>, Record<string, MenuItem[]>>;
|
|
77
68
|
hasMenu: import('vue').ComputedRef<boolean>;
|
|
78
|
-
index: import('vue').ComputedRef<string>;
|
|
79
69
|
setMenuList: (menus: MenuItem[]) => void;
|
|
80
|
-
setIndexMenu: (menu: MenuItem) => void;
|
|
81
|
-
setMenuFromRemote: (remoteMenus: RemoteMenuItem[], options?: {
|
|
82
|
-
skipIndexMenu?: boolean;
|
|
83
|
-
}) => void;
|
|
84
70
|
clearMenu: () => void;
|
|
85
|
-
|
|
71
|
+
generateRoutes: (menus: MenuItem[]) => AppRoute[];
|
|
72
|
+
addRoutes: (menus: MenuItem[]) => void;
|
|
73
|
+
}, "hasMenu">, Pick<{
|
|
86
74
|
menuList: import('vue').Ref<{
|
|
87
|
-
|
|
75
|
+
id: number | string;
|
|
88
76
|
name: string;
|
|
89
77
|
path: string;
|
|
90
78
|
component?: string | undefined;
|
|
@@ -94,12 +82,11 @@ export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<
|
|
|
94
82
|
hidden?: boolean | undefined;
|
|
95
83
|
keepAlive?: boolean | undefined;
|
|
96
84
|
affix?: boolean | undefined;
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
closable?: boolean | undefined;
|
|
85
|
+
order?: number | undefined;
|
|
86
|
+
parentId?: number | string | null | undefined;
|
|
100
87
|
children?: /*elided*/ any[] | undefined;
|
|
101
88
|
}[], MenuItem[] | {
|
|
102
|
-
|
|
89
|
+
id: number | string;
|
|
103
90
|
name: string;
|
|
104
91
|
path: string;
|
|
105
92
|
component?: string | undefined;
|
|
@@ -109,18 +96,13 @@ export declare const useMenuStore: import('pinia').StoreDefinition<"menu", Pick<
|
|
|
109
96
|
hidden?: boolean | undefined;
|
|
110
97
|
keepAlive?: boolean | undefined;
|
|
111
98
|
affix?: boolean | undefined;
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
closable?: boolean | undefined;
|
|
99
|
+
order?: number | undefined;
|
|
100
|
+
parentId?: number | string | null | undefined;
|
|
115
101
|
children?: /*elided*/ any[] | undefined;
|
|
116
102
|
}[]>;
|
|
117
|
-
menuBtnListMap: import('vue').Ref<Record<string, MenuItem[]>, Record<string, MenuItem[]>>;
|
|
118
103
|
hasMenu: import('vue').ComputedRef<boolean>;
|
|
119
|
-
index: import('vue').ComputedRef<string>;
|
|
120
104
|
setMenuList: (menus: MenuItem[]) => void;
|
|
121
|
-
setIndexMenu: (menu: MenuItem) => void;
|
|
122
|
-
setMenuFromRemote: (remoteMenus: RemoteMenuItem[], options?: {
|
|
123
|
-
skipIndexMenu?: boolean;
|
|
124
|
-
}) => void;
|
|
125
105
|
clearMenu: () => void;
|
|
126
|
-
|
|
106
|
+
generateRoutes: (menus: MenuItem[]) => AppRoute[];
|
|
107
|
+
addRoutes: (menus: MenuItem[]) => void;
|
|
108
|
+
}, "setMenuList" | "clearMenu" | "generateRoutes" | "addRoutes">>;
|
package/dist/stores/user.d.ts
CHANGED
|
@@ -1,93 +1,113 @@
|
|
|
1
1
|
import { UserInfo } from '../types/api';
|
|
2
|
-
|
|
3
2
|
export declare const useUserStore: import('pinia').StoreDefinition<"user", Pick<{
|
|
4
3
|
userInfo: import('vue').Ref<{
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
userName: string;
|
|
9
|
-
departmentName?: string | undefined;
|
|
10
|
-
email?: string | undefined;
|
|
11
|
-
mobilePhone?: string | undefined;
|
|
12
|
-
positionName?: string | undefined;
|
|
4
|
+
id: number | string;
|
|
5
|
+
username: string;
|
|
6
|
+
nickname: string;
|
|
13
7
|
avatar?: string | undefined;
|
|
14
|
-
workNo?: string | undefined;
|
|
15
|
-
} | null, UserInfo | {
|
|
16
|
-
uId: string;
|
|
17
|
-
appId: string;
|
|
18
|
-
userId: string;
|
|
19
|
-
userName: string;
|
|
20
|
-
departmentName?: string | undefined;
|
|
21
8
|
email?: string | undefined;
|
|
22
|
-
|
|
23
|
-
|
|
9
|
+
phone?: string | undefined;
|
|
10
|
+
status: number;
|
|
11
|
+
roles: string[];
|
|
12
|
+
permissions: string[];
|
|
13
|
+
createTime?: string | undefined;
|
|
14
|
+
updateTime?: string | undefined;
|
|
15
|
+
} | null, UserInfo | {
|
|
16
|
+
id: number | string;
|
|
17
|
+
username: string;
|
|
18
|
+
nickname: string;
|
|
24
19
|
avatar?: string | undefined;
|
|
25
|
-
|
|
20
|
+
email?: string | undefined;
|
|
21
|
+
phone?: string | undefined;
|
|
22
|
+
status: number;
|
|
23
|
+
roles: string[];
|
|
24
|
+
permissions: string[];
|
|
25
|
+
createTime?: string | undefined;
|
|
26
|
+
updateTime?: string | undefined;
|
|
26
27
|
} | null>;
|
|
28
|
+
roles: import('vue').Ref<string[], string[]>;
|
|
29
|
+
permissions: import('vue').Ref<string[], string[]>;
|
|
27
30
|
isLoggedIn: import('vue').ComputedRef<boolean>;
|
|
28
|
-
|
|
31
|
+
username: import('vue').ComputedRef<string>;
|
|
32
|
+
nickname: import('vue').ComputedRef<string>;
|
|
29
33
|
avatar: import('vue').ComputedRef<string>;
|
|
30
|
-
userId: import('vue').ComputedRef<string | undefined>;
|
|
34
|
+
userId: import('vue').ComputedRef<string | number | undefined>;
|
|
31
35
|
setUserInfo: (info: UserInfo) => void;
|
|
32
36
|
clearUserInfo: () => void;
|
|
33
|
-
|
|
37
|
+
hasPermission: (permission: string | string[]) => boolean;
|
|
38
|
+
hasRole: (role: string | string[]) => boolean;
|
|
39
|
+
}, "userInfo" | "roles" | "permissions">, Pick<{
|
|
34
40
|
userInfo: import('vue').Ref<{
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
userName: string;
|
|
39
|
-
departmentName?: string | undefined;
|
|
40
|
-
email?: string | undefined;
|
|
41
|
-
mobilePhone?: string | undefined;
|
|
42
|
-
positionName?: string | undefined;
|
|
41
|
+
id: number | string;
|
|
42
|
+
username: string;
|
|
43
|
+
nickname: string;
|
|
43
44
|
avatar?: string | undefined;
|
|
44
|
-
workNo?: string | undefined;
|
|
45
|
-
} | null, UserInfo | {
|
|
46
|
-
uId: string;
|
|
47
|
-
appId: string;
|
|
48
|
-
userId: string;
|
|
49
|
-
userName: string;
|
|
50
|
-
departmentName?: string | undefined;
|
|
51
45
|
email?: string | undefined;
|
|
52
|
-
|
|
53
|
-
|
|
46
|
+
phone?: string | undefined;
|
|
47
|
+
status: number;
|
|
48
|
+
roles: string[];
|
|
49
|
+
permissions: string[];
|
|
50
|
+
createTime?: string | undefined;
|
|
51
|
+
updateTime?: string | undefined;
|
|
52
|
+
} | null, UserInfo | {
|
|
53
|
+
id: number | string;
|
|
54
|
+
username: string;
|
|
55
|
+
nickname: string;
|
|
54
56
|
avatar?: string | undefined;
|
|
55
|
-
|
|
57
|
+
email?: string | undefined;
|
|
58
|
+
phone?: string | undefined;
|
|
59
|
+
status: number;
|
|
60
|
+
roles: string[];
|
|
61
|
+
permissions: string[];
|
|
62
|
+
createTime?: string | undefined;
|
|
63
|
+
updateTime?: string | undefined;
|
|
56
64
|
} | null>;
|
|
65
|
+
roles: import('vue').Ref<string[], string[]>;
|
|
66
|
+
permissions: import('vue').Ref<string[], string[]>;
|
|
57
67
|
isLoggedIn: import('vue').ComputedRef<boolean>;
|
|
58
|
-
|
|
68
|
+
username: import('vue').ComputedRef<string>;
|
|
69
|
+
nickname: import('vue').ComputedRef<string>;
|
|
59
70
|
avatar: import('vue').ComputedRef<string>;
|
|
60
|
-
userId: import('vue').ComputedRef<string | undefined>;
|
|
71
|
+
userId: import('vue').ComputedRef<string | number | undefined>;
|
|
61
72
|
setUserInfo: (info: UserInfo) => void;
|
|
62
73
|
clearUserInfo: () => void;
|
|
63
|
-
|
|
74
|
+
hasPermission: (permission: string | string[]) => boolean;
|
|
75
|
+
hasRole: (role: string | string[]) => boolean;
|
|
76
|
+
}, "isLoggedIn" | "username" | "nickname" | "avatar" | "userId">, Pick<{
|
|
64
77
|
userInfo: import('vue').Ref<{
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
userName: string;
|
|
69
|
-
departmentName?: string | undefined;
|
|
70
|
-
email?: string | undefined;
|
|
71
|
-
mobilePhone?: string | undefined;
|
|
72
|
-
positionName?: string | undefined;
|
|
78
|
+
id: number | string;
|
|
79
|
+
username: string;
|
|
80
|
+
nickname: string;
|
|
73
81
|
avatar?: string | undefined;
|
|
74
|
-
workNo?: string | undefined;
|
|
75
|
-
} | null, UserInfo | {
|
|
76
|
-
uId: string;
|
|
77
|
-
appId: string;
|
|
78
|
-
userId: string;
|
|
79
|
-
userName: string;
|
|
80
|
-
departmentName?: string | undefined;
|
|
81
82
|
email?: string | undefined;
|
|
82
|
-
|
|
83
|
-
|
|
83
|
+
phone?: string | undefined;
|
|
84
|
+
status: number;
|
|
85
|
+
roles: string[];
|
|
86
|
+
permissions: string[];
|
|
87
|
+
createTime?: string | undefined;
|
|
88
|
+
updateTime?: string | undefined;
|
|
89
|
+
} | null, UserInfo | {
|
|
90
|
+
id: number | string;
|
|
91
|
+
username: string;
|
|
92
|
+
nickname: string;
|
|
84
93
|
avatar?: string | undefined;
|
|
85
|
-
|
|
94
|
+
email?: string | undefined;
|
|
95
|
+
phone?: string | undefined;
|
|
96
|
+
status: number;
|
|
97
|
+
roles: string[];
|
|
98
|
+
permissions: string[];
|
|
99
|
+
createTime?: string | undefined;
|
|
100
|
+
updateTime?: string | undefined;
|
|
86
101
|
} | null>;
|
|
102
|
+
roles: import('vue').Ref<string[], string[]>;
|
|
103
|
+
permissions: import('vue').Ref<string[], string[]>;
|
|
87
104
|
isLoggedIn: import('vue').ComputedRef<boolean>;
|
|
88
|
-
|
|
105
|
+
username: import('vue').ComputedRef<string>;
|
|
106
|
+
nickname: import('vue').ComputedRef<string>;
|
|
89
107
|
avatar: import('vue').ComputedRef<string>;
|
|
90
|
-
userId: import('vue').ComputedRef<string | undefined>;
|
|
108
|
+
userId: import('vue').ComputedRef<string | number | undefined>;
|
|
91
109
|
setUserInfo: (info: UserInfo) => void;
|
|
92
110
|
clearUserInfo: () => void;
|
|
93
|
-
|
|
111
|
+
hasPermission: (permission: string | string[]) => boolean;
|
|
112
|
+
hasRole: (role: string | string[]) => boolean;
|
|
113
|
+
}, "setUserInfo" | "clearUserInfo" | "hasPermission" | "hasRole">>;
|
package/dist/style.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
:root{--color-primary: #409eff;--color-primary-light-3: #79bbff;--color-primary-light-5: #a0cfff;--color-primary-light-7: #c6e2ff;--color-primary-light-8: #d9ecff;--color-primary-light-9: #ecf5ff;--color-primary-dark-2: #337ecc;--color-success: #67c23a;--color-success-light: #e1f3d8;--color-success-dark: #529b2e;--color-warning: #e6a23c;--color-warning-light: #fdf6ec;--color-warning-dark: #b88230;--color-danger: #f56c6c;--color-danger-light: #fde2e2;--color-danger-dark: #c45656;--color-info: #909399;--color-info-light: #f4f4f5;--color-info-dark: #73767a;--color-text-primary: #303133;--color-text-regular: #606266;--color-text-secondary: #909399;--color-text-placeholder: #a8abb2;--color-text-disabled: #c0c4cc;--color-border: #dcdfe6;--color-border-light: #e4e7ed;--color-border-lighter: #ebeef5;--color-border-extra-light: #f2f6fc;--color-border-dark: #d4d7de;--color-fill: #f5f7fa;--color-fill-light: #fafafa;--color-fill-lighter: #fafcff;--color-fill-blank: #ffffff;--bg-color: #ffffff;--bg-color-page: #f2f3f5;--bg-color-overlay: #ffffff;--box-shadow: 0 2px 12px 0 rgba(0, 0, 0, .1);--box-shadow-light: 0 2px 8px 0 rgba(0, 0, 0, .06);--box-shadow-lighter: 0 1px 4px 0 rgba(0, 0, 0, .04);--box-shadow-dark: 0 4px 16px 0 rgba(0, 0, 0, .12);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-size-base: 14px;--font-size-small: 12px;--font-size-large: 16px;--font-size-extra-large: 18px;--border-radius-base: 4px;--border-radius-small: 2px;--border-radius-large: 8px;--border-radius-round: 20px;--border-radius-circle: 50%;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--component-size-large: 40px;--component-size-default: 32px;--component-size-small: 24px;--transition-duration: .3s;--transition-duration-fast: .2s;--transition-duration-slow: .5s;--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: 210px;--sidebar-collapsed-width: 64px;--header-height: 50px;--tabs-height: 40px;--footer-height: 30px}.dark{--color-text-primary: #e5eaf3;--color-text-regular: #cfd3dc;--color-text-secondary: #a3a6ad;--color-text-placeholder: #8d9095;--color-text-disabled: #6c6e72;--color-border: #4c4d4f;--color-border-light: #414243;--color-border-lighter: #363637;--color-border-extra-light: #2b2b2c;--color-border-dark: #58585b;--color-fill: #303030;--color-fill-light: #262727;--color-fill-lighter: #1d1d1d;--color-fill-blank: #141414;--bg-color: #1d1e1f;--bg-color-page: #0a0a0a;--bg-color-overlay: #1d1e1f;--box-shadow: 0 2px 12px 0 rgba(0, 0, 0, .3);--box-shadow-light: 0 2px 8px 0 rgba(0, 0, 0, .24);--box-shadow-lighter: 0 1px 4px 0 rgba(0, 0, 0, .2);--box-shadow-dark: 0 4px 16px 0 rgba(0, 0, 0, .36)}.grayscale{--color-primary: #909399;--color-primary-light-3: #a6a9ad;--color-primary-light-5: #bcbec1;--color-primary-light-7: #d2d4d6;--color-primary-light-8: #e0e1e2;--color-primary-light-9: #eeefef;--color-primary-dark-2: #73767a;--color-success: #909399;--color-success-light: #f4f4f5;--color-success-dark: #73767a;--color-warning: #909399;--color-warning-light: #f4f4f5;--color-warning-dark: #73767a;--color-danger: #909399;--color-danger-light: #f4f4f5;--color-danger-dark: #73767a;--color-info: #909399;--color-info-light: #f4f4f5;--color-info-dark: #73767a;--color-text-primary: #5a5e66;--color-text-regular: #8a8e99;--color-text-secondary: #a8abb2;--color-text-placeholder: #c0c4cc;--color-text-disabled: #d3d4d6;--color-border: #d3d4d6;--color-border-light: #e0e1e2;--color-border-lighter: #ebedef;--color-border-extra-light: #f2f3f5;--color-border-dark: #c0c4cc;--color-fill: #f5f6f7;--color-fill-light: #fafbfb;--color-fill-lighter: #fcfcfc;--color-fill-blank: #ffffff;--bg-color: #ffffff;--bg-color-page: #f5f6f7;--bg-color-overlay: #ffffff}.grayscale img,.grayscale svg,.grayscale .xto-icon{filter:grayscale(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}.dark .x-menu-item{color:#cfd3dc!important}.dark .x-menu-item:hover{background-color:#262727!important}.dark .x-menu-item.is-active{background-color:#262727!important;color:#cfd3dc!important}.dark .x-sub-menu__title{color:#cfd3dc!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__arrow{color:#a3a6ad}.dark .x-sub-menu.is-opened>.x-sub-menu__title{background-color:#262727!important}.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 .x-button.x-button--default{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-button.x-button--default:hover{border-color:var(--color-primary);color:var(--color-primary)}.dark .x-button.x-button--text{color:var(--color-primary)}.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:var(--color-primary)}.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:var(--color-primary)}.dark .x-pagination{color:#cfd3dc}.dark .x-pagination__item{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-pagination__item:hover{color:var(--color-primary)}.dark .x-pagination__item.is-active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.dark .login{background:linear-gradient(135deg,#1a1a2e,#16213e)}.dark .login__container{background-color:#1d1e1f;border:1px solid #363637}.dark .login__title{color:var(--color-primary)}.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}.grayscale .sidebar__logo-text{color:var(--color-primary)}.grayscale .x-menu-item.is-active{background-color:var(--color-fill)!important;color:var(--color-text-primary)!important}.grayscale .x-sub-menu.is-active .x-sub-menu__title{color:var(--color-text-primary)!important}.grayscale .x-button--default:hover{border-color:var(--color-primary);color:var(--color-primary)}.grayscale .x-button--text{color:var(--color-primary)}.grayscale .x-input.is-focus{border-color:var(--color-primary)}.grayscale .x-switch.is-checked{background-color:var(--color-primary)}.grayscale .x-pagination__item:hover{color:var(--color-primary)}.grayscale .x-pagination__item.is-active{background-color:var(--color-primary);border-color:var(--color-primary)}.grayscale .login__title{color:var(--color-primary)}.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}.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-wrap{flex-wrap:wrap}.flex-1{flex:1}.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)}.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)}.mt-10{margin-top:10px}.mt-20{margin-top:20px}.mb-10{margin-bottom:10px}.mb-20{margin-bottom:20px}.ml-10{margin-left:10px}.mr-10{margin-right:10px}.p-10{padding:10px}.p-20{padding:20px}.card{background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow-light);padding:var(--spacing-md)}.page-container{padding:var(--spacing-md);min-height:100%}.search-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.table-container{background-color:var(--bg-color);border-radius:var(--border-radius-base);padding:var(--spacing-md)}.pagination-container{display:flex;justify-content:flex-end;margin-top:var(--spacing-md)}.sidebar[data-v-d6c5528d]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color)}.sidebar__logo[data-v-d6c5528d]{height:50px;display:flex;align-items:center;justify-content:center;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-d6c5528d]{width:32px;height:32px}.sidebar__logo-text[data-v-d6c5528d]{font-size:16px;font-weight:600;color:var(--color-primary);white-space:nowrap}.sidebar__menu[data-v-d6c5528d]{flex:1;border-right:none;overflow-y:auto;overflow-x:visible;background-color:transparent!important}.sidebar__menu[data-v-d6c5528d] .x-menu{background-color:transparent;border-right:none}.sidebar__menu[data-v-d6c5528d] .x-menu-item{height:46px;line-height:46px}.sidebar__menu[data-v-d6c5528d] .x-menu-item:hover{background-color:var(--color-fill)}.sidebar__menu[data-v-d6c5528d] .x-menu-item.is-active{background-color:var(--color-fill);color:var(--color-text-primary)!important}.sidebar__menu[data-v-d6c5528d] .x-sub-menu__title{height:46px;line-height:46px}.sidebar__menu[data-v-d6c5528d] .x-sub-menu__title:hover{background-color:var(--color-fill)}.sidebar__menu[data-v-d6c5528d] .x-sub-menu.is-active .x-sub-menu__title{color:var(--color-text-primary)!important}.sidebar__menu[data-v-d6c5528d] .x-sub-menu .x-menu{background-color:#00000005}.sidebar__menu[data-v-d6c5528d] .x-sub-menu .x-menu-item{padding-left:50px!important}.sidebar__user[data-v-d6c5528d]{padding:12px 16px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between;background-color:#fff}.sidebar__user-info[data-v-d6c5528d]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-d6c5528d]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.sidebar__user-role[data-v-d6c5528d]{font-size:12px;color:var(--color-text-secondary)}.setting-drawer[data-v-3a74bfd0]{padding:0 4px}.setting-section[data-v-3a74bfd0]{margin-bottom:24px}.setting-section__title[data-v-3a74bfd0]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin:0 0 12px}.layout-options[data-v-3a74bfd0]{display:flex;gap:12px}.layout-option[data-v-3a74bfd0]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;border:2px solid var(--color-border);border-radius:4px;cursor:pointer;transition:all .2s}.layout-option[data-v-3a74bfd0]:hover{border-color:var(--color-primary-light-5)}.layout-option.is-active[data-v-3a74bfd0]{border-color:var(--color-primary);background-color:#409eff0d}.layout-option__preview[data-v-3a74bfd0]{width:40px;height:40px;display:flex;align-items:center;justify-content:center}.layout-option__preview[data-v-3a74bfd0] svg{width:100%;height:100%;color:var(--color-text-regular)}.layout-option__label[data-v-3a74bfd0]{font-size:12px;color:var(--color-text-secondary)}.layout-option.is-active .layout-option__label[data-v-3a74bfd0]{color:var(--color-primary)}.setting-item[data-v-3a74bfd0]{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.setting-item__label[data-v-3a74bfd0]{font-size:14px;color:var(--color-text-primary)}.breadcrumb[data-v-31468670]{display:flex;align-items:center;font-size:14px}.breadcrumb__item[data-v-31468670]{color:var(--color-text-regular)}.breadcrumb__item--link[data-v-31468670]{color:var(--color-text-secondary);cursor:pointer;transition:color .2s}.breadcrumb__item--link[data-v-31468670]:hover{color:var(--color-primary)}.breadcrumb__separator[data-v-31468670]{margin:0 8px;color:var(--color-text-placeholder)}.header[data-v-b15434d8]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%}.header__left[data-v-b15434d8]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-b15434d8]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:var(--color-text-regular);border-radius:4px;transition:all .2s}.header__collapse[data-v-b15434d8]:hover{color:var(--color-primary);background-color:var(--color-fill)}.header__right[data-v-b15434d8]{display:flex;align-items:center;gap:12px}.header__search[data-v-b15434d8]{position:relative;width:120px}.header__search-results[data-v-b15434d8]{position:absolute;top:calc(100% + 8px);left:0;right:0;background-color:var(--bg-color);border:1px solid var(--color-border-lighter);border-radius:4px;box-shadow:0 2px 12px #00000026;max-height:300px;overflow-y:auto;z-index:100}.header__search-item[data-v-b15434d8]{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background-color .2s}.header__search-item[data-v-b15434d8]:hover{background-color:var(--color-fill)}.header__search-icon[data-v-b15434d8]{width:20px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.header__search-info[data-v-b15434d8]{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.header__search-title[data-v-b15434d8]{font-size:14px;color:var(--color-text-primary)}.header__search-parent[data-v-b15434d8]{font-size:12px;color:var(--color-text-secondary)}.header__action[data-v-b15434d8]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;transition:all .2s;color:var(--color-text-regular)}.header__action[data-v-b15434d8]:hover{background-color:var(--color-fill)}.header__user[data-v-b15434d8]{position:relative}.header__user-trigger[data-v-b15434d8]{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 12px;border-radius:4px;transition:background-color .2s}.header__user-trigger[data-v-b15434d8]:hover{background-color:var(--color-fill)}.header__user-name[data-v-b15434d8]{font-size:14px;color:var(--color-text-primary)}.header__user-arrow[data-v-b15434d8]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-b15434d8]{transform:rotate(180deg)}.header__avatar[data-v-b15434d8]{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#409eff,#66b1ff);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.header__dropdown[data-v-b15434d8]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:4px;box-shadow:0 2px 12px #00000026;overflow:hidden;z-index:100}.header__dropdown-header[data-v-b15434d8]{display:flex;align-items:center;gap:12px;padding:16px;background-color:var(--color-fill)}.header__dropdown-avatar[data-v-b15434d8]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#409eff,#66b1ff);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.header__dropdown-info[data-v-b15434d8]{flex:1}.header__dropdown-name[data-v-b15434d8]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-b15434d8]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-b15434d8]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-b15434d8]{padding:8px 0}.header__dropdown-item[data-v-b15434d8]{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-b15434d8]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-b15434d8]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-b15434d8]:hover{background-color:#f56c6c1a;color:var(--color-danger)}.dropdown-enter-active[data-v-b15434d8],.dropdown-leave-active[data-v-b15434d8]{transition:all .2s ease}.dropdown-enter-from[data-v-b15434d8],.dropdown-leave-to[data-v-b15434d8]{opacity:0;transform:translateY(-10px)}.top-menu[data-v-f9b502d8]{flex:1;display:flex;align-items:center;padding-left:20px}.top-menu__inner[data-v-f9b502d8]{border-bottom:none!important;background-color:transparent!important}.top-menu[data-v-f9b502d8] .x-menu-item{height:50px;line-height:50px;border-bottom:2px solid transparent!important}.top-menu[data-v-f9b502d8] .x-menu-item:hover{background-color:var(--color-fill)}.top-menu[data-v-f9b502d8] .x-menu-item.is-active{border-bottom-color:transparent!important}.top-menu[data-v-f9b502d8] .x-sub-menu__title{height:50px;line-height:50px;border-bottom:2px solid transparent!important}.top-menu[data-v-f9b502d8] .x-sub-menu__title:hover{background-color:var(--color-fill)}.top-menu[data-v-f9b502d8] .x-sub-menu.is-active .x-sub-menu__title{border-bottom-color:transparent!important}.layout[data-v-a2789d75]{display:flex;width:100%;height:100%}.layout__aside[data-v-a2789d75]{transition:width .3s;overflow:visible;flex-shrink:0;height:100%}.layout__main[data-v-a2789d75]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__top[data-v-a2789d75]{display:flex;align-items:center;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__logo[data-v-a2789d75]{width:60px;height:50px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.layout__logo-img[data-v-a2789d75]{width:32px;height:32px}.layout__header[data-v-a2789d75]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__header--top[data-v-a2789d75]{border-bottom:none}.layout__content[data-v-a2789d75]{flex:1;overflow:auto;background-color:var(--bg-color-page)}.layout--top[data-v-a2789d75]{flex-direction:column}.tabs-wrapper[data-v-3b1e382a]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:12px}.footer[data-v-317ae311]{width:100%;text-align:center;font-size:12px;color:var(--color-text-secondary)}.login[data-v-a48f4a52]{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:flex-end;padding-right:15%;background:linear-gradient(135deg,var(--color-primary-light-9) 0%,var(--color-primary-light-7) 100%)}.login__container[data-v-a48f4a52]{width:400px;padding:40px;background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-dark)}.login__header[data-v-a48f4a52]{text-align:center;margin-bottom:30px}.login__logo[data-v-a48f4a52]{width:60px;height:60px}.login__title[data-v-a48f4a52]{font-size:28px;font-weight:600;color:var(--color-primary);margin:15px 0 5px}.login__subtitle[data-v-a48f4a52]{font-size:14px;color:var(--color-text-secondary)}.login__form[data-v-a48f4a52] .t-form-item{margin-bottom:20px}.login__submit[data-v-a48f4a52]{width:100%}.login__input-icon[data-v-a48f4a52]{display:inline-flex;align-items:center;justify-content:center}.login__input-icon[data-v-a48f4a52] svg{width:16px;height:16px;color:var(--color-text-secondary)}.login__input-icon--clickable[data-v-a48f4a52]{cursor:pointer}.login__input-icon--clickable[data-v-a48f4a52]:hover svg{color:var(--color-primary)}.error-page[data-v-25c06185]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-25c06185]{text-align:center}.error-page__code[data-v-25c06185]{font-size:120px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:20px}.error-page__title[data-v-25c06185]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-25c06185]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.error-page[data-v-42d7e36e]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-42d7e36e]{text-align:center}.error-page__code[data-v-42d7e36e]{font-size:120px;font-weight:600;color:var(--color-warning);line-height:1;margin-bottom:20px}.error-page__title[data-v-42d7e36e]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-42d7e36e]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}
|
|
1
|
+
.sidebar[data-v-1d224580]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color)}.sidebar__logo[data-v-1d224580]{height:50px;display:flex;align-items:center;justify-content:center;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-1d224580]{width:32px;height:32px}.sidebar__logo-text[data-v-1d224580]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__search[data-v-1d224580]{padding:10px;border-bottom:1px solid var(--color-border-lighter);position:relative}.sidebar__search-results[data-v-1d224580]{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-color);border:1px solid var(--color-border-lighter);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);max-height:300px;overflow-y:auto;z-index:100}.sidebar__search-item[data-v-1d224580]{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background-color .2s}.sidebar__search-item[data-v-1d224580]:hover{background-color:var(--color-fill)}.sidebar__search-item-info[data-v-1d224580]{display:flex;flex-direction:column;gap:2px}.sidebar__search-item-title[data-v-1d224580]{font-size:14px;color:var(--color-text-primary)}.sidebar__search-item-parent[data-v-1d224580]{font-size:12px;color:var(--color-text-secondary)}.sidebar__menu[data-v-1d224580]{flex:1;border-right:none;overflow-y:auto}.sidebar__user[data-v-1d224580]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-1d224580]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-1d224580]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-1d224580]{font-size:12px;color:var(--color-text-secondary)}.menu-icon[data-v-1d224580]{margin-right:8px}.header[data-v-7af82b67]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%}.header__left[data-v-7af82b67]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-7af82b67]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--color-text-regular)}.header__collapse[data-v-7af82b67]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-7af82b67]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .is-current[data-v-7af82b67]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-7af82b67]{display:flex;align-items:center;gap:15px}.header__action[data-v-7af82b67]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);font-size:16px}.header__action[data-v-7af82b67]:hover{background-color:var(--color-fill)}.header__user[data-v-7af82b67]{position:relative}.header__user-trigger[data-v-7af82b67]{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-7af82b67]:hover{background-color:var(--color-fill)}.header__user-name[data-v-7af82b67]{font-size:14px;color:var(--color-text-primary)}.header__user-arrow[data-v-7af82b67]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-7af82b67]{transform:rotate(180deg)}.header__avatar[data-v-7af82b67]{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-7af82b67]{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-7af82b67]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-7af82b67]{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-7af82b67]{flex:1}.header__dropdown-name[data-v-7af82b67]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-7af82b67]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-7af82b67]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-7af82b67]{padding:8px 0}.header__dropdown-item[data-v-7af82b67]{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-7af82b67]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-7af82b67]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-7af82b67]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__dropdown-icon[data-v-7af82b67]{font-size:16px}.dropdown-enter-active[data-v-7af82b67],.dropdown-leave-active[data-v-7af82b67]{transition:all .2s ease}.dropdown-enter-from[data-v-7af82b67],.dropdown-leave-to[data-v-7af82b67]{opacity:0;transform:translateY(-10px)}.layout[data-v-0bcf8553]{display:flex;width:100%;height:100%}.layout__aside[data-v-0bcf8553]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__main[data-v-0bcf8553]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-0bcf8553]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-0bcf8553]{flex:1;overflow:auto;background-color:var(--bg-color-page)}.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[data-v-cc0ffe99]{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:flex-end;padding-right:15%;background:linear-gradient(135deg,var(--color-primary-light-9) 0%,var(--color-primary-light-7) 100%)}.login__container[data-v-cc0ffe99]{width:400px;padding:40px;background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-dark)}.login__header[data-v-cc0ffe99]{text-align:center;margin-bottom:30px}.login__logo[data-v-cc0ffe99]{width:60px;height:60px}.login__title[data-v-cc0ffe99]{font-size:28px;font-weight:600;color:var(--color-primary);margin:15px 0 5px}.login__subtitle[data-v-cc0ffe99]{font-size:14px;color:var(--color-text-secondary)}.login__form[data-v-cc0ffe99] .t-form-item{margin-bottom:20px}.login__form[data-v-cc0ffe99] .x-input__prefix{margin-right:8px}.login__submit[data-v-cc0ffe99]{width:100%}.login__footer[data-v-cc0ffe99]{text-align:center;margin-top:20px;font-size:12px;color:var(--color-text-placeholder)}.error-page[data-v-c3c12c24]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-c3c12c24]{text-align:center}.error-page__code[data-v-c3c12c24]{font-size:120px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:20px}.error-page__title[data-v-c3c12c24]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-c3c12c24]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.error-page[data-v-dd5f2795]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-dd5f2795]{text-align:center}.error-page__code[data-v-dd5f2795]{font-size:120px;font-weight:600;color:var(--color-warning);line-height:1;margin-bottom:20px}.error-page__title[data-v-dd5f2795]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-dd5f2795]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.dashboard[data-v-44648cb1]{padding:20px}.dashboard__stats[data-v-44648cb1]{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:20px}@media (max-width: 1200px){.dashboard__stats[data-v-44648cb1]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard__stats[data-v-44648cb1]{grid-template-columns:1fr}}.dashboard__main[data-v-44648cb1]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}@media (max-width: 992px){.dashboard__main[data-v-44648cb1]{grid-template-columns:1fr}}.dashboard__quick[data-v-44648cb1],.dashboard__activity[data-v-44648cb1]{min-height:300px}.card-title[data-v-44648cb1]{font-size:16px;font-weight:500}.stat-card__content[data-v-44648cb1]{display:flex;align-items:center;gap:15px}.stat-card__icon[data-v-44648cb1]{width:50px;height:50px;display:flex;align-items:center;justify-content:center;font-size:24px;border-radius:var(--border-radius-base)}.stat-card__info[data-v-44648cb1]{flex:1}.stat-card__title[data-v-44648cb1]{font-size:14px;color:var(--color-text-secondary);margin-bottom:5px}.stat-card__value[data-v-44648cb1]{font-size:24px;font-weight:600}.quick-links[data-v-44648cb1]{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}@media (max-width: 768px){.quick-links[data-v-44648cb1]{grid-template-columns:repeat(2,1fr)}}.quick-link[data-v-44648cb1]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;border-radius:var(--border-radius-base);background-color:var(--color-fill);text-decoration:none;transition:all var(--transition-duration-fast)}.quick-link[data-v-44648cb1]:hover{background-color:var(--color-primary-light-9);transform:translateY(-2px)}.quick-link__icon[data-v-44648cb1]{font-size:28px;margin-bottom:10px}.quick-link__title[data-v-44648cb1]{font-size:14px;color:var(--color-text-primary)}.activity-list[data-v-44648cb1]{display:flex;flex-direction:column;gap:15px}.activity-item[data-v-44648cb1]{display:flex;align-items:center;gap:10px;padding-bottom:15px;border-bottom:1px solid var(--color-border-lighter)}.activity-item[data-v-44648cb1]:last-child{border-bottom:none;padding-bottom:0}.activity-item__action[data-v-44648cb1]{flex:1;font-size:14px;color:var(--color-text-regular)}.activity-item__time[data-v-44648cb1]{font-size:12px;color:var(--color-text-placeholder)}.system-info[data-v-44648cb1]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 768px){.system-info[data-v-44648cb1]{grid-template-columns:1fr}}.system-info__item[data-v-44648cb1]{display:flex;align-items:center;gap:10px}.system-info__label[data-v-44648cb1]{font-size:14px;color:var(--color-text-secondary);min-width:80px}.system-info__value[data-v-44648cb1]{font-size:14px;color:var(--color-text-primary)}.user-page[data-v-d2491ae0]{padding:20px}.user-page .search-card[data-v-d2491ae0]{margin-bottom:20px}.user-page .toolbar[data-v-d2491ae0]{margin-bottom:15px}.data-table[data-v-d2491ae0]{width:100%;border-collapse:collapse}.data-table th[data-v-d2491ae0],.data-table td[data-v-d2491ae0]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-d2491ae0]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-d2491ae0],.data-table .empty-cell[data-v-d2491ae0]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-d2491ae0]{display:flex;justify-content:flex-end;margin-top:20px}.role-page[data-v-8ad30bc6]{padding:20px}.role-page .search-card[data-v-8ad30bc6]{margin-bottom:20px}.role-page .toolbar[data-v-8ad30bc6]{margin-bottom:15px}.data-table[data-v-8ad30bc6]{width:100%;border-collapse:collapse}.data-table th[data-v-8ad30bc6],.data-table td[data-v-8ad30bc6]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-8ad30bc6]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-8ad30bc6],.data-table .empty-cell[data-v-8ad30bc6]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-8ad30bc6]{display:flex;justify-content:flex-end;margin-top:20px}.menu-page[data-v-2a272a68]{padding:20px}.menu-page .toolbar[data-v-2a272a68]{margin-bottom:15px}.tree-table[data-v-2a272a68]{width:100%;border-collapse:collapse}.tree-table th[data-v-2a272a68],.tree-table td[data-v-2a272a68]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.tree-table th[data-v-2a272a68]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.tree-table .tree-row--level-1 td[data-v-2a272a68]:first-child{padding-left:30px}.tree-indent[data-v-2a272a68]{display:inline-block;width:20px}.menu-name[data-v-2a272a68]{cursor:pointer;color:var(--color-primary)}.menu-name[data-v-2a272a68]:hover{text-decoration:underline}
|
package/dist/utils/auth.d.ts
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Token 管理
|
|
3
3
|
*/
|
|
4
|
-
export interface
|
|
5
|
-
|
|
4
|
+
export interface TokenInfo {
|
|
5
|
+
token: string;
|
|
6
6
|
refreshToken: string;
|
|
7
|
-
|
|
8
|
-
refreshTime: string;
|
|
9
|
-
tokenType: string;
|
|
10
|
-
code: string;
|
|
7
|
+
expireTime: number;
|
|
11
8
|
}
|
|
12
|
-
export declare const getLoginInfo: () => LoginInfo | null;
|
|
13
|
-
export declare const setLoginInfo: (data: Record<string, unknown>) => void;
|
|
14
9
|
export declare const getToken: () => string | null;
|
|
15
|
-
export declare const
|
|
16
|
-
export declare const
|
|
10
|
+
export declare const setToken: (token: string) => void;
|
|
11
|
+
export declare const getRefreshToken: () => string | null;
|
|
12
|
+
export declare const setRefreshToken: (refreshToken: string) => void;
|
|
13
|
+
export declare const getTokenExpire: () => number | null;
|
|
14
|
+
export declare const setTokenExpire: (expireTime: number) => void;
|
|
15
|
+
export declare const setTokenInfo: (info: TokenInfo) => void;
|
|
17
16
|
export declare const clearToken: () => void;
|
|
17
|
+
export declare const isTokenExpired: () => boolean;
|
|
18
18
|
export declare const hasToken: () => boolean;
|
|
@@ -2,7 +2,16 @@
|
|
|
2
2
|
* 权限工具函数
|
|
3
3
|
*/
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
5
|
+
* 检查是否有权限
|
|
6
6
|
* @param permission 权限标识
|
|
7
7
|
*/
|
|
8
8
|
export declare function hasPermission(permission: string | string[]): boolean;
|
|
9
|
+
/**
|
|
10
|
+
* 检查是否有角色
|
|
11
|
+
* @param role 角色标识
|
|
12
|
+
*/
|
|
13
|
+
export declare function hasRole(role: string | string[]): boolean;
|
|
14
|
+
/**
|
|
15
|
+
* 检查是否是管理员
|
|
16
|
+
*/
|
|
17
|
+
export declare function isAdmin(): boolean;
|
package/dist/utils/request.d.ts
CHANGED
|
@@ -1,39 +1,23 @@
|
|
|
1
1
|
import { AxiosInstance, AxiosRequestConfig } from 'axios';
|
|
2
|
-
|
|
3
2
|
export interface ApiResponse<T = unknown> {
|
|
4
3
|
code: number;
|
|
5
4
|
data: T;
|
|
6
5
|
message: string;
|
|
7
6
|
}
|
|
8
7
|
export interface PageParams {
|
|
9
|
-
|
|
8
|
+
pageNo: number;
|
|
10
9
|
pageSize: number;
|
|
11
10
|
}
|
|
12
11
|
export interface PageResponse<T> {
|
|
13
|
-
|
|
12
|
+
records: T[];
|
|
14
13
|
total: number;
|
|
15
|
-
page: number;
|
|
16
|
-
pageSize: number;
|
|
17
14
|
}
|
|
18
|
-
/**
|
|
19
|
-
* 获取请求实例
|
|
20
|
-
*/
|
|
21
|
-
export declare function getRequest(): AxiosInstance;
|
|
22
|
-
/**
|
|
23
|
-
* 重置请求实例(配置变更时调用)
|
|
24
|
-
*/
|
|
25
|
-
export declare function resetRequest(): void;
|
|
26
15
|
declare const request: AxiosInstance;
|
|
27
16
|
export declare const http: {
|
|
28
|
-
get<T = unknown>(url: string, config?: AxiosRequestConfig): Promise<
|
|
29
|
-
post<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<
|
|
30
|
-
put<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<
|
|
31
|
-
patch<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<
|
|
32
|
-
delete<T = unknown>(url: string, config?: AxiosRequestConfig): Promise<
|
|
33
|
-
/**
|
|
34
|
-
* 下载文件(blob 响应)
|
|
35
|
-
* 直接返回 Blob 对象,绕过响应拦截器的业务错误处理
|
|
36
|
-
*/
|
|
37
|
-
download(url: string, config?: AxiosRequestConfig): Promise<Blob>;
|
|
17
|
+
get<T = unknown>(url: string, config?: AxiosRequestConfig): Promise<T>;
|
|
18
|
+
post<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<T>;
|
|
19
|
+
put<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<T>;
|
|
20
|
+
patch<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<T>;
|
|
21
|
+
delete<T = unknown>(url: string, config?: AxiosRequestConfig): Promise<T>;
|
|
38
22
|
};
|
|
39
23
|
export default request;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {},
|
|
1
|
+
declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, HTMLDivElement>;
|
|
2
2
|
export default _default;
|