adtec-core-package 2.2.6 → 2.2.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (211) hide show
  1. package/README.en.md +36 -36
  2. package/adtec-core-package/adtec-core-package.css +1 -0
  3. package/adtec-core-package/adtec-core-package.js +41605 -0
  4. package/adtec-core-package/adtec-core-package.umd.cjs +79 -0
  5. package/adtec-core-package/favicon.ico +0 -0
  6. package/eslint.config.js +21 -11
  7. package/package.json +69 -71
  8. package/src/api/BasicApi.ts +26 -26
  9. package/src/api/DeptInfoApi.ts +19 -19
  10. package/src/api/DocumentApi.ts +27 -27
  11. package/src/api/EmployeeInfoApi.ts +17 -17
  12. package/src/api/SysDictCacheApi.ts +29 -29
  13. package/src/api/SysUserApi.ts +35 -35
  14. package/src/api/framework.ts +12 -12
  15. package/src/api/workflow/workflow.ts +31 -31
  16. package/src/api/workflow/workflowInstApi.ts +72 -72
  17. package/src/assets/style/ant.scss +19 -19
  18. package/src/assets/style/index.less +180 -180
  19. package/src/components/ElCardList.vue +64 -64
  20. package/src/components/ElFlex/ElFlex.vue +297 -297
  21. package/src/components/ElTotalTools.vue +70 -70
  22. package/src/components/OperationAuth/operationAuth.vue +32 -32
  23. package/src/components/RichTextEditor/RichTextEditor.vue +414 -414
  24. package/src/components/Scrollbars/ElScrollbars.vue +21 -21
  25. package/src/components/Search/ElIconSearch.vue +267 -267
  26. package/src/components/Search/ElSearch.vue +154 -154
  27. package/src/components/SelectInDicators/SelectInDicators.vue +225 -225
  28. package/src/components/SelectInDicators/api/DataIndicatorsApi.ts +28 -28
  29. package/src/components/SelectInDicators/interface/IComIndex.ts +26 -26
  30. package/src/components/SelectInDicators/interface/IComIndexAttri.ts +18 -18
  31. package/src/components/Table/ElTableColumnDynamic.vue +25 -25
  32. package/src/components/Table/ElTableColumnEdit.vue +265 -265
  33. package/src/components/Table/ElTableTool.ts +37 -37
  34. package/src/components/Title/ElTitle.vue +53 -53
  35. package/src/components/autoToolTip/ElAutoToolTip.vue +62 -62
  36. package/src/components/baseEcharts/index.vue +48 -48
  37. package/src/components/bpmntree/api/modules/role.ts +31 -31
  38. package/src/components/bpmntree/api/modules/user.ts +17 -17
  39. package/src/components/bpmntree/components/AdvancedFilter/Operator.vue +112 -112
  40. package/src/components/bpmntree/components/AdvancedFilter/Trigger.vue +23 -23
  41. package/src/components/bpmntree/components/AdvancedFilter/index.vue +230 -230
  42. package/src/components/bpmntree/components/AdvancedFilter/type.ts +20 -20
  43. package/src/components/bpmntree/components/FlowIcon/index.scss +7 -7
  44. package/src/components/bpmntree/components/FlowIcon/index.tsx +68 -68
  45. package/src/components/bpmntree/components/Render/render.vue +90 -90
  46. package/src/components/bpmntree/components/Render/type.ts +12 -12
  47. package/src/components/bpmntree/components/RoleSelector/RolePicker.vue +264 -264
  48. package/src/components/bpmntree/components/RoleSelector/RoleTag.vue +48 -48
  49. package/src/components/bpmntree/components/RoleSelector/index.vue +113 -113
  50. package/src/components/bpmntree/components/UserSelector/UserTag.vue +73 -73
  51. package/src/components/bpmntree/components/UserSelector/index.vue +140 -140
  52. package/src/components/bpmntree/hooks/useDraggableScroll.ts +44 -44
  53. package/src/components/bpmntree/typings/index.d.ts +1 -1
  54. package/src/components/bpmntree/views/flowDesign/index.vue +653 -653
  55. package/src/components/bpmntree/views/flowDesign/nodes/Add.vue +184 -184
  56. package/src/components/bpmntree/views/flowDesign/nodes/ApprovalNode.vue +127 -127
  57. package/src/components/bpmntree/views/flowDesign/nodes/CcNode.vue +93 -93
  58. package/src/components/bpmntree/views/flowDesign/nodes/ConcurrentNode.vue +61 -61
  59. package/src/components/bpmntree/views/flowDesign/nodes/ConditionNode.vue +60 -60
  60. package/src/components/bpmntree/views/flowDesign/nodes/EndNode.vue +80 -80
  61. package/src/components/bpmntree/views/flowDesign/nodes/ExclusiveNode.vue +20 -20
  62. package/src/components/bpmntree/views/flowDesign/nodes/GatewayNode.vue +173 -173
  63. package/src/components/bpmntree/views/flowDesign/nodes/InclusiveNode.vue +20 -20
  64. package/src/components/bpmntree/views/flowDesign/nodes/JumpNode.vue +49 -49
  65. package/src/components/bpmntree/views/flowDesign/nodes/Node.vue +346 -346
  66. package/src/components/bpmntree/views/flowDesign/nodes/NotifyNode.vue +115 -115
  67. package/src/components/bpmntree/views/flowDesign/nodes/ParallelNode.vue +20 -20
  68. package/src/components/bpmntree/views/flowDesign/nodes/PopoverView.vue +78 -78
  69. package/src/components/bpmntree/views/flowDesign/nodes/StartNode.vue +84 -84
  70. package/src/components/bpmntree/views/flowDesign/nodes/TimerNode.vue +50 -50
  71. package/src/components/bpmntree/views/flowDesign/nodes/TreeNode.vue +45 -45
  72. package/src/components/bpmntree/views/flowDesign/nodes/type.ts +196 -196
  73. package/src/components/bpmntree/views/flowDesign/panels/ApprovalPanel.vue +553 -553
  74. package/src/components/bpmntree/views/flowDesign/panels/AssigneePanel.vue +120 -120
  75. package/src/components/bpmntree/views/flowDesign/panels/CcPanel.vue +99 -99
  76. package/src/components/bpmntree/views/flowDesign/panels/ConditionPanel.vue +41 -41
  77. package/src/components/bpmntree/views/flowDesign/panels/EndPanel.vue +18 -18
  78. package/src/components/bpmntree/views/flowDesign/panels/ExecutionListeners.vue +110 -110
  79. package/src/components/bpmntree/views/flowDesign/panels/JumpPanel.vue +32 -32
  80. package/src/components/bpmntree/views/flowDesign/panels/NotifyPanel.vue +101 -101
  81. package/src/components/bpmntree/views/flowDesign/panels/ParaPanel.vue +248 -248
  82. package/src/components/bpmntree/views/flowDesign/panels/StartPanel.vue +160 -160
  83. package/src/components/bpmntree/views/flowDesign/panels/TaskListeners.vue +110 -110
  84. package/src/components/bpmntree/views/flowDesign/panels/TimerPanel.vue +51 -51
  85. package/src/components/bpmntree/views/flowDesign/panels/index.vue +85 -85
  86. package/src/components/bpmntree/views/view.index.vue +291 -291
  87. package/src/components/business/comp.selectUser.vue +60 -60
  88. package/src/components/business/comp.userForm.vue +311 -311
  89. package/src/components/business/userSelect.vue +413 -413
  90. package/src/components/icon/ElIconBtn.vue +243 -243
  91. package/src/components/kFrame/IframeOptions.ts +116 -116
  92. package/src/components/kFrame/KFrame.vue +161 -161
  93. package/src/components/tooltip/index.ts +11 -11
  94. package/src/components/tooltip/src/tooltip.ts +518 -518
  95. package/src/components/upload/ElUploads.vue +364 -364
  96. package/src/components/upload/FileView.vue +214 -214
  97. package/src/components/upload/FileViewComponents.vue +56 -56
  98. package/src/components/vxeGrid/index.vue +36 -36
  99. package/src/components/workflow/TaskOperation.vue +241 -241
  100. package/src/components/workflow/WorkflowTodoDialog.vue +83 -83
  101. package/src/components/workflow/components/AddOrMinusMultiDialog.vue +159 -159
  102. package/src/components/workflow/components/CheckDialog.vue +350 -350
  103. package/src/components/workflow/components/ProcessDetailComp.vue +149 -149
  104. package/src/components/workflow/components/ProcessDetailDialog.vue +129 -129
  105. package/src/components/workflow/components/ProcessInstance.vue +117 -117
  106. package/src/components/workflow/components/ProcessInstanceStep.vue +266 -266
  107. package/src/components/workflow/components/SelectAssigneeDialog.vue +109 -109
  108. package/src/components/workflow/components/SelectReturnActivityDialog.vue +104 -104
  109. package/src/config/ElementPlusConfig.ts +95 -95
  110. package/src/config/VxeTableConfig.ts +251 -247
  111. package/src/css/elementUI/autocomplete.scss +89 -89
  112. package/src/css/elementUI/checkbox.scss +298 -298
  113. package/src/css/elementUI/common/var.scss +1549 -1549
  114. package/src/css/elementUI/date-picker/picker.scss +219 -219
  115. package/src/css/elementUI/descriptions.scss +152 -152
  116. package/src/css/elementUI/drawer.scss +164 -164
  117. package/src/css/elementUI/radio.scss +215 -215
  118. package/src/css/elementUI/table.scss +697 -697
  119. package/src/css/elementUI/tabs.scss +659 -659
  120. package/src/css/vxeTableUI/all.scss +9 -9
  121. package/src/css/vxeTableUI/base.scss +16 -16
  122. package/src/css/vxeTableUI/components/colgroup.scss +0 -0
  123. package/src/css/vxeTableUI/components/column.scss +0 -0
  124. package/src/css/vxeTableUI/components/grid.scss +83 -83
  125. package/src/css/vxeTableUI/components/icon.scss +1017 -1017
  126. package/src/css/vxeTableUI/components/iconTable.scss +205 -205
  127. package/src/css/vxeTableUI/components/old-icon.scss +715 -715
  128. package/src/css/vxeTableUI/components/table-module/all.scss +6 -6
  129. package/src/css/vxeTableUI/components/table-module/custom.scss +490 -490
  130. package/src/css/vxeTableUI/components/table-module/edit.scss +0 -0
  131. package/src/css/vxeTableUI/components/table-module/export.scss +130 -130
  132. package/src/css/vxeTableUI/components/table-module/filter.scss +127 -127
  133. package/src/css/vxeTableUI/components/table-module/keyboard.scss +0 -0
  134. package/src/css/vxeTableUI/components/table-module/menu.scss +85 -85
  135. package/src/css/vxeTableUI/components/table-module/validator.scss +0 -0
  136. package/src/css/vxeTableUI/components/table.scss +2256 -2256
  137. package/src/css/vxeTableUI/components/toolbar.scss +99 -99
  138. package/src/css/vxeTableUI/components/ui.scss +0 -0
  139. package/src/css/vxeTableUI/components/v-x-e-table.scss +0 -0
  140. package/src/css/vxeTableUI/cssvar.scss +2 -2
  141. package/src/css/vxeTableUI/default.scss +2 -2
  142. package/src/css/vxeTableUI/helpers/baseMixin.scss +82 -82
  143. package/src/css/vxeTableUI/icon/iconfont.ttf +0 -0
  144. package/src/css/vxeTableUI/icon/iconfont.woff +0 -0
  145. package/src/css/vxeTableUI/icon/iconfont.woff2 +0 -0
  146. package/src/css/vxeTableUI/index.scss +4 -4
  147. package/src/css/vxeTableUI/modules.scss +5 -5
  148. package/src/css/vxeTableUI/theme/base.scss +88 -88
  149. package/src/css/vxeTableUI/theme/dark.scss +46 -46
  150. package/src/css/vxeTableUI/theme/light.scss +41 -41
  151. package/src/css/vxeTableUI/variable.scss +41 -41
  152. package/src/directives/vKeydown.ts +91 -91
  153. package/src/hooks/useDictHooks.ts +119 -119
  154. package/src/hooks/useEcharts.ts +58 -58
  155. package/src/hooks/useFileView.ts +11 -11
  156. package/src/hooks/useListenerHooks.ts +137 -137
  157. package/src/hooks/useMessageHooks.ts +132 -132
  158. package/src/hooks/useOpenNewMenu.ts +30 -30
  159. package/src/hooks/usePermissionHooks.ts +139 -139
  160. package/src/hooks/usePermissionToolHooks.ts +21 -21
  161. package/src/hooks/useResetRefHooks.ts +18 -18
  162. package/src/hooks/userWorkflowHooks.ts +106 -106
  163. package/src/hooks/workflowTodo.ts +85 -85
  164. package/src/interface/BaseEntity.ts +30 -30
  165. package/src/interface/IMdmDept.ts +84 -84
  166. package/src/interface/IMdmEmployee.ts +153 -153
  167. package/src/interface/IMdmEmployeeQuery.ts +21 -21
  168. package/src/interface/IMdmOrg.ts +29 -29
  169. package/src/interface/IMdmOrgQuery.ts +13 -13
  170. package/src/interface/IOrgDeptInfo.ts +12 -12
  171. package/src/interface/ISortList.ts +6 -6
  172. package/src/interface/ISysDictDataCacheVo.ts +46 -46
  173. package/src/interface/ISysDictType.ts +37 -37
  174. package/src/interface/ISysMenuDataVo.ts +22 -22
  175. package/src/interface/ISysMenuInfoVo.ts +83 -83
  176. package/src/interface/ISysMenuOperationVo.ts +21 -21
  177. package/src/interface/ISysUploadFiles.ts +16 -16
  178. package/src/interface/ISysUserInfo.ts +70 -70
  179. package/src/interface/IUserBaseInfo.ts +90 -90
  180. package/src/interface/IUserPermissionVo.ts +41 -41
  181. package/src/interface/IVxeTable.ts +1 -1
  182. package/src/interface/Message.ts +73 -72
  183. package/src/interface/PageData.ts +17 -17
  184. package/src/interface/ResponseData.ts +16 -16
  185. package/src/interface/dictMapType.ts +11 -11
  186. package/src/interface/enum/MessageEnum.ts +41 -41
  187. package/src/interface/workflow/IWfProcessDefVo.ts +14 -14
  188. package/src/interface/workflow/IWfReturnNodeVo.ts +16 -16
  189. package/src/interface/workflow/IWfTaskAskVo.ts +65 -65
  190. package/src/interface/workflow/IWfTaskQueryVo.ts +30 -30
  191. package/src/interface/workflow/IWfTaskUsersVo.ts +21 -21
  192. package/src/interface/workflow/IWfTaskVo.ts +187 -187
  193. package/src/interface/workflow/workflow.ts +22 -22
  194. package/src/mixin/globalMixin.ts +48 -48
  195. package/src/packages/index.ts +18 -18
  196. package/src/packages/text.vue +13 -13
  197. package/src/plugins/echartsConfig.ts +74 -74
  198. package/src/plugins/plugins.ts +12 -12
  199. package/src/plugins/renderDialog.ts +74 -74
  200. package/src/stores/dictStore.ts +51 -51
  201. package/src/stores/messageStore.ts +49 -49
  202. package/src/stores/permissionStore.ts +112 -112
  203. package/src/stores/storeConfig.ts +23 -23
  204. package/src/stores/userInfoStore.ts +31 -31
  205. package/src/utils/AxiosConfig.ts +226 -226
  206. package/src/utils/FrameworkUtils.ts +358 -358
  207. package/src/utils/commonUtils.ts +335 -335
  208. package/src/utils/encrypt.ts +18 -18
  209. package/src/utils/modules.ts +8 -8
  210. package/src/utils/request.ts +76 -76
  211. package/src/utils/tree.ts +50 -50
