adtec-core-package 2.5.3 → 2.5.4

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 (344) hide show
  1. package/.editorconfig +6 -6
  2. package/.prettierrc.json +7 -7
  3. package/.vscode/extensions.json +8 -8
  4. package/README.en.md +36 -36
  5. package/README.md +39 -39
  6. package/env.d.ts +1 -1
  7. package/eslint.config.js +56 -56
  8. package/index.html +13 -13
  9. package/package.json +71 -71
  10. package/src/App.vue +9 -9
  11. package/src/api/BasicApi.ts +26 -26
  12. package/src/api/DeptInfoApi.ts +19 -19
  13. package/src/api/DocumentApi.ts +27 -27
  14. package/src/api/EmployeeInfoApi.ts +17 -17
  15. package/src/api/SysDictCacheApi.ts +29 -29
  16. package/src/api/SysUserApi.ts +35 -35
  17. package/src/api/framework.ts +12 -12
  18. package/src/api/workflow/workflow.ts +31 -31
  19. package/src/api/workflow/workflowCommentApi.ts +20 -20
  20. package/src/api/workflow/workflowInstApi.ts +72 -72
  21. package/src/assets/base.css +86 -86
  22. package/src/assets/logo.svg +1 -1
  23. package/src/assets/main.css +35 -35
  24. package/src/assets/style/ant.scss +19 -19
  25. package/src/assets/style/index.less +180 -180
  26. package/src/assets/style/transition.scss +49 -49
  27. package/src/components/ElCardList.vue +64 -64
  28. package/src/components/ElFlex/ElFlex.vue +297 -297
  29. package/src/components/ElTotalTools.vue +83 -70
  30. package/src/components/OperationAuth/operationAuth.vue +43 -43
  31. package/src/components/RichTextEditor/RichTextEditor.vue +442 -442
  32. package/src/components/Scrollbars/ElScrollbars.vue +21 -21
  33. package/src/components/Search/ElIconSearch.vue +267 -267
  34. package/src/components/Search/ElSearch.vue +154 -154
  35. package/src/components/SelectInDicators/SelectInDicators.vue +225 -225
  36. package/src/components/SelectInDicators/api/DataIndicatorsApi.ts +28 -28
  37. package/src/components/SelectInDicators/interface/IComIndex.ts +26 -26
  38. package/src/components/SelectInDicators/interface/IComIndexAttri.ts +18 -18
  39. package/src/components/Table/ElTableColumnDynamic.vue +25 -25
  40. package/src/components/Table/ElTableColumnEdit.vue +265 -265
  41. package/src/components/Table/ElTableTool.ts +37 -37
  42. package/src/components/Title/ElTitle.vue +53 -53
  43. package/src/components/autoToolTip/ElAutoToolTip.vue +62 -62
  44. package/src/components/baseEcharts/index.vue +48 -48
  45. package/src/components/bpmntree/api/modules/role.ts +31 -31
  46. package/src/components/bpmntree/api/modules/user.ts +17 -17
  47. package/src/components/bpmntree/components/AdvancedFilter/Operator.vue +112 -112
  48. package/src/components/bpmntree/components/AdvancedFilter/Trigger.vue +23 -23
  49. package/src/components/bpmntree/components/AdvancedFilter/index.vue +230 -230
  50. package/src/components/bpmntree/components/AdvancedFilter/type.ts +20 -20
  51. package/src/components/bpmntree/components/FlowIcon/index.scss +7 -7
  52. package/src/components/bpmntree/components/FlowIcon/index.tsx +68 -68
  53. package/src/components/bpmntree/components/Render/render.vue +90 -90
  54. package/src/components/bpmntree/components/Render/type.ts +12 -12
  55. package/src/components/bpmntree/components/RoleSelector/RolePicker.vue +264 -264
  56. package/src/components/bpmntree/components/RoleSelector/RoleTag.vue +48 -48
  57. package/src/components/bpmntree/components/RoleSelector/index.vue +113 -113
  58. package/src/components/bpmntree/components/UserSelector/UserTag.vue +73 -73
  59. package/src/components/bpmntree/components/UserSelector/index.vue +140 -140
  60. package/src/components/bpmntree/hooks/useDraggableScroll.ts +44 -44
  61. package/src/components/bpmntree/typings/index.d.ts +1 -1
  62. package/src/components/bpmntree/views/flowDesign/index.vue +653 -653
  63. package/src/components/bpmntree/views/flowDesign/nodes/Add.vue +184 -184
  64. package/src/components/bpmntree/views/flowDesign/nodes/ApprovalNode.vue +127 -127
  65. package/src/components/bpmntree/views/flowDesign/nodes/CcNode.vue +93 -93
  66. package/src/components/bpmntree/views/flowDesign/nodes/ConcurrentNode.vue +61 -61
  67. package/src/components/bpmntree/views/flowDesign/nodes/ConditionNode.vue +60 -60
  68. package/src/components/bpmntree/views/flowDesign/nodes/EndNode.vue +80 -80
  69. package/src/components/bpmntree/views/flowDesign/nodes/ExclusiveNode.vue +20 -20
  70. package/src/components/bpmntree/views/flowDesign/nodes/GatewayNode.vue +173 -173
  71. package/src/components/bpmntree/views/flowDesign/nodes/InclusiveNode.vue +20 -20
  72. package/src/components/bpmntree/views/flowDesign/nodes/JumpNode.vue +49 -49
  73. package/src/components/bpmntree/views/flowDesign/nodes/Node.vue +346 -346
  74. package/src/components/bpmntree/views/flowDesign/nodes/NotifyNode.vue +115 -115
  75. package/src/components/bpmntree/views/flowDesign/nodes/ParallelNode.vue +20 -20
  76. package/src/components/bpmntree/views/flowDesign/nodes/PopoverView.vue +78 -78
  77. package/src/components/bpmntree/views/flowDesign/nodes/StartNode.vue +84 -84
  78. package/src/components/bpmntree/views/flowDesign/nodes/TimerNode.vue +50 -50
  79. package/src/components/bpmntree/views/flowDesign/nodes/TreeNode.vue +45 -45
  80. package/src/components/bpmntree/views/flowDesign/nodes/type.ts +204 -204
  81. package/src/components/bpmntree/views/flowDesign/panels/ApprovalPanel.vue +581 -581
  82. package/src/components/bpmntree/views/flowDesign/panels/AssigneePanel.vue +120 -120
  83. package/src/components/bpmntree/views/flowDesign/panels/CcPanel.vue +99 -99
  84. package/src/components/bpmntree/views/flowDesign/panels/ConditionPanel.vue +41 -41
  85. package/src/components/bpmntree/views/flowDesign/panels/EndPanel.vue +18 -18
  86. package/src/components/bpmntree/views/flowDesign/panels/ExecutionListeners.vue +110 -110
  87. package/src/components/bpmntree/views/flowDesign/panels/JumpPanel.vue +32 -32
  88. package/src/components/bpmntree/views/flowDesign/panels/NotifyPanel.vue +101 -101
  89. package/src/components/bpmntree/views/flowDesign/panels/ParaPanel.vue +248 -248
  90. package/src/components/bpmntree/views/flowDesign/panels/StartPanel.vue +160 -160
  91. package/src/components/bpmntree/views/flowDesign/panels/TaskListeners.vue +110 -110
  92. package/src/components/bpmntree/views/flowDesign/panels/TimerPanel.vue +51 -51
  93. package/src/components/bpmntree/views/flowDesign/panels/index.vue +85 -85
  94. package/src/components/bpmntree/views/view.index.vue +291 -291
  95. package/src/components/business/comp.selectUser.vue +60 -60
  96. package/src/components/business/comp.userForm.vue +311 -311
  97. package/src/components/business/userSelect.vue +413 -413
  98. package/src/components/icon/ElIconBtn.vue +243 -243
  99. package/src/components/icon/ElIcons.vue +38 -38
  100. package/src/components/kFrame/IframeOptions.ts +116 -116
  101. package/src/components/kFrame/KFrame.vue +161 -161
  102. package/src/components/tooltip/index.ts +11 -11
  103. package/src/components/tooltip/src/tooltip.ts +518 -518
  104. package/src/components/upload/ElUploads.vue +364 -364
  105. package/src/components/upload/FileView.vue +214 -214
  106. package/src/components/upload/FileViewComponents.vue +56 -56
  107. package/src/components/vxeGrid/index.vue +36 -36
  108. package/src/components/workflow/TaskOperation.vue +252 -252
  109. package/src/components/workflow/WorkflowTodoDialog.vue +91 -91
  110. package/src/components/workflow/components/AddOrMinusMultiDialog.vue +159 -159
  111. package/src/components/workflow/components/CheckDialog.vue +367 -367
  112. package/src/components/workflow/components/ProcessDetailComp.vue +157 -157
  113. package/src/components/workflow/components/ProcessDetailDialog.vue +129 -129
  114. package/src/components/workflow/components/ProcessInstance.vue +117 -117
  115. package/src/components/workflow/components/ProcessInstanceStep.vue +378 -378
  116. package/src/components/workflow/components/SelectAssigneeDialog.vue +109 -109
  117. package/src/components/workflow/components/SelectReturnActivityDialog.vue +104 -104
  118. package/src/config/ElementPlusConfig.ts +95 -95
  119. package/src/config/VxeTableConfig.ts +254 -254
  120. package/src/css/elementUI/affix.scss +7 -7
  121. package/src/css/elementUI/alert.scss +115 -115
  122. package/src/css/elementUI/anchor-link.scss +41 -41
  123. package/src/css/elementUI/anchor.scss +88 -88
  124. package/src/css/elementUI/aside.scss +8 -8
  125. package/src/css/elementUI/autocomplete.scss +89 -89
  126. package/src/css/elementUI/avatar.scss +55 -55
  127. package/src/css/elementUI/backtop.scss +29 -29
  128. package/src/css/elementUI/badge.scss +58 -58
  129. package/src/css/elementUI/base.scss +3 -3
  130. package/src/css/elementUI/breadcrumb.scss +62 -62
  131. package/src/css/elementUI/button-group.scss +80 -80
  132. package/src/css/elementUI/button.scss +304 -304
  133. package/src/css/elementUI/calendar.scss +80 -80
  134. package/src/css/elementUI/card.scss +45 -45
  135. package/src/css/elementUI/carousel-item.scss +58 -58
  136. package/src/css/elementUI/carousel.scss +188 -188
  137. package/src/css/elementUI/cascader-panel.scss +138 -138
  138. package/src/css/elementUI/cascader.scss +230 -230
  139. package/src/css/elementUI/check-tag.scss +60 -60
  140. package/src/css/elementUI/checkbox-button.scss +140 -140
  141. package/src/css/elementUI/checkbox-group.scss +7 -7
  142. package/src/css/elementUI/checkbox.scss +298 -298
  143. package/src/css/elementUI/col.scss +48 -48
  144. package/src/css/elementUI/collapse.scss +70 -70
  145. package/src/css/elementUI/color/index.scss +20 -20
  146. package/src/css/elementUI/color-picker.scss +392 -392
  147. package/src/css/elementUI/common/popup.scss +47 -47
  148. package/src/css/elementUI/common/transition.scss +122 -122
  149. package/src/css/elementUI/common/var.scss +1549 -1549
  150. package/src/css/elementUI/container.scss +14 -14
  151. package/src/css/elementUI/dark/css-vars.scss +39 -39
  152. package/src/css/elementUI/dark/var.scss +222 -222
  153. package/src/css/elementUI/date-picker/date-picker.scss +110 -110
  154. package/src/css/elementUI/date-picker/date-range-picker.scss +113 -113
  155. package/src/css/elementUI/date-picker/date-table.scss +158 -158
  156. package/src/css/elementUI/date-picker/month-table.scss +112 -112
  157. package/src/css/elementUI/date-picker/picker-panel.scss +131 -131
  158. package/src/css/elementUI/date-picker/picker.scss +219 -219
  159. package/src/css/elementUI/date-picker/time-picker.scss +90 -90
  160. package/src/css/elementUI/date-picker/time-range-picker.scss +33 -33
  161. package/src/css/elementUI/date-picker/time-spinner.scss +111 -111
  162. package/src/css/elementUI/date-picker/year-table.scss +108 -108
  163. package/src/css/elementUI/date-picker.scss +9 -9
  164. package/src/css/elementUI/descriptions-item.scss +73 -73
  165. package/src/css/elementUI/descriptions.scss +152 -152
  166. package/src/css/elementUI/dialog.scss +199 -199
  167. package/src/css/elementUI/display.scss +12 -12
  168. package/src/css/elementUI/divider.scss +48 -48
  169. package/src/css/elementUI/drawer.scss +164 -164
  170. package/src/css/elementUI/dropdown.scss +208 -208
  171. package/src/css/elementUI/empty.scss +49 -49
  172. package/src/css/elementUI/footer.scss +12 -12
  173. package/src/css/elementUI/form.scss +243 -243
  174. package/src/css/elementUI/header.scss +12 -12
  175. package/src/css/elementUI/icon.scss +45 -45
  176. package/src/css/elementUI/image-viewer.scss +139 -139
  177. package/src/css/elementUI/image.scss +49 -49
  178. package/src/css/elementUI/index.scss +110 -110
  179. package/src/css/elementUI/input-number.scss +178 -178
  180. package/src/css/elementUI/input.scss +478 -478
  181. package/src/css/elementUI/link.scss +90 -90
  182. package/src/css/elementUI/loading.scss +104 -104
  183. package/src/css/elementUI/main.scss +14 -14
  184. package/src/css/elementUI/mention.scss +88 -88
  185. package/src/css/elementUI/menu.scss +339 -339
  186. package/src/css/elementUI/message-box.scss +213 -213
  187. package/src/css/elementUI/message.scss +98 -98
  188. package/src/css/elementUI/mixins/_button.scss +165 -165
  189. package/src/css/elementUI/mixins/_col.scss +33 -33
  190. package/src/css/elementUI/mixins/_var.scss +67 -67
  191. package/src/css/elementUI/mixins/config.scss +5 -5
  192. package/src/css/elementUI/mixins/function.scss +88 -88
  193. package/src/css/elementUI/mixins/mixins.scss +237 -237
  194. package/src/css/elementUI/mixins/utils.scss +39 -39
  195. package/src/css/elementUI/notification.scss +104 -104
  196. package/src/css/elementUI/option-group.scss +33 -33
  197. package/src/css/elementUI/option.scss +71 -71
  198. package/src/css/elementUI/overlay.scss +17 -17
  199. package/src/css/elementUI/page-header.scss +60 -60
  200. package/src/css/elementUI/pagination.scss +238 -238
  201. package/src/css/elementUI/popconfirm.scss +16 -16
  202. package/src/css/elementUI/popover.scss +61 -61
  203. package/src/css/elementUI/popper.scss +106 -106
  204. package/src/css/elementUI/progress.scss +179 -179
  205. package/src/css/elementUI/radio-button.scss +169 -169
  206. package/src/css/elementUI/radio-group.scss +9 -9
  207. package/src/css/elementUI/radio.scss +215 -215
  208. package/src/css/elementUI/rate.scss +108 -108
  209. package/src/css/elementUI/reset.scss +98 -98
  210. package/src/css/elementUI/result.scss +57 -57
  211. package/src/css/elementUI/row.scss +35 -35
  212. package/src/css/elementUI/scrollbar.scss +97 -97
  213. package/src/css/elementUI/segmented.scss +183 -183
  214. package/src/css/elementUI/select-dropdown-v2.scss +1 -1
  215. package/src/css/elementUI/select-dropdown.scss +57 -57
  216. package/src/css/elementUI/select-v2.scss +4 -4
  217. package/src/css/elementUI/select.scss +253 -253
  218. package/src/css/elementUI/skeleton-item.scss +83 -83
  219. package/src/css/elementUI/skeleton.scss +44 -44
  220. package/src/css/elementUI/slider.scss +212 -212
  221. package/src/css/elementUI/space.scss +20 -20
  222. package/src/css/elementUI/spinner.scss +43 -43
  223. package/src/css/elementUI/statistic.scss +35 -35
  224. package/src/css/elementUI/step.scss +316 -316
  225. package/src/css/elementUI/steps.scss +21 -21
  226. package/src/css/elementUI/switch.scss +300 -300
  227. package/src/css/elementUI/table-column.scss +98 -98
  228. package/src/css/elementUI/table-v2.scss +236 -236
  229. package/src/css/elementUI/table.scss +697 -697
  230. package/src/css/elementUI/tabs.scss +659 -659
  231. package/src/css/elementUI/tag.scss +181 -181
  232. package/src/css/elementUI/text.scss +51 -51
  233. package/src/css/elementUI/time-picker.scss +5 -5
  234. package/src/css/elementUI/time-select.scss +37 -37
  235. package/src/css/elementUI/timeline-item.scss +84 -84
  236. package/src/css/elementUI/timeline.scss +46 -46
  237. package/src/css/elementUI/tooltip-v2.scss +95 -95
  238. package/src/css/elementUI/tour.scss +187 -187
  239. package/src/css/elementUI/transfer.scss +203 -203
  240. package/src/css/elementUI/tree-select.scss +41 -41
  241. package/src/css/elementUI/tree.scss +134 -134
  242. package/src/css/elementUI/upload.scss +654 -654
  243. package/src/css/elementUI/var.scss +87 -87
  244. package/src/css/elementUI/virtual-list.scss +40 -40
  245. package/src/css/vxeTableUI/all.scss +9 -9
  246. package/src/css/vxeTableUI/base.scss +16 -16
  247. package/src/css/vxeTableUI/components/colgroup.scss +0 -0
  248. package/src/css/vxeTableUI/components/column.scss +0 -0
  249. package/src/css/vxeTableUI/components/grid.scss +83 -83
  250. package/src/css/vxeTableUI/components/icon.scss +1017 -1017
  251. package/src/css/vxeTableUI/components/iconTable.scss +205 -205
  252. package/src/css/vxeTableUI/components/old-icon.scss +715 -715
  253. package/src/css/vxeTableUI/components/table-module/all.scss +6 -6
  254. package/src/css/vxeTableUI/components/table-module/custom.scss +490 -490
  255. package/src/css/vxeTableUI/components/table-module/edit.scss +0 -0
  256. package/src/css/vxeTableUI/components/table-module/export.scss +130 -130
  257. package/src/css/vxeTableUI/components/table-module/filter.scss +127 -127
  258. package/src/css/vxeTableUI/components/table-module/keyboard.scss +0 -0
  259. package/src/css/vxeTableUI/components/table-module/menu.scss +85 -85
  260. package/src/css/vxeTableUI/components/table-module/validator.scss +0 -0
  261. package/src/css/vxeTableUI/components/table.scss +2256 -2256
  262. package/src/css/vxeTableUI/components/toolbar.scss +99 -99
  263. package/src/css/vxeTableUI/components/ui.scss +0 -0
  264. package/src/css/vxeTableUI/components/v-x-e-table.scss +0 -0
  265. package/src/css/vxeTableUI/cssvar.scss +2 -2
  266. package/src/css/vxeTableUI/default.scss +2 -2
  267. package/src/css/vxeTableUI/helpers/baseMixin.scss +82 -82
  268. package/src/css/vxeTableUI/icon/iconfont.ttf +0 -0
  269. package/src/css/vxeTableUI/icon/iconfont.woff +0 -0
  270. package/src/css/vxeTableUI/icon/iconfont.woff2 +0 -0
  271. package/src/css/vxeTableUI/index.scss +4 -4
  272. package/src/css/vxeTableUI/modules.scss +5 -5
  273. package/src/css/vxeTableUI/theme/base.scss +88 -88
  274. package/src/css/vxeTableUI/theme/dark.scss +46 -46
  275. package/src/css/vxeTableUI/theme/light.scss +41 -41
  276. package/src/css/vxeTableUI/variable.scss +41 -41
  277. package/src/directives/vKeydown.ts +91 -91
  278. package/src/hooks/useDictHooks.ts +120 -120
  279. package/src/hooks/useEcharts.ts +58 -58
  280. package/src/hooks/useFileView.ts +11 -11
  281. package/src/hooks/useListenerHooks.ts +137 -137
  282. package/src/hooks/useMessageHooks.ts +132 -132
  283. package/src/hooks/useOpenNewMenu.ts +30 -30
  284. package/src/hooks/usePermissionHooks.ts +139 -139
  285. package/src/hooks/usePermissionToolHooks.ts +21 -21
  286. package/src/hooks/useResetRefHooks.ts +18 -18
  287. package/src/hooks/userWorkflowHooks.ts +112 -112
  288. package/src/hooks/workflowTodo.ts +85 -85
  289. package/src/interface/BaseEntity.ts +30 -30
  290. package/src/interface/IMdmDept.ts +84 -84
  291. package/src/interface/IMdmEmployee.ts +153 -153
  292. package/src/interface/IMdmEmployeeQuery.ts +21 -21
  293. package/src/interface/IMdmOrg.ts +29 -29
  294. package/src/interface/IMdmOrgQuery.ts +13 -13
  295. package/src/interface/IOrgDeptInfo.ts +12 -12
  296. package/src/interface/ISortList.ts +6 -6
  297. package/src/interface/ISysDictDataCacheVo.ts +46 -46
  298. package/src/interface/ISysDictType.ts +37 -37
  299. package/src/interface/ISysMenuDataVo.ts +22 -22
  300. package/src/interface/ISysMenuInfoVo.ts +83 -83
  301. package/src/interface/ISysMenuOperationVo.ts +21 -21
  302. package/src/interface/ISysUploadFiles.ts +16 -16
  303. package/src/interface/ISysUserInfo.ts +70 -70
  304. package/src/interface/ITpReviewBatch.ts +52 -52
  305. package/src/interface/IUserBaseInfo.ts +90 -90
  306. package/src/interface/IUserPermissionVo.ts +44 -44
  307. package/src/interface/IVxeTable.ts +1 -1
  308. package/src/interface/Message.ts +73 -73
  309. package/src/interface/PageData.ts +17 -17
  310. package/src/interface/ResponseData.ts +16 -16
  311. package/src/interface/dictMapType.ts +11 -11
  312. package/src/interface/enum/FlexEnum.ts +85 -85
  313. package/src/interface/enum/MessageEnum.ts +41 -41
  314. package/src/interface/workflow/IWfProcessDefVo.ts +14 -14
  315. package/src/interface/workflow/IWfReturnNodeVo.ts +16 -16
  316. package/src/interface/workflow/IWfTaskAskVo.ts +70 -70
  317. package/src/interface/workflow/IWfTaskQueryVo.ts +30 -30
  318. package/src/interface/workflow/IWfTaskUsersVo.ts +21 -21
  319. package/src/interface/workflow/IWfTaskVo.ts +192 -192
  320. package/src/interface/workflow/workflow.ts +22 -22
  321. package/src/main.ts +14 -14
  322. package/src/mixin/globalMixin.ts +48 -48
  323. package/src/packages/index.ts +18 -18
  324. package/src/packages/text.vue +13 -13
  325. package/src/plugins/echartsConfig.ts +74 -74
  326. package/src/plugins/plugins.ts +12 -12
  327. package/src/plugins/renderDialog.ts +74 -74
  328. package/src/router/index.ts +23 -23
  329. package/src/stores/dictStore.ts +51 -51
  330. package/src/stores/messageStore.ts +49 -49
  331. package/src/stores/permissionStore.ts +112 -112
  332. package/src/stores/storeConfig.ts +23 -23
  333. package/src/stores/userInfoStore.ts +31 -31
  334. package/src/utils/AxiosConfig.ts +226 -226
  335. package/src/utils/FrameworkUtils.ts +370 -370
  336. package/src/utils/commonUtils.ts +335 -335
  337. package/src/utils/encrypt.ts +18 -18
  338. package/src/utils/modules.ts +8 -8
  339. package/src/utils/request.ts +76 -76
  340. package/src/utils/tree.ts +50 -50
  341. package/tsconfig.app.json +12 -12
  342. package/tsconfig.json +11 -11
  343. package/tsconfig.node.json +18 -18
  344. package/vite.config.ts +38 -38
