adtec-core-package 2.3.8 → 2.3.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (344) hide show
  1. package/.editorconfig +6 -6
  2. package/.prettierrc.json +7 -7
  3. package/.vscode/extensions.json +8 -8
  4. package/README.en.md +36 -36
  5. package/README.md +39 -39
  6. package/env.d.ts +1 -1
  7. package/eslint.config.js +56 -56
  8. package/index.html +13 -13
  9. package/package.json +71 -71
  10. package/src/App.vue +9 -9
  11. package/src/api/BasicApi.ts +26 -26
  12. package/src/api/DeptInfoApi.ts +19 -19
  13. package/src/api/DocumentApi.ts +27 -27
  14. package/src/api/EmployeeInfoApi.ts +17 -17
  15. package/src/api/SysDictCacheApi.ts +29 -29
  16. package/src/api/SysUserApi.ts +35 -35
  17. package/src/api/framework.ts +12 -12
  18. package/src/api/workflow/workflow.ts +31 -31
  19. package/src/api/workflow/workflowCommentApi.ts +20 -0
  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 +241 -241
  109. package/src/components/workflow/WorkflowTodoDialog.vue +89 -89
  110. package/src/components/workflow/components/AddOrMinusMultiDialog.vue +159 -159
  111. package/src/components/workflow/components/CheckDialog.vue +350 -350
  112. package/src/components/workflow/components/ProcessDetailComp.vue +149 -149
  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 +347 -266
  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 +106 -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 +65 -65
  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 +188 -188
  319. package/src/interface/workflow/IWorkflowCommentVo.ts +24 -0
  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,518 +1,518 @@
