adtec-core-package 2.4.3 → 2.4.5

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 +23 -23
  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 +70 -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 +247 -247
  109. package/src/components/workflow/WorkflowTodoDialog.vue +91 -89
  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 -371
  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 +119 -119
  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 -106
  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/IUserBaseInfo.ts +90 -90
  305. package/src/interface/IUserPermissionVo.ts +44 -44
  306. package/src/interface/IVxeTable.ts +1 -1
  307. package/src/interface/Message.ts +73 -73
  308. package/src/interface/PageData.ts +17 -17
  309. package/src/interface/ResponseData.ts +16 -16
  310. package/src/interface/dictMapType.ts +11 -11
  311. package/src/interface/enum/FlexEnum.ts +85 -85
  312. package/src/interface/enum/MessageEnum.ts +41 -41
  313. package/src/interface/workflow/IWfProcessDefVo.ts +14 -14
  314. package/src/interface/workflow/IWfReturnNodeVo.ts +16 -16
  315. package/src/interface/workflow/IWfTaskAskVo.ts +66 -66
  316. package/src/interface/workflow/IWfTaskQueryVo.ts +30 -30
  317. package/src/interface/workflow/IWfTaskUsersVo.ts +21 -21
  318. package/src/interface/workflow/IWfTaskVo.ts +192 -188
  319. package/src/interface/workflow/IWorkflowCommentVo.ts +24 -24
  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,243 +1,243 @@