@@ -1,364 +1,364 @@
1
- <!--创建人 丁盼-->
2
- <!--说明: 文档上传组件-->
3
- <!--创建时间: 2024/12/2 下午1:59-->
4
- <!--修改时间: 2024/12/2 下午1:59-->
5
- <template>
6
- <div v-if="!isEdlt">
7
- <el-auto-tool-tip v-if="uploadFilesList?.length">
8
- <template #tooltipContent>
9
- <div style="display:flex;flex-direction:column">
10
- <span
11
- v-for="item in uploadFilesList"
12
- :key="item.id"
13
- style="margin: 0 2px"
14
- >{{ item.name }}
15
- </span>
16
- </div>
17
- </template>
18
- <template #content>
19
- <div style="display:flex;flex-direction:column">
20
- <div v-for="item in uploadFilesList" :key="item.id"
21
- class="file-item"
22
- style="display:flex; align-items:center;">
23
- <el-icons :model-value="getIcon(item.name)" style="margin-right: 5px"></el-icons>
24
- <span class="link-name" @click="fileView(item.id)">{{ item.name }}</span>
25
- </div>
26
- </div>
27
- </template>
28
- </el-auto-tool-tip>
29
- <div style="text-align: center;color: var(--el-disabled-text-color)" v-else>
30
- 暂无附件
31
- </div>
32
- </div>
33
- <el-upload
34
- v-else
35
- ref="ref_upload"
36
- :file-list="uploadFilesList"
37
- @success="success"
38
- @remove="remove"
39
- @preview="preview"
40
- @error="error"
41
- @exceed="exceed"
42
- :before-upload="beforeUpload"
43
- drag
44
- :accept="getAccept"
45
- :action="'/api/doc/uploadFile/' + business + '/' + businessId + '/' + association"
46
- multiple
47
- :limit="limit"
48
- :headers="uploadHeaders"
49
- >
50
- <el-icon class="el-icon--upload">
51
- <upload-filled />
52
- </el-icon>
53
- <div class="el-upload__text">拖动文件或<em>点击上传</em></div>
54
- <div class="el-upload__tip">最大上传文件大小{{ size }}MB</div>
55
- <template #file="{ file }">
56
- <el-flex
57
- class="file-class"
58
- @mousemove="mousemove(file.name)"
59
- @mouseout="mouseout"
60
- @click="preview(file)"
61
- height="20px"
62
- :width="itemWidth"
63
- >
64
- <el-flex align="center" justify="flex-start">
65
- <el-tooltip class="box-item" :content="file.name" placement="top">
66
- <el-text truncated style="cursor: pointer">
67
- <el-icons :model-value="getIcon(file.name)" style="margin-right: 5px"></el-icons>
68
- {{ file.name }}
69
- </el-text>
70
- </el-tooltip>
71
- </el-flex>
72
- <el-flex align="center" justify="flex-end" width="50px">
73
- <el-text v-if="!file?.businessId && file.percentage !== 100"
74
- >{{ file.percentage }}%
75
- </el-text>
76
- <el-icons
77
- v-if="file?.businessId || file.percentage === 100"
78
- @click.prevent.stop="fileClick(file)"
79
- :model-value="file.name === hoverfileName ? 'adtec-close' : 'adtec-success'"
80
- style="color: var(--el-color-success); font-size: 14px"
81
- :style="{
82
- color:
83
- file.name === hoverfileName ? 'var(--el-color-danger)' : 'var(--el-color-success)',
84
- }"
85
- ></el-icons>
86
- </el-flex>
87
- </el-flex>
88
- </template>
89
- </el-upload>
90
- </template>
91
-
92
- <script setup lang="ts">
93
- import { UploadFilled } from '@element-plus/icons-vue'
94
- import { computed, onMounted, ref, watch } from 'vue'
95
- import {
96
- ElMessage,
97
- ElMessageBox,
98
- type UploadFile,
99
- type UploadFiles,
100
- type UploadUserFile,
101
- } from 'element-plus'
102
- import type { ISysUploadFiles } from '../../interface/ISysUploadFiles'
103
- //@ts-ignore
104
- import useFileView from '../../hooks/useFileView.ts'
105
- import documentApi from '../../api/DocumentApi.ts'
106
- import frameworkUtils from '../../utils/FrameworkUtils.ts'
107
-
108
- const { fileView: fileView } = useFileView()
109
- const uploadHeaders = ref({
110
- Authorization: '',
111
- })
112
- const ref_upload = ref()
113
- const hoverfileName = ref('')
114
- const props = defineProps({
115
- /**
116
- * @description 上传文件数量
117
- * @default 1
118
- */
119
- limit: {
120
- type: Number,
121
- default: 1,
122
- },
123
- /**
124
- * @description 纵向排列
125
- * @default false
126
- */
127
- vertical: {
128
- type: Boolean,
129
- default: false,
130
- },
131
- /**
132
- * @description 上传文件类型
133
- * @default ''
134
- * @type {'images'|'document'|'txt'|'pdf'|'word'|'excel'|'ppt'}
135
- */
136
- accept: {
137
- type: String,
138
- default: '',
139
- },
140
- /**
141
- * @description 业务类型
142
- * @default 'default'
143
- */
144
- business: {
145
- type: String,
146
- default: 'default',
147
- },
148
- /**
149
- * @description 业务id
150
- * @default ''
151
- */
152
- businessId: {
153
- type: String,
154
- default: 'default',
155
- },
156
- /**
157
- * 文件列表
158
- */
159
- uploadFilesList: {
160
- type: Array<ISysUploadFiles>,
161
- default: () => [],
162
- },
163
- /**
164
- * @description 是否编辑状态
165
- * @default 'true'
166
- * @type {true|false}
167
- */
168
- isEdlt: {
169
- type: Boolean,
170
- default: true,
171
- },
172
- /**
173
- * @description 文档上传是否默认关联,默认不关联
174
- * @default 'false'
175
- * @type {true|false}
176
- */
177
- association: {
178
- type: Boolean,
179
- default: false,
180
- },
181
- size: {
182
- type: Number,
183
- default: 50,
184
- },
185
- //附件宽度
186
- itemWidth: {
187
- type: String,
188
- default: '100%',
189
- },
190
- })
191
- const mousemove = (fileName: string) => {
192
- hoverfileName.value = fileName
193
- }
194
- const mouseout = () => {
195
- hoverfileName.value = ''
196
- }
197
- const getAccept = computed(() => {
198
- if (props.accept === 'images') {
199
- return '.jpg,.jpeg,.png,.gif,.bmp,.JPG,.JPEG,.PBG,.GIF,.BMP'
200
- } else if (props.accept === 'document') {
201
- return '.txt,.pdf,.doc,.docx,.xls,.xlsx,.ppt,.pptx'
202
- } else if (props.accept === 'txt') {
203
- return '.txt'
204
- } else if (props.accept === 'pdf') {
205
- return '.pdf'
206
- } else if (props.accept === 'word') {
207
- return '.doc,.docx'
208
- } else if (props.accept === 'excel') {
209
- return '.xls,.xlsx'
210
- } else if (props.accept === 'ppt') {
211
- return '.ppt,.pptx'
212
- } else {
213
- return ''
214
- }
215
- })
216
- const getIcon = (fileName: string) => {
217
- const type: string = fileName.split('.').pop() + ''
218
- if ('.jpg,.jpeg,.png,.gif,.bmp,.JPG,.JPEG,.PBG,.GIF,.BMP'.includes(type)) {
219
- return 'adtec-image'
220
- } else if ('txt'.includes(type)) {
221
- return 'adtec-text'
222
- } else if ('pdf'.includes(type)) {
223
- return 'adtec-pdf'
224
- } else if ('doc,docx'.includes(type)) {
225
- return 'adtec-word'
226
- } else if ('xls,xlsx'.includes(type)) {
227
- return 'adtec-excel'
228
- } else if ('ppt,pptx'.includes(type)) {
229
- return 'adtec-ppt'
230
- } else {
231
- return 'adtec-text'
232
- }
233
- }
234
- const success = (response: any, uploadFile: UploadFile, uploadFiles: UploadFiles) => {
235
- if (response.code === '0') {
236
- props.uploadFilesList.push(response.data as ISysUploadFiles)
237
- } else {
238
- ElMessage.error(response.msg)
239
- ref_upload.value?.handleRemove(uploadFile)
240
- }
241
- for (let i = loadingFiles.value.length - 1; i >= 0; i--) {
242
- if (loadingFiles.value[i] === uploadFile.name) {
243
- loadingFiles.value.splice(i, 1)
244
- }
245
- }
246
- }
247
- const loading = defineModel<boolean>('loading')
248
- const loadingFiles = ref<string[]>([])
249
- watch(
250
- loadingFiles,
251
- (val) => {
252
- if (val.length > 0) {
253
- loading.value = true
254
- } else {
255
- loading.value = false
256
- }
257
- },
258
- { deep: true },
259
- )
260
- const beforeUpload = (file: File) => {
261
- const f = props.uploadFilesList.find((c) => c.name === file.name)
262
- if (f) {
263
- ElMessage.warning(file.name + ',文件已存在')
264
- return false
265
- } else if (file.size > props.size * 1024 * 1024) {
266
- ElMessage.warning('文件大小不能超过' + props.size + 'MB')
267
- return false
268
- }
269
- loadingFiles.value.push(file.name)
270
- return true
271
- }
272
- const fileClick = async (file: UploadFile) => {
273
- if (file.name === hoverfileName.value) {
274
- const flag = await ElMessageBox.confirm('删除不可恢复!您确定删除此附件?', '提示', {
275
- confirmButtonText: '确定',
276
- cancelButtonText: '取消',
277
- type: 'warning',
278
- })
279
- if (!flag) {
280
- return
281
- }
282
- ref_upload.value?.handleRemove(file)
283
- } else {
284
- preview(file)
285
- }
286
- }
287
- const exceed = (files: File[], uploadFiles: UploadUserFile[]) => {
288
- ElMessage.warning('最多上传' + props.limit + '个文件,上传文件数量已达到限制')
289
- }
290
- const error = (error: Error, uploadFile: UploadFile, uploadFiles: UploadFiles) => {
291
- ElMessage.error('上传失败')
292
- for (let i = loadingFiles.value.length - 1; i >= 0; i--) {
293
- if (loadingFiles.value[i] === uploadFile.name) {
294
- loadingFiles.value.splice(i, 1)
295
- }
296
- }
297
- }
298
- const preview = async (uploadFile: UploadFile) => {
299
- const file = props.uploadFilesList.find((c) => c.name === uploadFile.name)
300
- if (file) {
301
- //if ((uploadFile.response as any).code === '0') {
302
- // const data = (uploadFile.response as any).data as ISysUploadFiles
303
- fileView(file.id)
304
- }
305
- }
306
- const remove = async (file: UploadFile) => {
307
- // if ((file.response as any).code === '0') {
308
- // const data = (file.response as any).data as ISysUploadFiles
309
- const find = props.uploadFilesList.find((c) => c.name === file.name)
310
- if (find) {
311
- try {
312
- await documentApi.delSysUploadFile(find.id)
313
- props.uploadFilesList.splice(props.uploadFilesList.indexOf(find), 1)
314
- } catch (err: any) {
315
- frameworkUtils.messageError(err)
316
- }
317
- }
318
- // }
319
- }
320
- onMounted(() => {
321
- uploadHeaders.value.Authorization = sessionStorage.getItem('Authorization') + ''
322
- })
323
- defineExpose({
324
- remove
325
- })
326
- </script>
327
- <style scoped lang="scss">
328
- .file-class {
329
- }
330
-
331
- .file-class :hover {
332
- color: var(--el-color-primary);
333
- }
334
-
335
- :deep {
336
- .el-icon--upload {
337
- margin-bottom: 0;
338
- }
339
- }
340
- .file-item {
341
- position: relative;
342
- padding: 2px 0;
343
- border-radius: 4px;
344
- transition: background-color 0.2s ease;
345
-
346
- &:hover {
347
- background-color: var(--el-fill-color-light);
348
-
349
- .delete-icon {
350
- visibility: visible;
351
- opacity: 1;
352
- transform: scale(1);
353
- }
354
- }
355
- }
356
- .link-name {
357
- cursor: pointer;
358
- }
359
-
360
- .link-name:hover {
361
- color: var(--el-color-primary);
362
- text-decoration: underline;
363
- }
364
- </style>
1
+ <!--创建人 丁盼-->
2
+ <!--说明: 文档上传组件-->
3
+ <!--创建时间: 2024/12/2 下午1:59-->
4
+ <!--修改时间: 2024/12/2 下午1:59-->
5
+ <template>
6
+ <div v-if="!isEdlt">
7
+ <el-auto-tool-tip v-if="uploadFilesList?.length">
8
+ <template #tooltipContent>
9
+ <div style="display:flex;flex-direction:column">
10
+ <span
11
+ v-for="item in uploadFilesList"
12
+ :key="item.id"
13
+ style="margin: 0 2px"
14
+ >{{ item.name }}
15
+ </span>
16
+ </div>
17
+ </template>
18
+ <template #content>
19
+ <div style="display:flex;flex-direction:column">
20
+ <div v-for="item in uploadFilesList" :key="item.id"
21
+ class="file-item"
22
+ style="display:flex; align-items:center;">
23
+ <el-icons :model-value="getIcon(item.name)" style="margin-right: 5px"></el-icons>
24
+ <span class="link-name" @click="fileView(item.id)">{{ item.name }}</span>
25
+ </div>
26
+ </div>
27
+ </template>
28
+ </el-auto-tool-tip>
29
+ <div style="text-align: center;color: var(--el-disabled-text-color)" v-else>
30
+ 暂无附件
31
+ </div>
32
+ </div>
33
+ <el-upload
34
+ v-else
35
+ ref="ref_upload"
36
+ :file-list="uploadFilesList"
37
+ @success="success"
38
+ @remove="remove"
39
+ @preview="preview"
40
+ @error="error"
41
+ @exceed="exceed"
42
+ :before-upload="beforeUpload"
43
+ drag
44
+ :accept="getAccept"
45
+ :action="'/api/doc/uploadFile/' + business + '/' + businessId + '/' + association"
46
+ multiple
47
+ :limit="limit"
48
+ :headers="uploadHeaders"
49
+ >
50
+ <el-icon class="el-icon--upload">
51
+ <upload-filled />
52
+ </el-icon>
53
+ <div class="el-upload__text">拖动文件或<em>点击上传</em></div>
54
+ <div class="el-upload__tip">最大上传文件大小{{ size }}MB</div>
55
+ <template #file="{ file }">
56
+ <el-flex
57
+ class="file-class"
58
+ @mousemove="mousemove(file.name)"
59
+ @mouseout="mouseout"
60
+ @click="preview(file)"
61
+ height="20px"
62
+ :width="itemWidth"
63
+ >
64
+ <el-flex align="center" justify="flex-start">
65
+ <el-tooltip class="box-item" :content="file.name" placement="top">
66
+ <el-text truncated style="cursor: pointer">
67
+ <el-icons :model-value="getIcon(file.name)" style="margin-right: 5px"></el-icons>
68
+ {{ file.name }}
69
+ </el-text>
70
+ </el-tooltip>
71
+ </el-flex>
72
+ <el-flex align="center" justify="flex-end" width="50px">
73
+ <el-text v-if="!file?.businessId && file.percentage !== 100"
74
+ >{{ file.percentage }}%
75
+ </el-text>
76
+ <el-icons
77
+ v-if="file?.businessId || file.percentage === 100"
78
+ @click.prevent.stop="fileClick(file)"
79
+ :model-value="file.name === hoverfileName ? 'adtec-close' : 'adtec-success'"
80
+ style="color: var(--el-color-success); font-size: 14px"
81
+ :style="{
82
+ color:
83
+ file.name === hoverfileName ? 'var(--el-color-danger)' : 'var(--el-color-success)',
84
+ }"
85
+ ></el-icons>
86
+ </el-flex>
87
+ </el-flex>
88
+ </template>
89
+ </el-upload>
90
+ </template>
91
+
92
+ <script setup lang="ts">
93
+ import { UploadFilled } from '@element-plus/icons-vue'
94
+ import { computed, onMounted, ref, watch } from 'vue'
95
+ import {
96
+ ElMessage,
97
+ ElMessageBox,
98
+ type UploadFile,
99
+ type UploadFiles,
100
+ type UploadUserFile,
101
+ } from 'element-plus'
102
+ import type { ISysUploadFiles } from '../../interface/ISysUploadFiles'
103
+ //@ts-ignore
104
+ import useFileView from '../../hooks/useFileView.ts'
105
+ import documentApi from '../../api/DocumentApi.ts'
106
+ import frameworkUtils from '../../utils/FrameworkUtils.ts'
107
+
108
+ const { fileView: fileView } = useFileView()
109
+ const uploadHeaders = ref({
110
+ Authorization: '',
111
+ })
112
+ const ref_upload = ref()
113
+ const hoverfileName = ref('')
114
+ const props = defineProps({
115
+ /**
116
+ * @description 上传文件数量
117
+ * @default 1
118
+ */
119
+ limit: {
120
+ type: Number,
121
+ default: 1,
122
+ },
123
+ /**
124
+ * @description 纵向排列
125
+ * @default false
126
+ */
127
+ vertical: {
128
+ type: Boolean,
129
+ default: false,
130
+ },
131
+ /**
132
+ * @description 上传文件类型
133
+ * @default ''
134
+ * @type {'images'|'document'|'txt'|'pdf'|'word'|'excel'|'ppt'}
135
+ */
136
+ accept: {
137
+ type: String,
138
+ default: '',
139
+ },
140
+ /**
141
+ * @description 业务类型
142
+ * @default 'default'
143
+ */
144
+ business: {
145
+ type: String,
146
+ default: 'default',
147
+ },
148
+ /**
149
+ * @description 业务id
150
+ * @default ''
151
+ */
152
+ businessId: {
153
+ type: String,
154
+ default: 'default',
155
+ },
156
+ /**
157
+ * 文件列表
158
+ */
159
+ uploadFilesList: {
160
+ type: Array<ISysUploadFiles>,
161
+ default: () => [],
162
+ },
163
+ /**
164
+ * @description 是否编辑状态
165
+ * @default 'true'
166
+ * @type {true|false}
167
+ */
168
+ isEdlt: {
169
+ type: Boolean,
170
+ default: true,
171
+ },
172
+ /**
173
+ * @description 文档上传是否默认关联,默认不关联
174
+ * @default 'false'
175
+ * @type {true|false}
176
+ */
177
+ association: {
178
+ type: Boolean,
179
+ default: false,
180
+ },
181
+ size: {
182
+ type: Number,
183
+ default: 50,
184
+ },
185
+ //附件宽度
186
+ itemWidth: {
187
+ type: String,
188
+ default: '100%',
189
+ },
190
+ })
191
+ const mousemove = (fileName: string) => {
192
+ hoverfileName.value = fileName
193
+ }
194
+ const mouseout = () => {
195
+ hoverfileName.value = ''
196
+ }
197
+ const getAccept = computed(() => {
198
+ if (props.accept === 'images') {
199
+ return '.jpg,.jpeg,.png,.gif,.bmp,.JPG,.JPEG,.PBG,.GIF,.BMP'
200
+ } else if (props.accept === 'document') {
201
+ return '.txt,.pdf,.doc,.docx,.xls,.xlsx,.ppt,.pptx'
202
+ } else if (props.accept === 'txt') {
203
+ return '.txt'
204
+ } else if (props.accept === 'pdf') {
205
+ return '.pdf'
206
+ } else if (props.accept === 'word') {
207
+ return '.doc,.docx'
208
+ } else if (props.accept === 'excel') {
209
+ return '.xls,.xlsx'
210
+ } else if (props.accept === 'ppt') {
211
+ return '.ppt,.pptx'
212
+ } else {
213
+ return ''
214
+ }
215
+ })
216
+ const getIcon = (fileName: string) => {
217
+ const type: string = fileName.split('.').pop() + ''
218
+ if ('.jpg,.jpeg,.png,.gif,.bmp,.JPG,.JPEG,.PBG,.GIF,.BMP'.includes(type)) {
219
+ return 'adtec-image'
220
+ } else if ('txt'.includes(type)) {
221
+ return 'adtec-text'
222
+ } else if ('pdf'.includes(type)) {
223
+ return 'adtec-pdf'
224
+ } else if ('doc,docx'.includes(type)) {
225
+ return 'adtec-word'
226
+ } else if ('xls,xlsx'.includes(type)) {
227
+ return 'adtec-excel'
228
+ } else if ('ppt,pptx'.includes(type)) {
229
+ return 'adtec-ppt'
230
+ } else {
231
+ return 'adtec-text'
232
+ }
233
+ }
234
+ const success = (response: any, uploadFile: UploadFile, uploadFiles: UploadFiles) => {
235
+ if (response.code === '0') {
236
+ props.uploadFilesList.push(response.data as ISysUploadFiles)
237
+ } else {
238
+ ElMessage.error(response.msg)
239
+ ref_upload.value?.handleRemove(uploadFile)
240
+ }
241
+ for (let i = loadingFiles.value.length - 1; i >= 0; i--) {
242
+ if (loadingFiles.value[i] === uploadFile.name) {
243
+ loadingFiles.value.splice(i, 1)
244
+ }
245
+ }
246
+ }
247
+ const loading = defineModel<boolean>('loading')
248
+ const loadingFiles = ref<string[]>([])
249
+ watch(
250
+ loadingFiles,
251
+ (val) => {
252
+ if (val.length > 0) {
253
+ loading.value = true
254
+ } else {
255
+ loading.value = false
256
+ }
257
+ },
258
+ { deep: true },
259
+ )
260
+ const beforeUpload = (file: File) => {
261
+ const f = props.uploadFilesList.find((c) => c.name === file.name)
262
+ if (f) {
263
+ ElMessage.warning(file.name + ',文件已存在')
264
+ return false
265
+ } else if (file.size > props.size * 1024 * 1024) {
266
+ ElMessage.warning('文件大小不能超过' + props.size + 'MB')
267
+ return false
268
+ }
269
+ loadingFiles.value.push(file.name)
270
+ return true
271
+ }
272
+ const fileClick = async (file: UploadFile) => {
273
+ if (file.name === hoverfileName.value) {
274
+ const flag = await ElMessageBox.confirm('删除不可恢复!您确定删除此附件?', '提示', {
275
+ confirmButtonText: '确定',
276
+ cancelButtonText: '取消',
277
+ type: 'warning',
278
+ })
279
+ if (!flag) {
280
+ return
281
+ }
282
+ ref_upload.value?.handleRemove(file)
283
+ } else {
284
+ preview(file)
285
+ }
286
+ }
287
+ const exceed = (files: File[], uploadFiles: UploadUserFile[]) => {
288
+ ElMessage.warning('最多上传' + props.limit + '个文件,上传文件数量已达到限制')
289
+ }
290
+ const error = (error: Error, uploadFile: UploadFile, uploadFiles: UploadFiles) => {
291
+ ElMessage.error('上传失败')
292
+ for (let i = loadingFiles.value.length - 1; i >= 0; i--) {
293
+ if (loadingFiles.value[i] === uploadFile.name) {
294
+ loadingFiles.value.splice(i, 1)
295
+ }
296
+ }
297
+ }
298
+ const preview = async (uploadFile: UploadFile) => {
299
+ const file = props.uploadFilesList.find((c) => c.name === uploadFile.name)
300
+ if (file) {
301
+ //if ((uploadFile.response as any).code === '0') {
302
+ // const data = (uploadFile.response as any).data as ISysUploadFiles
303
+ fileView(file.id)
304
+ }
305
+ }
306
+ const remove = async (file: UploadFile) => {
307
+ // if ((file.response as any).code === '0') {
308
+ // const data = (file.response as any).data as ISysUploadFiles
309
+ const find = props.uploadFilesList.find((c) => c.name === file.name)
310
+ if (find) {
311
+ try {
312
+ await documentApi.delSysUploadFile(find.id)
313
+ props.uploadFilesList.splice(props.uploadFilesList.indexOf(find), 1)
314
+ } catch (err: any) {
315
+ frameworkUtils.messageError(err)
316
+ }
317
+ }
318
+ // }
319
+ }
320
+ onMounted(() => {
321
+ uploadHeaders.value.Authorization = sessionStorage.getItem('Authorization') + ''
322
+ })
323
+ defineExpose({
324
+ remove
325
+ })
326
+ </script>
327
+ <style scoped lang="scss">
328
+ .file-class {
329
+ }
330
+
331
+ .file-class :hover {
332
+ color: var(--el-color-primary);
333
+ }
334
+
335
+ :deep {
336
+ .el-icon--upload {
337
+ margin-bottom: 0;
338
+ }
339
+ }
340
+ .file-item {
341
+ position: relative;
342
+ padding: 2px 0;
343
+ border-radius: 4px;
344
+ transition: background-color 0.2s ease;
345
+
346
+ &:hover {
347
+ background-color: var(--el-fill-color-light);
348
+
349
+ .delete-icon {
350
+ visibility: visible;
351
+ opacity: 1;
352
+ transform: scale(1);
353
+ }
354
+ }
355
+ }
356
+ .link-name {
357
+ cursor: pointer;
358
+ }
359
+
360
+ .link-name:hover {
361
+ color: var(--el-color-primary);
362
+ text-decoration: underline;
363
+ }
364
+ </style>