@@ -1,335 +1,335 @@
1
- import {ElMessageBox} from 'element-plus'
2
-
3
- export default {
4
- /**
5
- * 校验身份证号码
6
- * @param rule
7
- * @param value
8
- * @param callback
9
- */
10
- validateIDCard: (rule: any, value: any, callback: any) => {
11
- if (!value) {
12
- callback()
13
- } else if (value.length !== 18) {
14
- callback(new Error('身份证号码必须是18位'))
15
- } else {
16
- const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
17
- const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
18
- let sum = 0
19
- for (let i = 0; i < 17; i++) {
20
- sum += parseInt(value[i]) * weight[i]
21
- }
22
- const mod = sum % 11
23
- if (checkCode[mod] === value[17]) {
24
- callback()
25
- } else {
26
- callback(new Error('身份证号码校验错误'))
27
- }
28
- }
29
- },
30
- /**
31
- * 校验身份证号码
32
- * @param value
33
- * @return boolean
34
- */
35
- isValidIDCard: (value: string) => {
36
- if (!value) {
37
- return false
38
- } else if (value.length !== 18) {
39
- return false
40
- } else {
41
- const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
42
- const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
43
- let sum = 0
44
- for (let i = 0; i < 17; i++) {
45
- sum += parseInt(value[i]) * weight[i]
46
- }
47
- const mod = sum % 11
48
- return checkCode[mod] === value[17];
49
- }
50
- },
51
- /**
52
- * 校验手机号码
53
- * @param rule
54
- * @param value
55
- * @param callback
56
- */
57
- validatePhone: (rule: any, value: any, callback: any) => {
58
- const phoneReg = /^1[3-9]\d{9}$/
59
- if (!value || value === '') {
60
- callback()
61
- } else if (!phoneReg.test(value)) {
62
- callback(new Error('请输入正确的手机号码'))
63
- } else {
64
- callback()
65
- }
66
- },
67
- /**
68
- * 校验手机号码
69
- * @param value
70
- * @return boolean
71
- */
72
- isValidPhone: (value: string) => {
73
- if (!value) return false
74
- const phoneReg = /^1[3-9]\d{9}$/
75
- return phoneReg.test(value)
76
- },
77
- /**
78
- * 校验邮箱
79
- */
80
- validateEmail: (rule: any, value: any, callback: any) => {
81
- const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
82
- if (!value || value === '') {
83
- callback()
84
- } else if (!emailReg.test(value)) {
85
- callback(new Error('请输入正确的邮箱'))
86
- } else {
87
- callback()
88
- }
89
- },
90
- /**
91
- * 校验邮箱
92
- * @param value
93
- * @return boolean
94
- */
95
- isValidEmail: (value: string) => {
96
- if (!value) return false
97
- const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
98
- return emailReg.test(value)
99
- },
100
- /**
101
- *解析身份证号码
102
- */
103
- parseIDCard: (idCard: string) => {
104
- if (idCard) {
105
- if (idCard.length === 18) {
106
- return {
107
- birthday: `${idCard.slice(6, 10)}-${idCard.slice(10, 12)}-${idCard.slice(12, 14)}`,
108
- sex: parseInt(idCard.slice(16, 17), 10) % 2 === 1 ? '1' : '2'
109
- }
110
- }
111
- }
112
- return {
113
- birthday: '',
114
- sex: ''
115
- }
116
- },
117
- /**
118
- * 判断数组中是否有props相同的对象
119
- * @param arr
120
- * @param props
121
- */
122
- hasDuplicate(arr: any[], props: string[]): boolean {
123
- const map = new Map()
124
- for (const obj of arr) {
125
- let key = ''
126
- for (const prop of props) {
127
- key += obj[prop] + '|'
128
- }
129
- if (map.has(key)) {
130
- return true
131
- }
132
- map.set(key, true)
133
- }
134
- return false
135
- },
136
- /**
137
- * 删除确认函数
138
- * @param fun
139
- * @param args
140
- */
141
- deleteFun(fun: Function, ...args: any[]): void {
142
- ElMessageBox.confirm(`是否确认删除该数据?`, '删除提示', {
143
- confirmButtonText: '确定',
144
- cancelButtonText: '取消',
145
- type: 'warning',
146
- }).then(async () => {
147
- fun(...args)
148
- })
149
- },
150
- calculateAge(birthDateStr: string | undefined): number | undefined {
151
- if (!birthDateStr) return undefined
152
- const birthDate = new Date(birthDateStr)
153
- const currentDate = new Date()
154
-
155
- let age = currentDate.getFullYear() - birthDate.getFullYear()
156
- const monthDiff = currentDate.getMonth() - birthDate.getMonth()
157
-
158
- if (monthDiff < 0 || (monthDiff === 0 && currentDate.getDate() < birthDate.getDate())) {
159
- age--
160
- }
161
-
162
- return age
163
- },
164
- formatCurrency(amount: number): number {
165
- return (Math.round(amount * 100) / 100).toFixed(2) as unknown as number;
166
- },
167
- stripRichText(html: string): string {
168
- // 如果输入不是字符串或为空,直接返回空字符串
169
- if (typeof html !== 'string' || html.trim() === '') {
170
- return '';
171
- }
172
-
173
- // 1. 移除所有HTML标签
174
- let text = html.replace(/<[^>]*>?/gm, '');
175
-
176
- // 2. 处理HTML实体(如&nbsp; &amp; &lt; &gt;等)
177
- const entities: Record<string, string> = {
178
- '&nbsp;': ' ',
179
- '&amp;': '&',
180
- '&lt;': '<',
181
- '&gt;': '>',
182
- '&quot;': '"',
183
- '&#39;': "'",
184
- '&#160;': ' '
185
- };
186
-
187
- text = text.replace(/&[a-zA-Z0-9#]+;/g, match => {
188
- return entities[match] || match;
189
- });
190
-
191
- // 3. 去除多余的空格和空行
192
- text = text
193
- .replace(/\s+/g, ' ') // 将多个空格/换行符替换为单个空格
194
- .trim(); // 去除首尾空格
195
-
196
- return text;
197
- },
198
- isRichTextEmpty(content: string | undefined): boolean {
199
- if (!content) return true;
200
- const textContent = this.stripRichText(content);
201
- return !textContent;
202
- },
203
- /**
204
- * 解析数学不等式规则,判断x是否满足规则
205
- * @param {string} rule - 不等式规则,如"x=100"、"x≤50"、"10<x<20"等
206
- * @param {string|number} xValue - 变量x的值,可为字符串或数字
207
- * @returns {boolean} - x是否满足规则
208
- */
209
- isValueValidForRule(rule: string, xValue: number | string): boolean {
210
- // 去除规则中的空格,统一格式
211
- rule = rule.replace(/\s/g, '');
212
-
213
- // 将字符串类型的数值转换为数字,若转换失败则设为NaN
214
- const x = typeof xValue === 'string' ? parseFloat(xValue) : xValue;
215
-
216
- // 检查转换后的值是否为有效数字
217
- if (isNaN(x)) {
218
- throw new Error(`Invalid xValue: ${xValue}`);
219
- }
220
-
221
- // 解析规则中的数值并进行匹配
222
- try {
223
- // 处理 "x=a" 类型规则
224
- if (rule.includes('=')) {
225
- const match = rule.match(/^x=([+-]?\d+(\.\d+)?)$/);
226
- if (match) {
227
- const a = parseFloat(match[1]);
228
- if (isNaN(a)) {
229
- throw new Error(`Invalid rule value: ${match[1]}`);
230
- }
231
- return x === a;
232
- }
233
- }
234
-
235
- // 处理 "x<a" 类型规则
236
- if (rule.includes('<') && !rule.includes('≤') && !rule.includes('±')) {
237
- // 先尝试匹配 "a<x<b" 类型
238
- const rangeMatch = rule.match(/^([+-]?\d+(\.\d+)?)<x<([+-]?\d+(\.\d+)?)$/);
239
- if (rangeMatch) {
240
- const a = parseFloat(rangeMatch[1]);
241
- const b = parseFloat(rangeMatch[3]);
242
- if (isNaN(a) || isNaN(b)) {
243
- throw new Error(`Invalid rule values: ${rangeMatch[1]} or ${rangeMatch[3]}`);
244
- }
245
- return x > a && x < b;
246
- }
247
-
248
- // 再尝试匹配 "x<a" 类型
249
- const match = rule.match(/^x<([+-]?\d+(\.\d+)?)$/);
250
- if (match) {
251
- const a = parseFloat(match[1]);
252
- if (isNaN(a)) {
253
- throw new Error(`Invalid rule value: ${match[1]}`);
254
- }
255
- return x < a;
256
- }
257
- }
258
-
259
- // 处理 "x≤a" 类型规则
260
- if (rule.includes('≤')) {
261
- const match = rule.match(/^x≤([+-]?\d+(\.\d+)?)$/);
262
- if (match) {
263
- const a = parseFloat(match[1]);
264
- if (isNaN(a)) {
265
- throw new Error(`Invalid rule value: ${match[1]}`);
266
- }
267
- return x <= a;
268
- }
269
- }
270
-
271
- // 处理 "x>a" 类型规则
272
- if (rule.includes('>') && !rule.includes('≥')) {
273
- const match = rule.match(/^x>([+-]?\d+(\.\d+)?)$/);
274
- if (match) {
275
- const a = parseFloat(match[1]);
276
- if (isNaN(a)) {
277
- throw new Error(`Invalid rule value: ${match[1]}`);
278
- }
279
- return x > a;
280
- }
281
- }
282
-
283
- // 处理 "x≥a" 类型规则
284
- if (rule.includes('≥')) {
285
- const match = rule.match(/^x≥([+-]?\d+(\.\d+)?)$/);
286
- if (match) {
287
- const a = parseFloat(match[1]);
288
- if (isNaN(a)) {
289
- throw new Error(`Invalid rule value: ${match[1]}`);
290
- }
291
- return x >= a;
292
- }
293
- }
294
-
295
- // 处理 "x±a" 类型规则
296
- if (rule.includes('±')) {
297
- const match = rule.match(/^x±([+-]?\d+(\.\d+)?)$/);
298
- if (match) {
299
- const a = parseFloat(match[1]);
300
- if (isNaN(a)) {
301
- throw new Error(`Invalid rule value: ${match[1]}`);
302
- }
303
- return x >= a - Math.abs(a) && x <= a + Math.abs(a);
304
- }
305
- }
306
-
307
- // 处理 "a≤x<b" 类型规则
308
- if (rule.includes('≤x<')) {
309
- const match = rule.match(/^([+-]?\d+(\.\d+)?)≤x<([+-]?\d+(\.\d+)?)$/);
310
- if (match) {
311
- const a = parseFloat(match[1]);
312
- const b = parseFloat(match[3]);
313
- if (isNaN(a) || isNaN(b)) {
314
- throw new Error(`Invalid rule values: ${match[1]} or ${match[3]}`);
315
- }
316
- return x >= a && x < b;
317
- }
318
- }
319
-
320
- } catch (error) {
321
- throw new Error(`Rule parsing error: ${(error as Error).message}`);
322
- }
323
-
324
- throw new Error(`Unsupported rule format: ${rule}`);
325
- },
326
- parseUrlParams: (queryStr: string):Record<string, any> => {
327
- return Object.fromEntries(new URLSearchParams(queryStr.slice(queryStr.indexOf('?') + 1)));
328
- },
329
- jsonToUrlQuery: (jsonObj: Record<string, string>) => {
330
- const keyValuePairs = Object.entries(jsonObj).map(([key, value]) => {
331
- return `${encodeURIComponent(key)}=${encodeURIComponent(value)}`
332
- })
333
- return keyValuePairs.length > 0 ? `?${keyValuePairs.join('&')}` : ''
334
- }
335
- }
1
+ import {ElMessageBox} from 'element-plus'
2
+
3
+ export default {
4
+ /**
5
+ * 校验身份证号码
6
+ * @param rule
7
+ * @param value
8
+ * @param callback
9
+ */
10
+ validateIDCard: (rule: any, value: any, callback: any) => {
11
+ if (!value) {
12
+ callback()
13
+ } else if (value.length !== 18) {
14
+ callback(new Error('身份证号码必须是18位'))
15
+ } else {
16
+ const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
17
+ const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
18
+ let sum = 0
19
+ for (let i = 0; i < 17; i++) {
20
+ sum += parseInt(value[i]) * weight[i]
21
+ }
22
+ const mod = sum % 11
23
+ if (checkCode[mod] === value[17]) {
24
+ callback()
25
+ } else {
26
+ callback(new Error('身份证号码校验错误'))
27
+ }
28
+ }
29
+ },
30
+ /**
31
+ * 校验身份证号码
32
+ * @param value
33
+ * @return boolean
34
+ */
35
+ isValidIDCard: (value: string) => {
36
+ if (!value) {
37
+ return false
38
+ } else if (value.length !== 18) {
39
+ return false
40
+ } else {
41
+ const weight = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
42
+ const checkCode = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2']
43
+ let sum = 0
44
+ for (let i = 0; i < 17; i++) {
45
+ sum += parseInt(value[i]) * weight[i]
46
+ }
47
+ const mod = sum % 11
48
+ return checkCode[mod] === value[17];
49
+ }
50
+ },
51
+ /**
52
+ * 校验手机号码
53
+ * @param rule
54
+ * @param value
55
+ * @param callback
56
+ */
57
+ validatePhone: (rule: any, value: any, callback: any) => {
58
+ const phoneReg = /^1[3-9]\d{9}$/
59
+ if (!value || value === '') {
60
+ callback()
61
+ } else if (!phoneReg.test(value)) {
62
+ callback(new Error('请输入正确的手机号码'))
63
+ } else {
64
+ callback()
65
+ }
66
+ },
67
+ /**
68
+ * 校验手机号码
69
+ * @param value
70
+ * @return boolean
71
+ */
72
+ isValidPhone: (value: string) => {
73
+ if (!value) return false
74
+ const phoneReg = /^1[3-9]\d{9}$/
75
+ return phoneReg.test(value)
76
+ },
77
+ /**
78
+ * 校验邮箱
79
+ */
80
+ validateEmail: (rule: any, value: any, callback: any) => {
81
+ const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
82
+ if (!value || value === '') {
83
+ callback()
84
+ } else if (!emailReg.test(value)) {
85
+ callback(new Error('请输入正确的邮箱'))
86
+ } else {
87
+ callback()
88
+ }
89
+ },
90
+ /**
91
+ * 校验邮箱
92
+ * @param value
93
+ * @return boolean
94
+ */
95
+ isValidEmail: (value: string) => {
96
+ if (!value) return false
97
+ const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
98
+ return emailReg.test(value)
99
+ },
100
+ /**
101
+ *解析身份证号码
102
+ */
103
+ parseIDCard: (idCard: string) => {
104
+ if (idCard) {
105
+ if (idCard.length === 18) {
106
+ return {
107
+ birthday: `${idCard.slice(6, 10)}-${idCard.slice(10, 12)}-${idCard.slice(12, 14)}`,
108
+ sex: parseInt(idCard.slice(16, 17), 10) % 2 === 1 ? '1' : '2'
109
+ }
110
+ }
111
+ }
112
+ return {
113
+ birthday: '',
114
+ sex: ''
115
+ }
116
+ },
117
+ /**
118
+ * 判断数组中是否有props相同的对象
119
+ * @param arr
120
+ * @param props
121
+ */
122
+ hasDuplicate(arr: any[], props: string[]): boolean {
123
+ const map = new Map()
124
+ for (const obj of arr) {
125
+ let key = ''
126
+ for (const prop of props) {
127
+ key += obj[prop] + '|'
128
+ }
129
+ if (map.has(key)) {
130
+ return true
131
+ }
132
+ map.set(key, true)
133
+ }
134
+ return false
135
+ },
136
+ /**
137
+ * 删除确认函数
138
+ * @param fun
139
+ * @param args
140
+ */
141
+ deleteFun(fun: Function, ...args: any[]): void {
142
+ ElMessageBox.confirm(`是否确认删除该数据?`, '删除提示', {
143
+ confirmButtonText: '确定',
144
+ cancelButtonText: '取消',
145
+ type: 'warning',
146
+ }).then(async () => {
147
+ fun(...args)
148
+ })
149
+ },
150
+ calculateAge(birthDateStr: string | undefined): number | undefined {
151
+ if (!birthDateStr) return undefined
152
+ const birthDate = new Date(birthDateStr)
153
+ const currentDate = new Date()
154
+
155
+ let age = currentDate.getFullYear() - birthDate.getFullYear()
156
+ const monthDiff = currentDate.getMonth() - birthDate.getMonth()
157
+
158
+ if (monthDiff < 0 || (monthDiff === 0 && currentDate.getDate() < birthDate.getDate())) {
159
+ age--
160
+ }
161
+
162
+ return age
163
+ },
164
+ formatCurrency(amount: number): number {
165
+ return (Math.round(amount * 100) / 100).toFixed(2) as unknown as number;
166
+ },
167
+ stripRichText(html: string): string {
168
+ // 如果输入不是字符串或为空,直接返回空字符串
169
+ if (typeof html !== 'string' || html.trim() === '') {
170
+ return '';
171
+ }
172
+
173
+ // 1. 移除所有HTML标签
174
+ let text = html.replace(/<[^>]*>?/gm, '');
175
+
176
+ // 2. 处理HTML实体(如&nbsp; &amp; &lt; &gt;等)
177
+ const entities: Record<string, string> = {
178
+ '&nbsp;': ' ',
179
+ '&amp;': '&',
180
+ '&lt;': '<',
181
+ '&gt;': '>',
182
+ '&quot;': '"',
183
+ '&#39;': "'",
184
+ '&#160;': ' '
185
+ };
186
+
187
+ text = text.replace(/&[a-zA-Z0-9#]+;/g, match => {
188
+ return entities[match] || match;
189
+ });
190
+
191
+ // 3. 去除多余的空格和空行
192
+ text = text
193
+ .replace(/\s+/g, ' ') // 将多个空格/换行符替换为单个空格
194
+ .trim(); // 去除首尾空格
195
+
196
+ return text;
197
+ },
198
+ isRichTextEmpty(content: string | undefined): boolean {
199
+ if (!content) return true;
200
+ const textContent = this.stripRichText(content);
201
+ return !textContent;
202
+ },
203
+ /**
204
+ * 解析数学不等式规则,判断x是否满足规则
205
+ * @param {string} rule - 不等式规则,如"x=100"、"x≤50"、"10<x<20"等
206
+ * @param {string|number} xValue - 变量x的值,可为字符串或数字
207
+ * @returns {boolean} - x是否满足规则
208
+ */
209
+ isValueValidForRule(rule: string, xValue: number | string): boolean {
210
+ // 去除规则中的空格,统一格式
211
+ rule = rule.replace(/\s/g, '');
212
+
213
+ // 将字符串类型的数值转换为数字,若转换失败则设为NaN
214
+ const x = typeof xValue === 'string' ? parseFloat(xValue) : xValue;
215
+
216
+ // 检查转换后的值是否为有效数字
217
+ if (isNaN(x)) {
218
+ throw new Error(`Invalid xValue: ${xValue}`);
219
+ }
220
+
221
+ // 解析规则中的数值并进行匹配
222
+ try {
223
+ // 处理 "x=a" 类型规则
224
+ if (rule.includes('=')) {
225
+ const match = rule.match(/^x=([+-]?\d+(\.\d+)?)$/);
226
+ if (match) {
227
+ const a = parseFloat(match[1]);
228
+ if (isNaN(a)) {
229
+ throw new Error(`Invalid rule value: ${match[1]}`);
230
+ }
231
+ return x === a;
232
+ }
233
+ }
234
+
235
+ // 处理 "x<a" 类型规则
236
+ if (rule.includes('<') && !rule.includes('≤') && !rule.includes('±')) {
237
+ // 先尝试匹配 "a<x<b" 类型
238
+ const rangeMatch = rule.match(/^([+-]?\d+(\.\d+)?)<x<([+-]?\d+(\.\d+)?)$/);
239
+ if (rangeMatch) {
240
+ const a = parseFloat(rangeMatch[1]);
241
+ const b = parseFloat(rangeMatch[3]);
242
+ if (isNaN(a) || isNaN(b)) {
243
+ throw new Error(`Invalid rule values: ${rangeMatch[1]} or ${rangeMatch[3]}`);
244
+ }
245
+ return x > a && x < b;
246
+ }
247
+
248
+ // 再尝试匹配 "x<a" 类型
249
+ const match = rule.match(/^x<([+-]?\d+(\.\d+)?)$/);
250
+ if (match) {
251
+ const a = parseFloat(match[1]);
252
+ if (isNaN(a)) {
253
+ throw new Error(`Invalid rule value: ${match[1]}`);
254
+ }
255
+ return x < a;
256
+ }
257
+ }
258
+
259
+ // 处理 "x≤a" 类型规则
260
+ if (rule.includes('≤')) {
261
+ const match = rule.match(/^x≤([+-]?\d+(\.\d+)?)$/);
262
+ if (match) {
263
+ const a = parseFloat(match[1]);
264
+ if (isNaN(a)) {
265
+ throw new Error(`Invalid rule value: ${match[1]}`);
266
+ }
267
+ return x <= a;
268
+ }
269
+ }
270
+
271
+ // 处理 "x>a" 类型规则
272
+ if (rule.includes('>') && !rule.includes('≥')) {
273
+ const match = rule.match(/^x>([+-]?\d+(\.\d+)?)$/);
274
+ if (match) {
275
+ const a = parseFloat(match[1]);
276
+ if (isNaN(a)) {
277
+ throw new Error(`Invalid rule value: ${match[1]}`);
278
+ }
279
+ return x > a;
280
+ }
281
+ }
282
+
283
+ // 处理 "x≥a" 类型规则
284
+ if (rule.includes('≥')) {
285
+ const match = rule.match(/^x≥([+-]?\d+(\.\d+)?)$/);
286
+ if (match) {
287
+ const a = parseFloat(match[1]);
288
+ if (isNaN(a)) {
289
+ throw new Error(`Invalid rule value: ${match[1]}`);
290
+ }
291
+ return x >= a;
292
+ }
293
+ }
294
+
295
+ // 处理 "x±a" 类型规则
296
+ if (rule.includes('±')) {
297
+ const match = rule.match(/^x±([+-]?\d+(\.\d+)?)$/);
298
+ if (match) {
299
+ const a = parseFloat(match[1]);
300
+ if (isNaN(a)) {
301
+ throw new Error(`Invalid rule value: ${match[1]}`);
302
+ }
303
+ return x >= a - Math.abs(a) && x <= a + Math.abs(a);
304
+ }
305
+ }
306
+
307
+ // 处理 "a≤x<b" 类型规则
308
+ if (rule.includes('≤x<')) {
309
+ const match = rule.match(/^([+-]?\d+(\.\d+)?)≤x<([+-]?\d+(\.\d+)?)$/);
310
+ if (match) {
311
+ const a = parseFloat(match[1]);
312
+ const b = parseFloat(match[3]);
313
+ if (isNaN(a) || isNaN(b)) {
314
+ throw new Error(`Invalid rule values: ${match[1]} or ${match[3]}`);
315
+ }
316
+ return x >= a && x < b;
317
+ }
318
+ }
319
+
320
+ } catch (error) {
321
+ throw new Error(`Rule parsing error: ${(error as Error).message}`);
322
+ }
323
+
324
+ throw new Error(`Unsupported rule format: ${rule}`);
325
+ },
326
+ parseUrlParams: (queryStr: string):Record<string, any> => {
327
+ return Object.fromEntries(new URLSearchParams(queryStr.slice(queryStr.indexOf('?') + 1)));
328
+ },
329
+ jsonToUrlQuery: (jsonObj: Record<string, string>) => {
330
+ const keyValuePairs = Object.entries(jsonObj).map(([key, value]) => {
331
+ return `${encodeURIComponent(key)}=${encodeURIComponent(value)}`
332
+ })
333
+ return keyValuePairs.length > 0 ? `?${keyValuePairs.join('&')}` : ''
334
+ }
335
+ }