1
- <!--创建人 丁盼-->
2
- <!--说明: ElIconBtn-->
3
- <!--创建时间: 2024/11/24 下午3:12-->
4
- <!--修改时间: 2024/11/24 下午3:12-->
5
- <template>
6
- <el-button
7
- v-if="elementType === 'button'"
8
- :disabled="disabled"
9
- ref="ref_icons"
10
- @click.stop="iconClick"
11
- style="padding: 8px 10px; margin-left: 4px"
12
- >
13
- <el-icon
14
- @mouseenter="visible = true"
15
- @mouseleave="visible = false"
16
- class="icon-btn"
17
- style="margin: 0"
18
- :class="getClass"
19
- >
20
- <svg v-if="selcomp" class="icon" aria-hidden="true">
21
- <use :href="'#' + iconName"></use>
22
- </svg>
23
- <component v-else :is="iconName"></component>
24
- <el-tooltip
25
- v-model:visible="visible"
26
- v-if="tip"
27
- :content="tip"
28
- placement="top"
29
- effect="light"
30
- trigger="click"
31
- virtual-triggering
32
- :virtual-ref="ref_icons"
33
- />
34
- </el-icon>
35
- </el-button>
36
- <el-icon
37
- v-else-if="disabled"
38
- ref="ref_icons"
39
- :disabled="disabled"
40
- @mouseenter="visible = true"
41
- @mouseleave="visible = false"
42
- class="icon-btn"
43
- :class="getClass"
44
- >
45
- <svg v-if="selcomp" class="icon" aria-hidden="true">
46
- <use :href="'#' + iconName"></use>
47
- </svg>
48
- <component v-else :is="iconName"></component>
49
- <el-tooltip
50
- v-model:visible="visible"
51
- v-if="tip"
52
- :content="tip"
53
- placement="top"
54
- effect="light"
55
- trigger="click"
56
- virtual-triggering
57
- :virtual-ref="ref_icons"
58
- />
59
- </el-icon>
60
- <el-icon
61
- v-else
62
- ref="ref_icons"
63
- @click.stop="iconClick"
64
- @mouseenter="visible = true"
65
- @mouseleave="visible = false"
66
- class="icon-btn"
67
- :class="getClass"
68
- >
69
- <svg v-if="selcomp" class="icon" aria-hidden="true">
70
- <use :href="'#' + iconName"></use>
71
- </svg>
72
- <component v-else :is="iconName"></component>
73
- <el-tooltip
74
- v-model:visible="visible"
75
- v-if="tip"
76
- :content="tip"
77
- placement="top"
78
- effect="light"
79
- trigger="click"
80
- virtual-triggering
81
- :virtual-ref="ref_icons"
82
- />
83
- </el-icon>
84
- </template>
85
- <script setup lang="ts">
86
- import { useVModel } from '@vueuse/core'
87
- import { computed, ref } from 'vue'
88
-
89
- const visible = ref(false)
90
- const ref_icons = ref()
91
- const selcomp = computed(() => {
92
- if (iconName.value?.includes('adtec')) {
93
- return true
94
- } else {
95
- return false
96
- }
97
- })
98
- const iconClick = (ev: any) => {
99
- //@ts-ignore
100
- emit('click', ev)
101
- }
102
- /**
103
- * 获取样式
104
- */
105
- const getClass = computed(() => {
106
- let className = 'icon-btn--'
107
- // + props.type
108
- if (props.type !== 'default') {
109
- className += props.type
110
- if (props.disabled) {
111
- className += ' icon-btn--' + props.type + '--disabled'
112
- }
113
- } else {
114
- if (iconName.value === 'adtec-plus') {
115
- className += 'primary'
116
- if (props.disabled) {
117
- className += ' icon-btn--primary--disabled'
118
- }
119
- } else if (iconName.value === 'adtec-refresh') {
120
- className += 'default'
121
- if (props.disabled) {
122
- className += ' icon-btn--default--disabled'
123
- }
124
- } else if (iconName.value === 'adtec-delete') {
125
- className += 'danger'
126
- if (props.disabled) {
127
- className += ' icon-btn--danger--disabled'
128
- }
129
- } else if (iconName.value === 'adtec-edit') {
130
- className += 'warning'
131
- if (props.disabled) {
132
- className += ' icon-btn--warning--disabled'
133
- }
134
- }
135
- }
136
- className += ' icon-btn--size-' + props.size
137
- return className
138
- })
139
- // 定义Props类型
140
- const props = defineProps({
141
- /**
142
- * @type string
143
- * @default ''
144
- * @description 提示文字
145
- */
146
- tip: {
147
- type: String,
148
- default: '',
149
- },
150
- /**
151
- * @type {'adtec-plus'|'adtec-refresh'|'adtec-delete'|'adtec-edit'}
152
- * @default 'default'
153
- * @description 图标
154
- */
155
- modelValue: {
156
- type: String,
157
- default: '',
158
- },
159
- /**
160
- * @type {'small'|'default'|'large'|'medium'}
161
- * @default 'default'
162
- * @description 图标大小
163
- */
164
- size: {
165
- type: String,
166
- default: 'default',
167
- // 注意:在`<script setup>`中,直接使用函数进行验证,JSDoc辅助IDE提示
168
- validator: (value: string) => ['large', 'default', 'medium', 'small'].includes(value),
169
- },
170
- /**
171
- * @type {"default" | "success" | "warning" | "info" | "primary" | "danger"}
172
- * @default 'default'
173
- * @description 图标类型
174
- */
175
- type: {
176
- type: String,
177
- default: 'default',
178
- validator: (value: string) =>
179
- ['default', 'success', 'warning', 'info', 'primary', 'danger'].includes(value),
180
- },
181
- /**
182
- * @type {"icon" | "button"}
183
- * @default 'icon'
184
- * @description 元素类型
185
- */
186
- elementType: {
187
- type: String,
188
- default: 'icon',
189
- },
190
- disabled: {
191
- type: Boolean,
192
- default: false,
193
- },
194
- })
195
- const emit = defineEmits(['update:modelValue', 'click'])
196
- const iconName = useVModel(props, 'modelValue', emit)
197
- </script>
198
- <style scoped lang="scss">
199
- .icon-btn {
200
- cursor: pointer;
201
- margin: 0px 0px 0px 8px;
202
- //margin-left: 5px;
203
- --el-button-hover-bg-color: var(--el-color-primary-light-3);
204
-
205
- &:hover {
206
- color: var(--el-button-hover-bg-color);
207
- }
208
-
209
- &--disabled {
210
- color: var(--el-color-disabled-text-color) !important;
211
- cursor: not-allowed !important;
212
- }
213
-
214
- &--size-large {
215
- font-size: var(--el-font-size-large);
216
- }
217
-
218
- &--size-default {
219
- font-size: var(--el-font-size-base);
220
- }
221
-
222
- &--size-medium {
223
- font-size: var(--el-font-size-medium);
224
- }
225
-
226
- &--size-small {
227
- font-size: var(--el-font-size-small);
228
- }
229
-
230
- @each $type in (primary, success, warning, danger, info) {
231
- &--#{$type} {
232
- --el-button-hover-bg-color: var(--el-color-#{$type}-light-3);
233
- --el-button-disabled-bg-color: var(--el-color-#{$type}-light-5);
234
- color: var(--el-color-#{$type});
235
- }
236
- //icon-btn--danger--disabled
237
- &--#{$type}--disabled{
238
- color: var(--el-color-#{$type}-light-5) !important;
239
- cursor: not-allowed !important;
240
- }
241
- }
242
- }
243
- </style>
1
+ <!--创建人 丁盼-->
2
+ <!--说明: ElIconBtn-->
3
+ <!--创建时间: 2024/11/24 下午3:12-->
4
+ <!--修改时间: 2024/11/24 下午3:12-->
5
+ <template>
6
+ <el-button
7
+ v-if="elementType === 'button'"
8
+ :disabled="disabled"
9
+ ref="ref_icons"
10
+ @click.stop="iconClick"
11
+ style="padding: 8px 10px; margin-left: 4px"
12
+ >
13
+ <el-icon
14
+ @mouseenter="visible = true"
15
+ @mouseleave="visible = false"
16
+ class="icon-btn"
17
+ style="margin: 0"
18
+ :class="getClass"
19
+ >
20
+ <svg v-if="selcomp" class="icon" aria-hidden="true">
21
+ <use :href="'#' + iconName"></use>
22
+ </svg>
23
+ <component v-else :is="iconName"></component>
24
+ <el-tooltip
25
+ v-model:visible="visible"
26
+ v-if="tip"
27
+ :content="tip"
28
+ placement="top"
29
+ effect="light"
30
+ trigger="click"
31
+ virtual-triggering
32
+ :virtual-ref="ref_icons"
33
+ />
34
+ </el-icon>
35
+ </el-button>
36
+ <el-icon
37
+ v-else-if="disabled"
38
+ ref="ref_icons"
39
+ :disabled="disabled"
40
+ @mouseenter="visible = true"
41
+ @mouseleave="visible = false"
42
+ class="icon-btn"
43
+ :class="getClass"
44
+ >
45
+ <svg v-if="selcomp" class="icon" aria-hidden="true">
46
+ <use :href="'#' + iconName"></use>
47
+ </svg>
48
+ <component v-else :is="iconName"></component>
49
+ <el-tooltip
50
+ v-model:visible="visible"
51
+ v-if="tip"
52
+ :content="tip"
53
+ placement="top"
54
+ effect="light"
55
+ trigger="click"
56
+ virtual-triggering
57
+ :virtual-ref="ref_icons"
58
+ />
59
+ </el-icon>
60
+ <el-icon
61
+ v-else
62
+ ref="ref_icons"
63
+ @click.stop="iconClick"
64
+ @mouseenter="visible = true"
65
+ @mouseleave="visible = false"
66
+ class="icon-btn"
67
+ :class="getClass"
68
+ >
69
+ <svg v-if="selcomp" class="icon" aria-hidden="true">
70
+ <use :href="'#' + iconName"></use>
71
+ </svg>
72
+ <component v-else :is="iconName"></component>
73
+ <el-tooltip
74
+ v-model:visible="visible"
75
+ v-if="tip"
76
+ :content="tip"
77
+ placement="top"
78
+ effect="light"
79
+ trigger="click"
80
+ virtual-triggering
81
+ :virtual-ref="ref_icons"
82
+ />
83
+ </el-icon>
84
+ </template>
85
+ <script setup lang="ts">
86
+ import { useVModel } from '@vueuse/core'
87
+ import { computed, ref } from 'vue'
88
+
89
+ const visible = ref(false)
90
+ const ref_icons = ref()
91
+ const selcomp = computed(() => {
92
+ if (iconName.value?.includes('adtec')) {
93
+ return true
94
+ } else {
95
+ return false
96
+ }
97
+ })
98
+ const iconClick = (ev: any) => {
99
+ //@ts-ignore
100
+ emit('click', ev)
101
+ }
102
+ /**
103
+ * 获取样式
104
+ */
105
+ const getClass = computed(() => {
106
+ let className = 'icon-btn--'
107
+ // + props.type
108
+ if (props.type !== 'default') {
109
+ className += props.type
110
+ if (props.disabled) {
111
+ className += ' icon-btn--' + props.type + '--disabled'
112
+ }
113
+ } else {
114
+ if (iconName.value === 'adtec-plus') {
115
+ className += 'primary'
116
+ if (props.disabled) {
117
+ className += ' icon-btn--primary--disabled'
118
+ }
119
+ } else if (iconName.value === 'adtec-refresh') {
120
+ className += 'default'
121
+ if (props.disabled) {
122
+ className += ' icon-btn--default--disabled'
123
+ }
124
+ } else if (iconName.value === 'adtec-delete') {
125
+ className += 'danger'
126
+ if (props.disabled) {
127
+ className += ' icon-btn--danger--disabled'
128
+ }
129
+ } else if (iconName.value === 'adtec-edit') {
130
+ className += 'warning'
131
+ if (props.disabled) {
132
+ className += ' icon-btn--warning--disabled'
133
+ }
134
+ }
135
+ }
136
+ className += ' icon-btn--size-' + props.size
137
+ return className
138
+ })
139
+ // 定义Props类型
140
+ const props = defineProps({
141
+ /**
142
+ * @type string
143
+ * @default ''
144
+ * @description 提示文字
145
+ */
146
+ tip: {
147
+ type: String,
148
+ default: '',
149
+ },
150
+ /**
151
+ * @type {'adtec-plus'|'adtec-refresh'|'adtec-delete'|'adtec-edit'}
152
+ * @default 'default'
153
+ * @description 图标
154
+ */
155
+ modelValue: {
156
+ type: String,
157
+ default: '',
158
+ },
159
+ /**
160
+ * @type {'small'|'default'|'large'|'medium'}
161
+ * @default 'default'
162
+ * @description 图标大小
163
+ */
164
+ size: {
165
+ type: String,
166
+ default: 'default',
167
+ // 注意:在`<script setup>`中,直接使用函数进行验证,JSDoc辅助IDE提示
168
+ validator: (value: string) => ['large', 'default', 'medium', 'small'].includes(value),
169
+ },
170
+ /**
171
+ * @type {"default" | "success" | "warning" | "info" | "primary" | "danger"}
172
+ * @default 'default'
173
+ * @description 图标类型
174
+ */
175
+ type: {
176
+ type: String,
177
+ default: 'default',
178
+ validator: (value: string) =>
179
+ ['default', 'success', 'warning', 'info', 'primary', 'danger'].includes(value),
180
+ },
181
+ /**
182
+ * @type {"icon" | "button"}
183
+ * @default 'icon'
184
+ * @description 元素类型
185
+ */
186
+ elementType: {
187
+ type: String,
188
+ default: 'icon',
189
+ },
190
+ disabled: {
191
+ type: Boolean,
192
+ default: false,
193
+ },
194
+ })
195
+ const emit = defineEmits(['update:modelValue', 'click'])
196
+ const iconName = useVModel(props, 'modelValue', emit)
197
+ </script>
198
+ <style scoped lang="scss">
199
+ .icon-btn {
200
+ cursor: pointer;
201
+ margin: 0px 0px 0px 8px;
202
+ //margin-left: 5px;
203
+ --el-button-hover-bg-color: var(--el-color-primary-light-3);
204
+
205
+ &:hover {
206
+ color: var(--el-button-hover-bg-color);
207
+ }
208
+
209
+ &--disabled {
210
+ color: var(--el-color-disabled-text-color) !important;
211
+ cursor: not-allowed !important;
212
+ }
213
+
214
+ &--size-large {
215
+ font-size: var(--el-font-size-large);
216
+ }
217
+
218
+ &--size-default {
219
+ font-size: var(--el-font-size-base);
220
+ }
221
+
222
+ &--size-medium {
223
+ font-size: var(--el-font-size-medium);
224
+ }
225
+
226
+ &--size-small {
227
+ font-size: var(--el-font-size-small);
228
+ }
229
+
230
+ @each $type in (primary, success, warning, danger, info) {
231
+ &--#{$type} {
232
+ --el-button-hover-bg-color: var(--el-color-#{$type}-light-3);
233
+ --el-button-disabled-bg-color: var(--el-color-#{$type}-light-5);
234
+ color: var(--el-color-#{$type});
235
+ }
236
+ //icon-btn--danger--disabled
237
+ &--#{$type}--disabled{
238
+ color: var(--el-color-#{$type}-light-5) !important;
239
+ cursor: not-allowed !important;
240
+ }
241
+ }
242
+ }
243
+ </style>
@@ -1,38 +1,38 @@
1
- <!--创建人 丁盼-->
2
- <!--说明: ElIcons-->
3
- <!--创建时间: 2024/10/18 上午11:47-->
4
- <!--修改时间: 2024/10/18 上午11:47-->
5
- <template>
6
- <!-- <span v-if="selcomp" class="adtec" :class="iconName"></span>-->
7
- <el-icon>
8
- <svg v-if="selcomp" class="icon" aria-hidden="true">
9
- <use :href="'#' + iconName"></use>
10
- </svg>
11
- <component v-else :is="iconName"></component>
12
- </el-icon>
13
- </template>
14
- <script setup lang="ts">
15
- import { computed } from 'vue'
16
- import { useVModel } from '@vueuse/core'
17
- const props = defineProps({
18
- modelValue: String,
19
- })
20
- const emit = defineEmits(['update:modelValue'])
21
- const iconName = useVModel(props, 'modelValue', emit)
22
- const selcomp = computed(() => {
23
- if (iconName.value?.includes('adtec')) {
24
- return true
25
- } else {
26
- return false
27
- }
28
- })
29
- </script>
30
- <style scoped lang="scss">
31
- .icon {
32
- width: 1em;
33
- height: 1em;
34
- vertical-align: -0.15em;
35
- fill: currentColor;
36
- overflow: hidden;
37
- }
38
- </style>
1
+ <!--创建人 丁盼-->
2
+ <!--说明: ElIcons-->
3
+ <!--创建时间: 2024/10/18 上午11:47-->
4
+ <!--修改时间: 2024/10/18 上午11:47-->
5
+ <template>
6
+ <!-- <span v-if="selcomp" class="adtec" :class="iconName"></span>-->
7
+ <el-icon>
8
+ <svg v-if="selcomp" class="icon" aria-hidden="true">
9
+ <use :href="'#' + iconName"></use>
10
+ </svg>
11
+ <component v-else :is="iconName"></component>
12
+ </el-icon>
13
+ </template>
14
+ <script setup lang="ts">
15
+ import { computed } from 'vue'
16
+ import { useVModel } from '@vueuse/core'
17
+ const props = defineProps({
18
+ modelValue: String,
19
+ })
20
+ const emit = defineEmits(['update:modelValue'])
21
+ const iconName = useVModel(props, 'modelValue', emit)
22
+ const selcomp = computed(() => {
23
+ if (iconName.value?.includes('adtec')) {
24
+ return true
25
+ } else {
26
+ return false
27
+ }
28
+ })
29
+ </script>
30
+ <style scoped lang="scss">
31
+ .icon {
32
+ width: 1em;
33
+ height: 1em;
34
+ vertical-align: -0.15em;
35
+ fill: currentColor;
36
+ overflow: hidden;
37
+ }
38
+ </style>