@utogether/udp-core 1.0.1-beta.15 → 1.0.1-beta.17
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/build/plugins.ts +39 -39
- package/dist/{403-DpJevH-h.js → 403-C3cfjZIT.js} +1 -1
- package/dist/{404-BpqJK3YD.js → 404-Bg3j7QIo.js} +1 -1
- package/dist/{500-DyvRbMD_.js → 500-CMT7Zyy7.js} +1 -1
- package/dist/{AuthorityInfo-Cyu4XHXx.js → AuthorityInfo-B1mvqs4x.js} +1 -1
- package/dist/{AuthorityInfo.vue_vue_type_style_index_0_lang-BxmnEEFq.js → AuthorityInfo.vue_vue_type_style_index_0_lang-DwoW7QWO.js} +3 -3
- package/dist/{Company-BLygcYrI.js → Company-qTguidK8.js} +3 -3
- package/dist/{CompanyPanel-D5Tgw6LF.js → CompanyPanel-BBC-o-k3.js} +17 -17
- package/dist/{Department-qI9OninZ.js → Department-C3mKZOnK.js} +3 -3
- package/dist/{DepartmentPanel-P-P8fPZQ.js → DepartmentPanel-CNdpOHBT.js} +25 -25
- package/dist/{DesignPanel-BxjD0AZi.js → DesignPanel-D9jrRCoG.js} +1 -1
- package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-DN_OKxCu.js → DesignPanel.vue_vue_type_style_index_0_lang-A-Aj1Hl0.js} +6 -6
- package/dist/{DictView-PWL_Vf0T.js → DictView-CgdVkSiP.js} +15 -16
- package/dist/{InvOrganization-JXBXyn3G.js → InvOrganization-RE7s3vBq.js} +1 -1
- package/dist/{Org-DcTJn6YQ.js → Org-wXDGvTrS.js} +3 -3
- package/dist/{Preview-IKvbHI8a.js → Preview-Pvt1__BV.js} +1 -1
- package/dist/{ReportDefine-_G7ts7Ch.js → ReportDefine-xEQsgFyv.js} +1 -1
- package/dist/{ReportDesign-7h5oFklh.js → ReportDesign-jOSuEFH9.js} +9 -9
- package/dist/{ReportQuery-dj0BQUyi.js → ReportQuery-DxEmmGiN.js} +1 -1
- package/dist/{ReportQueryFrom-6WaZPg9i.js → ReportQueryFrom-CFlxfS5M.js} +1 -1
- package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-ChhcBPqa.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-iHpiYz8f.js} +1 -1
- package/dist/{ReportTemplate-DIvJ3RrB.js → ReportTemplate-Dtz3aet7.js} +11 -11
- package/dist/{Role-ia_3qAZU.js → Role-B_NsHIyE.js} +3 -3
- package/dist/{RoleAssign-D0zVl4y3.js → RoleAssign-C9wm4zq4.js} +8 -8
- package/dist/{RolePanel-CQxOiAzj.js → RolePanel-BlHidBR0.js} +1 -1
- package/dist/{RolePanel-BiGGmP2w.js → RolePanel-DWM9mfNs.js} +1 -1
- package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-BYDLRS_x.js → RolePanel.vue_vue_type_script_setup_true_lang-Cn4RRzXm.js} +1 -1
- package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-Dwv5LFbf.js → RolePanel.vue_vue_type_script_setup_true_lang-DVQ9aqb1.js} +9 -9
- package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-gPP4duO8.js → ScrollPanel.vue_vue_type_style_index_0_lang-CCm-_i8O.js} +8 -8
- package/dist/{Staff-Bf_oUqF6.js → Staff-BfDc61QS.js} +3 -3
- package/dist/{StaffInfo-D5aisjx2.js → StaffInfo-BaJFo4mg.js} +1 -1
- package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-6PX7Bx6A.js → StaffInfo.vue_vue_type_script_setup_true_lang-Bwj4x1wu.js} +7 -7
- package/dist/{StaffPanel--zKzd4rt.js → StaffPanel-B6I2ZS6A.js} +1 -1
- package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-BWZSIFpq.js → StaffPanel.vue_vue_type_script_setup_true_lang-vbyS4w3V.js} +2 -2
- package/dist/{SysUser-BelbESLR.js → SysUser-B_r9LYc5.js} +2 -2
- package/dist/{SysUserPanel-BixKqQcA.js → SysUserPanel-C4ajcHPV.js} +1 -1
- package/dist/{SysUserPanel.vue_vue_type_script_setup_true_lang-BhaWZEfo.js → SysUserPanel.vue_vue_type_script_setup_true_lang-8Q0VvC9B.js} +41 -37
- package/dist/{SystemMenu-D40tzcSj.js → SystemMenu-CyPG23uP.js} +10 -10
- package/dist/{UserInfo-DTyk071j.js → UserInfo-BkoGt4ib.js} +1 -1
- package/dist/{UserInfo.vue_vue_type_style_index_0_lang-p9MByikC.js → UserInfo.vue_vue_type_style_index_0_lang-DrzF1YYG.js} +10 -10
- package/dist/{childView-so5qSxr0.js → childView-9vEO8ymO.js} +1 -1
- package/dist/{childView-xL3iE1yN.js → childView-Dh0NyiQe.js} +1 -1
- package/dist/{childView.vue_vue_type_style_index_0_lang-CKcXpSqa.js → childView.vue_vue_type_style_index_0_lang-BOeoZuAK.js} +7 -7
- package/dist/{childView.vue_vue_type_style_index_0_lang-DK1ei5uM.js → childView.vue_vue_type_style_index_0_lang-CMOjfXBX.js} +1 -1
- package/dist/{code-rule-DC35y76w.js → code-rule-C7jI_1gJ.js} +6 -6
- package/dist/core.es.js +17 -12
- package/dist/{cron-task-BhjQ4S68.js → cron-task-Dg9DJXvv.js} +11 -11
- package/dist/{frameView-G_zhG9pf.js → frameView-CeR-_hjB.js} +1 -1
- package/dist/{index-C6ehxLLO.js → index-Bb7gIEvu.js} +739 -496
- package/dist/{layoutView-CO2U8qCQ.js → layoutView-wsLHrEeX.js} +1347 -1346
- package/dist/login-CluzzdqH.js +249 -0
- package/dist/{lov-view-Cr929NMD.js → lov-view-BvQCvwbW.js} +5 -5
- package/dist/{menuInfo-BWuROp7u.js → menuInfo-B8RLelIC.js} +1 -1
- package/dist/{menuInfo.vue_vue_type_style_index_0_lang-9nouHUjO.js → menuInfo.vue_vue_type_style_index_0_lang-DvkapEZr.js} +7 -7
- package/dist/{pda-app-CQP1sMAI.js → pda-app-D3LNmD9a.js} +19 -19
- package/dist/{resource-BDQLrMpK.js → resource-D8JA_03-.js} +7 -7
- package/dist/{su-welcome-CZysrZQ1.js → su-welcome-BjxeEKSo.js} +88 -88
- package/dist/{sys-config-BiGNMYSA.js → sys-config-sbeLk9bP.js} +6 -6
- package/dist/udp-core.css +1 -9
- package/dist/utogether-MlnyYtNS.js +4 -0
- package/index.ts +48 -40
- package/package.json +1 -1
- package/src/App.vue +65 -65
- package/src/components/SuCharts/src/UserInfo.vue +78 -78
- package/src/components/SuScrollTree/ScrollPanel.vue +170 -175
- package/src/components/udp/{grid.vue → grid/index.vue} +27 -24
- package/src/components/udp/index.ts +2 -9
- package/src/components/udp/utils.ts +60 -107
- package/src/layout/components/lay-navbar/index.vue +239 -239
- package/src/layout/components/lay-panel/index.vue +150 -150
- package/src/layout/components/lay-search/index.vue +25 -25
- package/src/layout/components/lay-select-org/index.vue +64 -64
- package/src/layout/components/lay-sidebar/horizontal.vue +190 -190
- package/src/layout/components/lay-sidebar/mixNav.vue +260 -260
- package/src/layout/components/lay-sidebar/sidebar-logo.vue +92 -92
- package/src/layout/components/lay-tag/index.vue +20 -48
- package/src/layout/hooks/useNav.ts +173 -173
- package/src/layout/hooks/useTag.ts +223 -233
- package/src/layout/types.ts +3 -2
- package/src/main.ts +117 -113
- package/src/plugins/i18n/en.ts +302 -302
- package/src/plugins/i18n/zh.ts +356 -354
- package/src/plugins/vxe-table/index.ts +116 -53
- package/src/plugins/vxe-table/render.tsx +956 -956
- package/src/router/index.ts +186 -177
- package/src/router/modules/remaining.ts +58 -58
- package/src/router/utils.ts +393 -377
- package/src/store/modules/app.ts +1 -3
- package/src/store/modules/multiTags.ts +110 -109
- package/src/store/modules/permission.ts +113 -100
- package/src/style/button.scss +85 -85
- package/src/style/login.css +1 -1
- package/src/style/vxetable.scss +25 -2
- package/src/utils/index.ts +3 -1
- package/src/views/organization/company/CompanyPanel.vue +259 -259
- package/src/views/organization/department/DepartmentPanel.vue +269 -283
- package/src/views/system/menu/SystemMenu.vue +183 -183
- package/src/views/system/menu/menuInfo.vue +363 -363
- package/src/views/system/role/UserInfo.vue +195 -195
- package/src/views/system/role-assign/RoleAssign.vue +57 -57
- package/src/views/system/role-assign/RolePanel.vue +139 -139
- package/src/views/system/sys/sys-config.vue +336 -336
- package/src/views/system/sysUser/SysUserPanel.vue +279 -278
- package/src/views/uapp/pda/pda-app.vue +208 -208
- package/src/views/udev/dict/DictView.vue +118 -118
- package/src/views/udev/dict/childView.vue +1 -1
- package/src/views/udev/lov/lov-view.vue +91 -91
- package/src/views/ulogin/login.vue +2 -2
- package/src/views/upms/interface/log-out.vue +101 -101
- package/src/views/urpt/design/DesignPanel.vue +507 -507
- package/types/global.d.ts +2 -8
- package/dist/login-DzyK2soP.js +0 -278
- package/dist/utogether-BRirriOz.js +0 -182
- package/src/components/udp/count-down.vue +0 -536
- package/src/components/udp/flip-down/FlipCard/flip-card.vue +0 -251
- package/src/components/udp/flip-down/FlipCard/interfaces.ts +0 -4
- package/src/components/udp/flip-down/FlipClock/flip-clock.vue +0 -113
- package/src/components/udp/form-upload.vue +0 -482
- package/src/components/udp/form.vue +0 -112
- package/src/components/udp/lov.vue +0 -388
- package/src/components/udp/modal-form.vue +0 -190
- package/src/components/udp/modal-grid.vue +0 -298
- package/src/components/udp/upload.vue +0 -423
- package/src/utils/udp/http/index.ts +0 -294
- package/src/utils/udp/http/types.d.ts +0 -49
- package/src/utils/udp/useRender.ts +0 -431
package/src/store/modules/app.ts
CHANGED
|
@@ -14,9 +14,7 @@ import { responsiveStorageNameSpace, getConfig } from '../../config';
|
|
|
14
14
|
export const useAppStore = defineStore('udp-app', {
|
|
15
15
|
state: (): appType => ({
|
|
16
16
|
sidebar: {
|
|
17
|
-
opened:
|
|
18
|
-
storageLocal.getItem(`${responsiveStorageNameSpace()}layout`)?.sidebarStatus ??
|
|
19
|
-
getConfig().SidebarStatus,
|
|
17
|
+
opened: storageLocal.getItem(`${responsiveStorageNameSpace()}layout`)?.sidebarStatus ?? getConfig().SidebarStatus,
|
|
20
18
|
withoutAnimation: false,
|
|
21
19
|
isClickCollapse: false
|
|
22
20
|
},
|
|
@@ -1,109 +1,110 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* @Author: wei.li
|
|
3
|
-
* @Date: 2021-12-23 17:33:20
|
|
4
|
-
* @LastEditors:
|
|
5
|
-
* @LastEditTime:
|
|
6
|
-
* @Description: file content
|
|
7
|
-
*/
|
|
8
|
-
import { defineStore } from 'pinia';
|
|
9
|
-
import { isEqual, isBoolean } from 'xe-utils';
|
|
10
|
-
import { storageLocal, isUrl } from '@utogether/utils';
|
|
11
|
-
import { store } from '../index';
|
|
12
|
-
import { routerArrays } from '../../layout/types';
|
|
13
|
-
import { usePermissionStoreHook } from './permission';
|
|
14
|
-
import { responsiveStorageNameSpace } from '../../config';
|
|
15
|
-
import type { multiType, positionType } from './types';
|
|
16
|
-
|
|
17
|
-
export const useMultiTagsStore = defineStore('udp-multiTags', {
|
|
18
|
-
state: () => ({
|
|
19
|
-
// 存储标签页信息(路由信息)
|
|
20
|
-
multiTags: storageLocal.getItem(`${responsiveStorageNameSpace()}configure`)?.multiTagsCache
|
|
21
|
-
? storageLocal.getItem(`${responsiveStorageNameSpace()}tags`)
|
|
22
|
-
: [...routerArrays, ...usePermissionStoreHook().flatteningRoutes.filter(v => v?.meta?.fixedTag)],
|
|
23
|
-
multiTagsCache: storageLocal.getItem(`${responsiveStorageNameSpace()}configure`)?.multiTagsCache
|
|
24
|
-
}),
|
|
25
|
-
getters: {
|
|
26
|
-
getMultiTagsCache(state) {
|
|
27
|
-
return state.multiTagsCache;
|
|
28
|
-
}
|
|
29
|
-
},
|
|
30
|
-
actions: {
|
|
31
|
-
multiTagsCacheChange(multiTagsCache: boolean) {
|
|
32
|
-
this.multiTagsCache = multiTagsCache;
|
|
33
|
-
if (multiTagsCache) {
|
|
34
|
-
storageLocal.setItem(`${responsiveStorageNameSpace()}tags`, this.multiTags);
|
|
35
|
-
} else {
|
|
36
|
-
storageLocal.removeItem(`${responsiveStorageNameSpace()}tags`);
|
|
37
|
-
}
|
|
38
|
-
},
|
|
39
|
-
tagsCache(multiTags) {
|
|
40
|
-
this.getMultiTagsCache && storageLocal.setItem(`${responsiveStorageNameSpace()}tags`, multiTags);
|
|
41
|
-
},
|
|
42
|
-
handleTags<T>(mode: string, value?: T | multiType, position?: positionType): T {
|
|
43
|
-
switch (mode) {
|
|
44
|
-
case 'equal':
|
|
45
|
-
this.multiTags = value;
|
|
46
|
-
this.tagsCache(this.multiTags);
|
|
47
|
-
break;
|
|
48
|
-
case 'push':
|
|
49
|
-
{
|
|
50
|
-
const tagVal = value as multiType;
|
|
51
|
-
// 不添加到标签页
|
|
52
|
-
if (tagVal?.meta?.hiddenTag) return;
|
|
53
|
-
// 如果是外链无需添加信息到标签页
|
|
54
|
-
if (isUrl(tagVal?.name)) return;
|
|
55
|
-
// 如果title为空拒绝添加空信息到标签页
|
|
56
|
-
if (tagVal?.meta?.title?.length === 0) return;
|
|
57
|
-
// showLink:false 不添加到标签页
|
|
58
|
-
if (isBoolean(tagVal?.meta?.showLink) && !tagVal?.meta?.showLink) return;
|
|
59
|
-
const tagPath = tagVal.path;
|
|
60
|
-
// 判断tag是否已存在
|
|
61
|
-
const tagHasExits = this.multiTags.some(tag => {
|
|
62
|
-
return tag.path === tagPath;
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
// 判断tag中的query键值是否相等
|
|
66
|
-
const tagQueryHasExits = this.multiTags.some(tag => {
|
|
67
|
-
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
// 判断tag中的params键值是否相等
|
|
71
|
-
const tagParamsHasExits = this.multiTags.some(tag => {
|
|
72
|
-
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
if (tagHasExits && tagQueryHasExits && tagParamsHasExits) return;
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
index
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
this.
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
1
|
+
/*
|
|
2
|
+
* @Author: wei.li
|
|
3
|
+
* @Date: 2021-12-23 17:33:20
|
|
4
|
+
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
+
* @LastEditTime: 2025-10-19 12:01:05
|
|
6
|
+
* @Description: file content
|
|
7
|
+
*/
|
|
8
|
+
import { defineStore } from 'pinia';
|
|
9
|
+
import { isEqual, isBoolean } from 'xe-utils';
|
|
10
|
+
import { storageLocal, isUrl } from '@utogether/utils';
|
|
11
|
+
import { store } from '../index';
|
|
12
|
+
import { routerArrays } from '../../layout/types';
|
|
13
|
+
import { usePermissionStoreHook } from './permission';
|
|
14
|
+
import { responsiveStorageNameSpace } from '../../config';
|
|
15
|
+
import type { multiType, positionType } from './types';
|
|
16
|
+
|
|
17
|
+
export const useMultiTagsStore = defineStore('udp-multiTags', {
|
|
18
|
+
state: () => ({
|
|
19
|
+
// 存储标签页信息(路由信息)
|
|
20
|
+
multiTags: storageLocal.getItem(`${responsiveStorageNameSpace()}configure`)?.multiTagsCache
|
|
21
|
+
? storageLocal.getItem(`${responsiveStorageNameSpace()}tags`)
|
|
22
|
+
: [...routerArrays, ...usePermissionStoreHook().flatteningRoutes.filter(v => v?.meta?.fixedTag)],
|
|
23
|
+
multiTagsCache: storageLocal.getItem(`${responsiveStorageNameSpace()}configure`)?.multiTagsCache
|
|
24
|
+
}),
|
|
25
|
+
getters: {
|
|
26
|
+
getMultiTagsCache(state) {
|
|
27
|
+
return state.multiTagsCache;
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
actions: {
|
|
31
|
+
multiTagsCacheChange(multiTagsCache: boolean) {
|
|
32
|
+
this.multiTagsCache = multiTagsCache;
|
|
33
|
+
if (multiTagsCache) {
|
|
34
|
+
storageLocal.setItem(`${responsiveStorageNameSpace()}tags`, this.multiTags);
|
|
35
|
+
} else {
|
|
36
|
+
storageLocal.removeItem(`${responsiveStorageNameSpace()}tags`);
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
tagsCache(multiTags) {
|
|
40
|
+
this.getMultiTagsCache && storageLocal.setItem(`${responsiveStorageNameSpace()}tags`, multiTags);
|
|
41
|
+
},
|
|
42
|
+
handleTags<T>(mode: string, value?: T | multiType, position?: positionType): T {
|
|
43
|
+
switch (mode) {
|
|
44
|
+
case 'equal':
|
|
45
|
+
this.multiTags = value;
|
|
46
|
+
this.tagsCache(this.multiTags);
|
|
47
|
+
break;
|
|
48
|
+
case 'push':
|
|
49
|
+
{
|
|
50
|
+
const tagVal = value as multiType;
|
|
51
|
+
// 不添加到标签页
|
|
52
|
+
if (tagVal?.meta?.hiddenTag) return;
|
|
53
|
+
// 如果是外链无需添加信息到标签页
|
|
54
|
+
if (isUrl(tagVal?.name)) return;
|
|
55
|
+
// 如果title为空拒绝添加空信息到标签页
|
|
56
|
+
if (tagVal?.meta?.title?.length === 0) return;
|
|
57
|
+
// showLink:false 不添加到标签页
|
|
58
|
+
if (isBoolean(tagVal?.meta?.showLink) && !tagVal?.meta?.showLink) return;
|
|
59
|
+
const tagPath = tagVal.path;
|
|
60
|
+
// 判断tag是否已存在
|
|
61
|
+
const tagHasExits = this.multiTags.some(tag => {
|
|
62
|
+
return tag.path === tagPath && isEqual(tag?.query, tagVal?.query) && isEqual(tag?.params, tagVal?.params);
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
// 判断tag中的query键值是否相等
|
|
66
|
+
// const tagQueryHasExits = this.multiTags.some(tag => {
|
|
67
|
+
// return isEqual(tag?.query, tagVal?.query);
|
|
68
|
+
// });
|
|
69
|
+
|
|
70
|
+
// // 判断tag中的params键值是否相等
|
|
71
|
+
// const tagParamsHasExits = this.multiTags.some(tag => {
|
|
72
|
+
// return isEqual(tag?.params, tagVal?.params);
|
|
73
|
+
// });
|
|
74
|
+
|
|
75
|
+
// if (tagHasExits && tagQueryHasExits && tagParamsHasExits) return;
|
|
76
|
+
if (tagHasExits) return;
|
|
77
|
+
|
|
78
|
+
// 动态路由可打开的最大数量
|
|
79
|
+
const dynamicLevel = tagVal?.meta?.dynamicLevel ?? -1;
|
|
80
|
+
if (dynamicLevel > 0) {
|
|
81
|
+
if (this.multiTags.filter(e => e?.path === tagPath).length >= dynamicLevel) {
|
|
82
|
+
// 如果当前已打开的动态路由数大于dynamicLevel,替换第一个动态路由标签
|
|
83
|
+
const index = this.multiTags.findIndex(item => item?.path === tagPath);
|
|
84
|
+
index !== -1 && this.multiTags.splice(index, 1);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
this.multiTags.push(value);
|
|
88
|
+
this.tagsCache(this.multiTags);
|
|
89
|
+
}
|
|
90
|
+
break;
|
|
91
|
+
case 'splice':
|
|
92
|
+
if (!position) {
|
|
93
|
+
const index = this.multiTags.findIndex(v => v.path === value);
|
|
94
|
+
if (index === -1) return;
|
|
95
|
+
this.multiTags.splice(index, 1);
|
|
96
|
+
} else {
|
|
97
|
+
this.multiTags.splice(position?.startIndex, position?.length);
|
|
98
|
+
}
|
|
99
|
+
this.tagsCache(this.multiTags);
|
|
100
|
+
return this.multiTags;
|
|
101
|
+
case 'slice':
|
|
102
|
+
return this.multiTags.slice(-1);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
export function useMultiTagsStoreHook() {
|
|
109
|
+
return useMultiTagsStore(store);
|
|
110
|
+
}
|
|
@@ -1,100 +1,113 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* @Author: wei.li
|
|
3
|
-
* @Date: 2021-11-17 16:02:30
|
|
4
|
-
* @LastEditors:
|
|
5
|
-
* @LastEditTime:
|
|
6
|
-
* @Description: file content
|
|
7
|
-
*/
|
|
8
|
-
import { defineStore } from 'pinia';
|
|
9
|
-
import { store } from '../index';
|
|
10
|
-
import type { cacheType } from './types';
|
|
11
|
-
import { constantMenus } from '../../router';
|
|
12
|
-
import { clone,
|
|
13
|
-
import { getKeyList } from '../../utils';
|
|
14
|
-
import { ascending, filterTree, formatFlatteningRoutes } from '../../router/utils';
|
|
15
|
-
import { useMultiTagsStoreHook } from './multiTags';
|
|
16
|
-
|
|
17
|
-
export const usePermissionStore = defineStore('udp-permission', {
|
|
18
|
-
state: () => ({
|
|
19
|
-
// 静态路由生成的菜单
|
|
20
|
-
constantMenus,
|
|
21
|
-
// 整体路由生成的菜单(静态、动态)
|
|
22
|
-
wholeMenus: [],
|
|
23
|
-
// 深拷贝一个菜单树,与导航菜单不冲突
|
|
24
|
-
menusTree: [],
|
|
25
|
-
// 整体路由(一维数组格式)
|
|
26
|
-
flatteningRoutes: [],
|
|
27
|
-
buttonAuth: [],
|
|
28
|
-
// 缓存页面keepAlive
|
|
29
|
-
cachePageList: []
|
|
30
|
-
}),
|
|
31
|
-
getters: {
|
|
32
|
-
getButtonAuth() {
|
|
33
|
-
return this.buttonAuth;
|
|
34
|
-
}
|
|
35
|
-
},
|
|
36
|
-
actions: {
|
|
37
|
-
asyncActionRoutes(routes = []) {
|
|
38
|
-
if (this.wholeMenus.length > 0) return;
|
|
39
|
-
const idx = findLastIndexOf(routes, item => item.menuCode === 'SysHome');
|
|
40
|
-
const constantMenus = clone(this.constantMenus, true);
|
|
41
|
-
if (idx !== -1) {
|
|
42
|
-
const homeRouter = this.constantMenus.find(f => f.name === 'home');
|
|
43
|
-
// 过滤非路由分类非菜单的数据
|
|
44
|
-
routes[idx].children && homeRouter.children.push(...routes[idx].children);
|
|
45
|
-
routes.splice(idx, 1);
|
|
46
|
-
}
|
|
47
|
-
this.wholeMenus = filterTree(ascending(this.constantMenus.concat(routes)));
|
|
48
|
-
this.flatteningRoutes = formatFlatteningRoutes(this.constantMenus.concat(routes));
|
|
49
|
-
this.menusTree = clone(this.wholeMenus, true);
|
|
50
|
-
this.constantMenus = constantMenus;
|
|
51
|
-
},
|
|
52
|
-
async changeSetting(routes) {
|
|
53
|
-
await this.asyncActionRoutes(routes);
|
|
54
|
-
},
|
|
55
|
-
setAuthButton(buttonAuth) {
|
|
56
|
-
this.buttonAuth = buttonAuth;
|
|
57
|
-
},
|
|
58
|
-
setWholeMenus(wholeMenus) {
|
|
59
|
-
this.wholeMenus = wholeMenus;
|
|
60
|
-
},
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
this.cachePageList.
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
}
|
|
1
|
+
/*
|
|
2
|
+
* @Author: wei.li
|
|
3
|
+
* @Date: 2021-11-17 16:02:30
|
|
4
|
+
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
+
* @LastEditTime: 2025-10-19 11:58:29
|
|
6
|
+
* @Description: file content
|
|
7
|
+
*/
|
|
8
|
+
import { defineStore } from 'pinia';
|
|
9
|
+
import { store } from '../index';
|
|
10
|
+
import type { cacheType } from './types';
|
|
11
|
+
import { constantMenus } from '../../router';
|
|
12
|
+
import { clone, findLastIndexOf } from 'xe-utils';
|
|
13
|
+
import { getKeyList } from '../../utils';
|
|
14
|
+
import { ascending, filterTree, formatFlatteningRoutes } from '../../router/utils';
|
|
15
|
+
import { useMultiTagsStoreHook } from './multiTags';
|
|
16
|
+
|
|
17
|
+
export const usePermissionStore = defineStore('udp-permission', {
|
|
18
|
+
state: () => ({
|
|
19
|
+
// 静态路由生成的菜单
|
|
20
|
+
constantMenus,
|
|
21
|
+
// 整体路由生成的菜单(静态、动态)
|
|
22
|
+
wholeMenus: [],
|
|
23
|
+
// 深拷贝一个菜单树,与导航菜单不冲突
|
|
24
|
+
menusTree: [],
|
|
25
|
+
// 整体路由(一维数组格式)
|
|
26
|
+
flatteningRoutes: [],
|
|
27
|
+
buttonAuth: [],
|
|
28
|
+
// 缓存页面keepAlive
|
|
29
|
+
cachePageList: []
|
|
30
|
+
}),
|
|
31
|
+
getters: {
|
|
32
|
+
getButtonAuth() {
|
|
33
|
+
return this.buttonAuth;
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
actions: {
|
|
37
|
+
asyncActionRoutes(routes = []) {
|
|
38
|
+
if (this.wholeMenus.length > 0) return;
|
|
39
|
+
const idx = findLastIndexOf(routes, item => item.menuCode === 'SysHome');
|
|
40
|
+
const constantMenus = clone(this.constantMenus, true);
|
|
41
|
+
if (idx !== -1) {
|
|
42
|
+
const homeRouter = this.constantMenus.find(f => f.name === 'home');
|
|
43
|
+
// 过滤非路由分类非菜单的数据
|
|
44
|
+
routes[idx].children && homeRouter.children.push(...routes[idx].children);
|
|
45
|
+
routes.splice(idx, 1);
|
|
46
|
+
}
|
|
47
|
+
this.wholeMenus = filterTree(ascending(this.constantMenus.concat(routes)));
|
|
48
|
+
this.flatteningRoutes = formatFlatteningRoutes(this.constantMenus.concat(routes));
|
|
49
|
+
this.menusTree = clone(this.wholeMenus, true);
|
|
50
|
+
this.constantMenus = constantMenus;
|
|
51
|
+
},
|
|
52
|
+
async changeSetting(routes) {
|
|
53
|
+
await this.asyncActionRoutes(routes);
|
|
54
|
+
},
|
|
55
|
+
setAuthButton(buttonAuth) {
|
|
56
|
+
this.buttonAuth = buttonAuth;
|
|
57
|
+
},
|
|
58
|
+
setWholeMenus(wholeMenus) {
|
|
59
|
+
this.wholeMenus = wholeMenus;
|
|
60
|
+
},
|
|
61
|
+
|
|
62
|
+
/** 监听缓存页面是否存在于标签页,不存在则删除 */
|
|
63
|
+
clearCache() {
|
|
64
|
+
let cacheLength = this.cachePageList.length;
|
|
65
|
+
const nameList = getKeyList(useMultiTagsStoreHook().multiTags, 'name');
|
|
66
|
+
while (cacheLength > 0) {
|
|
67
|
+
nameList.findIndex(v => v === this.cachePageList[cacheLength - 1]) === -1 &&
|
|
68
|
+
this.cachePageList.splice(this.cachePageList.indexOf(this.cachePageList[cacheLength - 1]), 1);
|
|
69
|
+
cacheLength--;
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
cacheOperate({ mode, name }: cacheType) {
|
|
73
|
+
const delIndex = this.cachePageList.findIndex(v => v === name);
|
|
74
|
+
switch (mode) {
|
|
75
|
+
case 'refresh':
|
|
76
|
+
this.cachePageList = this.cachePageList.filter(v => v !== name);
|
|
77
|
+
this.clearCache();
|
|
78
|
+
break;
|
|
79
|
+
case 'add':
|
|
80
|
+
this.cachePageList.push(name);
|
|
81
|
+
break;
|
|
82
|
+
case 'delete':
|
|
83
|
+
delIndex !== -1 && this.cachePageList.splice(delIndex, 1);
|
|
84
|
+
this.clearCache();
|
|
85
|
+
break;
|
|
86
|
+
case 'reset':
|
|
87
|
+
this.cachePageList = [];
|
|
88
|
+
break;
|
|
89
|
+
}
|
|
90
|
+
/** 监听缓存页面是否存在于标签页,不存在则删除 */
|
|
91
|
+
// debounce(() => {
|
|
92
|
+
// let cacheLength = this.cachePageList.length;
|
|
93
|
+
// const nameList = getKeyList(useMultiTagsStoreHook().multiTags, 'name');
|
|
94
|
+
// while (cacheLength > 0) {
|
|
95
|
+
// nameList.findIndex(v => v === this.cachePageList[cacheLength - 1]) === -1 &&
|
|
96
|
+
// this.cachePageList.splice(this.cachePageList.indexOf(this.cachePageList[cacheLength - 1]), 1);
|
|
97
|
+
// cacheLength--;
|
|
98
|
+
// }
|
|
99
|
+
// }, 500)();
|
|
100
|
+
},
|
|
101
|
+
/** 清空缓存页面 */
|
|
102
|
+
clearAllCachePage() {
|
|
103
|
+
this.wholeMenus = [];
|
|
104
|
+
this.menusTree = [];
|
|
105
|
+
this.buttonAuth = [];
|
|
106
|
+
this.cachePageList = [];
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
export function usePermissionStoreHook() {
|
|
112
|
+
return usePermissionStore(store);
|
|
113
|
+
}
|
package/src/style/button.scss
CHANGED
|
@@ -1,85 +1,85 @@
|
|
|
1
|
-
.vxe-button.size--mini.type--button {
|
|
2
|
-
height: 25px;
|
|
3
|
-
}
|
|
4
|
-
|
|
5
|
-
.vxe-button.size--small.type--button {
|
|
6
|
-
height: 25px;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
.vxe-button.type--button.theme--u-cyan,
|
|
10
|
-
.vxe-button.type--button.theme--u-cyan:hover {
|
|
11
|
-
color: #fff;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
.vxe-button.type--button.theme--u-cyan {
|
|
15
|
-
background-color: #1cbbb4;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
.vxe-button.type--button.theme--u-cyan:active {
|
|
19
|
-
background-color: #39b54a;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
// 禁用状态
|
|
23
|
-
.vxe-button.type--button.theme--u-cyan.is--disabled {
|
|
24
|
-
background-color: #69e4de;
|
|
25
|
-
border-color: #69e4de;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
.vxe-button.type--button.theme--u-color-shallow,
|
|
29
|
-
.vxe-button.type--button.theme--u-color-shallow:hover {
|
|
30
|
-
color: #fff;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
.vxe-button.type--button.theme--u-color-shallow {
|
|
34
|
-
background-color: #fbbd08;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
.vxe-button.type--button.theme--u-color-shallow:active {
|
|
38
|
-
background-color: #fff;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
.layout-theme-default .vxe-button.type--button.theme--u-cyan:not(.is--disabled):hover {
|
|
42
|
-
background-color: #40e0d0;
|
|
43
|
-
border-color: #40e0d0;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
.vxe-button.type--button:not(.is--disabled):hover {
|
|
47
|
-
color:
|
|
48
|
-
|
|
49
|
-
.vxe-button--icon,
|
|
50
|
-
.vxe-button--item {
|
|
51
|
-
color: inherit;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
.vxe-button[name='favorite'].type--button:not(.is--disabled):hover {
|
|
56
|
-
.vxe-button--item {
|
|
57
|
-
color: var(--udp-theme-vxeColor);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
.u-color-royalBlue {
|
|
62
|
-
color: #4169e1;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
.u-color-turquoise {
|
|
66
|
-
color: #40e0d0;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
.el-dropdown {
|
|
70
|
-
.el-dropdown__caret-button {
|
|
71
|
-
margin-left: 0;
|
|
72
|
-
border-top-left-radius: 0;
|
|
73
|
-
border-bottom-left-radius: 0;
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
.el-button-group + .el-button {
|
|
77
|
-
border-top-right-radius: 0 !important;
|
|
78
|
-
border-bottom-right-radius: 0 !important;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
.el-button:first-child {
|
|
82
|
-
border-top-right-radius: 0 !important;
|
|
83
|
-
border-bottom-right-radius: 0 !important;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
1
|
+
.vxe-button.size--mini.type--button {
|
|
2
|
+
height: 25px;
|
|
3
|
+
}
|
|
4
|
+
|
|
5
|
+
.vxe-button.size--small.type--button {
|
|
6
|
+
height: 25px;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.vxe-button.type--button.theme--u-cyan,
|
|
10
|
+
.vxe-button.type--button.theme--u-cyan:hover {
|
|
11
|
+
color: #fff;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.vxe-button.type--button.theme--u-cyan {
|
|
15
|
+
background-color: #1cbbb4;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
.vxe-button.type--button.theme--u-cyan:active {
|
|
19
|
+
background-color: #39b54a;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// 禁用状态
|
|
23
|
+
.vxe-button.type--button.theme--u-cyan.is--disabled {
|
|
24
|
+
background-color: #69e4de;
|
|
25
|
+
border-color: #69e4de;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
.vxe-button.type--button.theme--u-color-shallow,
|
|
29
|
+
.vxe-button.type--button.theme--u-color-shallow:hover {
|
|
30
|
+
color: #fff;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.vxe-button.type--button.theme--u-color-shallow {
|
|
34
|
+
background-color: #fbbd08;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.vxe-button.type--button.theme--u-color-shallow:active {
|
|
38
|
+
background-color: #fff;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.layout-theme-default .vxe-button.type--button.theme--u-cyan:not(.is--disabled):hover {
|
|
42
|
+
background-color: #40e0d0;
|
|
43
|
+
border-color: #40e0d0;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.vxe-button.type--button:not(.is--disabled):hover {
|
|
47
|
+
color: inherit;
|
|
48
|
+
|
|
49
|
+
.vxe-button--icon,
|
|
50
|
+
.vxe-button--item {
|
|
51
|
+
color: inherit;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.vxe-button[name='favorite'].type--button:not(.is--disabled):hover {
|
|
56
|
+
.vxe-button--item {
|
|
57
|
+
color: var(--udp-theme-vxeColor);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
.u-color-royalBlue {
|
|
62
|
+
color: #4169e1;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.u-color-turquoise {
|
|
66
|
+
color: #40e0d0;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.el-dropdown {
|
|
70
|
+
.el-dropdown__caret-button {
|
|
71
|
+
margin-left: 0;
|
|
72
|
+
border-top-left-radius: 0;
|
|
73
|
+
border-bottom-left-radius: 0;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
.el-button-group + .el-button {
|
|
77
|
+
border-top-right-radius: 0 !important;
|
|
78
|
+
border-bottom-right-radius: 0 !important;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
.el-button:first-child {
|
|
82
|
+
border-top-right-radius: 0 !important;
|
|
83
|
+
border-bottom-right-radius: 0 !important;
|
|
84
|
+
}
|
|
85
|
+
}
|
package/src/style/login.css
CHANGED
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
height: 100vh;
|
|
12
12
|
display: flex;
|
|
13
13
|
justify-content: flex-end;
|
|
14
|
-
background-color: #
|
|
14
|
+
background-color: #2a5f97;
|
|
15
15
|
/* background: url('../assets/login/default-bg.png') no-repeat center; */
|
|
16
16
|
background-repeat: no-repeat;
|
|
17
17
|
background-position: center;
|