1
- //@ts-ignore
2
- import {
3
- h,
4
- ref,
5
- nextTick,
6
- onBeforeUnmount,
7
- onMounted,
8
- computed,
9
- reactive,
10
- watch,
11
- type PropType,
12
- type VNode
13
- } from 'vue'
14
-
15
- // 定义属性类型
16
- interface VxeTooltipPropTypes {
17
- modelValue?: boolean
18
- content?: string | number
19
- trigger?: 'hover' | 'click'
20
- theme?: 'dark' | 'light'
21
- enterDelay?: number
22
- leaveDelay?: number
23
- isArrow?: boolean
24
- enterable?: boolean
25
- }
26
-
27
- // 定义响应式数据类型
28
- interface TooltipReactData {
29
- target: HTMLElement | null
30
- isUpdate: boolean
31
- visible: boolean
32
- tipContent: string | number
33
- tipActive: boolean
34
- tipTarget: HTMLElement | null
35
- tipZindex: number
36
- tipStore: {
37
- style: Record<string, string | number>
38
- placement: string
39
- arrowStyle: Record<string, string | number> | null
40
- }
41
- }
42
-
43
- // 定义内部数据类型
44
- interface TooltipInternalData {
45
- showDelayTip?: Function
46
- }
47
-
48
- // 定义组件方法类型
49
- interface TooltipMethods {
50
- open: (target?: HTMLElement | null, content?: string | number) => void
51
- close: () => void
52
- updatePlacement: () => Promise<void>
53
- isActived: () => boolean
54
- setActived: (active: boolean) => void
55
- }
56
-
57
- // 简单的防抖函数
58
- function debounce(func: Function, wait: number) {
59
- let timeout: number | null = null
60
- return function (this: any, ...args: any[]) {
61
- if (timeout) {
62
- clearTimeout(timeout)
63
- }
64
- timeout = window.setTimeout(() => {
65
- func.apply(this, args)
66
- }, wait) as any
67
- }
68
- }
69
-
70
- // 检查值是否为空
71
- function isNull(value: any): boolean {
72
- return value === null || value === undefined
73
- }
74
-
75
- // 检查值是否相等
76
- function eqNull(value: any): boolean {
77
- return value === null || value === undefined || value === ''
78
- }
79
-
80
- export default {
81
- name: 'VxeTooltip',
82
- props: {
83
- modelValue: Boolean,
84
- content: [String, Number],
85
- trigger: {
86
- type: String as PropType<'hover' | 'click'>,
87
- default: 'hover'
88
- },
89
- theme: {
90
- type: String as PropType<'dark' | 'light'>,
91
- default: 'dark'
92
- },
93
- isArrow: {
94
- type: Boolean,
95
- default: true
96
- },
97
- enterable: {
98
- type: Boolean,
99
- default: true
100
- },
101
- enterDelay: {
102
- type: Number,
103
- default: 0
104
- },
105
- leaveDelay: {
106
- type: Number,
107
- default: 0
108
- }
109
- },
110
- emits: ['update:modelValue'],
111
- setup(props: VxeTooltipPropTypes, { slots, emit }: any) {
112
- // 响应式数据
113
- const reactData = reactive<TooltipReactData>({
114
- target: null,
115
- isUpdate: false,
116
- visible: false,
117
- tipContent: '',
118
- tipActive: false,
119
- tipTarget: null,
120
- tipZindex: 0,
121
- tipStore: {
122
- style: {},
123
- placement: '',
124
- arrowStyle: {}
125
- }
126
- })
127
-
128
- // 内部数据
129
- const internalData: TooltipInternalData = {}
130
-
131
- // DOM 引用
132
- const refElem = ref<HTMLDivElement>()
133
- const contentWrapperfElem = ref<HTMLDivElement>()
134
-
135
- // 获取 DOM 位置信息
136
- const getDomNode = () => {
137
- return {
138
- scrollTop: window.scrollY || document.documentElement.scrollTop,
139
- scrollLeft: window.scrollX || document.documentElement.scrollLeft,
140
- visibleWidth: document.documentElement.clientWidth
141
- }
142
- }
143
-
144
- // 获取元素绝对位置
145
- const getAbsolutePos = (element: HTMLElement) => {
146
- const rect = element.getBoundingClientRect()
147
- return {
148
- top: rect.top + getDomNode().scrollTop,
149
- left: rect.left + getDomNode().scrollLeft
150
- }
151
- }
152
-
153
- // 更新提示框位置
154
- const updateTipStyle = () => {
155
- const { tipTarget, tipStore } = reactData
156
- if (tipTarget) {
157
- const { scrollTop, scrollLeft, visibleWidth } = getDomNode()
158
- const { top, left } = getAbsolutePos(tipTarget)
159
- const el = refElem.value
160
- if (!el) return
161
-
162
- const marginSize = 6
163
- const offsetHeight = el.offsetHeight
164
- const offsetWidth = el.offsetWidth
165
-
166
- let tipLeft = left
167
- let tipTop = top - offsetHeight - marginSize
168
-
169
- // 水平居中
170
- tipLeft = Math.max(
171
- marginSize,
172
- left + Math.floor((tipTarget.offsetWidth - offsetWidth) / 2)
173
- )
174
-
175
- // 检查是否超出右边界
176
- if (tipLeft + offsetWidth + marginSize > scrollLeft + visibleWidth) {
177
- tipLeft = scrollLeft + visibleWidth - offsetWidth - marginSize
178
- }
179
-
180
- // 检查是否超出上边界,如果超出则显示在底部
181
- if (top - offsetHeight < scrollTop + marginSize) {
182
- tipStore.placement = 'bottom'
183
- tipTop = top + tipTarget.offsetHeight + marginSize
184
- }
185
-
186
- tipStore.style.top = `${tipTop}px`
187
- tipStore.style.left = `${tipLeft}px`
188
- tipStore.arrowStyle = {
189
- left: `${left - tipLeft + tipTarget.offsetWidth / 2}px`
190
- }
191
- }
192
- }
193
-
194
- // 更新值
195
- const updateValue = (value: boolean) => {
196
- if (value !== reactData.visible) {
197
- reactData.visible = value
198
- reactData.isUpdate = true
199
- emit('update:modelValue', value)
200
- }
201
- }
202
-
203
- // 显示提示框
204
- const showTip = () => {
205
- const el = refElem.value
206
- if (el) {
207
- const parentNode = el.parentNode
208
- if (!parentNode) {
209
- document.body.appendChild(el)
210
- }
211
- }
212
-
213
- updateValue(true)
214
- reactData.tipZindex = 1000 // 简化的 z-index
215
- reactData.tipStore.placement = 'top'
216
- reactData.tipStore.style = {
217
- width: 'auto',
218
- left: 0,
219
- top: 0,
220
- zIndex: reactData.tipZindex
221
- }
222
- reactData.tipStore.arrowStyle = { left: '50%' }
223
-
224
- return nextTick().then(() => {
225
- updateTipStyle()
226
- return nextTick().then(() => {
227
- updateTipStyle()
228
- })
229
- })
230
- }
231
-
232
- // 处理延迟函数
233
- const handleDelayFn = () => {
234
- internalData.showDelayTip = debounce(() => {
235
- if (reactData.tipActive) {
236
- showTip()
237
- }
238
- //@ts-ignore
239
- }, props.enterDelay)
240
- }
241
-
242
- // 处理显示逻辑
243
- const handleVisible = (target: HTMLElement | null, content?: string | number) => {
244
- const contentSlot = slots.content
245
- if (!contentSlot && (content === '' || eqNull(content))) {
246
- return nextTick()
247
- }
248
-
249
- if (target) {
250
- const { showDelayTip } = internalData
251
- const { trigger, enterDelay } = props
252
- reactData.tipActive = true
253
- reactData.tipTarget = target
254
- //@ts-ignore
255
- reactData.tipContent = isNull(content) ? '' : content
256
-
257
- if (enterDelay && trigger === 'hover') {
258
- if (showDelayTip) {
259
- showDelayTip()
260
- }
261
- } else {
262
- return showTip()
263
- }
264
- }
265
- return nextTick()
266
- }
267
-
268
- // 事件处理函数
269
- const targetMouseenterEvent = () => {
270
- handleVisible(reactData.target, props.content)
271
- }
272
-
273
- const targetMouseleaveEvent = () => {
274
- const { trigger, enterable, leaveDelay } = props
275
- reactData.tipActive = false
276
-
277
- if (enterable && trigger === 'hover') {
278
- setTimeout(() => {
279
- if (!reactData.tipActive) {
280
- close()
281
- }
282
- }, leaveDelay)
283
- } else {
284
- close()
285
- }
286
- }
287
-
288
- const wrapperMouseenterEvent = () => {
289
- reactData.tipActive = true
290
- }
291
-
292
- const wrapperMouseleaveEvent = () => {
293
- const { trigger, enterable, leaveDelay } = props
294
- reactData.tipActive = false
295
-
296
- if (enterable && trigger === 'hover') {
297
- setTimeout(() => {
298
- if (!reactData.tipActive) {
299
- close()
300
- }
301
- }, leaveDelay)
302
- }
303
- }
304
-
305
- const clickEvent = () => {
306
- if (reactData.visible) {
307
- close()
308
- } else {
309
- handleVisible(reactData.target, props.content)
310
- }
311
- }
312
-
313
- // 关闭方法
314
- const close = () => {
315
- reactData.tipTarget = null
316
- reactData.tipActive = false
317
- Object.assign(reactData.tipStore, {
318
- style: {},
319
- placement: '',
320
- arrowStyle: null
321
- })
322
- updateValue(false)
323
- return nextTick()
324
- }
325
-
326
- // 公开方法
327
- const tooltipMethods: TooltipMethods = {
328
- open(target?: HTMLElement | null, content?: string | number) {
329
- return handleVisible(target || reactData.target, content)
330
- },
331
- close,
332
- updatePlacement() {
333
- return nextTick().then(() => {
334
- const { tipTarget } = reactData
335
- const el = refElem.value
336
- if (tipTarget && el) {
337
- updateTipStyle()
338
- return nextTick().then(() => {
339
- updateTipStyle()
340
- })
341
- }
342
- })
343
- },
344
- isActived() {
345
- return reactData.tipActive
346
- },
347
- setActived(active: boolean) {
348
- reactData.tipActive = !!active
349
- }
350
- }
351
-
352
- // 渲染内容
353
- const renderContent = () => {
354
- const { tipContent } = reactData
355
- const contentSlot = slots.content
356
-
357
- const contVNs: VNode[] = []
358
- if (contentSlot) {
359
- contVNs.push(
360
- h('div', {}, contentSlot({}))
361
- )
362
- } else {
363
- contVNs.push(
364
- h('div', {}, `${tipContent}`)
365
- )
366
- }
367
-
368
- return h('div', {
369
- ref: contentWrapperfElem,
370
- class: 'vxe-tooltip--content'
371
- }, contVNs)
372
- }
373
-
374
- // 渲染虚拟节点
375
- const renderVN = () => {
376
- const { theme, isArrow, enterable } = props
377
- const { tipActive, visible, tipStore } = reactData
378
- const defaultSlot = slots.default
379
-
380
- let ons
381
- if (enterable) {
382
- ons = {
383
- onMouseenter: wrapperMouseenterEvent,
384
- onMouseleave: wrapperMouseleaveEvent
385
- }
386
- }
387
-
388
- return h('div', {
389
- ref: refElem,
390
- class: [
391
- 'vxe-tooltip--wrapper',
392
- `theme--${theme}`,
393
- {
394
- [`placement--${tipStore.placement}`]: tipStore.placement,
395
- 'is--enterable': enterable,
396
- 'is--visible': visible,
397
- 'is--arrow': isArrow,
398
- 'is--active': tipActive
399
- }
400
- ],
401
- style: {
402
- ...tipStore.style,
403
- // 添加过渡效果
404
- transition: 'opacity 0.2s ease, transform 0.2s ease',
405
- opacity: visible ? 1 : 0,
406
- transform: visible ? 'scale(1)' : 'scale(0.95)'
407
- },
408
- ...ons
409
- }, [
410
- renderContent(),
411
- isArrow
412
- ? h('div', {
413
- class: 'vxe-tooltip--arrow',
414
- style: tipStore.arrowStyle
415
- })
416
- : null,
417
- ...(defaultSlot ? defaultSlot({}) : [])
418
- ])
419
- }
420
-
421
- // 监听器
422
- watch(() => props.enterDelay, () => {
423
- handleDelayFn()
424
- })
425
-
426
- watch(() => props.content, (val) => {
427
- //@ts-ignore
428
- reactData.tipContent = isNull(val) ? '' : val
429
- })
430
-
431
- watch(() => props.modelValue, (val) => {
432
- if (!reactData.isUpdate) {
433
- if (val) {
434
- handleVisible(reactData.target, props.content)
435
- } else {
436
- close()
437
- }
438
- }
439
- reactData.isUpdate = false
440
- })
441
-
442
- // 生命周期钩子
443
- onMounted(() => {
444
- nextTick(() => {
445
- const { trigger, content } = props
446
- const wrapperElem = refElem.value
447
-
448
- if (wrapperElem) {
449
- const parentNode = wrapperElem.parentNode
450
- if (parentNode) {
451
- //@ts-ignore
452
- reactData.tipContent = isNull(content) ? '' : content
453
- reactData.tipZindex = 1000
454
-
455
- // 将子元素移动到父级
456
- const children = Array.from(wrapperElem.children)
457
- children.forEach((elem, index) => {
458
- if (index > 1) {
459
- parentNode.insertBefore(elem, wrapperElem)
460
- if (!reactData.target) {
461
- reactData.target = elem as HTMLElement
462
- }
463
- }
464
- })
465
-
466
- parentNode.removeChild(wrapperElem)
467
-
468
- // 绑定事件
469
- const { target } = reactData
470
- if (target) {
471
- if (trigger === 'hover') {
472
- target.onmouseenter = targetMouseenterEvent
473
- target.onmouseleave = targetMouseleaveEvent
474
- } else if (trigger === 'click') {
475
- target.onclick = clickEvent
476
- }
477
- }
478
-
479
- // 如果 modelValue 为 true,则显示
480
- if (props.modelValue) {
481
- handleVisible(target, content)
482
- }
483
- }
484
- }
485
- })
486
- })
487
-
488
- onBeforeUnmount(() => {
489
- const { target } = reactData
490
- const wrapperElem = refElem.value
491
-
492
- if (target) {
493
- target.onmouseenter = null
494
- target.onmouseleave = null
495
- target.onclick = null
496
- }
497
-
498
- if (wrapperElem) {
499
- const parentNode = wrapperElem.parentNode
500
- if (parentNode) {
501
- parentNode.removeChild(wrapperElem)
502
- }
503
- }
504
- })
505
-
506
- handleDelayFn()
507
-
508
- return {
509
- ...tooltipMethods,
510
- renderVN
511
- }
512
- },
513
- //@ts-ignore
514
- render() {
515
- //@ts-ignore
516
- return this.renderVN()
517
- }
518
- }
1
+ //@ts-ignore
2
+ import {
3
+ h,
4
+ ref,
5
+ nextTick,
6
+ onBeforeUnmount,
7
+ onMounted,
8
+ computed,
9
+ reactive,
10
+ watch,
11
+ type PropType,
12
+ type VNode
13
+ } from 'vue'
14
+
15
+ // 定义属性类型
16
+ interface VxeTooltipPropTypes {
17
+ modelValue?: boolean
18
+ content?: string | number
19
+ trigger?: 'hover' | 'click'
20
+ theme?: 'dark' | 'light'
21
+ enterDelay?: number
22
+ leaveDelay?: number
23
+ isArrow?: boolean
24
+ enterable?: boolean
25
+ }
26
+
27
+ // 定义响应式数据类型
28
+ interface TooltipReactData {
29
+ target: HTMLElement | null
30
+ isUpdate: boolean
31
+ visible: boolean
32
+ tipContent: string | number
33
+ tipActive: boolean
34
+ tipTarget: HTMLElement | null
35
+ tipZindex: number
36
+ tipStore: {
37
+ style: Record<string, string | number>
38
+ placement: string
39
+ arrowStyle: Record<string, string | number> | null
40
+ }
41
+ }
42
+
43
+ // 定义内部数据类型
44
+ interface TooltipInternalData {
45
+ showDelayTip?: Function
46
+ }
47
+
48
+ // 定义组件方法类型
49
+ interface TooltipMethods {
50
+ open: (target?: HTMLElement | null, content?: string | number) => void
51
+ close: () => void
52
+ updatePlacement: () => Promise<void>
53
+ isActived: () => boolean
54
+ setActived: (active: boolean) => void
55
+ }
56
+
57
+ // 简单的防抖函数
58
+ function debounce(func: Function, wait: number) {
59
+ let timeout: number | null = null
60
+ return function (this: any, ...args: any[]) {
61
+ if (timeout) {
62
+ clearTimeout(timeout)
63
+ }
64
+ timeout = window.setTimeout(() => {
65
+ func.apply(this, args)
66
+ }, wait) as any
67
+ }
68
+ }
69
+
70
+ // 检查值是否为空
71
+ function isNull(value: any): boolean {
72
+ return value === null || value === undefined
73
+ }
74
+
75
+ // 检查值是否相等
76
+ function eqNull(value: any): boolean {
77
+ return value === null || value === undefined || value === ''
78
+ }
79
+
80
+ export default {
81
+ name: 'VxeTooltip',
82
+ props: {
83
+ modelValue: Boolean,
84
+ content: [String, Number],
85
+ trigger: {
86
+ type: String as PropType<'hover' | 'click'>,
87
+ default: 'hover'
88
+ },
89
+ theme: {
90
+ type: String as PropType<'dark' | 'light'>,
91
+ default: 'dark'
92
+ },
93
+ isArrow: {
94
+ type: Boolean,
95
+ default: true
96
+ },
97
+ enterable: {
98
+ type: Boolean,
99
+ default: true
100
+ },
101
+ enterDelay: {
102
+ type: Number,
103
+ default: 0
104
+ },
105
+ leaveDelay: {
106
+ type: Number,
107
+ default: 0
108
+ }
109
+ },
110
+ emits: ['update:modelValue'],
111
+ setup(props: VxeTooltipPropTypes, { slots, emit }: any) {
112
+ // 响应式数据
113
+ const reactData = reactive<TooltipReactData>({
114
+ target: null,
115
+ isUpdate: false,
116
+ visible: false,
117
+ tipContent: '',
118
+ tipActive: false,
119
+ tipTarget: null,
120
+ tipZindex: 0,
121
+ tipStore: {
122
+ style: {},
123
+ placement: '',
124
+ arrowStyle: {}
125
+ }
126
+ })
127
+
128
+ // 内部数据
129
+ const internalData: TooltipInternalData = {}
130
+
131
+ // DOM 引用
132
+ const refElem = ref<HTMLDivElement>()
133
+ const contentWrapperfElem = ref<HTMLDivElement>()
134
+
135
+ // 获取 DOM 位置信息
136
+ const getDomNode = () => {
137
+ return {
138
+ scrollTop: window.scrollY || document.documentElement.scrollTop,
139
+ scrollLeft: window.scrollX || document.documentElement.scrollLeft,
140
+ visibleWidth: document.documentElement.clientWidth
141
+ }
142
+ }
143
+
144
+ // 获取元素绝对位置
145
+ const getAbsolutePos = (element: HTMLElement) => {
146
+ const rect = element.getBoundingClientRect()
147
+ return {
148
+ top: rect.top + getDomNode().scrollTop,
149
+ left: rect.left + getDomNode().scrollLeft
150
+ }
151
+ }
152
+
153
+ // 更新提示框位置
154
+ const updateTipStyle = () => {
155
+ const { tipTarget, tipStore } = reactData
156
+ if (tipTarget) {
157
+ const { scrollTop, scrollLeft, visibleWidth } = getDomNode()
158
+ const { top, left } = getAbsolutePos(tipTarget)
159
+ const el = refElem.value
160
+ if (!el) return
161
+
162
+ const marginSize = 6
163
+ const offsetHeight = el.offsetHeight
164
+ const offsetWidth = el.offsetWidth
165
+
166
+ let tipLeft = left
167
+ let tipTop = top - offsetHeight - marginSize
168
+
169
+ // 水平居中
170
+ tipLeft = Math.max(
171
+ marginSize,
172
+ left + Math.floor((tipTarget.offsetWidth - offsetWidth) / 2)
173
+ )
174
+
175
+ // 检查是否超出右边界
176
+ if (tipLeft + offsetWidth + marginSize > scrollLeft + visibleWidth) {
177
+ tipLeft = scrollLeft + visibleWidth - offsetWidth - marginSize
178
+ }
179
+
180
+ // 检查是否超出上边界,如果超出则显示在底部
181
+ if (top - offsetHeight < scrollTop + marginSize) {
182
+ tipStore.placement = 'bottom'
183
+ tipTop = top + tipTarget.offsetHeight + marginSize
184
+ }
185
+
186
+ tipStore.style.top = `${tipTop}px`
187
+ tipStore.style.left = `${tipLeft}px`
188
+ tipStore.arrowStyle = {
189
+ left: `${left - tipLeft + tipTarget.offsetWidth / 2}px`
190
+ }
191
+ }
192
+ }
193
+
194
+ // 更新值
195
+ const updateValue = (value: boolean) => {
196
+ if (value !== reactData.visible) {
197
+ reactData.visible = value
198
+ reactData.isUpdate = true
199
+ emit('update:modelValue', value)
200
+ }
201
+ }
202
+
203
+ // 显示提示框
204
+ const showTip = () => {
205
+ const el = refElem.value
206
+ if (el) {
207
+ const parentNode = el.parentNode
208
+ if (!parentNode) {
209
+ document.body.appendChild(el)
210
+ }
211
+ }
212
+
213
+ updateValue(true)
214
+ reactData.tipZindex = 1000 // 简化的 z-index
215
+ reactData.tipStore.placement = 'top'
216
+ reactData.tipStore.style = {
217
+ width: 'auto',
218
+ left: 0,
219
+ top: 0,
220
+ zIndex: reactData.tipZindex
221
+ }
222
+ reactData.tipStore.arrowStyle = { left: '50%' }
223
+
224
+ return nextTick().then(() => {
225
+ updateTipStyle()
226
+ return nextTick().then(() => {
227
+ updateTipStyle()
228
+ })
229
+ })
230
+ }
231
+
232
+ // 处理延迟函数
233
+ const handleDelayFn = () => {
234
+ internalData.showDelayTip = debounce(() => {
235
+ if (reactData.tipActive) {
236
+ showTip()
237
+ }
238
+ //@ts-ignore
239
+ }, props.enterDelay)
240
+ }
241
+
242
+ // 处理显示逻辑
243
+ const handleVisible = (target: HTMLElement | null, content?: string | number) => {
244
+ const contentSlot = slots.content
245
+ if (!contentSlot && (content === '' || eqNull(content))) {
246
+ return nextTick()
247
+ }
248
+
249
+ if (target) {
250
+ const { showDelayTip } = internalData
251
+ const { trigger, enterDelay } = props
252
+ reactData.tipActive = true
253
+ reactData.tipTarget = target
254
+ //@ts-ignore
255
+ reactData.tipContent = isNull(content) ? '' : content
256
+
257
+ if (enterDelay && trigger === 'hover') {
258
+ if (showDelayTip) {
259
+ showDelayTip()
260
+ }
261
+ } else {
262
+ return showTip()
263
+ }
264
+ }
265
+ return nextTick()
266
+ }
267
+
268
+ // 事件处理函数
269
+ const targetMouseenterEvent = () => {
270
+ handleVisible(reactData.target, props.content)
271
+ }
272
+
273
+ const targetMouseleaveEvent = () => {
274
+ const { trigger, enterable, leaveDelay } = props
275
+ reactData.tipActive = false
276
+
277
+ if (enterable && trigger === 'hover') {
278
+ setTimeout(() => {
279
+ if (!reactData.tipActive) {
280
+ close()
281
+ }
282
+ }, leaveDelay)
283
+ } else {
284
+ close()
285
+ }
286
+ }
287
+
288
+ const wrapperMouseenterEvent = () => {
289
+ reactData.tipActive = true
290
+ }
291
+
292
+ const wrapperMouseleaveEvent = () => {
293
+ const { trigger, enterable, leaveDelay } = props
294
+ reactData.tipActive = false
295
+
296
+ if (enterable && trigger === 'hover') {
297
+ setTimeout(() => {
298
+ if (!reactData.tipActive) {
299
+ close()
300
+ }
301
+ }, leaveDelay)
302
+ }
303
+ }
304
+
305
+ const clickEvent = () => {
306
+ if (reactData.visible) {
307
+ close()
308
+ } else {
309
+ handleVisible(reactData.target, props.content)
310
+ }
311
+ }
312
+
313
+ // 关闭方法
314
+ const close = () => {
315
+ reactData.tipTarget = null
316
+ reactData.tipActive = false
317
+ Object.assign(reactData.tipStore, {
318
+ style: {},
319
+ placement: '',
320
+ arrowStyle: null
321
+ })
322
+ updateValue(false)
323
+ return nextTick()
324
+ }
325
+
326
+ // 公开方法
327
+ const tooltipMethods: TooltipMethods = {
328
+ open(target?: HTMLElement | null, content?: string | number) {
329
+ return handleVisible(target || reactData.target, content)
330
+ },
331
+ close,
332
+ updatePlacement() {
333
+ return nextTick().then(() => {
334
+ const { tipTarget } = reactData
335
+ const el = refElem.value
336
+ if (tipTarget && el) {
337
+ updateTipStyle()
338
+ return nextTick().then(() => {
339
+ updateTipStyle()
340
+ })
341
+ }
342
+ })
343
+ },
344
+ isActived() {
345
+ return reactData.tipActive
346
+ },
347
+ setActived(active: boolean) {
348
+ reactData.tipActive = !!active
349
+ }
350
+ }
351
+
352
+ // 渲染内容
353
+ const renderContent = () => {
354
+ const { tipContent } = reactData
355
+ const contentSlot = slots.content
356
+
357
+ const contVNs: VNode[] = []
358
+ if (contentSlot) {
359
+ contVNs.push(
360
+ h('div', {}, contentSlot({}))
361
+ )
362
+ } else {
363
+ contVNs.push(
364
+ h('div', {}, `${tipContent}`)
365
+ )
366
+ }
367
+
368
+ return h('div', {
369
+ ref: contentWrapperfElem,
370
+ class: 'vxe-tooltip--content'
371
+ }, contVNs)
372
+ }
373
+
374
+ // 渲染虚拟节点
375
+ const renderVN = () => {
376
+ const { theme, isArrow, enterable } = props
377
+ const { tipActive, visible, tipStore } = reactData
378
+ const defaultSlot = slots.default
379
+
380
+ let ons
381
+ if (enterable) {
382
+ ons = {
383
+ onMouseenter: wrapperMouseenterEvent,
384
+ onMouseleave: wrapperMouseleaveEvent
385
+ }
386
+ }
387
+
388
+ return h('div', {
389
+ ref: refElem,
390
+ class: [
391
+ 'vxe-tooltip--wrapper',
392
+ `theme--${theme}`,
393
+ {
394
+ [`placement--${tipStore.placement}`]: tipStore.placement,
395
+ 'is--enterable': enterable,
396
+ 'is--visible': visible,
397
+ 'is--arrow': isArrow,
398
+ 'is--active': tipActive
399
+ }
400
+ ],
401
+ style: {
402
+ ...tipStore.style,
403
+ // 添加过渡效果
404
+ transition: 'opacity 0.2s ease, transform 0.2s ease',
405
+ opacity: visible ? 1 : 0,
406
+ transform: visible ? 'scale(1)' : 'scale(0.95)'
407
+ },
408
+ ...ons
409
+ }, [
410
+ renderContent(),
411
+ isArrow
412
+ ? h('div', {
413
+ class: 'vxe-tooltip--arrow',
414
+ style: tipStore.arrowStyle
415
+ })
416
+ : null,
417
+ ...(defaultSlot ? defaultSlot({}) : [])
418
+ ])
419
+ }
420
+
421
+ // 监听器
422
+ watch(() => props.enterDelay, () => {
423
+ handleDelayFn()
424
+ })
425
+
426
+ watch(() => props.content, (val) => {
427
+ //@ts-ignore
428
+ reactData.tipContent = isNull(val) ? '' : val
429
+ })
430
+
431
+ watch(() => props.modelValue, (val) => {
432
+ if (!reactData.isUpdate) {
433
+ if (val) {
434
+ handleVisible(reactData.target, props.content)
435
+ } else {
436
+ close()
437
+ }
438
+ }
439
+ reactData.isUpdate = false
440
+ })
441
+
442
+ // 生命周期钩子
443
+ onMounted(() => {
444
+ nextTick(() => {
445
+ const { trigger, content } = props
446
+ const wrapperElem = refElem.value
447
+
448
+ if (wrapperElem) {
449
+ const parentNode = wrapperElem.parentNode
450
+ if (parentNode) {
451
+ //@ts-ignore
452
+ reactData.tipContent = isNull(content) ? '' : content
453
+ reactData.tipZindex = 1000
454
+
455
+ // 将子元素移动到父级
456
+ const children = Array.from(wrapperElem.children)
457
+ children.forEach((elem, index) => {
458
+ if (index > 1) {
459
+ parentNode.insertBefore(elem, wrapperElem)
460
+ if (!reactData.target) {
461
+ reactData.target = elem as HTMLElement
462
+ }
463
+ }
464
+ })
465
+
466
+ parentNode.removeChild(wrapperElem)
467
+
468
+ // 绑定事件
469
+ const { target } = reactData
470
+ if (target) {
471
+ if (trigger === 'hover') {
472
+ target.onmouseenter = targetMouseenterEvent
473
+ target.onmouseleave = targetMouseleaveEvent
474
+ } else if (trigger === 'click') {
475
+ target.onclick = clickEvent
476
+ }
477
+ }
478
+
479
+ // 如果 modelValue 为 true,则显示
480
+ if (props.modelValue) {
481
+ handleVisible(target, content)
482
+ }
483
+ }
484
+ }
485
+ })
486
+ })
487
+
488
+ onBeforeUnmount(() => {
489
+ const { target } = reactData
490
+ const wrapperElem = refElem.value
491
+
492
+ if (target) {
493
+ target.onmouseenter = null
494
+ target.onmouseleave = null
495
+ target.onclick = null
496
+ }
497
+
498
+ if (wrapperElem) {
499
+ const parentNode = wrapperElem.parentNode
500
+ if (parentNode) {
501
+ parentNode.removeChild(wrapperElem)
502
+ }
503
+ }
504
+ })
505
+
506
+ handleDelayFn()
507
+
508
+ return {
509
+ ...tooltipMethods,
510
+ renderVN
511
+ }
512
+ },
513
+ //@ts-ignore
514
+ render() {
515
+ //@ts-ignore
516
+ return this.renderVN()
517
+ }
518
+ }