adtec-core-package 2.1.8 → 2.2.0
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/README.en.md +36 -36
- package/adtec-core-package/adtec-core-package.css +1 -0
- package/adtec-core-package/adtec-core-package.js +41605 -0
- package/adtec-core-package/adtec-core-package.umd.cjs +79 -0
- package/adtec-core-package/favicon.ico +0 -0
- package/eslint.config.js +21 -11
- package/package.json +71 -71
- package/src/api/BasicApi.ts +26 -26
- package/src/api/DeptInfoApi.ts +19 -19
- package/src/api/DocumentApi.ts +27 -27
- package/src/api/EmployeeInfoApi.ts +17 -17
- package/src/api/SysDictCacheApi.ts +29 -29
- package/src/api/SysUserApi.ts +35 -35
- package/src/api/framework.ts +12 -12
- package/src/api/workflow/workflow.ts +31 -31
- package/src/api/workflow/workflowInstApi.ts +72 -72
- package/src/assets/style/ant.scss +19 -19
- package/src/assets/style/index.less +180 -180
- package/src/components/ElCardList.vue +64 -64
- package/src/components/ElFlex/ElFlex.vue +297 -297
- package/src/components/ElTotalTools.vue +70 -70
- package/src/components/OperationAuth/operationAuth.vue +32 -32
- package/src/components/RichTextEditor/RichTextEditor.vue +414 -402
- package/src/components/Scrollbars/ElScrollbars.vue +21 -21
- package/src/components/Search/ElIconSearch.vue +267 -267
- package/src/components/Search/ElSearch.vue +154 -154
- package/src/components/SelectInDicators/SelectInDicators.vue +225 -225
- package/src/components/SelectInDicators/api/DataIndicatorsApi.ts +28 -28
- package/src/components/SelectInDicators/interface/IComIndex.ts +26 -26
- package/src/components/SelectInDicators/interface/IComIndexAttri.ts +18 -18
- package/src/components/Table/ElTableColumnDynamic.vue +25 -25
- package/src/components/Table/ElTableColumnEdit.vue +265 -265
- package/src/components/Table/ElTableTool.ts +37 -37
- package/src/components/Title/ElTitle.vue +53 -53
- package/src/components/autoToolTip/ElAutoToolTip.vue +62 -62
- package/src/components/baseEcharts/index.vue +48 -48
- package/src/components/bpmntree/api/modules/role.ts +31 -31
- package/src/components/bpmntree/api/modules/user.ts +17 -17
- package/src/components/bpmntree/components/AdvancedFilter/Operator.vue +112 -112
- package/src/components/bpmntree/components/AdvancedFilter/Trigger.vue +23 -23
- package/src/components/bpmntree/components/AdvancedFilter/index.vue +230 -230
- package/src/components/bpmntree/components/AdvancedFilter/type.ts +20 -20
- package/src/components/bpmntree/components/FlowIcon/index.scss +7 -7
- package/src/components/bpmntree/components/FlowIcon/index.tsx +68 -68
- package/src/components/bpmntree/components/Render/render.vue +90 -90
- package/src/components/bpmntree/components/Render/type.ts +12 -12
- package/src/components/bpmntree/components/RoleSelector/RolePicker.vue +264 -264
- package/src/components/bpmntree/components/RoleSelector/RoleTag.vue +48 -48
- package/src/components/bpmntree/components/RoleSelector/index.vue +113 -113
- package/src/components/bpmntree/components/UserSelector/UserTag.vue +73 -73
- package/src/components/bpmntree/components/UserSelector/index.vue +140 -140
- package/src/components/bpmntree/hooks/useDraggableScroll.ts +44 -44
- package/src/components/bpmntree/typings/index.d.ts +1 -1
- package/src/components/bpmntree/views/flowDesign/index.vue +653 -653
- package/src/components/bpmntree/views/flowDesign/nodes/Add.vue +184 -184
- package/src/components/bpmntree/views/flowDesign/nodes/ApprovalNode.vue +127 -127
- package/src/components/bpmntree/views/flowDesign/nodes/CcNode.vue +93 -93
- package/src/components/bpmntree/views/flowDesign/nodes/ConcurrentNode.vue +61 -61
- package/src/components/bpmntree/views/flowDesign/nodes/ConditionNode.vue +60 -60
- package/src/components/bpmntree/views/flowDesign/nodes/EndNode.vue +80 -80
- package/src/components/bpmntree/views/flowDesign/nodes/ExclusiveNode.vue +20 -20
- package/src/components/bpmntree/views/flowDesign/nodes/GatewayNode.vue +173 -173
- package/src/components/bpmntree/views/flowDesign/nodes/InclusiveNode.vue +20 -20
- package/src/components/bpmntree/views/flowDesign/nodes/JumpNode.vue +49 -49
- package/src/components/bpmntree/views/flowDesign/nodes/Node.vue +346 -346
- package/src/components/bpmntree/views/flowDesign/nodes/NotifyNode.vue +115 -115
- package/src/components/bpmntree/views/flowDesign/nodes/ParallelNode.vue +20 -20
- package/src/components/bpmntree/views/flowDesign/nodes/PopoverView.vue +78 -78
- package/src/components/bpmntree/views/flowDesign/nodes/StartNode.vue +84 -84
- package/src/components/bpmntree/views/flowDesign/nodes/TimerNode.vue +50 -50
- package/src/components/bpmntree/views/flowDesign/nodes/TreeNode.vue +45 -45
- package/src/components/bpmntree/views/flowDesign/nodes/type.ts +196 -196
- package/src/components/bpmntree/views/flowDesign/panels/ApprovalPanel.vue +553 -553
- package/src/components/bpmntree/views/flowDesign/panels/AssigneePanel.vue +120 -120
- package/src/components/bpmntree/views/flowDesign/panels/CcPanel.vue +99 -99
- package/src/components/bpmntree/views/flowDesign/panels/ConditionPanel.vue +41 -41
- package/src/components/bpmntree/views/flowDesign/panels/EndPanel.vue +18 -18
- package/src/components/bpmntree/views/flowDesign/panels/ExecutionListeners.vue +110 -110
- package/src/components/bpmntree/views/flowDesign/panels/JumpPanel.vue +32 -32
- package/src/components/bpmntree/views/flowDesign/panels/NotifyPanel.vue +101 -101
- package/src/components/bpmntree/views/flowDesign/panels/ParaPanel.vue +248 -248
- package/src/components/bpmntree/views/flowDesign/panels/StartPanel.vue +160 -160
- package/src/components/bpmntree/views/flowDesign/panels/TaskListeners.vue +110 -110
- package/src/components/bpmntree/views/flowDesign/panels/TimerPanel.vue +51 -51
- package/src/components/bpmntree/views/flowDesign/panels/index.vue +85 -85
- package/src/components/bpmntree/views/view.index.vue +291 -291
- package/src/components/business/comp.selectUser.vue +60 -60
- package/src/components/business/comp.userForm.vue +311 -311
- package/src/components/business/userSelect.vue +413 -413
- package/src/components/icon/ElIconBtn.vue +243 -243
- package/src/components/kFrame/IframeOptions.ts +116 -116
- package/src/components/kFrame/KFrame.vue +161 -161
- package/src/components/upload/ElUploads.vue +331 -331
- package/src/components/upload/FileView.vue +214 -213
- package/src/components/upload/FileViewComponents.vue +56 -56
- package/src/components/workflow/TaskOperation.vue +240 -240
- package/src/components/workflow/WorkflowTodoDialog.vue +83 -83
- package/src/components/workflow/components/AddOrMinusMultiDialog.vue +159 -159
- package/src/components/workflow/components/CheckDialog.vue +350 -350
- package/src/components/workflow/components/ProcessDetailComp.vue +149 -149
- package/src/components/workflow/components/ProcessDetailDialog.vue +129 -129
- package/src/components/workflow/components/ProcessInstance.vue +117 -117
- package/src/components/workflow/components/ProcessInstanceStep.vue +266 -266
- package/src/components/workflow/components/SelectAssigneeDialog.vue +109 -109
- package/src/components/workflow/components/SelectReturnActivityDialog.vue +104 -104
- package/src/config/ElementPlusConfig.ts +95 -95
- package/src/config/VxeTableConfig.ts +247 -247
- package/src/css/elementUI/autocomplete.scss +89 -89
- package/src/css/elementUI/checkbox.scss +298 -298
- package/src/css/elementUI/common/var.scss +1549 -1549
- package/src/css/elementUI/date-picker/picker.scss +219 -219
- package/src/css/elementUI/descriptions.scss +152 -152
- package/src/css/elementUI/drawer.scss +164 -164
- package/src/css/elementUI/radio.scss +215 -215
- package/src/css/elementUI/table.scss +697 -697
- package/src/css/elementUI/tabs.scss +659 -659
- package/src/css/vxeTableUI/all.scss +9 -9
- package/src/css/vxeTableUI/base.scss +16 -16
- package/src/css/vxeTableUI/components/colgroup.scss +0 -0
- package/src/css/vxeTableUI/components/column.scss +0 -0
- package/src/css/vxeTableUI/components/grid.scss +83 -83
- package/src/css/vxeTableUI/components/icon.scss +1017 -1017
- package/src/css/vxeTableUI/components/iconTable.scss +205 -205
- package/src/css/vxeTableUI/components/old-icon.scss +715 -715
- package/src/css/vxeTableUI/components/table-module/all.scss +6 -6
- package/src/css/vxeTableUI/components/table-module/custom.scss +490 -490
- package/src/css/vxeTableUI/components/table-module/edit.scss +0 -0
- package/src/css/vxeTableUI/components/table-module/export.scss +130 -130
- package/src/css/vxeTableUI/components/table-module/filter.scss +127 -127
- package/src/css/vxeTableUI/components/table-module/keyboard.scss +0 -0
- package/src/css/vxeTableUI/components/table-module/menu.scss +85 -85
- package/src/css/vxeTableUI/components/table-module/validator.scss +0 -0
- package/src/css/vxeTableUI/components/table.scss +2256 -2256
- package/src/css/vxeTableUI/components/toolbar.scss +99 -99
- package/src/css/vxeTableUI/components/ui.scss +0 -0
- package/src/css/vxeTableUI/components/v-x-e-table.scss +0 -0
- package/src/css/vxeTableUI/cssvar.scss +2 -2
- package/src/css/vxeTableUI/default.scss +2 -2
- package/src/css/vxeTableUI/helpers/baseMixin.scss +82 -82
- package/src/css/vxeTableUI/icon/iconfont.ttf +0 -0
- package/src/css/vxeTableUI/icon/iconfont.woff +0 -0
- package/src/css/vxeTableUI/icon/iconfont.woff2 +0 -0
- package/src/css/vxeTableUI/index.scss +4 -4
- package/src/css/vxeTableUI/modules.scss +5 -5
- package/src/css/vxeTableUI/theme/base.scss +88 -88
- package/src/css/vxeTableUI/theme/dark.scss +46 -46
- package/src/css/vxeTableUI/theme/light.scss +41 -41
- package/src/css/vxeTableUI/variable.scss +41 -41
- package/src/directives/vKeydown.ts +91 -91
- package/src/hooks/useDictHooks.ts +119 -119
- package/src/hooks/useEcharts.ts +58 -58
- package/src/hooks/useFileView.ts +11 -11
- package/src/hooks/useListenerHooks.ts +137 -137
- package/src/hooks/useMessageHooks.ts +132 -132
- package/src/hooks/usePermissionToolHooks.ts +21 -21
- package/src/hooks/useResetRefHooks.ts +18 -18
- package/src/hooks/userWorkflowHooks.ts +106 -106
- package/src/hooks/workflowTodo.ts +85 -85
- package/src/interface/BaseEntity.ts +30 -30
- package/src/interface/IMdmDept.ts +84 -84
- package/src/interface/IMdmEmployee.ts +153 -153
- package/src/interface/IMdmEmployeeQuery.ts +21 -21
- package/src/interface/IMdmOrg.ts +29 -29
- package/src/interface/IMdmOrgQuery.ts +13 -13
- package/src/interface/IOrgDeptInfo.ts +12 -12
- package/src/interface/ISortList.ts +6 -6
- package/src/interface/ISysDictDataCacheVo.ts +46 -46
- package/src/interface/ISysDictType.ts +37 -37
- package/src/interface/ISysMenuDataVo.ts +22 -22
- package/src/interface/ISysMenuInfoVo.ts +83 -83
- package/src/interface/ISysMenuOperationVo.ts +21 -21
- package/src/interface/ISysUploadFiles.ts +16 -16
- package/src/interface/ISysUserInfo.ts +70 -70
- package/src/interface/IUserBaseInfo.ts +90 -90
- package/src/interface/IUserPermissionVo.ts +41 -41
- package/src/interface/IVxeTable.ts +1 -1
- package/src/interface/Message.ts +73 -72
- package/src/interface/PageData.ts +17 -17
- package/src/interface/ResponseData.ts +16 -16
- package/src/interface/dictMapType.ts +11 -11
- package/src/interface/enum/MessageEnum.ts +41 -41
- package/src/interface/workflow/IWfProcessDefVo.ts +14 -14
- package/src/interface/workflow/IWfReturnNodeVo.ts +16 -16
- package/src/interface/workflow/IWfTaskAskVo.ts +65 -65
- package/src/interface/workflow/IWfTaskQueryVo.ts +30 -30
- package/src/interface/workflow/IWfTaskUsersVo.ts +21 -21
- package/src/interface/workflow/IWfTaskVo.ts +187 -187
- package/src/interface/workflow/workflow.ts +22 -22
- package/src/mixin/globalMixin.ts +48 -48
- package/src/packages/index.ts +18 -18
- package/src/packages/text.vue +13 -13
- package/src/plugins/echartsConfig.ts +74 -74
- package/src/plugins/plugins.ts +12 -12
- package/src/plugins/renderDialog.ts +74 -74
- package/src/stores/dictStore.ts +51 -51
- package/src/stores/messageStore.ts +49 -49
- package/src/stores/permissionStore.ts +112 -112
- package/src/stores/storeConfig.ts +23 -23
- package/src/stores/userInfoStore.ts +31 -31
- package/src/utils/AxiosConfig.ts +226 -226
- package/src/utils/FrameworkUtils.ts +358 -358
- package/src/utils/commonUtils.ts +115 -115
- package/src/utils/encrypt.ts +18 -18
- package/src/utils/modules.ts +8 -8
- package/src/utils/request.ts +76 -76
- package/src/utils/tree.ts +50 -50
package/src/utils/commonUtils.ts
CHANGED
|
@@ -1,115 +1,115 @@
|
|
|
1
|
-
export default {
|
|
2
|
-
/**
|
|
3
|
-
* 校验身份证号码
|
|
4
|
-
* @param rule
|
|
5
|
-
* @param value
|
|
6
|
-
* @param callback
|
|
7
|
-
*/
|
|
8
|
-
validateIDCard: (rule: any, value: any, callback: any) => {
|
|
9
|
-
if (!value) {
|
|
10
|
-
callback()
|
|
11
|
-
} else if (value.length !== 18) {
|
|
12
|
-
callback(new Error('身份证号码必须是18位'))
|
|
13
|
-
} else {
|
|
14
|
-
const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
|
|
15
|
-
const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
|
|
16
|
-
let sum = 0
|
|
17
|
-
for (let i = 0; i < 17; i++) {
|
|
18
|
-
sum += parseInt(value[i]) * weight[i]
|
|
19
|
-
}
|
|
20
|
-
const mod = sum % 11
|
|
21
|
-
if (checkCode[mod] === value[17]) {
|
|
22
|
-
callback()
|
|
23
|
-
} else {
|
|
24
|
-
callback(new Error('身份证号码校验错误'))
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
},
|
|
28
|
-
/**
|
|
29
|
-
* 校验身份证号码
|
|
30
|
-
* @param value
|
|
31
|
-
* @return boolean
|
|
32
|
-
*/
|
|
33
|
-
isValidIDCard: (value: string) => {
|
|
34
|
-
if (!value) {
|
|
35
|
-
return false
|
|
36
|
-
} else if (value.length !== 18) {
|
|
37
|
-
return false
|
|
38
|
-
} else {
|
|
39
|
-
const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
|
|
40
|
-
const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
|
|
41
|
-
let sum = 0
|
|
42
|
-
for (let i = 0; i < 17; i++) {
|
|
43
|
-
sum += parseInt(value[i]) * weight[i]
|
|
44
|
-
}
|
|
45
|
-
const mod = sum % 11
|
|
46
|
-
return checkCode[mod] === value[17];
|
|
47
|
-
}
|
|
48
|
-
},
|
|
49
|
-
/**
|
|
50
|
-
* 校验手机号码
|
|
51
|
-
* @param rule
|
|
52
|
-
* @param value
|
|
53
|
-
* @param callback
|
|
54
|
-
*/
|
|
55
|
-
validatePhone: (rule: any, value: any, callback: any) => {
|
|
56
|
-
const phoneReg = /^1[3-9]\d{9}$/
|
|
57
|
-
if (!value || value === '') {
|
|
58
|
-
callback()
|
|
59
|
-
} else if (!phoneReg.test(value)) {
|
|
60
|
-
callback(new Error('请输入正确的手机号码'))
|
|
61
|
-
} else {
|
|
62
|
-
callback()
|
|
63
|
-
}
|
|
64
|
-
},
|
|
65
|
-
/**
|
|
66
|
-
* 校验手机号码
|
|
67
|
-
* @param value
|
|
68
|
-
* @return boolean
|
|
69
|
-
*/
|
|
70
|
-
isValidPhone: (value: string) => {
|
|
71
|
-
if (!value) return false
|
|
72
|
-
const phoneReg = /^1[3-9]\d{9}$/
|
|
73
|
-
return phoneReg.test(value)
|
|
74
|
-
},
|
|
75
|
-
/**
|
|
76
|
-
* 校验邮箱
|
|
77
|
-
*/
|
|
78
|
-
validateEmail: (rule: any, value: any, callback: any) => {
|
|
79
|
-
const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
|
|
80
|
-
if (!value || value === '') {
|
|
81
|
-
callback()
|
|
82
|
-
} else if (!emailReg.test(value)) {
|
|
83
|
-
callback(new Error('请输入正确的邮箱'))
|
|
84
|
-
} else {
|
|
85
|
-
callback()
|
|
86
|
-
}
|
|
87
|
-
},
|
|
88
|
-
/**
|
|
89
|
-
* 校验邮箱
|
|
90
|
-
* @param value
|
|
91
|
-
* @return boolean
|
|
92
|
-
*/
|
|
93
|
-
isValidEmail: (value: string) => {
|
|
94
|
-
if (!value) return false
|
|
95
|
-
const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
|
|
96
|
-
return emailReg.test(value)
|
|
97
|
-
},
|
|
98
|
-
/**
|
|
99
|
-
*解析身份证号码
|
|
100
|
-
*/
|
|
101
|
-
parseIDCard: (idCard: string) => {
|
|
102
|
-
if (idCard) {
|
|
103
|
-
if (idCard.length === 18) {
|
|
104
|
-
return {
|
|
105
|
-
birthday: `${idCard.slice(6, 10)}-${idCard.slice(10, 12)}-${idCard.slice(12, 14)}`,
|
|
106
|
-
sex: parseInt(idCard.slice(16, 17), 10) % 2 === 1 ? '1' : '2'
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
return {
|
|
111
|
-
birthday: '',
|
|
112
|
-
sex: ''
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
}
|
|
1
|
+
export default {
|
|
2
|
+
/**
|
|
3
|
+
* 校验身份证号码
|
|
4
|
+
* @param rule
|
|
5
|
+
* @param value
|
|
6
|
+
* @param callback
|
|
7
|
+
*/
|
|
8
|
+
validateIDCard: (rule: any, value: any, callback: any) => {
|
|
9
|
+
if (!value) {
|
|
10
|
+
callback()
|
|
11
|
+
} else if (value.length !== 18) {
|
|
12
|
+
callback(new Error('身份证号码必须是18位'))
|
|
13
|
+
} else {
|
|
14
|
+
const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
|
|
15
|
+
const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
|
|
16
|
+
let sum = 0
|
|
17
|
+
for (let i = 0; i < 17; i++) {
|
|
18
|
+
sum += parseInt(value[i]) * weight[i]
|
|
19
|
+
}
|
|
20
|
+
const mod = sum % 11
|
|
21
|
+
if (checkCode[mod] === value[17]) {
|
|
22
|
+
callback()
|
|
23
|
+
} else {
|
|
24
|
+
callback(new Error('身份证号码校验错误'))
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
},
|
|
28
|
+
/**
|
|
29
|
+
* 校验身份证号码
|
|
30
|
+
* @param value
|
|
31
|
+
* @return boolean
|
|
32
|
+
*/
|
|
33
|
+
isValidIDCard: (value: string) => {
|
|
34
|
+
if (!value) {
|
|
35
|
+
return false
|
|
36
|
+
} else if (value.length !== 18) {
|
|
37
|
+
return false
|
|
38
|
+
} else {
|
|
39
|
+
const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
|
|
40
|
+
const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
|
|
41
|
+
let sum = 0
|
|
42
|
+
for (let i = 0; i < 17; i++) {
|
|
43
|
+
sum += parseInt(value[i]) * weight[i]
|
|
44
|
+
}
|
|
45
|
+
const mod = sum % 11
|
|
46
|
+
return checkCode[mod] === value[17];
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
/**
|
|
50
|
+
* 校验手机号码
|
|
51
|
+
* @param rule
|
|
52
|
+
* @param value
|
|
53
|
+
* @param callback
|
|
54
|
+
*/
|
|
55
|
+
validatePhone: (rule: any, value: any, callback: any) => {
|
|
56
|
+
const phoneReg = /^1[3-9]\d{9}$/
|
|
57
|
+
if (!value || value === '') {
|
|
58
|
+
callback()
|
|
59
|
+
} else if (!phoneReg.test(value)) {
|
|
60
|
+
callback(new Error('请输入正确的手机号码'))
|
|
61
|
+
} else {
|
|
62
|
+
callback()
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
/**
|
|
66
|
+
* 校验手机号码
|
|
67
|
+
* @param value
|
|
68
|
+
* @return boolean
|
|
69
|
+
*/
|
|
70
|
+
isValidPhone: (value: string) => {
|
|
71
|
+
if (!value) return false
|
|
72
|
+
const phoneReg = /^1[3-9]\d{9}$/
|
|
73
|
+
return phoneReg.test(value)
|
|
74
|
+
},
|
|
75
|
+
/**
|
|
76
|
+
* 校验邮箱
|
|
77
|
+
*/
|
|
78
|
+
validateEmail: (rule: any, value: any, callback: any) => {
|
|
79
|
+
const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
|
|
80
|
+
if (!value || value === '') {
|
|
81
|
+
callback()
|
|
82
|
+
} else if (!emailReg.test(value)) {
|
|
83
|
+
callback(new Error('请输入正确的邮箱'))
|
|
84
|
+
} else {
|
|
85
|
+
callback()
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
/**
|
|
89
|
+
* 校验邮箱
|
|
90
|
+
* @param value
|
|
91
|
+
* @return boolean
|
|
92
|
+
*/
|
|
93
|
+
isValidEmail: (value: string) => {
|
|
94
|
+
if (!value) return false
|
|
95
|
+
const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
|
|
96
|
+
return emailReg.test(value)
|
|
97
|
+
},
|
|
98
|
+
/**
|
|
99
|
+
*解析身份证号码
|
|
100
|
+
*/
|
|
101
|
+
parseIDCard: (idCard: string) => {
|
|
102
|
+
if (idCard) {
|
|
103
|
+
if (idCard.length === 18) {
|
|
104
|
+
return {
|
|
105
|
+
birthday: `${idCard.slice(6, 10)}-${idCard.slice(10, 12)}-${idCard.slice(12, 14)}`,
|
|
106
|
+
sex: parseInt(idCard.slice(16, 17), 10) % 2 === 1 ? '1' : '2'
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return {
|
|
111
|
+
birthday: '',
|
|
112
|
+
sex: ''
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
package/src/utils/encrypt.ts
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import JSEncrypt from 'jsencrypt'
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
encrypt(data: string): string {
|
|
5
|
-
// 读取解析pem格式的秘钥, 生成秘钥实例 (RSAKey)
|
|
6
|
-
const pk = `MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAiDRlNQzjeuGxJoXmD1O5fZR/BxmEUdngGQKkFPLshR7x4AZR4gcH9PZu4phJUmZ1F/TEL6BwY0dqIVBQgjhwY4ypKOviCFD85H6dgOzaQ/Akl6QfSpP717vYPgeDC+P1+2+205qoQPyQ7+RiQYgnjyDs8TeVQ3nRaTC+XvxjyS06kIpbobMP5texJ74O96JMSZv6u6QBz+vq7lW0oWMowezWOyv9k+bHfqxUxlvw1gD7WrG3DKy8K9qba3mKJ4SQDJ5kKQ+C4Bb5PakiVB4XTJzNqbXWdQvRs0ZP8TgOJKIkTemjjyTxfa0HSp0U9iHAGBBPt25wc0s8dz4w45mOvQIDAQAB`
|
|
7
|
-
const jsEncrypt = new JSEncrypt()
|
|
8
|
-
jsEncrypt.setPublicKey(pk)
|
|
9
|
-
return jsEncrypt.encrypt(data).toString()
|
|
10
|
-
},
|
|
11
|
-
//解析 base64
|
|
12
|
-
decodeBase64(base64: string) {
|
|
13
|
-
const binaryString = atob(base64)
|
|
14
|
-
const bytes = Uint8Array.from(binaryString, (c) => c.charCodeAt(0))
|
|
15
|
-
const decoder = new TextDecoder('utf-8')
|
|
16
|
-
return decoder.decode(bytes)
|
|
17
|
-
},
|
|
18
|
-
}
|
|
1
|
+
import JSEncrypt from 'jsencrypt'
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
encrypt(data: string): string {
|
|
5
|
+
// 读取解析pem格式的秘钥, 生成秘钥实例 (RSAKey)
|
|
6
|
+
const pk = `MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAiDRlNQzjeuGxJoXmD1O5fZR/BxmEUdngGQKkFPLshR7x4AZR4gcH9PZu4phJUmZ1F/TEL6BwY0dqIVBQgjhwY4ypKOviCFD85H6dgOzaQ/Akl6QfSpP717vYPgeDC+P1+2+205qoQPyQ7+RiQYgnjyDs8TeVQ3nRaTC+XvxjyS06kIpbobMP5texJ74O96JMSZv6u6QBz+vq7lW0oWMowezWOyv9k+bHfqxUxlvw1gD7WrG3DKy8K9qba3mKJ4SQDJ5kKQ+C4Bb5PakiVB4XTJzNqbXWdQvRs0ZP8TgOJKIkTemjjyTxfa0HSp0U9iHAGBBPt25wc0s8dz4w45mOvQIDAQAB`
|
|
7
|
+
const jsEncrypt = new JSEncrypt()
|
|
8
|
+
jsEncrypt.setPublicKey(pk)
|
|
9
|
+
return jsEncrypt.encrypt(data).toString()
|
|
10
|
+
},
|
|
11
|
+
//解析 base64
|
|
12
|
+
decodeBase64(base64: string) {
|
|
13
|
+
const binaryString = atob(base64)
|
|
14
|
+
const bytes = Uint8Array.from(binaryString, (c) => c.charCodeAt(0))
|
|
15
|
+
const decoder = new TextDecoder('utf-8')
|
|
16
|
+
return decoder.decode(bytes)
|
|
17
|
+
},
|
|
18
|
+
}
|
package/src/utils/modules.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Create by丁盼
|
|
3
|
-
* 说明: modules
|
|
4
|
-
* 创建时间: 2025/1/20 10:53
|
|
5
|
-
* 修改时间: 2025/1/20 10:53
|
|
6
|
-
*/
|
|
7
|
-
const modules = import.meta.glob('/src/**/*.vue')
|
|
8
|
-
export default modules
|
|
1
|
+
/**
|
|
2
|
+
* Create by丁盼
|
|
3
|
+
* 说明: modules
|
|
4
|
+
* 创建时间: 2025/1/20 10:53
|
|
5
|
+
* 修改时间: 2025/1/20 10:53
|
|
6
|
+
*/
|
|
7
|
+
const modules = import.meta.glob('/src/**/*.vue')
|
|
8
|
+
export default modules
|
package/src/utils/request.ts
CHANGED
|
@@ -1,76 +1,76 @@
|
|
|
1
|
-
import request from './AxiosConfig'
|
|
2
|
-
|
|
3
|
-
export default {
|
|
4
|
-
/**
|
|
5
|
-
* get 请求
|
|
6
|
-
* @param url URL地址
|
|
7
|
-
* @param data 请求数据
|
|
8
|
-
* @param isAntiShake 防抖
|
|
9
|
-
* @param antiShakeTime 防抖时间
|
|
10
|
-
* @param menuId 菜单ID,setInterval 调用接口 请传入当前菜单的菜单ID否则会重新接口权限不正确情况
|
|
11
|
-
*/
|
|
12
|
-
get<T = unknown>(
|
|
13
|
-
url: string,
|
|
14
|
-
params?: any,
|
|
15
|
-
isAntiShake: boolean = false,
|
|
16
|
-
antiShakeTime: number = 500,
|
|
17
|
-
menuId?: string,
|
|
18
|
-
): Promise<T> {
|
|
19
|
-
//@ts-ignore
|
|
20
|
-
return request<T>({
|
|
21
|
-
url: url,
|
|
22
|
-
method: 'get',
|
|
23
|
-
params: this.trimObjectSpaces(params),
|
|
24
|
-
isAntiShake: isAntiShake,
|
|
25
|
-
antiShakeTime: antiShakeTime,
|
|
26
|
-
menuId: menuId,
|
|
27
|
-
})
|
|
28
|
-
},
|
|
29
|
-
/**
|
|
30
|
-
* post 请求
|
|
31
|
-
* @param url URL地址
|
|
32
|
-
* @param data 请求数据
|
|
33
|
-
* @param isAntiShake 防抖
|
|
34
|
-
* @param antiShakeTime 防抖时间
|
|
35
|
-
* @param menuId 菜单ID,setInterval 调用接口 请传入当前菜单的菜单ID否则会重新接口权限不正确情况
|
|
36
|
-
*/
|
|
37
|
-
post<T = unknown>(
|
|
38
|
-
url: string,
|
|
39
|
-
data?: any,
|
|
40
|
-
isAntiShake: boolean = false,
|
|
41
|
-
antiShakeTime: number = 500,
|
|
42
|
-
menuId?: string,
|
|
43
|
-
): Promise<T> {
|
|
44
|
-
//@ts-ignore
|
|
45
|
-
return request<T>({
|
|
46
|
-
url: url,
|
|
47
|
-
method: 'post',
|
|
48
|
-
data: this.trimObjectSpaces(data),
|
|
49
|
-
isAntiShake: isAntiShake,
|
|
50
|
-
antiShakeTime: antiShakeTime,
|
|
51
|
-
menuId: menuId,
|
|
52
|
-
})
|
|
53
|
-
},
|
|
54
|
-
/**
|
|
55
|
-
* 去除对象中所有字符串的前后空格
|
|
56
|
-
* @param obj 要处理的对象
|
|
57
|
-
* @returns 处理后的对象
|
|
58
|
-
*/
|
|
59
|
-
trimObjectSpaces(obj:any) {
|
|
60
|
-
if (typeof obj !== 'object' || obj === null) return obj
|
|
61
|
-
// 遍历对象或数组的每个属性
|
|
62
|
-
for (const key in obj) {
|
|
63
|
-
if (obj.hasOwnProperty(key)) {
|
|
64
|
-
const value = obj[key]
|
|
65
|
-
if (typeof value === 'string') {
|
|
66
|
-
// 去除前后空格
|
|
67
|
-
obj[key] = value.trim()
|
|
68
|
-
} else if (typeof value === 'object') {
|
|
69
|
-
// 递归处理嵌套对象或数组
|
|
70
|
-
this.trimObjectSpaces(value)
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
return obj
|
|
75
|
-
},
|
|
76
|
-
}
|
|
1
|
+
import request from './AxiosConfig'
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
/**
|
|
5
|
+
* get 请求
|
|
6
|
+
* @param url URL地址
|
|
7
|
+
* @param data 请求数据
|
|
8
|
+
* @param isAntiShake 防抖
|
|
9
|
+
* @param antiShakeTime 防抖时间
|
|
10
|
+
* @param menuId 菜单ID,setInterval 调用接口 请传入当前菜单的菜单ID否则会重新接口权限不正确情况
|
|
11
|
+
*/
|
|
12
|
+
get<T = unknown>(
|
|
13
|
+
url: string,
|
|
14
|
+
params?: any,
|
|
15
|
+
isAntiShake: boolean = false,
|
|
16
|
+
antiShakeTime: number = 500,
|
|
17
|
+
menuId?: string,
|
|
18
|
+
): Promise<T> {
|
|
19
|
+
//@ts-ignore
|
|
20
|
+
return request<T>({
|
|
21
|
+
url: url,
|
|
22
|
+
method: 'get',
|
|
23
|
+
params: this.trimObjectSpaces(params),
|
|
24
|
+
isAntiShake: isAntiShake,
|
|
25
|
+
antiShakeTime: antiShakeTime,
|
|
26
|
+
menuId: menuId,
|
|
27
|
+
})
|
|
28
|
+
},
|
|
29
|
+
/**
|
|
30
|
+
* post 请求
|
|
31
|
+
* @param url URL地址
|
|
32
|
+
* @param data 请求数据
|
|
33
|
+
* @param isAntiShake 防抖
|
|
34
|
+
* @param antiShakeTime 防抖时间
|
|
35
|
+
* @param menuId 菜单ID,setInterval 调用接口 请传入当前菜单的菜单ID否则会重新接口权限不正确情况
|
|
36
|
+
*/
|
|
37
|
+
post<T = unknown>(
|
|
38
|
+
url: string,
|
|
39
|
+
data?: any,
|
|
40
|
+
isAntiShake: boolean = false,
|
|
41
|
+
antiShakeTime: number = 500,
|
|
42
|
+
menuId?: string,
|
|
43
|
+
): Promise<T> {
|
|
44
|
+
//@ts-ignore
|
|
45
|
+
return request<T>({
|
|
46
|
+
url: url,
|
|
47
|
+
method: 'post',
|
|
48
|
+
data: this.trimObjectSpaces(data),
|
|
49
|
+
isAntiShake: isAntiShake,
|
|
50
|
+
antiShakeTime: antiShakeTime,
|
|
51
|
+
menuId: menuId,
|
|
52
|
+
})
|
|
53
|
+
},
|
|
54
|
+
/**
|
|
55
|
+
* 去除对象中所有字符串的前后空格
|
|
56
|
+
* @param obj 要处理的对象
|
|
57
|
+
* @returns 处理后的对象
|
|
58
|
+
*/
|
|
59
|
+
trimObjectSpaces(obj:any) {
|
|
60
|
+
if (typeof obj !== 'object' || obj === null) return obj
|
|
61
|
+
// 遍历对象或数组的每个属性
|
|
62
|
+
for (const key in obj) {
|
|
63
|
+
if (obj.hasOwnProperty(key)) {
|
|
64
|
+
const value = obj[key]
|
|
65
|
+
if (typeof value === 'string') {
|
|
66
|
+
// 去除前后空格
|
|
67
|
+
obj[key] = value.trim()
|
|
68
|
+
} else if (typeof value === 'object') {
|
|
69
|
+
// 递归处理嵌套对象或数组
|
|
70
|
+
this.trimObjectSpaces(value)
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
return obj
|
|
75
|
+
},
|
|
76
|
+
}
|
package/src/utils/tree.ts
CHANGED
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 构造树型结构数据
|
|
3
|
-
* @param {*} data 数据源
|
|
4
|
-
* @param {*} id id字段 默认 'id'
|
|
5
|
-
* @param {*} parentId 父节点字段 默认 'parentId'
|
|
6
|
-
* @param {*} children 孩子节点字段 默认 'children'
|
|
7
|
-
*/
|
|
8
|
-
export function handleTree(data: any[], id?: string, parentId?: string, children?: string) {
|
|
9
|
-
const config = {
|
|
10
|
-
id: id || 'id',
|
|
11
|
-
parentId: parentId || 'parentId',
|
|
12
|
-
childrenList: children || 'children'
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
const childrenListMap: any = {}
|
|
16
|
-
const nodeIds: any = {}
|
|
17
|
-
const tree: any = []
|
|
18
|
-
|
|
19
|
-
for (const d of data) {
|
|
20
|
-
const parentId = d[config.parentId]
|
|
21
|
-
if (childrenListMap[parentId] == null) {
|
|
22
|
-
childrenListMap[parentId] = []
|
|
23
|
-
}
|
|
24
|
-
nodeIds[d[config.id]] = d
|
|
25
|
-
childrenListMap[parentId].push(d)
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
for (const d of data) {
|
|
29
|
-
const parentId = d[config.parentId]
|
|
30
|
-
if (nodeIds[parentId] == null) {
|
|
31
|
-
tree.push(d)
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
for (const t of tree) {
|
|
36
|
-
adaptToChildrenList(t)
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
function adaptToChildrenList(o: any) {
|
|
40
|
-
if (childrenListMap[o[config.id]] !== null) {
|
|
41
|
-
o[config.childrenList] = childrenListMap[o[config.id]]
|
|
42
|
-
}
|
|
43
|
-
if (o[config.childrenList]) {
|
|
44
|
-
for (const c of o[config.childrenList]) {
|
|
45
|
-
adaptToChildrenList(c)
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
return tree
|
|
50
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* 构造树型结构数据
|
|
3
|
+
* @param {*} data 数据源
|
|
4
|
+
* @param {*} id id字段 默认 'id'
|
|
5
|
+
* @param {*} parentId 父节点字段 默认 'parentId'
|
|
6
|
+
* @param {*} children 孩子节点字段 默认 'children'
|
|
7
|
+
*/
|
|
8
|
+
export function handleTree(data: any[], id?: string, parentId?: string, children?: string) {
|
|
9
|
+
const config = {
|
|
10
|
+
id: id || 'id',
|
|
11
|
+
parentId: parentId || 'parentId',
|
|
12
|
+
childrenList: children || 'children'
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const childrenListMap: any = {}
|
|
16
|
+
const nodeIds: any = {}
|
|
17
|
+
const tree: any = []
|
|
18
|
+
|
|
19
|
+
for (const d of data) {
|
|
20
|
+
const parentId = d[config.parentId]
|
|
21
|
+
if (childrenListMap[parentId] == null) {
|
|
22
|
+
childrenListMap[parentId] = []
|
|
23
|
+
}
|
|
24
|
+
nodeIds[d[config.id]] = d
|
|
25
|
+
childrenListMap[parentId].push(d)
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
for (const d of data) {
|
|
29
|
+
const parentId = d[config.parentId]
|
|
30
|
+
if (nodeIds[parentId] == null) {
|
|
31
|
+
tree.push(d)
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
for (const t of tree) {
|
|
36
|
+
adaptToChildrenList(t)
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function adaptToChildrenList(o: any) {
|
|
40
|
+
if (childrenListMap[o[config.id]] !== null) {
|
|
41
|
+
o[config.childrenList] = childrenListMap[o[config.id]]
|
|
42
|
+
}
|
|
43
|
+
if (o[config.childrenList]) {
|
|
44
|
+
for (const c of o[config.childrenList]) {
|
|
45
|
+
adaptToChildrenList(c)
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return tree
|
|
50
|
+
}
|