adtec-core-package 2.2.6 → 2.2.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (211) hide show
  1. package/README.en.md +36 -36
  2. package/adtec-core-package/adtec-core-package.css +1 -0
  3. package/adtec-core-package/adtec-core-package.js +41605 -0
  4. package/adtec-core-package/adtec-core-package.umd.cjs +79 -0
  5. package/adtec-core-package/favicon.ico +0 -0
  6. package/eslint.config.js +21 -11
  7. package/package.json +69 -71
  8. package/src/api/BasicApi.ts +26 -26
  9. package/src/api/DeptInfoApi.ts +19 -19
  10. package/src/api/DocumentApi.ts +27 -27
  11. package/src/api/EmployeeInfoApi.ts +17 -17
  12. package/src/api/SysDictCacheApi.ts +29 -29
  13. package/src/api/SysUserApi.ts +35 -35
  14. package/src/api/framework.ts +12 -12
  15. package/src/api/workflow/workflow.ts +31 -31
  16. package/src/api/workflow/workflowInstApi.ts +72 -72
  17. package/src/assets/style/ant.scss +19 -19
  18. package/src/assets/style/index.less +180 -180
  19. package/src/components/ElCardList.vue +64 -64
  20. package/src/components/ElFlex/ElFlex.vue +297 -297
  21. package/src/components/ElTotalTools.vue +70 -70
  22. package/src/components/OperationAuth/operationAuth.vue +32 -32
  23. package/src/components/RichTextEditor/RichTextEditor.vue +414 -414
  24. package/src/components/Scrollbars/ElScrollbars.vue +21 -21
  25. package/src/components/Search/ElIconSearch.vue +267 -267
  26. package/src/components/Search/ElSearch.vue +154 -154
  27. package/src/components/SelectInDicators/SelectInDicators.vue +225 -225
  28. package/src/components/SelectInDicators/api/DataIndicatorsApi.ts +28 -28
  29. package/src/components/SelectInDicators/interface/IComIndex.ts +26 -26
  30. package/src/components/SelectInDicators/interface/IComIndexAttri.ts +18 -18
  31. package/src/components/Table/ElTableColumnDynamic.vue +25 -25
  32. package/src/components/Table/ElTableColumnEdit.vue +265 -265
  33. package/src/components/Table/ElTableTool.ts +37 -37
  34. package/src/components/Title/ElTitle.vue +53 -53
  35. package/src/components/autoToolTip/ElAutoToolTip.vue +62 -62
  36. package/src/components/baseEcharts/index.vue +48 -48
  37. package/src/components/bpmntree/api/modules/role.ts +31 -31
  38. package/src/components/bpmntree/api/modules/user.ts +17 -17
  39. package/src/components/bpmntree/components/AdvancedFilter/Operator.vue +112 -112
  40. package/src/components/bpmntree/components/AdvancedFilter/Trigger.vue +23 -23
  41. package/src/components/bpmntree/components/AdvancedFilter/index.vue +230 -230
  42. package/src/components/bpmntree/components/AdvancedFilter/type.ts +20 -20
  43. package/src/components/bpmntree/components/FlowIcon/index.scss +7 -7
  44. package/src/components/bpmntree/components/FlowIcon/index.tsx +68 -68
  45. package/src/components/bpmntree/components/Render/render.vue +90 -90
  46. package/src/components/bpmntree/components/Render/type.ts +12 -12
  47. package/src/components/bpmntree/components/RoleSelector/RolePicker.vue +264 -264
  48. package/src/components/bpmntree/components/RoleSelector/RoleTag.vue +48 -48
  49. package/src/components/bpmntree/components/RoleSelector/index.vue +113 -113
  50. package/src/components/bpmntree/components/UserSelector/UserTag.vue +73 -73
  51. package/src/components/bpmntree/components/UserSelector/index.vue +140 -140
  52. package/src/components/bpmntree/hooks/useDraggableScroll.ts +44 -44
  53. package/src/components/bpmntree/typings/index.d.ts +1 -1
  54. package/src/components/bpmntree/views/flowDesign/index.vue +653 -653
  55. package/src/components/bpmntree/views/flowDesign/nodes/Add.vue +184 -184
  56. package/src/components/bpmntree/views/flowDesign/nodes/ApprovalNode.vue +127 -127
  57. package/src/components/bpmntree/views/flowDesign/nodes/CcNode.vue +93 -93
  58. package/src/components/bpmntree/views/flowDesign/nodes/ConcurrentNode.vue +61 -61
  59. package/src/components/bpmntree/views/flowDesign/nodes/ConditionNode.vue +60 -60
  60. package/src/components/bpmntree/views/flowDesign/nodes/EndNode.vue +80 -80
  61. package/src/components/bpmntree/views/flowDesign/nodes/ExclusiveNode.vue +20 -20
  62. package/src/components/bpmntree/views/flowDesign/nodes/GatewayNode.vue +173 -173
  63. package/src/components/bpmntree/views/flowDesign/nodes/InclusiveNode.vue +20 -20
  64. package/src/components/bpmntree/views/flowDesign/nodes/JumpNode.vue +49 -49
  65. package/src/components/bpmntree/views/flowDesign/nodes/Node.vue +346 -346
  66. package/src/components/bpmntree/views/flowDesign/nodes/NotifyNode.vue +115 -115
  67. package/src/components/bpmntree/views/flowDesign/nodes/ParallelNode.vue +20 -20
  68. package/src/components/bpmntree/views/flowDesign/nodes/PopoverView.vue +78 -78
  69. package/src/components/bpmntree/views/flowDesign/nodes/StartNode.vue +84 -84
  70. package/src/components/bpmntree/views/flowDesign/nodes/TimerNode.vue +50 -50
  71. package/src/components/bpmntree/views/flowDesign/nodes/TreeNode.vue +45 -45
  72. package/src/components/bpmntree/views/flowDesign/nodes/type.ts +196 -196
  73. package/src/components/bpmntree/views/flowDesign/panels/ApprovalPanel.vue +553 -553
  74. package/src/components/bpmntree/views/flowDesign/panels/AssigneePanel.vue +120 -120
  75. package/src/components/bpmntree/views/flowDesign/panels/CcPanel.vue +99 -99
  76. package/src/components/bpmntree/views/flowDesign/panels/ConditionPanel.vue +41 -41
  77. package/src/components/bpmntree/views/flowDesign/panels/EndPanel.vue +18 -18
  78. package/src/components/bpmntree/views/flowDesign/panels/ExecutionListeners.vue +110 -110
  79. package/src/components/bpmntree/views/flowDesign/panels/JumpPanel.vue +32 -32
  80. package/src/components/bpmntree/views/flowDesign/panels/NotifyPanel.vue +101 -101
  81. package/src/components/bpmntree/views/flowDesign/panels/ParaPanel.vue +248 -248
  82. package/src/components/bpmntree/views/flowDesign/panels/StartPanel.vue +160 -160
  83. package/src/components/bpmntree/views/flowDesign/panels/TaskListeners.vue +110 -110
  84. package/src/components/bpmntree/views/flowDesign/panels/TimerPanel.vue +51 -51
  85. package/src/components/bpmntree/views/flowDesign/panels/index.vue +85 -85
  86. package/src/components/bpmntree/views/view.index.vue +291 -291
  87. package/src/components/business/comp.selectUser.vue +60 -60
  88. package/src/components/business/comp.userForm.vue +311 -311
  89. package/src/components/business/userSelect.vue +413 -413
  90. package/src/components/icon/ElIconBtn.vue +243 -243
  91. package/src/components/kFrame/IframeOptions.ts +116 -116
  92. package/src/components/kFrame/KFrame.vue +161 -161
  93. package/src/components/tooltip/index.ts +11 -11
  94. package/src/components/tooltip/src/tooltip.ts +518 -518
  95. package/src/components/upload/ElUploads.vue +364 -364
  96. package/src/components/upload/FileView.vue +214 -214
  97. package/src/components/upload/FileViewComponents.vue +56 -56
  98. package/src/components/vxeGrid/index.vue +36 -36
  99. package/src/components/workflow/TaskOperation.vue +241 -241
  100. package/src/components/workflow/WorkflowTodoDialog.vue +83 -83
  101. package/src/components/workflow/components/AddOrMinusMultiDialog.vue +159 -159
  102. package/src/components/workflow/components/CheckDialog.vue +350 -350
  103. package/src/components/workflow/components/ProcessDetailComp.vue +149 -149
  104. package/src/components/workflow/components/ProcessDetailDialog.vue +129 -129
  105. package/src/components/workflow/components/ProcessInstance.vue +117 -117
  106. package/src/components/workflow/components/ProcessInstanceStep.vue +266 -266
  107. package/src/components/workflow/components/SelectAssigneeDialog.vue +109 -109
  108. package/src/components/workflow/components/SelectReturnActivityDialog.vue +104 -104
  109. package/src/config/ElementPlusConfig.ts +95 -95
  110. package/src/config/VxeTableConfig.ts +251 -247
  111. package/src/css/elementUI/autocomplete.scss +89 -89
  112. package/src/css/elementUI/checkbox.scss +298 -298
  113. package/src/css/elementUI/common/var.scss +1549 -1549
  114. package/src/css/elementUI/date-picker/picker.scss +219 -219
  115. package/src/css/elementUI/descriptions.scss +152 -152
  116. package/src/css/elementUI/drawer.scss +164 -164
  117. package/src/css/elementUI/radio.scss +215 -215
  118. package/src/css/elementUI/table.scss +697 -697
  119. package/src/css/elementUI/tabs.scss +659 -659
  120. package/src/css/vxeTableUI/all.scss +9 -9
  121. package/src/css/vxeTableUI/base.scss +16 -16
  122. package/src/css/vxeTableUI/components/colgroup.scss +0 -0
  123. package/src/css/vxeTableUI/components/column.scss +0 -0
  124. package/src/css/vxeTableUI/components/grid.scss +83 -83
  125. package/src/css/vxeTableUI/components/icon.scss +1017 -1017
  126. package/src/css/vxeTableUI/components/iconTable.scss +205 -205
  127. package/src/css/vxeTableUI/components/old-icon.scss +715 -715
  128. package/src/css/vxeTableUI/components/table-module/all.scss +6 -6
  129. package/src/css/vxeTableUI/components/table-module/custom.scss +490 -490
  130. package/src/css/vxeTableUI/components/table-module/edit.scss +0 -0
  131. package/src/css/vxeTableUI/components/table-module/export.scss +130 -130
  132. package/src/css/vxeTableUI/components/table-module/filter.scss +127 -127
  133. package/src/css/vxeTableUI/components/table-module/keyboard.scss +0 -0
  134. package/src/css/vxeTableUI/components/table-module/menu.scss +85 -85
  135. package/src/css/vxeTableUI/components/table-module/validator.scss +0 -0
  136. package/src/css/vxeTableUI/components/table.scss +2256 -2256
  137. package/src/css/vxeTableUI/components/toolbar.scss +99 -99
  138. package/src/css/vxeTableUI/components/ui.scss +0 -0
  139. package/src/css/vxeTableUI/components/v-x-e-table.scss +0 -0
  140. package/src/css/vxeTableUI/cssvar.scss +2 -2
  141. package/src/css/vxeTableUI/default.scss +2 -2
  142. package/src/css/vxeTableUI/helpers/baseMixin.scss +82 -82
  143. package/src/css/vxeTableUI/icon/iconfont.ttf +0 -0
  144. package/src/css/vxeTableUI/icon/iconfont.woff +0 -0
  145. package/src/css/vxeTableUI/icon/iconfont.woff2 +0 -0
  146. package/src/css/vxeTableUI/index.scss +4 -4
  147. package/src/css/vxeTableUI/modules.scss +5 -5
  148. package/src/css/vxeTableUI/theme/base.scss +88 -88
  149. package/src/css/vxeTableUI/theme/dark.scss +46 -46
  150. package/src/css/vxeTableUI/theme/light.scss +41 -41
  151. package/src/css/vxeTableUI/variable.scss +41 -41
  152. package/src/directives/vKeydown.ts +91 -91
  153. package/src/hooks/useDictHooks.ts +119 -119
  154. package/src/hooks/useEcharts.ts +58 -58
  155. package/src/hooks/useFileView.ts +11 -11
  156. package/src/hooks/useListenerHooks.ts +137 -137
  157. package/src/hooks/useMessageHooks.ts +132 -132
  158. package/src/hooks/useOpenNewMenu.ts +30 -30
  159. package/src/hooks/usePermissionHooks.ts +139 -139
  160. package/src/hooks/usePermissionToolHooks.ts +21 -21
  161. package/src/hooks/useResetRefHooks.ts +18 -18
  162. package/src/hooks/userWorkflowHooks.ts +106 -106
  163. package/src/hooks/workflowTodo.ts +85 -85
  164. package/src/interface/BaseEntity.ts +30 -30
  165. package/src/interface/IMdmDept.ts +84 -84
  166. package/src/interface/IMdmEmployee.ts +153 -153
  167. package/src/interface/IMdmEmployeeQuery.ts +21 -21
  168. package/src/interface/IMdmOrg.ts +29 -29
  169. package/src/interface/IMdmOrgQuery.ts +13 -13
  170. package/src/interface/IOrgDeptInfo.ts +12 -12
  171. package/src/interface/ISortList.ts +6 -6
  172. package/src/interface/ISysDictDataCacheVo.ts +46 -46
  173. package/src/interface/ISysDictType.ts +37 -37
  174. package/src/interface/ISysMenuDataVo.ts +22 -22
  175. package/src/interface/ISysMenuInfoVo.ts +83 -83
  176. package/src/interface/ISysMenuOperationVo.ts +21 -21
  177. package/src/interface/ISysUploadFiles.ts +16 -16
  178. package/src/interface/ISysUserInfo.ts +70 -70
  179. package/src/interface/IUserBaseInfo.ts +90 -90
  180. package/src/interface/IUserPermissionVo.ts +41 -41
  181. package/src/interface/IVxeTable.ts +1 -1
  182. package/src/interface/Message.ts +73 -72
  183. package/src/interface/PageData.ts +17 -17
  184. package/src/interface/ResponseData.ts +16 -16
  185. package/src/interface/dictMapType.ts +11 -11
  186. package/src/interface/enum/MessageEnum.ts +41 -41
  187. package/src/interface/workflow/IWfProcessDefVo.ts +14 -14
  188. package/src/interface/workflow/IWfReturnNodeVo.ts +16 -16
  189. package/src/interface/workflow/IWfTaskAskVo.ts +65 -65
  190. package/src/interface/workflow/IWfTaskQueryVo.ts +30 -30
  191. package/src/interface/workflow/IWfTaskUsersVo.ts +21 -21
  192. package/src/interface/workflow/IWfTaskVo.ts +187 -187
  193. package/src/interface/workflow/workflow.ts +22 -22
  194. package/src/mixin/globalMixin.ts +48 -48
  195. package/src/packages/index.ts +18 -18
  196. package/src/packages/text.vue +13 -13
  197. package/src/plugins/echartsConfig.ts +74 -74
  198. package/src/plugins/plugins.ts +12 -12
  199. package/src/plugins/renderDialog.ts +74 -74
  200. package/src/stores/dictStore.ts +51 -51
  201. package/src/stores/messageStore.ts +49 -49
  202. package/src/stores/permissionStore.ts +112 -112
  203. package/src/stores/storeConfig.ts +23 -23
  204. package/src/stores/userInfoStore.ts +31 -31
  205. package/src/utils/AxiosConfig.ts +226 -226
  206. package/src/utils/FrameworkUtils.ts +358 -358
  207. package/src/utils/commonUtils.ts +335 -335
  208. package/src/utils/encrypt.ts +18 -18
  209. package/src/utils/modules.ts +8 -8
  210. package/src/utils/request.ts +76 -76
  211. package/src/utils/tree.ts +50 -50
@@ -1,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>