adtec-core-package 2.0.5 → 2.0.7

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 (335) 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 +46 -56
  8. package/index.html +13 -13
  9. package/package.json +69 -69
  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/workflowInstApi.ts +72 -72
  20. package/src/assets/base.css +86 -86
  21. package/src/assets/logo.svg +1 -1
  22. package/src/assets/main.css +35 -35
  23. package/src/assets/style/ant.scss +19 -19
  24. package/src/assets/style/index.less +180 -180
  25. package/src/assets/style/transition.scss +49 -49
  26. package/src/components/ElCardList.vue +64 -64
  27. package/src/components/ElFlex/ElFlex.vue +297 -297
  28. package/src/components/ElTotalTools.vue +70 -70
  29. package/src/components/OperationAuth/operationAuth.vue +26 -26
  30. package/src/components/RichTextEditor/RichTextEditor.vue +402 -383
  31. package/src/components/Scrollbars/ElScrollbars.vue +21 -21
  32. package/src/components/Search/ElIconSearch.vue +267 -267
  33. package/src/components/Search/ElSearch.vue +154 -154
  34. package/src/components/SelectInDicators/SelectInDicators.vue +225 -225
  35. package/src/components/SelectInDicators/api/DataIndicatorsApi.ts +28 -28
  36. package/src/components/SelectInDicators/interface/IComIndex.ts +26 -26
  37. package/src/components/SelectInDicators/interface/IComIndexAttri.ts +18 -18
  38. package/src/components/Table/ElTableColumnDynamic.vue +25 -25
  39. package/src/components/Table/ElTableColumnEdit.vue +265 -265
  40. package/src/components/Table/ElTableTool.ts +37 -37
  41. package/src/components/Title/ElTitle.vue +53 -53
  42. package/src/components/autoToolTip/ElAutoToolTip.vue +62 -62
  43. package/src/components/baseEcharts/index.vue +48 -48
  44. package/src/components/bpmntree/api/modules/role.ts +31 -31
  45. package/src/components/bpmntree/api/modules/user.ts +17 -17
  46. package/src/components/bpmntree/components/AdvancedFilter/Operator.vue +112 -112
  47. package/src/components/bpmntree/components/AdvancedFilter/Trigger.vue +23 -23
  48. package/src/components/bpmntree/components/AdvancedFilter/index.vue +230 -230
  49. package/src/components/bpmntree/components/AdvancedFilter/type.ts +20 -20
  50. package/src/components/bpmntree/components/FlowIcon/index.scss +7 -7
  51. package/src/components/bpmntree/components/FlowIcon/index.tsx +68 -68
  52. package/src/components/bpmntree/components/Render/render.vue +90 -90
  53. package/src/components/bpmntree/components/Render/type.ts +12 -12
  54. package/src/components/bpmntree/components/RoleSelector/RolePicker.vue +264 -264
  55. package/src/components/bpmntree/components/RoleSelector/RoleTag.vue +48 -48
  56. package/src/components/bpmntree/components/RoleSelector/index.vue +113 -113
  57. package/src/components/bpmntree/components/UserSelector/UserTag.vue +73 -73
  58. package/src/components/bpmntree/components/UserSelector/index.vue +140 -140
  59. package/src/components/bpmntree/hooks/useDraggableScroll.ts +44 -44
  60. package/src/components/bpmntree/typings/index.d.ts +1 -1
  61. package/src/components/bpmntree/views/flowDesign/index.vue +653 -653
  62. package/src/components/bpmntree/views/flowDesign/nodes/Add.vue +184 -184
  63. package/src/components/bpmntree/views/flowDesign/nodes/ApprovalNode.vue +127 -127
  64. package/src/components/bpmntree/views/flowDesign/nodes/CcNode.vue +93 -93
  65. package/src/components/bpmntree/views/flowDesign/nodes/ConcurrentNode.vue +61 -61
  66. package/src/components/bpmntree/views/flowDesign/nodes/ConditionNode.vue +60 -60
  67. package/src/components/bpmntree/views/flowDesign/nodes/EndNode.vue +80 -80
  68. package/src/components/bpmntree/views/flowDesign/nodes/ExclusiveNode.vue +20 -20
  69. package/src/components/bpmntree/views/flowDesign/nodes/GatewayNode.vue +173 -173
  70. package/src/components/bpmntree/views/flowDesign/nodes/InclusiveNode.vue +20 -20
  71. package/src/components/bpmntree/views/flowDesign/nodes/JumpNode.vue +49 -49
  72. package/src/components/bpmntree/views/flowDesign/nodes/Node.vue +346 -346
  73. package/src/components/bpmntree/views/flowDesign/nodes/NotifyNode.vue +115 -115
  74. package/src/components/bpmntree/views/flowDesign/nodes/ParallelNode.vue +20 -20
  75. package/src/components/bpmntree/views/flowDesign/nodes/PopoverView.vue +78 -78
  76. package/src/components/bpmntree/views/flowDesign/nodes/StartNode.vue +84 -84
  77. package/src/components/bpmntree/views/flowDesign/nodes/TimerNode.vue +50 -50
  78. package/src/components/bpmntree/views/flowDesign/nodes/TreeNode.vue +45 -45
  79. package/src/components/bpmntree/views/flowDesign/nodes/type.ts +196 -196
  80. package/src/components/bpmntree/views/flowDesign/panels/ApprovalPanel.vue +553 -553
  81. package/src/components/bpmntree/views/flowDesign/panels/AssigneePanel.vue +120 -120
  82. package/src/components/bpmntree/views/flowDesign/panels/CcPanel.vue +99 -99
  83. package/src/components/bpmntree/views/flowDesign/panels/ConditionPanel.vue +41 -41
  84. package/src/components/bpmntree/views/flowDesign/panels/EndPanel.vue +18 -18
  85. package/src/components/bpmntree/views/flowDesign/panels/ExecutionListeners.vue +110 -110
  86. package/src/components/bpmntree/views/flowDesign/panels/JumpPanel.vue +32 -32
  87. package/src/components/bpmntree/views/flowDesign/panels/NotifyPanel.vue +101 -101
  88. package/src/components/bpmntree/views/flowDesign/panels/ParaPanel.vue +248 -248
  89. package/src/components/bpmntree/views/flowDesign/panels/StartPanel.vue +160 -160
  90. package/src/components/bpmntree/views/flowDesign/panels/TaskListeners.vue +110 -110
  91. package/src/components/bpmntree/views/flowDesign/panels/TimerPanel.vue +51 -51
  92. package/src/components/bpmntree/views/flowDesign/panels/index.vue +85 -85
  93. package/src/components/bpmntree/views/view.index.vue +291 -291
  94. package/src/components/business/comp.selectUser.vue +58 -58
  95. package/src/components/business/comp.userForm.vue +297 -297
  96. package/src/components/business/userSelect.vue +413 -413
  97. package/src/components/icon/ElIconBtn.vue +243 -243
  98. package/src/components/icon/ElIcons.vue +38 -38
  99. package/src/components/kFrame/IframeOptions.ts +116 -116
  100. package/src/components/kFrame/KFrame.vue +161 -161
  101. package/src/components/upload/ElUploads.vue +331 -331
  102. package/src/components/upload/FileView.vue +213 -213
  103. package/src/components/upload/FileViewComponents.vue +56 -56
  104. package/src/components/workflow/TaskOperation.vue +240 -240
  105. package/src/components/workflow/WorkflowTodoDialog.vue +83 -83
  106. package/src/components/workflow/components/AddOrMinusMultiDialog.vue +159 -159
  107. package/src/components/workflow/components/CheckDialog.vue +334 -334
  108. package/src/components/workflow/components/ProcessDetailComp.vue +143 -143
  109. package/src/components/workflow/components/ProcessDetailDialog.vue +129 -129
  110. package/src/components/workflow/components/ProcessInstance.vue +117 -117
  111. package/src/components/workflow/components/ProcessInstanceStep.vue +266 -240
  112. package/src/components/workflow/components/SelectAssigneeDialog.vue +109 -109
  113. package/src/components/workflow/components/SelectReturnActivityDialog.vue +104 -104
  114. package/src/config/ElementPlusConfig.ts +95 -95
  115. package/src/config/VxeTableConfig.ts +249 -249
  116. package/src/css/elementUI/affix.scss +7 -7
  117. package/src/css/elementUI/alert.scss +115 -115
  118. package/src/css/elementUI/anchor-link.scss +41 -41
  119. package/src/css/elementUI/anchor.scss +88 -88
  120. package/src/css/elementUI/aside.scss +8 -8
  121. package/src/css/elementUI/autocomplete.scss +89 -89
  122. package/src/css/elementUI/avatar.scss +55 -55
  123. package/src/css/elementUI/backtop.scss +29 -29
  124. package/src/css/elementUI/badge.scss +58 -58
  125. package/src/css/elementUI/base.scss +3 -3
  126. package/src/css/elementUI/breadcrumb.scss +62 -62
  127. package/src/css/elementUI/button-group.scss +80 -80
  128. package/src/css/elementUI/button.scss +304 -304
  129. package/src/css/elementUI/calendar.scss +80 -80
  130. package/src/css/elementUI/card.scss +45 -45
  131. package/src/css/elementUI/carousel-item.scss +58 -58
  132. package/src/css/elementUI/carousel.scss +188 -188
  133. package/src/css/elementUI/cascader-panel.scss +138 -138
  134. package/src/css/elementUI/cascader.scss +230 -230
  135. package/src/css/elementUI/check-tag.scss +60 -60
  136. package/src/css/elementUI/checkbox-button.scss +140 -140
  137. package/src/css/elementUI/checkbox-group.scss +7 -7
  138. package/src/css/elementUI/checkbox.scss +298 -298
  139. package/src/css/elementUI/col.scss +48 -48
  140. package/src/css/elementUI/collapse.scss +70 -70
  141. package/src/css/elementUI/color/index.scss +20 -20
  142. package/src/css/elementUI/color-picker.scss +392 -392
  143. package/src/css/elementUI/common/popup.scss +47 -47
  144. package/src/css/elementUI/common/transition.scss +122 -122
  145. package/src/css/elementUI/common/var.scss +1549 -1549
  146. package/src/css/elementUI/container.scss +14 -14
  147. package/src/css/elementUI/dark/css-vars.scss +39 -39
  148. package/src/css/elementUI/dark/var.scss +222 -222
  149. package/src/css/elementUI/date-picker/date-picker.scss +110 -110
  150. package/src/css/elementUI/date-picker/date-range-picker.scss +113 -113
  151. package/src/css/elementUI/date-picker/date-table.scss +158 -158
  152. package/src/css/elementUI/date-picker/month-table.scss +112 -112
  153. package/src/css/elementUI/date-picker/picker-panel.scss +131 -131
  154. package/src/css/elementUI/date-picker/picker.scss +219 -219
  155. package/src/css/elementUI/date-picker/time-picker.scss +90 -90
  156. package/src/css/elementUI/date-picker/time-range-picker.scss +33 -33
  157. package/src/css/elementUI/date-picker/time-spinner.scss +111 -111
  158. package/src/css/elementUI/date-picker/year-table.scss +108 -108
  159. package/src/css/elementUI/date-picker.scss +9 -9
  160. package/src/css/elementUI/descriptions-item.scss +73 -73
  161. package/src/css/elementUI/descriptions.scss +152 -152
  162. package/src/css/elementUI/dialog.scss +199 -199
  163. package/src/css/elementUI/display.scss +12 -12
  164. package/src/css/elementUI/divider.scss +48 -48
  165. package/src/css/elementUI/drawer.scss +164 -164
  166. package/src/css/elementUI/dropdown.scss +208 -208
  167. package/src/css/elementUI/empty.scss +49 -49
  168. package/src/css/elementUI/footer.scss +12 -12
  169. package/src/css/elementUI/form.scss +243 -243
  170. package/src/css/elementUI/header.scss +12 -12
  171. package/src/css/elementUI/icon.scss +45 -45
  172. package/src/css/elementUI/image-viewer.scss +139 -139
  173. package/src/css/elementUI/image.scss +49 -49
  174. package/src/css/elementUI/index.scss +110 -110
  175. package/src/css/elementUI/input-number.scss +178 -178
  176. package/src/css/elementUI/input.scss +478 -478
  177. package/src/css/elementUI/link.scss +90 -90
  178. package/src/css/elementUI/loading.scss +104 -104
  179. package/src/css/elementUI/main.scss +14 -14
  180. package/src/css/elementUI/mention.scss +88 -88
  181. package/src/css/elementUI/menu.scss +339 -339
  182. package/src/css/elementUI/message-box.scss +213 -213
  183. package/src/css/elementUI/message.scss +98 -98
  184. package/src/css/elementUI/mixins/_button.scss +165 -165
  185. package/src/css/elementUI/mixins/_col.scss +33 -33
  186. package/src/css/elementUI/mixins/_var.scss +67 -67
  187. package/src/css/elementUI/mixins/config.scss +5 -5
  188. package/src/css/elementUI/mixins/function.scss +88 -88
  189. package/src/css/elementUI/mixins/mixins.scss +237 -237
  190. package/src/css/elementUI/mixins/utils.scss +39 -39
  191. package/src/css/elementUI/notification.scss +104 -104
  192. package/src/css/elementUI/option-group.scss +33 -33
  193. package/src/css/elementUI/option.scss +71 -71
  194. package/src/css/elementUI/overlay.scss +17 -17
  195. package/src/css/elementUI/page-header.scss +60 -60
  196. package/src/css/elementUI/pagination.scss +238 -238
  197. package/src/css/elementUI/popconfirm.scss +16 -16
  198. package/src/css/elementUI/popover.scss +61 -61
  199. package/src/css/elementUI/popper.scss +106 -106
  200. package/src/css/elementUI/progress.scss +179 -179
  201. package/src/css/elementUI/radio-button.scss +169 -169
  202. package/src/css/elementUI/radio-group.scss +9 -9
  203. package/src/css/elementUI/radio.scss +215 -215
  204. package/src/css/elementUI/rate.scss +108 -108
  205. package/src/css/elementUI/reset.scss +98 -98
  206. package/src/css/elementUI/result.scss +57 -57
  207. package/src/css/elementUI/row.scss +35 -35
  208. package/src/css/elementUI/scrollbar.scss +97 -97
  209. package/src/css/elementUI/segmented.scss +183 -183
  210. package/src/css/elementUI/select-dropdown-v2.scss +1 -1
  211. package/src/css/elementUI/select-dropdown.scss +57 -57
  212. package/src/css/elementUI/select-v2.scss +4 -4
  213. package/src/css/elementUI/select.scss +253 -253
  214. package/src/css/elementUI/skeleton-item.scss +83 -83
  215. package/src/css/elementUI/skeleton.scss +44 -44
  216. package/src/css/elementUI/slider.scss +212 -212
  217. package/src/css/elementUI/space.scss +20 -20
  218. package/src/css/elementUI/spinner.scss +43 -43
  219. package/src/css/elementUI/statistic.scss +35 -35
  220. package/src/css/elementUI/step.scss +316 -316
  221. package/src/css/elementUI/steps.scss +21 -21
  222. package/src/css/elementUI/switch.scss +300 -300
  223. package/src/css/elementUI/table-column.scss +98 -98
  224. package/src/css/elementUI/table-v2.scss +236 -236
  225. package/src/css/elementUI/table.scss +697 -697
  226. package/src/css/elementUI/tabs.scss +659 -659
  227. package/src/css/elementUI/tag.scss +181 -181
  228. package/src/css/elementUI/text.scss +51 -51
  229. package/src/css/elementUI/time-picker.scss +5 -5
  230. package/src/css/elementUI/time-select.scss +37 -37
  231. package/src/css/elementUI/timeline-item.scss +84 -84
  232. package/src/css/elementUI/timeline.scss +46 -46
  233. package/src/css/elementUI/tooltip-v2.scss +95 -95
  234. package/src/css/elementUI/tour.scss +187 -187
  235. package/src/css/elementUI/transfer.scss +203 -203
  236. package/src/css/elementUI/tree-select.scss +41 -41
  237. package/src/css/elementUI/tree.scss +134 -134
  238. package/src/css/elementUI/upload.scss +654 -654
  239. package/src/css/elementUI/var.scss +87 -87
  240. package/src/css/elementUI/virtual-list.scss +40 -40
  241. package/src/css/vxeTableUI/all.scss +9 -9
  242. package/src/css/vxeTableUI/base.scss +16 -16
  243. package/src/css/vxeTableUI/components/colgroup.scss +0 -0
  244. package/src/css/vxeTableUI/components/column.scss +0 -0
  245. package/src/css/vxeTableUI/components/grid.scss +83 -83
  246. package/src/css/vxeTableUI/components/icon.scss +1017 -1017
  247. package/src/css/vxeTableUI/components/iconTable.scss +205 -205
  248. package/src/css/vxeTableUI/components/old-icon.scss +715 -715
  249. package/src/css/vxeTableUI/components/table-module/all.scss +6 -6
  250. package/src/css/vxeTableUI/components/table-module/custom.scss +490 -490
  251. package/src/css/vxeTableUI/components/table-module/edit.scss +0 -0
  252. package/src/css/vxeTableUI/components/table-module/export.scss +130 -130
  253. package/src/css/vxeTableUI/components/table-module/filter.scss +127 -127
  254. package/src/css/vxeTableUI/components/table-module/keyboard.scss +0 -0
  255. package/src/css/vxeTableUI/components/table-module/menu.scss +85 -85
  256. package/src/css/vxeTableUI/components/table-module/validator.scss +0 -0
  257. package/src/css/vxeTableUI/components/table.scss +2256 -2256
  258. package/src/css/vxeTableUI/components/toolbar.scss +99 -99
  259. package/src/css/vxeTableUI/components/ui.scss +0 -0
  260. package/src/css/vxeTableUI/components/v-x-e-table.scss +0 -0
  261. package/src/css/vxeTableUI/cssvar.scss +2 -2
  262. package/src/css/vxeTableUI/default.scss +2 -2
  263. package/src/css/vxeTableUI/helpers/baseMixin.scss +82 -82
  264. package/src/css/vxeTableUI/icon/iconfont.ttf +0 -0
  265. package/src/css/vxeTableUI/icon/iconfont.woff +0 -0
  266. package/src/css/vxeTableUI/icon/iconfont.woff2 +0 -0
  267. package/src/css/vxeTableUI/index.scss +4 -4
  268. package/src/css/vxeTableUI/modules.scss +5 -5
  269. package/src/css/vxeTableUI/theme/base.scss +88 -88
  270. package/src/css/vxeTableUI/theme/dark.scss +46 -46
  271. package/src/css/vxeTableUI/theme/light.scss +41 -41
  272. package/src/css/vxeTableUI/variable.scss +41 -41
  273. package/src/directives/vKeydown.ts +91 -91
  274. package/src/hooks/useDictHooks.ts +119 -119
  275. package/src/hooks/useEcharts.ts +58 -58
  276. package/src/hooks/useFileView.ts +11 -11
  277. package/src/hooks/useMessageHooks.ts +132 -132
  278. package/src/hooks/usePermissionToolHooks.ts +21 -21
  279. package/src/hooks/useResetRefHooks.ts +18 -18
  280. package/src/hooks/userWorkflowHooks.ts +106 -106
  281. package/src/hooks/workflowTodo.ts +85 -0
  282. package/src/interface/BaseEntity.ts +30 -30
  283. package/src/interface/IMdmDept.ts +84 -84
  284. package/src/interface/IMdmEmployee.ts +150 -150
  285. package/src/interface/IMdmEmployeeQuery.ts +20 -20
  286. package/src/interface/IMdmOrg.ts +29 -29
  287. package/src/interface/IMdmOrgQuery.ts +13 -13
  288. package/src/interface/IOrgDeptInfo.ts +12 -12
  289. package/src/interface/ISysDictDataCacheVo.ts +46 -46
  290. package/src/interface/ISysDictType.ts +37 -37
  291. package/src/interface/ISysMenuDataVo.ts +22 -22
  292. package/src/interface/ISysMenuInfoVo.ts +83 -83
  293. package/src/interface/ISysMenuOperationVo.ts +21 -21
  294. package/src/interface/ISysUploadFiles.ts +16 -16
  295. package/src/interface/ISysUserInfo.ts +70 -70
  296. package/src/interface/IUserBaseInfo.ts +90 -90
  297. package/src/interface/IUserPermissionVo.ts +41 -41
  298. package/src/interface/IVxeTable.ts +1 -1
  299. package/src/interface/Message.ts +72 -73
  300. package/src/interface/PageData.ts +17 -17
  301. package/src/interface/ResponseData.ts +16 -16
  302. package/src/interface/dictMapType.ts +11 -11
  303. package/src/interface/enum/FlexEnum.ts +85 -85
  304. package/src/interface/enum/MessageEnum.ts +41 -41
  305. package/src/interface/workflow/IWfProcessDefVo.ts +14 -14
  306. package/src/interface/workflow/IWfReturnNodeVo.ts +16 -16
  307. package/src/interface/workflow/IWfTaskAskVo.ts +65 -65
  308. package/src/interface/workflow/IWfTaskQueryVo.ts +30 -30
  309. package/src/interface/workflow/IWfTaskUsersVo.ts +21 -21
  310. package/src/interface/workflow/IWfTaskVo.ts +187 -187
  311. package/src/interface/workflow/workflow.ts +22 -22
  312. package/src/main.ts +14 -14
  313. package/src/mixin/globalMixin.ts +48 -48
  314. package/src/packages/index.ts +18 -18
  315. package/src/packages/text.vue +13 -13
  316. package/src/plugins/echartsConfig.ts +74 -74
  317. package/src/plugins/plugins.ts +12 -12
  318. package/src/plugins/renderDialog.ts +74 -74
  319. package/src/router/index.ts +23 -23
  320. package/src/stores/dictStore.ts +51 -51
  321. package/src/stores/messageStore.ts +49 -49
  322. package/src/stores/permissionStore.ts +112 -112
  323. package/src/stores/storeConfig.ts +23 -23
  324. package/src/stores/userInfoStore.ts +31 -31
  325. package/src/utils/AxiosConfig.ts +226 -226
  326. package/src/utils/FrameworkUtils.ts +358 -358
  327. package/src/utils/commonUtils.ts +115 -115
  328. package/src/utils/encrypt.ts +18 -18
  329. package/src/utils/modules.ts +8 -8
  330. package/src/utils/request.ts +76 -76
  331. package/src/utils/tree.ts +50 -50
  332. package/tsconfig.app.json +12 -12
  333. package/tsconfig.json +11 -11
  334. package/tsconfig.node.json +18 -18
  335. 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>