vxe-pc-ui 3.13.11 → 3.13.13

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 (674) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +134 -134
  3. package/es/icon/style.css +1 -1
  4. package/es/style.css +1 -1
  5. package/es/style.min.css +1 -1
  6. package/es/tag/style.css +1 -3
  7. package/es/tag/style.min.css +1 -1
  8. package/es/ui/index.js +1 -1
  9. package/es/ui/src/log.js +1 -1
  10. package/es/vxe-tag/style.css +1 -3
  11. package/es/vxe-tag/style.min.css +1 -1
  12. package/lib/components.js +2 -1
  13. package/lib/components.min.js +1 -1
  14. package/lib/drawer/index.js +2 -1
  15. package/lib/drawer/index.min.js +1 -1
  16. package/lib/icon/style/style.css +1 -1
  17. package/lib/icon/style/style.min.css +1 -1
  18. package/lib/index.common.js +2 -1
  19. package/lib/index.umd.js +7962 -8834
  20. package/lib/index.umd.min.js +1 -1
  21. package/lib/modal/index.js +2 -1
  22. package/lib/modal/index.min.js +1 -1
  23. package/lib/style.css +1 -1
  24. package/lib/style.min.css +1 -1
  25. package/lib/tag/style/style.css +1 -3
  26. package/lib/tag/style/style.min.css +1 -1
  27. package/lib/ui/index.js +1 -1
  28. package/lib/ui/index.min.js +1 -1
  29. package/lib/ui/src/log.js +1 -1
  30. package/lib/ui/src/log.min.js +1 -1
  31. package/lib/vxe-alert/index.js +2 -1
  32. package/lib/vxe-alert/index.min.js +1 -1
  33. package/lib/vxe-anchor/index.js +2 -1
  34. package/lib/vxe-anchor/index.min.js +1 -1
  35. package/lib/vxe-anchor-link/index.js +2 -1
  36. package/lib/vxe-anchor-link/index.min.js +1 -1
  37. package/lib/vxe-avatar/index.js +2 -1
  38. package/lib/vxe-avatar/index.min.js +1 -1
  39. package/lib/vxe-backtop/index.js +2 -1
  40. package/lib/vxe-backtop/index.min.js +1 -1
  41. package/lib/vxe-badge/index.js +2 -1
  42. package/lib/vxe-badge/index.min.js +1 -1
  43. package/lib/vxe-breadcrumb/index.js +2 -1
  44. package/lib/vxe-breadcrumb/index.min.js +1 -1
  45. package/lib/vxe-breadcrumb-item/index.js +2 -1
  46. package/lib/vxe-breadcrumb-item/index.min.js +1 -1
  47. package/lib/vxe-button/index.js +2 -1
  48. package/lib/vxe-button/index.min.js +1 -1
  49. package/lib/vxe-button-group/index.js +2 -1
  50. package/lib/vxe-button-group/index.min.js +1 -1
  51. package/lib/vxe-calendar/index.js +2 -1
  52. package/lib/vxe-calendar/index.min.js +1 -1
  53. package/lib/vxe-card/index.js +2 -1
  54. package/lib/vxe-card/index.min.js +1 -1
  55. package/lib/vxe-carousel/index.js +2 -1
  56. package/lib/vxe-carousel/index.min.js +1 -1
  57. package/lib/vxe-carousel-item/index.js +2 -1
  58. package/lib/vxe-carousel-item/index.min.js +1 -1
  59. package/lib/vxe-cascader/index.js +2 -1
  60. package/lib/vxe-cascader/index.min.js +1 -1
  61. package/lib/vxe-checkbox/index.js +2 -1
  62. package/lib/vxe-checkbox/index.min.js +1 -1
  63. package/lib/vxe-checkbox-button/index.js +2 -1
  64. package/lib/vxe-checkbox-button/index.min.js +1 -1
  65. package/lib/vxe-checkbox-group/index.js +2 -1
  66. package/lib/vxe-checkbox-group/index.min.js +1 -1
  67. package/lib/vxe-col/index.js +2 -1
  68. package/lib/vxe-col/index.min.js +1 -1
  69. package/lib/vxe-collapse/index.js +2 -1
  70. package/lib/vxe-collapse/index.min.js +1 -1
  71. package/lib/vxe-collapse-pane/index.js +2 -1
  72. package/lib/vxe-collapse-pane/index.min.js +1 -1
  73. package/lib/vxe-color-picker/index.js +2 -1
  74. package/lib/vxe-color-picker/index.min.js +1 -1
  75. package/lib/vxe-context-menu/index.js +2 -1
  76. package/lib/vxe-context-menu/index.min.js +1 -1
  77. package/lib/vxe-countdown/index.js +2 -1
  78. package/lib/vxe-countdown/index.min.js +1 -1
  79. package/lib/vxe-date-panel/index.js +2 -1
  80. package/lib/vxe-date-panel/index.min.js +1 -1
  81. package/lib/vxe-date-picker/index.js +2 -1
  82. package/lib/vxe-date-picker/index.min.js +1 -1
  83. package/lib/vxe-date-range-picker/index.js +2 -1
  84. package/lib/vxe-date-range-picker/index.min.js +1 -1
  85. package/lib/vxe-drawer/index.js +2 -1
  86. package/lib/vxe-drawer/index.min.js +1 -1
  87. package/lib/vxe-empty/index.js +2 -1
  88. package/lib/vxe-empty/index.min.js +1 -1
  89. package/lib/vxe-form/index.js +2 -1
  90. package/lib/vxe-form/index.min.js +1 -1
  91. package/lib/vxe-form-gather/index.js +2 -1
  92. package/lib/vxe-form-gather/index.min.js +1 -1
  93. package/lib/vxe-form-group/index.js +2 -1
  94. package/lib/vxe-form-group/index.min.js +1 -1
  95. package/lib/vxe-form-item/index.js +2 -1
  96. package/lib/vxe-form-item/index.min.js +1 -1
  97. package/lib/vxe-icon/index.js +2 -1
  98. package/lib/vxe-icon/index.min.js +1 -1
  99. package/lib/vxe-icon-picker/index.js +2 -1
  100. package/lib/vxe-icon-picker/index.min.js +1 -1
  101. package/lib/vxe-image/index.js +2 -1
  102. package/lib/vxe-image/index.min.js +1 -1
  103. package/lib/vxe-image-group/index.js +2 -1
  104. package/lib/vxe-image-group/index.min.js +1 -1
  105. package/lib/vxe-image-preview/index.js +2 -1
  106. package/lib/vxe-image-preview/index.min.js +1 -1
  107. package/lib/vxe-input/index.js +2 -1
  108. package/lib/vxe-input/index.min.js +1 -1
  109. package/lib/vxe-layout-aside/index.js +2 -1
  110. package/lib/vxe-layout-aside/index.min.js +1 -1
  111. package/lib/vxe-layout-body/index.js +2 -1
  112. package/lib/vxe-layout-body/index.min.js +1 -1
  113. package/lib/vxe-layout-container/index.js +2 -1
  114. package/lib/vxe-layout-container/index.min.js +1 -1
  115. package/lib/vxe-layout-footer/index.js +2 -1
  116. package/lib/vxe-layout-footer/index.min.js +1 -1
  117. package/lib/vxe-layout-header/index.js +2 -1
  118. package/lib/vxe-layout-header/index.min.js +1 -1
  119. package/lib/vxe-link/index.js +2 -1
  120. package/lib/vxe-link/index.min.js +1 -1
  121. package/lib/vxe-list/index.js +2 -1
  122. package/lib/vxe-list/index.min.js +1 -1
  123. package/lib/vxe-loading/index.js +2 -1
  124. package/lib/vxe-loading/index.min.js +1 -1
  125. package/lib/vxe-mention/index.js +2 -1
  126. package/lib/vxe-mention/index.min.js +1 -1
  127. package/lib/vxe-menu/index.js +2 -1
  128. package/lib/vxe-menu/index.min.js +1 -1
  129. package/lib/vxe-modal/index.js +2 -1
  130. package/lib/vxe-modal/index.min.js +1 -1
  131. package/lib/vxe-notice-bar/index.js +2 -1
  132. package/lib/vxe-notice-bar/index.min.js +1 -1
  133. package/lib/vxe-number-input/index.js +2 -1
  134. package/lib/vxe-number-input/index.min.js +1 -1
  135. package/lib/vxe-optgroup/index.js +2 -1
  136. package/lib/vxe-optgroup/index.min.js +1 -1
  137. package/lib/vxe-option/index.js +2 -1
  138. package/lib/vxe-option/index.min.js +1 -1
  139. package/lib/vxe-pager/index.js +2 -1
  140. package/lib/vxe-pager/index.min.js +1 -1
  141. package/lib/vxe-password-input/index.js +2 -1
  142. package/lib/vxe-password-input/index.min.js +1 -1
  143. package/lib/vxe-print/index.js +2 -1
  144. package/lib/vxe-print/index.min.js +1 -1
  145. package/lib/vxe-print-page-break/index.js +2 -1
  146. package/lib/vxe-print-page-break/index.min.js +1 -1
  147. package/lib/vxe-pulldown/index.js +2 -1
  148. package/lib/vxe-pulldown/index.min.js +1 -1
  149. package/lib/vxe-radio/index.js +2 -1
  150. package/lib/vxe-radio/index.min.js +1 -1
  151. package/lib/vxe-radio-button/index.js +2 -1
  152. package/lib/vxe-radio-button/index.min.js +1 -1
  153. package/lib/vxe-radio-group/index.js +2 -1
  154. package/lib/vxe-radio-group/index.min.js +1 -1
  155. package/lib/vxe-rate/index.js +2 -1
  156. package/lib/vxe-rate/index.min.js +1 -1
  157. package/lib/vxe-result/index.js +2 -1
  158. package/lib/vxe-result/index.min.js +1 -1
  159. package/lib/vxe-row/index.js +2 -1
  160. package/lib/vxe-row/index.min.js +1 -1
  161. package/lib/vxe-segmented/index.js +2 -1
  162. package/lib/vxe-segmented/index.min.js +1 -1
  163. package/lib/vxe-select/index.js +2 -1
  164. package/lib/vxe-select/index.min.js +1 -1
  165. package/lib/vxe-slider/index.js +2 -1
  166. package/lib/vxe-slider/index.min.js +1 -1
  167. package/lib/vxe-split/index.js +2 -1
  168. package/lib/vxe-split/index.min.js +1 -1
  169. package/lib/vxe-split-pane/index.js +2 -1
  170. package/lib/vxe-split-pane/index.min.js +1 -1
  171. package/lib/vxe-splitter/index.js +2 -1
  172. package/lib/vxe-splitter/index.min.js +1 -1
  173. package/lib/vxe-splitter-panel/index.js +2 -1
  174. package/lib/vxe-splitter-panel/index.min.js +1 -1
  175. package/lib/vxe-steps/index.js +2 -1
  176. package/lib/vxe-steps/index.min.js +1 -1
  177. package/lib/vxe-switch/index.js +2 -1
  178. package/lib/vxe-switch/index.min.js +1 -1
  179. package/lib/vxe-tab-pane/index.js +2 -1
  180. package/lib/vxe-tab-pane/index.min.js +1 -1
  181. package/lib/vxe-table-select/index.js +2 -1
  182. package/lib/vxe-table-select/index.min.js +1 -1
  183. package/lib/vxe-tabs/index.js +2 -1
  184. package/lib/vxe-tabs/index.min.js +1 -1
  185. package/lib/vxe-tag/index.js +2 -1
  186. package/lib/vxe-tag/index.min.js +1 -1
  187. package/lib/vxe-tag/style/style.css +1 -3
  188. package/lib/vxe-tag/style/style.min.css +1 -1
  189. package/lib/vxe-text/index.js +2 -1
  190. package/lib/vxe-text/index.min.js +1 -1
  191. package/lib/vxe-text-ellipsis/index.js +2 -1
  192. package/lib/vxe-text-ellipsis/index.min.js +1 -1
  193. package/lib/vxe-textarea/index.js +2 -1
  194. package/lib/vxe-textarea/index.min.js +1 -1
  195. package/lib/vxe-timeline/index.js +2 -1
  196. package/lib/vxe-timeline/index.min.js +1 -1
  197. package/lib/vxe-timeline-item/index.js +2 -1
  198. package/lib/vxe-timeline-item/index.min.js +1 -1
  199. package/lib/vxe-tip/index.js +2 -1
  200. package/lib/vxe-tip/index.min.js +1 -1
  201. package/lib/vxe-tooltip/index.js +2 -1
  202. package/lib/vxe-tooltip/index.min.js +1 -1
  203. package/lib/vxe-tour/index.js +2 -1
  204. package/lib/vxe-tour/index.min.js +1 -1
  205. package/lib/vxe-tree/index.js +2 -1
  206. package/lib/vxe-tree/index.min.js +1 -1
  207. package/lib/vxe-tree-select/index.js +2 -1
  208. package/lib/vxe-tree-select/index.min.js +1 -1
  209. package/lib/vxe-u-i/index.js +2 -1
  210. package/lib/vxe-u-i/index.min.js +1 -1
  211. package/lib/vxe-ui/index.js +2 -1
  212. package/lib/vxe-ui/index.min.js +1 -1
  213. package/lib/vxe-upload/index.js +2 -1
  214. package/lib/vxe-upload/index.min.js +1 -1
  215. package/lib/vxe-watermark/index.js +2 -1
  216. package/lib/vxe-watermark/index.min.js +1 -1
  217. package/package.json +89 -89
  218. package/packages/alert/index.ts +16 -16
  219. package/packages/alert/src/alert.ts +106 -106
  220. package/packages/anchor/index.ts +16 -16
  221. package/packages/anchor/src/anchor-link.ts +158 -158
  222. package/packages/anchor/src/anchor.ts +267 -267
  223. package/packages/anchor/src/util.ts +23 -23
  224. package/packages/anchor-link/index.ts +16 -16
  225. package/packages/avatar/index.ts +16 -16
  226. package/packages/avatar/src/avatar.ts +141 -141
  227. package/packages/backtop/index.ts +16 -16
  228. package/packages/backtop/src/backtop.ts +330 -330
  229. package/packages/badge/index.ts +16 -16
  230. package/packages/badge/src/badge.ts +87 -87
  231. package/packages/breadcrumb/index.ts +16 -16
  232. package/packages/breadcrumb/src/breadcrumb-item.ts +118 -118
  233. package/packages/breadcrumb/src/breadcrumb.ts +89 -89
  234. package/packages/breadcrumb-item/index.ts +16 -16
  235. package/packages/button/index.ts +16 -16
  236. package/packages/button/src/button-group.ts +113 -113
  237. package/packages/button/src/button.ts +955 -955
  238. package/packages/button-group/index.ts +16 -16
  239. package/packages/calendar/index.ts +16 -16
  240. package/packages/calendar/src/calendar.ts +1527 -1527
  241. package/packages/card/index.ts +16 -16
  242. package/packages/card/src/card.ts +162 -162
  243. package/packages/carousel/index.ts +16 -16
  244. package/packages/carousel/src/carousel-item.ts +117 -117
  245. package/packages/carousel/src/carousel.ts +460 -460
  246. package/packages/carousel/src/util.ts +21 -21
  247. package/packages/carousel-item/index.ts +16 -16
  248. package/packages/cascader/index.ts +16 -16
  249. package/packages/cascader/src/cascader.ts +941 -941
  250. package/packages/checkbox/index.ts +16 -16
  251. package/packages/checkbox/src/button.ts +185 -185
  252. package/packages/checkbox/src/checkbox.ts +189 -189
  253. package/packages/checkbox/src/group.ts +259 -259
  254. package/packages/checkbox-button/index.ts +16 -16
  255. package/packages/checkbox-group/index.ts +16 -16
  256. package/packages/col/index.ts +16 -16
  257. package/packages/collapse/index.ts +16 -16
  258. package/packages/collapse/src/collapse-pane.ts +136 -136
  259. package/packages/collapse/src/collapse.ts +259 -259
  260. package/packages/collapse/src/util.ts +21 -21
  261. package/packages/collapse-pane/index.ts +16 -16
  262. package/packages/color-picker/index.ts +16 -16
  263. package/packages/color-picker/src/color-picker.ts +1277 -1277
  264. package/packages/color-picker/src/util.ts +198 -198
  265. package/packages/components.ts +307 -307
  266. package/packages/context-menu/index.ts +54 -54
  267. package/packages/context-menu/src/context-menu.ts +709 -709
  268. package/packages/countdown/index.ts +16 -16
  269. package/packages/countdown/src/countdown.ts +276 -276
  270. package/packages/date-panel/index.ts +16 -16
  271. package/packages/date-panel/src/date-panel.ts +2024 -2024
  272. package/packages/date-panel/src/util.ts +244 -244
  273. package/packages/date-picker/index.ts +17 -17
  274. package/packages/date-picker/src/date-picker.ts +1238 -1238
  275. package/packages/date-range-picker/index.ts +16 -16
  276. package/packages/date-range-picker/src/date-range-picker.ts +1466 -1466
  277. package/packages/drawer/index.ts +87 -87
  278. package/packages/drawer/src/drawer.ts +767 -767
  279. package/packages/dynamics/index.ts +125 -125
  280. package/packages/empty/index.ts +16 -16
  281. package/packages/empty/src/empty.ts +80 -80
  282. package/packages/form/index.ts +16 -16
  283. package/packages/form/render/index.ts +617 -617
  284. package/packages/form/src/form-config-item.ts +86 -86
  285. package/packages/form/src/form-group.ts +125 -125
  286. package/packages/form/src/form-item.ts +217 -217
  287. package/packages/form/src/form.ts +1032 -1032
  288. package/packages/form/src/itemInfo.ts +80 -80
  289. package/packages/form/src/render.ts +398 -398
  290. package/packages/form/src/util.ts +92 -92
  291. package/packages/form-gather/index.ts +18 -18
  292. package/packages/form-group/index.ts +16 -16
  293. package/packages/form-item/index.ts +16 -16
  294. package/packages/icon/index.ts +16 -16
  295. package/packages/icon/src/icon.ts +75 -75
  296. package/packages/icon-picker/index.ts +16 -16
  297. package/packages/icon-picker/src/icon-picker.ts +752 -752
  298. package/packages/image/index.ts +16 -16
  299. package/packages/image/src/group.ts +162 -162
  300. package/packages/image/src/image.ts +286 -286
  301. package/packages/image/src/preview.ts +737 -737
  302. package/packages/image/src/util.ts +62 -62
  303. package/packages/image-group/index.ts +16 -16
  304. package/packages/image-preview/index.ts +19 -19
  305. package/packages/index.ts +8 -8
  306. package/packages/input/index.ts +16 -16
  307. package/packages/input/src/input.ts +3187 -3187
  308. package/packages/language/ar-EG.ts +832 -832
  309. package/packages/language/de-DE.ts +832 -832
  310. package/packages/language/en-US.ts +832 -832
  311. package/packages/language/es-ES.ts +832 -832
  312. package/packages/language/fr-FR.ts +832 -832
  313. package/packages/language/hu-HU.ts +832 -832
  314. package/packages/language/hy-AM.ts +832 -832
  315. package/packages/language/id-ID.ts +832 -832
  316. package/packages/language/it-IT.ts +832 -832
  317. package/packages/language/ja-JP.ts +832 -832
  318. package/packages/language/ko-KR.ts +832 -832
  319. package/packages/language/ms-MY.ts +832 -832
  320. package/packages/language/nb-NO.ts +832 -832
  321. package/packages/language/pt-BR.ts +832 -832
  322. package/packages/language/ru-RU.ts +832 -832
  323. package/packages/language/th-TH.ts +832 -832
  324. package/packages/language/ug-CN.ts +832 -832
  325. package/packages/language/uk-UA.ts +832 -832
  326. package/packages/language/uz-UZ.ts +832 -832
  327. package/packages/language/vi-VN.ts +832 -832
  328. package/packages/language/zh-CHT.ts +832 -832
  329. package/packages/language/zh-CN.ts +832 -832
  330. package/packages/language/zh-HK.ts +3 -3
  331. package/packages/language/zh-MO.ts +3 -3
  332. package/packages/language/zh-TC.ts +3 -3
  333. package/packages/language/zh-TW.ts +3 -3
  334. package/packages/layout-aside/index.ts +16 -16
  335. package/packages/layout-aside/src/layout-aside.ts +115 -115
  336. package/packages/layout-body/index.ts +16 -16
  337. package/packages/layout-body/src/layout-body.ts +137 -137
  338. package/packages/layout-container/index.ts +16 -16
  339. package/packages/layout-container/src/layout-container.ts +65 -65
  340. package/packages/layout-footer/index.ts +16 -16
  341. package/packages/layout-footer/src/layout-footer.ts +53 -53
  342. package/packages/layout-header/index.ts +16 -16
  343. package/packages/layout-header/src/layout-header.ts +49 -49
  344. package/packages/link/index.ts +16 -16
  345. package/packages/link/src/link.ts +153 -153
  346. package/packages/list/index.ts +16 -16
  347. package/packages/list/src/list.ts +492 -492
  348. package/packages/loading/index.ts +34 -34
  349. package/packages/loading/src/loading.ts +162 -162
  350. package/packages/mention/index.ts +16 -16
  351. package/packages/mention/src/mention.ts +54 -54
  352. package/packages/menu/index.ts +16 -16
  353. package/packages/menu/src/menu.ts +632 -632
  354. package/packages/modal/index.ts +150 -150
  355. package/packages/modal/src/modal.ts +1657 -1657
  356. package/packages/notice-bar/index.ts +16 -16
  357. package/packages/notice-bar/src/notice-bar.ts +182 -182
  358. package/packages/number-input/index.ts +16 -16
  359. package/packages/number-input/src/number-input.ts +1255 -1255
  360. package/packages/number-input/src/util.ts +12 -12
  361. package/packages/optgroup/index.ts +16 -16
  362. package/packages/option/index.ts +16 -16
  363. package/packages/pager/index.ts +16 -16
  364. package/packages/pager/src/pager.ts +913 -913
  365. package/packages/password-input/index.ts +16 -16
  366. package/packages/password-input/src/password-input.ts +466 -466
  367. package/packages/print/index.ts +18 -18
  368. package/packages/print/src/page-break.ts +78 -78
  369. package/packages/print/src/print.ts +266 -266
  370. package/packages/print/src/util.ts +284 -284
  371. package/packages/print-page-break/index.ts +14 -14
  372. package/packages/pulldown/index.ts +16 -16
  373. package/packages/pulldown/src/pulldown.ts +532 -532
  374. package/packages/radio/index.ts +16 -16
  375. package/packages/radio/src/button.ts +221 -221
  376. package/packages/radio/src/group.ts +252 -252
  377. package/packages/radio/src/radio.ts +228 -228
  378. package/packages/radio-button/index.ts +16 -16
  379. package/packages/radio-group/index.ts +16 -16
  380. package/packages/rate/index.ts +16 -16
  381. package/packages/rate/src/rate.ts +199 -199
  382. package/packages/result/index.ts +16 -16
  383. package/packages/result/src/result.ts +93 -93
  384. package/packages/row/index.ts +16 -16
  385. package/packages/row/src/col.ts +130 -130
  386. package/packages/row/src/row.ts +106 -106
  387. package/packages/segmented/index.ts +16 -16
  388. package/packages/segmented/src/segmented.ts +281 -281
  389. package/packages/select/index.ts +16 -16
  390. package/packages/select/src/optgroup.ts +107 -107
  391. package/packages/select/src/option-info.ts +20 -20
  392. package/packages/select/src/option.ts +103 -103
  393. package/packages/select/src/select.ts +2000 -2000
  394. package/packages/select/src/util.ts +47 -47
  395. package/packages/slider/index.ts +16 -16
  396. package/packages/slider/src/slider.ts +332 -332
  397. package/packages/split/index.ts +16 -16
  398. package/packages/split-pane/index.ts +17 -17
  399. package/packages/splitter/index.ts +16 -16
  400. package/packages/splitter/src/splitter-panel.ts +171 -171
  401. package/packages/splitter/src/splitter.ts +1032 -1032
  402. package/packages/splitter/src/util.ts +21 -21
  403. package/packages/splitter-panel/index.ts +16 -16
  404. package/packages/steps/index.ts +16 -16
  405. package/packages/steps/src/steps.ts +57 -57
  406. package/packages/switch/index.ts +16 -16
  407. package/packages/switch/src/switch.ts +279 -279
  408. package/packages/tab-pane/index.ts +16 -16
  409. package/packages/table-select/index.ts +16 -16
  410. package/packages/table-select/src/table-select.ts +903 -903
  411. package/packages/tabs/index.ts +16 -16
  412. package/packages/tabs/src/tab-pane.ts +137 -137
  413. package/packages/tabs/src/tabs.ts +1014 -1014
  414. package/packages/tabs/src/util.ts +21 -21
  415. package/packages/tag/index.ts +16 -16
  416. package/packages/tag/src/tag.ts +195 -195
  417. package/packages/text/index.ts +16 -16
  418. package/packages/text/src/text.ts +267 -267
  419. package/packages/text-ellipsis/index.ts +16 -16
  420. package/packages/text-ellipsis/src/text-ellipsis.ts +291 -291
  421. package/packages/textarea/index.ts +16 -16
  422. package/packages/textarea/src/textarea.ts +436 -436
  423. package/packages/timeline/index.ts +16 -16
  424. package/packages/timeline/src/timeline-item.ts +41 -41
  425. package/packages/timeline/src/timeline.ts +54 -54
  426. package/packages/timeline-item/index.ts +16 -16
  427. package/packages/tip/index.ts +19 -19
  428. package/packages/tip/src/tip.ts +112 -112
  429. package/packages/tooltip/index.ts +16 -16
  430. package/packages/tooltip/src/tooltip.ts +641 -641
  431. package/packages/tour/index.ts +16 -16
  432. package/packages/tour/src/tour.ts +54 -54
  433. package/packages/tree/index.ts +16 -16
  434. package/packages/tree/src/store.ts +15 -15
  435. package/packages/tree/src/tree.ts +3080 -3080
  436. package/packages/tree/src/util.ts +44 -44
  437. package/packages/tree-select/index.ts +16 -16
  438. package/packages/tree-select/src/tree-select.ts +1115 -1115
  439. package/packages/ui/index.ts +695 -695
  440. package/packages/ui/src/anime.ts +52 -52
  441. package/packages/ui/src/comp.ts +3 -3
  442. package/packages/ui/src/dom.ts +263 -263
  443. package/packages/ui/src/log.ts +6 -6
  444. package/packages/ui/src/utils.ts +49 -49
  445. package/packages/ui/src/vn.ts +60 -60
  446. package/packages/upload/index.ts +20 -20
  447. package/packages/upload/src/upload.ts +2127 -2127
  448. package/packages/upload/src/util.ts +109 -109
  449. package/packages/vxe-u-i/index.ts +4 -4
  450. package/packages/watermark/index.ts +31 -31
  451. package/packages/watermark/src/util.ts +176 -176
  452. package/packages/watermark/src/watermark.ts +166 -166
  453. package/styles/all.scss +90 -90
  454. package/styles/base.scss +16 -16
  455. package/styles/components/alert.scss +101 -101
  456. package/styles/components/anchor.scss +44 -44
  457. package/styles/components/avatar.scss +115 -115
  458. package/styles/components/backtop.scss +82 -82
  459. package/styles/components/badge.scss +45 -45
  460. package/styles/components/breadcrumb.scss +29 -29
  461. package/styles/components/button-group.scss +30 -30
  462. package/styles/components/button.scss +415 -415
  463. package/styles/components/calendar.scss +471 -471
  464. package/styles/components/card.scss +121 -121
  465. package/styles/components/carousel.scss +184 -184
  466. package/styles/components/cascader.scss +140 -140
  467. package/styles/components/checkbox-button.scss +57 -57
  468. package/styles/components/checkbox.scss +81 -81
  469. package/styles/components/collapse.scss +56 -56
  470. package/styles/components/color-picker.scss +409 -409
  471. package/styles/components/context-menu.scss +102 -102
  472. package/styles/components/countdown.scss +35 -35
  473. package/styles/components/date-panel.scss +505 -505
  474. package/styles/components/date-picker.scss +247 -247
  475. package/styles/components/date-range-picker.scss +252 -252
  476. package/styles/components/drawer.scss +298 -298
  477. package/styles/components/empty.scss +79 -79
  478. package/styles/components/form.scss +668 -668
  479. package/styles/components/icon-picker.scss +211 -211
  480. package/styles/components/icon.scss +1044 -1044
  481. package/styles/components/image-group.scss +2 -2
  482. package/styles/components/image-preview.scss +215 -215
  483. package/styles/components/image.scss +16 -16
  484. package/styles/components/input.scss +846 -846
  485. package/styles/components/layout-aside.scss +22 -22
  486. package/styles/components/layout-body.scss +14 -14
  487. package/styles/components/layout-container.scss +13 -13
  488. package/styles/components/layout-footer.scss +14 -14
  489. package/styles/components/layout-header.scss +11 -11
  490. package/styles/components/link.scss +115 -115
  491. package/styles/components/list.scss +40 -40
  492. package/styles/components/loading.scss +137 -137
  493. package/styles/components/menu.scss +150 -150
  494. package/styles/components/modal.scss +480 -480
  495. package/styles/components/notice-bar.scss +91 -91
  496. package/styles/components/number-input.scss +283 -283
  497. package/styles/components/old-icon.scss +4 -4
  498. package/styles/components/pager.scss +282 -282
  499. package/styles/components/password-input.scss +374 -374
  500. package/styles/components/print.scss +3 -3
  501. package/styles/components/pulldown.scss +75 -75
  502. package/styles/components/radio-button.scss +57 -57
  503. package/styles/components/radio.scss +79 -79
  504. package/styles/components/rate.scss +76 -76
  505. package/styles/components/result.scss +91 -91
  506. package/styles/components/row.scss +69 -69
  507. package/styles/components/segmented.scss +215 -215
  508. package/styles/components/select.scss +244 -244
  509. package/styles/components/slider.scss +139 -139
  510. package/styles/components/split.scss +1 -1
  511. package/styles/components/splitter.scss +318 -318
  512. package/styles/components/switch.scss +128 -128
  513. package/styles/components/table-select.scss +105 -105
  514. package/styles/components/tabs.scss +745 -745
  515. package/styles/components/tag.scss +184 -184
  516. package/styles/components/text-ellipsis.scss +130 -130
  517. package/styles/components/text.scss +123 -123
  518. package/styles/components/textarea.scss +106 -106
  519. package/styles/components/tip.scss +97 -97
  520. package/styles/components/tooltip.scss +140 -140
  521. package/styles/components/tree-select.scss +166 -166
  522. package/styles/components/tree.scss +294 -294
  523. package/styles/components/upload.scss +497 -497
  524. package/styles/components/watermark.scss +26 -26
  525. package/styles/helpers/baseMixin.scss +95 -95
  526. package/styles/helpers/baseVar.scss +3 -3
  527. package/styles/helpers/placement.scss +38 -38
  528. package/styles/theme/base.scss +214 -214
  529. package/styles/theme/dark.scss +119 -119
  530. package/styles/theme/light.scss +118 -118
  531. package/styles/variable.scss +111 -111
  532. package/types/all.d.ts +328 -328
  533. package/types/components/alert.d.ts +80 -80
  534. package/types/components/anchor-link.d.ts +84 -84
  535. package/types/components/anchor.d.ts +84 -84
  536. package/types/components/avatar.d.ts +81 -81
  537. package/types/components/backtop.d.ts +115 -115
  538. package/types/components/badge.d.ts +69 -69
  539. package/types/components/breadcrumb-item.d.ts +73 -73
  540. package/types/components/breadcrumb.d.ts +80 -80
  541. package/types/components/button-group.d.ts +113 -113
  542. package/types/components/button.d.ts +314 -314
  543. package/types/components/calendar.d.ts +254 -254
  544. package/types/components/card.d.ts +86 -86
  545. package/types/components/carousel-item.d.ts +68 -68
  546. package/types/components/carousel.d.ts +126 -126
  547. package/types/components/cascader.d.ts +242 -242
  548. package/types/components/checkbox-button.d.ts +93 -93
  549. package/types/components/checkbox-group.d.ts +135 -135
  550. package/types/components/checkbox.d.ts +115 -115
  551. package/types/components/col.d.ts +73 -73
  552. package/types/components/colgroup.d.ts +131 -131
  553. package/types/components/collapse-pane.d.ts +82 -82
  554. package/types/components/collapse.d.ts +115 -115
  555. package/types/components/color-picker.d.ts +127 -127
  556. package/types/components/column.d.ts +852 -852
  557. package/types/components/context-menu.d.ts +300 -300
  558. package/types/components/countdown.d.ts +99 -99
  559. package/types/components/date-panel.d.ts +269 -269
  560. package/types/components/date-picker.d.ts +302 -302
  561. package/types/components/date-range-picker.d.ts +316 -316
  562. package/types/components/drawer.d.ts +295 -295
  563. package/types/components/empty.d.ts +71 -71
  564. package/types/components/flow-design.d.ts +78 -78
  565. package/types/components/flow-view.d.ts +78 -78
  566. package/types/components/form-design.d.ts +364 -364
  567. package/types/components/form-gather.d.ts +72 -72
  568. package/types/components/form-group.d.ts +63 -63
  569. package/types/components/form-item.d.ts +405 -405
  570. package/types/components/form-view.d.ts +175 -175
  571. package/types/components/form.d.ts +463 -463
  572. package/types/components/gantt-module/gantt-view.d.ts +170 -170
  573. package/types/components/gantt-module/index.d.ts +1 -1
  574. package/types/components/gantt-plugins/extend-gantt-chart.d.ts +114 -114
  575. package/types/components/gantt-plugins/index.d.ts +1 -1
  576. package/types/components/gantt.d.ts +1129 -1129
  577. package/types/components/grid.d.ts +1030 -1030
  578. package/types/components/icon-picker.d.ts +181 -181
  579. package/types/components/icon.d.ts +80 -80
  580. package/types/components/image-group.d.ts +120 -120
  581. package/types/components/image-preview.d.ts +159 -159
  582. package/types/components/image.d.ts +158 -158
  583. package/types/components/input.d.ts +425 -425
  584. package/types/components/layout-aside.d.ts +73 -73
  585. package/types/components/layout-body.d.ts +84 -84
  586. package/types/components/layout-container.d.ts +66 -66
  587. package/types/components/layout-footer.d.ts +66 -66
  588. package/types/components/layout-header.d.ts +64 -64
  589. package/types/components/link.d.ts +104 -104
  590. package/types/components/list-design.d.ts +177 -177
  591. package/types/components/list-view.d.ts +190 -190
  592. package/types/components/list.d.ts +196 -196
  593. package/types/components/loading.d.ts +96 -96
  594. package/types/components/mention.d.ts +70 -70
  595. package/types/components/menu.d.ts +203 -203
  596. package/types/components/modal.d.ts +540 -540
  597. package/types/components/notice-bar.d.ts +95 -95
  598. package/types/components/number-input.d.ts +300 -300
  599. package/types/components/optgroup.d.ts +81 -81
  600. package/types/components/option.d.ts +95 -95
  601. package/types/components/pager.d.ts +322 -322
  602. package/types/components/password-input.d.ts +129 -129
  603. package/types/components/print-page-break.d.ts +62 -62
  604. package/types/components/print.d.ts +199 -199
  605. package/types/components/pulldown.d.ts +222 -222
  606. package/types/components/radio-button.d.ts +104 -104
  607. package/types/components/radio-group.d.ts +136 -136
  608. package/types/components/radio.d.ts +121 -121
  609. package/types/components/rate.d.ts +75 -75
  610. package/types/components/result.d.ts +77 -77
  611. package/types/components/row.d.ts +72 -72
  612. package/types/components/segmented.d.ts +117 -117
  613. package/types/components/select.d.ts +515 -515
  614. package/types/components/slider.d.ts +117 -117
  615. package/types/components/split-pane.d.ts +135 -135
  616. package/types/components/split.d.ts +318 -318
  617. package/types/components/splitter-panel.d.ts +98 -98
  618. package/types/components/splitter.d.ts +283 -283
  619. package/types/components/steps.d.ts +61 -61
  620. package/types/components/switch.d.ts +124 -124
  621. package/types/components/tab-pane.d.ts +107 -107
  622. package/types/components/table-module/custom.d.ts +111 -111
  623. package/types/components/table-module/edit.d.ts +244 -244
  624. package/types/components/table-module/export.d.ts +96 -96
  625. package/types/components/table-module/filter.d.ts +140 -140
  626. package/types/components/table-module/index.d.ts +7 -7
  627. package/types/components/table-module/keyboard.d.ts +26 -26
  628. package/types/components/table-module/menu.d.ts +26 -26
  629. package/types/components/table-module/validator.d.ts +53 -53
  630. package/types/components/table-plugins/extend-cell-area.d.ts +734 -734
  631. package/types/components/table-plugins/extend-pivot-table.d.ts +62 -62
  632. package/types/components/table-plugins/filters-combination.d.ts +15 -15
  633. package/types/components/table-plugins/filters-complex-input.d.ts +9 -9
  634. package/types/components/table-plugins/index.d.ts +4 -4
  635. package/types/components/table-select.d.ts +212 -212
  636. package/types/components/table.d.ts +7222 -7206
  637. package/types/components/tabs.d.ts +324 -324
  638. package/types/components/tag.d.ts +107 -107
  639. package/types/components/text-ellipsis.d.ts +105 -105
  640. package/types/components/text.d.ts +115 -115
  641. package/types/components/textarea.d.ts +237 -237
  642. package/types/components/timeline-item.d.ts +68 -68
  643. package/types/components/timeline.d.ts +70 -70
  644. package/types/components/tip.d.ts +76 -76
  645. package/types/components/toolbar.d.ts +329 -329
  646. package/types/components/tooltip.d.ts +165 -165
  647. package/types/components/tour.d.ts +70 -70
  648. package/types/components/tree-select.d.ts +295 -295
  649. package/types/components/tree.d.ts +826 -826
  650. package/types/components/upload.d.ts +432 -432
  651. package/types/components/watermark.d.ts +113 -113
  652. package/types/index.d.ts +4 -4
  653. package/types/ui/commands.d.ts +57 -57
  654. package/types/ui/formats.d.ts +62 -62
  655. package/types/ui/global-config.d.ts +254 -254
  656. package/types/ui/global-icon.d.ts +292 -292
  657. package/types/ui/hooks.d.ts +11 -11
  658. package/types/ui/index.d.ts +95 -95
  659. package/types/ui/interceptor.d.ts +54 -54
  660. package/types/ui/menus.d.ts +77 -77
  661. package/types/ui/renderer.d.ts +1042 -1042
  662. package/types/ui/validators.d.ts +38 -38
  663. /package/es/icon/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  664. /package/es/icon/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  665. /package/es/icon/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  666. /package/es/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  667. /package/es/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  668. /package/es/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  669. /package/lib/icon/style/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  670. /package/lib/icon/style/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  671. /package/lib/icon/style/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  672. /package/lib/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  673. /package/lib/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  674. /package/lib/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
@@ -1,955 +1,955 @@
1
- import { CreateElement, VNode, PropType } from 'vue'
2
- import XEUtils from 'xe-utils'
3
- import { getConfig, globalEvents, getIcon, createEvent, renderer, globalMixins, permission, renderEmptyElement } from '../../ui'
4
- import { defineVxeComponent } from '../../ui/src/comp'
5
- import { getEventTargetNode, updatePanelPlacement } from '../../ui/src/dom'
6
- import { getFuncText, getLastZIndex, nextZIndex } from '../../ui/src/utils'
7
- import { getSlotVNs, getEventCaseName } from '../../ui/src/vn'
8
- import { warnLog } from '../../ui/src/log'
9
- import VxeTooltipComponent from '../../tooltip'
10
-
11
- import type { VxeButtonPropTypes, VxeButtonEmits, ButtonReactData, VxeButtonGroupConstructor, ButtonInternalData, VxeButtonDefines, VxeButtonGroupPrivateMethods, VxeFormConstructor, VxeDrawerConstructor, VxeDrawerMethods, VxeFormPrivateMethods, VxeModalConstructor, VxeModalMethods, VxeComponentPermissionInfo, VxeComponentSizeType, ValueOf, VxeTreeConstructor, VxeTreePrivateMethods } from '../../../types'
12
- import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
13
-
14
- export default /* define-vxe-component start */ defineVxeComponent({
15
- name: 'VxeButton',
16
- mixins: [
17
- globalMixins.sizeMixin,
18
- globalMixins.permissionMixin
19
- ],
20
- props: {
21
- /**
22
- * 按钮类型
23
- */
24
- type: String as PropType<VxeButtonPropTypes.Type>,
25
- mode: String as PropType<VxeButtonPropTypes.Mode>,
26
- className: [String, Function] as PropType<VxeButtonPropTypes.ClassName>,
27
- popupClassName: [String, Function] as PropType<VxeButtonPropTypes.PopupClassName>,
28
- /**
29
- * 按钮尺寸
30
- */
31
- size: {
32
- type: String as PropType<VxeButtonPropTypes.Size>,
33
- default: () => getConfig().button.size || getConfig().size
34
- },
35
- zIndex: Number as PropType<VxeButtonPropTypes.ZIndex>,
36
- /**
37
- * 用来标识这一项
38
- */
39
- name: [String, Number] as PropType<VxeButtonPropTypes.Name>,
40
- routerLink: Object as PropType<VxeButtonPropTypes.RouterLink>,
41
- /**
42
- * 权限码
43
- */
44
- permissionCode: [String, Number] as PropType<VxeButtonPropTypes.PermissionCode>,
45
- /**
46
- * 按钮内容
47
- */
48
- content: String as PropType<VxeButtonPropTypes.Content>,
49
- /**
50
- * 固定显示下拉面板的方向
51
- */
52
- placement: String as PropType<VxeButtonPropTypes.Placement>,
53
- /**
54
- * 按钮状态
55
- */
56
- status: String as PropType<VxeButtonPropTypes.Status>,
57
- /**
58
- * 标题
59
- */
60
- title: String as PropType<VxeButtonPropTypes.Title>,
61
- shadow: Boolean as PropType<VxeButtonPropTypes.Shadow>,
62
- /**
63
- * 按钮的前缀图标,属于 prefix-icon 的简写
64
- */
65
- icon: String as PropType<VxeButtonPropTypes.Icon>,
66
- iconRender: Object as PropType<VxeButtonPropTypes.IconRender>,
67
- /**
68
- * 按钮的前缀图标
69
- */
70
- prefixIcon: String as PropType<VxeButtonPropTypes.PrefixIcon>,
71
- prefixRender: Object as PropType<VxeButtonPropTypes.PrefixRender>,
72
- /**
73
- * 按钮的后缀图标
74
- */
75
- suffixIcon: String as PropType<VxeButtonPropTypes.SuffixIcon>,
76
- suffixRender: Object as PropType<VxeButtonPropTypes.SuffixRender>,
77
- /**
78
- * 圆角边框
79
- */
80
- round: Boolean as PropType<VxeButtonPropTypes.Round>,
81
- /**
82
- * 圆角按钮
83
- */
84
- circle: Boolean as PropType<VxeButtonPropTypes.Circle>,
85
- /**
86
- * 是否禁用
87
- */
88
- disabled: Boolean as PropType<VxeButtonPropTypes.Disabled>,
89
- /**
90
- * 是否加载中
91
- */
92
- loading: Boolean as PropType<VxeButtonPropTypes.Loading>,
93
- trigger: {
94
- type: String as PropType<VxeButtonPropTypes.Trigger>,
95
- default: () => getConfig().button.trigger
96
- },
97
- align: String as PropType<VxeButtonPropTypes.Align>,
98
- prefixTooltip: Object as PropType<VxeButtonPropTypes.PrefixTooltip>,
99
- suffixTooltip: Object as PropType<VxeButtonPropTypes.SuffixTooltip>,
100
- options: Array as PropType<VxeButtonPropTypes.Options>,
101
- showDropdownIcon: {
102
- type: Boolean,
103
- default: () => getConfig().button.showDropdownIcon
104
- },
105
- /**
106
- * 在下拉面板关闭时销毁内容
107
- */
108
- destroyOnClose: {
109
- type: Boolean as PropType<VxeButtonPropTypes.DestroyOnClose>,
110
- default: () => getConfig().button.destroyOnClose
111
- },
112
- popupConfig: Object as PropType<VxeButtonPropTypes.PopupConfig>,
113
- /**
114
- * 是否将弹框容器插入于 body 内
115
- */
116
- transfer: {
117
- type: Boolean as PropType<VxeButtonPropTypes.Transfer>,
118
- default: null
119
- }
120
- },
121
- inject: {
122
- $xeModal: {
123
- default: null
124
- },
125
- $xeDrawer: {
126
- default: null
127
- },
128
- $xeTable: {
129
- default: null
130
- },
131
- $xeTree: {
132
- default: null
133
- },
134
- $xeForm: {
135
- default: null
136
- },
137
- $xeButtonGroup: {
138
- default: null
139
- }
140
- },
141
- data () {
142
- const reactData: ButtonReactData = {
143
- initialized: false,
144
- visiblePanel: false,
145
- isAniVisible: false,
146
- isActivated: false,
147
- panelIndex: 0,
148
- panelStyle: {},
149
- panelPlacement: ''
150
- }
151
- const internalData: ButtonInternalData = {
152
- showTime: undefined
153
- }
154
- return {
155
- xID: XEUtils.uniqueId(),
156
- reactData,
157
- internalData
158
- }
159
- },
160
- computed: {
161
- ...({} as {
162
- computePermissionInfo(): VxeComponentPermissionInfo
163
- computeSize(): VxeComponentSizeType
164
- $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
165
- $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
166
- $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
167
- $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
168
- $xeTree(): (VxeTreeConstructor & VxeTreePrivateMethods) | null
169
- $xeButtonGroup(): (VxeButtonGroupConstructor & VxeButtonGroupPrivateMethods)| null
170
- }),
171
- computeBtnTransfer () {
172
- const $xeButton = this
173
- const props = $xeButton
174
- const $xeTable = $xeButton.$xeTable
175
- const $xeTree = $xeButton.$xeTree
176
- const $xeModal = $xeButton.$xeModal
177
- const $xeDrawer = $xeButton.$xeDrawer
178
- const $xeForm = $xeButton.$xeForm
179
-
180
- const { transfer } = props
181
- const popupOpts = $xeButton.computePopupOpts as VxeButtonPropTypes.PopupConfig
182
- if (XEUtils.isBoolean(popupOpts.transfer)) {
183
- return popupOpts.transfer
184
- }
185
- if (transfer === null) {
186
- const globalTransfer = getConfig().button.transfer
187
- if (XEUtils.isBoolean(globalTransfer)) {
188
- return globalTransfer
189
- }
190
- if ($xeTable || $xeTree || $xeModal || $xeDrawer || $xeForm) {
191
- return true
192
- }
193
- }
194
- return transfer
195
- },
196
- computeBtnDisabled () {
197
- const $xeButton = this
198
- const props = $xeButton
199
-
200
- const { disabled } = props
201
- const permissionInfo = $xeButton.computePermissionInfo
202
- return disabled || permissionInfo.disabled
203
- },
204
- computeIsFormBtn () {
205
- const $xeButton = this
206
- const props = $xeButton
207
-
208
- const { type } = props
209
- if (type) {
210
- return ['submit', 'reset', 'button'].indexOf(type) > -1
211
- }
212
- return false
213
- },
214
- computeBtnMode () {
215
- const $xeButton = this
216
- const props = $xeButton
217
-
218
- const { type, mode } = props
219
- const $xeButtonGroup = $xeButton.$xeButtonGroup
220
- if (mode === 'text' || type === 'text' || ($xeButtonGroup && $xeButtonGroup.mode === 'text')) {
221
- return 'text'
222
- }
223
- return 'button'
224
- },
225
- computeBtnStatus () {
226
- const $xeButton = this
227
- const props = $xeButton
228
-
229
- const { status } = props
230
- const $xeButtonGroup = $xeButton.$xeButtonGroup
231
- if (status) {
232
- return status
233
- }
234
- if ($xeButtonGroup) {
235
- return $xeButtonGroup.status
236
- }
237
- return ''
238
- },
239
- computeBtnRound () {
240
- const $xeButton = this
241
- const props = $xeButton
242
-
243
- const { round } = props
244
- const $xeButtonGroup = $xeButton.$xeButtonGroup
245
- if (round) {
246
- return round
247
- }
248
- if ($xeButtonGroup) {
249
- return $xeButtonGroup.round
250
- }
251
- return false
252
- },
253
- computeBtnAlign () {
254
- const $xeButton = this
255
- const props = $xeButton
256
-
257
- const { align } = props
258
- const $xeButtonGroup = $xeButton.$xeButtonGroup
259
- if (align) {
260
- return align
261
- }
262
- if ($xeButtonGroup) {
263
- return $xeButtonGroup.align
264
- }
265
- return false
266
- },
267
- computeBtnCircle () {
268
- const $xeButton = this
269
- const props = $xeButton
270
-
271
- const { circle } = props
272
- const $xeButtonGroup = $xeButton.$xeButtonGroup
273
- if (circle) {
274
- return circle
275
- }
276
- if ($xeButtonGroup) {
277
- return $xeButtonGroup.circle
278
- }
279
- return false
280
- },
281
- computeDownBtnList () {
282
- const $xeButton = this
283
- const props = $xeButton
284
-
285
- const { options } = props
286
- if (options) {
287
- return options.filter(item => {
288
- const { permissionCode } = item
289
- return !permissionCode || permission.checkVisible(permissionCode)
290
- })
291
- }
292
- return []
293
- },
294
- computePopupOpts () {
295
- const $xeButton = this
296
- const props = $xeButton
297
-
298
- return Object.assign({}, getConfig().button.popupConfig, props.popupConfig)
299
- },
300
- computePrefixTipOpts () {
301
- const $xeButton = this
302
- const props = $xeButton
303
-
304
- return Object.assign({}, getConfig().button.prefixTooltip, props.prefixTooltip)
305
- },
306
- computeSuffixTipOpts () {
307
- const $xeButton = this
308
- const props = $xeButton
309
-
310
- return Object.assign({}, getConfig().button.suffixTooltip, props.suffixTooltip)
311
- }
312
- },
313
- methods: {
314
- //
315
- // methods
316
- //
317
- dispatchEvent (type: ValueOf<VxeButtonEmits>, params: Record<string, any>, evnt: Event | null) {
318
- const $xeButton = this
319
- $xeButton.$emit(getEventCaseName($xeButton, type), createEvent(evnt, { $button: $xeButton }, params))
320
- },
321
- openPanel () {
322
- const $xeButton = this
323
- const props = $xeButton
324
- const reactData = $xeButton.reactData
325
- const internalData = $xeButton.internalData
326
-
327
- const { trigger } = props
328
- const btnTransfer = $xeButton.computeBtnTransfer
329
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
330
- if (panelElem) {
331
- panelElem.dataset.active = 'Y'
332
- if (!reactData.initialized) {
333
- reactData.initialized = true
334
- if (btnTransfer) {
335
- document.body.appendChild(panelElem)
336
- }
337
- }
338
- internalData.showTime = setTimeout(() => {
339
- if (panelElem.dataset.active === 'Y') {
340
- $xeButton.mouseenterDropdownEvent()
341
- } else {
342
- reactData.isAniVisible = false
343
- }
344
- }, trigger === 'click' ? 50 : 250)
345
- }
346
- return $xeButton.$nextTick()
347
- },
348
- closePanel () {
349
- const $xeButton = this
350
-
351
- return $xeButton.hidePanel()
352
- },
353
- hidePanel () {
354
- const $xeButton = this
355
- const reactData = $xeButton.reactData
356
- const internalData = $xeButton.internalData
357
-
358
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
359
- clearTimeout(internalData.showTime)
360
- if (panelElem) {
361
- panelElem.dataset.active = 'N'
362
- setTimeout(() => {
363
- if (panelElem.dataset.active !== 'Y') {
364
- reactData.visiblePanel = false
365
- setTimeout(() => {
366
- if (panelElem.dataset.active !== 'Y') {
367
- reactData.isAniVisible = false
368
- }
369
- }, 350)
370
- }
371
- }, 100)
372
- } else {
373
- reactData.isAniVisible = false
374
- reactData.visiblePanel = false
375
- }
376
- return $xeButton.$nextTick()
377
- },
378
- focus () {
379
- const $xeButton = this
380
-
381
- const btnElem = $xeButton.$refs.refButton as HTMLElement | undefined
382
- if (btnElem) {
383
- btnElem.focus()
384
- }
385
- return $xeButton.$nextTick()
386
- },
387
- blur () {
388
- const $xeButton = this
389
-
390
- const btnElem = $xeButton.$refs.refButton as HTMLElement | undefined
391
- if (btnElem) {
392
- btnElem.blur()
393
- }
394
- return $xeButton.$nextTick()
395
- },
396
-
397
- //
398
- // privateMethods
399
- //
400
- updateZindex () {
401
- const $xeButton = this
402
- const props = $xeButton
403
- const reactData = $xeButton.reactData
404
-
405
- const popupOpts = $xeButton.computePopupOpts
406
- const customZIndex = popupOpts.zIndex || props.zIndex
407
- if (customZIndex) {
408
- reactData.panelIndex = XEUtils.toNumber(customZIndex)
409
- } else if (reactData.panelIndex < getLastZIndex()) {
410
- reactData.panelIndex = nextZIndex()
411
- }
412
- },
413
- updatePlacement () {
414
- const $xeButton = this
415
- const props = $xeButton
416
- const reactData = $xeButton.reactData
417
-
418
- const { placement } = props
419
- const { panelIndex } = reactData
420
- const targetElem = $xeButton.$refs.refButton as HTMLElement | undefined
421
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
422
- const btnTransfer = $xeButton.computeBtnTransfer
423
- const popupOpts = $xeButton.computePopupOpts
424
- const handleStyle = () => {
425
- const ppObj = updatePanelPlacement(targetElem, panelElem, {
426
- placement: popupOpts.placement || placement,
427
- teleportTo: btnTransfer
428
- })
429
- const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
430
- zIndex: panelIndex
431
- })
432
- reactData.panelStyle = panelStyle
433
- reactData.panelPlacement = ppObj.placement
434
- }
435
- handleStyle()
436
- return $xeButton.$nextTick().then(handleStyle)
437
- },
438
- clickEvent (evnt: Event) {
439
- const $xeButton = this
440
- const props = $xeButton
441
- const $xeButtonGroup = $xeButton.$xeButtonGroup
442
-
443
- if ($xeButtonGroup) {
444
- $xeButtonGroup.handleClick({ name: props.name }, evnt)
445
- }
446
- $xeButton.dispatchEvent('click', { $event: evnt }, evnt)
447
- },
448
- downBtnClickEvent (params: VxeButtonDefines.ClickEventParams, option: VxeButtonDefines.DownButtonOption) {
449
- const $xeButton = this
450
-
451
- const { $event } = params
452
- $xeButton.hidePanel()
453
- $xeButton.dispatchEvent('dropdown-click', { name: option.name, option }, $event)
454
- },
455
- mousedownDropdownEvent (evnt: MouseEvent) {
456
- const isLeftBtn = evnt.button === 0
457
- if (isLeftBtn) {
458
- evnt.stopPropagation()
459
- }
460
- },
461
- clickDropdownEvent (evnt: Event) {
462
- const $xeButton = this
463
- const reactData = $xeButton.reactData
464
-
465
- const dropdownElem = evnt.currentTarget
466
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
467
- const { flag, targetElem } = getEventTargetNode(evnt, dropdownElem, 'vxe-button')
468
- if (flag) {
469
- if (panelElem) {
470
- panelElem.dataset.active = 'N'
471
- }
472
- reactData.visiblePanel = false
473
- setTimeout(() => {
474
- if (!panelElem || panelElem.dataset.active !== 'Y') {
475
- reactData.isAniVisible = false
476
- }
477
- }, 350)
478
- $xeButton.dispatchEvent('dropdown-click', { name: targetElem.getAttribute('name'), option: null, $event: evnt }, evnt)
479
- }
480
- },
481
- mouseenterDropdownEvent () {
482
- const $xeButton = this
483
- const reactData = $xeButton.reactData
484
-
485
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
486
- if (panelElem) {
487
- panelElem.dataset.active = 'Y'
488
- reactData.isAniVisible = true
489
- setTimeout(() => {
490
- if (panelElem.dataset.active === 'Y') {
491
- reactData.visiblePanel = true
492
- $xeButton.updateZindex()
493
- $xeButton.updatePlacement()
494
- setTimeout(() => {
495
- if (reactData.visiblePanel) {
496
- $xeButton.updatePlacement()
497
- }
498
- }, 50)
499
- }
500
- }, 20)
501
- }
502
- },
503
- mouseenterTargetEvent (evnt: MouseEvent) {
504
- const $xeButton = this
505
- const props = $xeButton
506
-
507
- const { loading } = props
508
- const btnDisabled = $xeButton.computeBtnDisabled
509
- if (!(btnDisabled || loading)) {
510
- $xeButton.openPanel()
511
- $xeButton.mouseenterEvent(evnt)
512
- }
513
- },
514
- mouseleaveTargetEvent (evnt: MouseEvent) {
515
- const $xeButton = this
516
-
517
- $xeButton.hidePanel()
518
- $xeButton.mouseleaveEvent(evnt)
519
- },
520
- mouseenterEvent (evnt: MouseEvent) {
521
- const $xeButton = this
522
-
523
- $xeButton.dispatchEvent('mouseenter', {}, evnt)
524
- },
525
- mouseleaveEvent (evnt: MouseEvent) {
526
- const $xeButton = this
527
-
528
- $xeButton.dispatchEvent('mouseleave', {}, evnt)
529
- },
530
- contextmenuEvent (evnt: MouseEvent) {
531
- const $xeButton = this
532
-
533
- $xeButton.dispatchEvent('contextmenu', {}, evnt)
534
- },
535
- clickTargetEvent (evnt: MouseEvent) {
536
- const $xeButton = this
537
- const props = $xeButton
538
- const reactData = $xeButton.reactData
539
-
540
- const { loading } = props
541
- const btnDisabled = $xeButton.computeBtnDisabled
542
- if (!(btnDisabled || loading)) {
543
- const { trigger } = props
544
- if (trigger === 'click') {
545
- if (reactData.visiblePanel) {
546
- $xeButton.hidePanel()
547
- } else {
548
- $xeButton.openPanel()
549
- }
550
- }
551
- $xeButton.clickEvent(evnt)
552
- }
553
- },
554
- mouseleaveDropdownEvent () {
555
- const $xeButton = this
556
-
557
- $xeButton.hidePanel()
558
- },
559
- handleGlobalMousewheelEvent (evnt: Event) {
560
- const $xeButton = this
561
- const reactData = $xeButton.reactData
562
-
563
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
564
- if (reactData.visiblePanel && !getEventTargetNode(evnt, panelElem).flag) {
565
- $xeButton.hidePanel()
566
- }
567
- },
568
- handleGlobalMousedownEvent (evnt: MouseEvent) {
569
- const $xeButton = this
570
- const reactData = $xeButton.reactData
571
-
572
- const btnDisabled = $xeButton.computeBtnDisabled
573
- const { visiblePanel } = reactData
574
- if (!btnDisabled) {
575
- const el = $xeButton.$refs.refElem
576
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
577
- reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
578
- if (visiblePanel && !reactData.isActivated) {
579
- $xeButton.hidePanel()
580
- }
581
- }
582
- },
583
- handleGlobalResizeEvent () {
584
- const $xeButton = this
585
- const reactData = $xeButton.reactData
586
-
587
- const { visiblePanel } = reactData
588
- if (visiblePanel) {
589
- $xeButton.updatePlacement()
590
- }
591
- },
592
-
593
- //
594
- // Render
595
- //
596
- renderTooltipIcon (h: CreateElement, tipOpts: VxeButtonPropTypes.PrefixTooltip | VxeButtonPropTypes.SuffixTooltip, type: 'prefix' | 'suffix') {
597
- return h(VxeTooltipComponent, {
598
- props: {
599
- useHTML: tipOpts.useHTML,
600
- content: tipOpts.content,
601
- enterable: tipOpts.enterable,
602
- theme: tipOpts.theme
603
- },
604
- scopedSlots: {
605
- default: () => {
606
- return h('span', {
607
- class: `vxe-button--item vxe-button--tooltip-${type}-icon`
608
- }, [
609
- h('i', {
610
- class: tipOpts.icon || getIcon().BUTTON_TOOLTIP_ICON
611
- })
612
- ])
613
- }
614
- }
615
- })
616
- },
617
- renderContent (h: CreateElement) {
618
- const $xeButton = this
619
- const props = $xeButton
620
- const slots = $xeButton.$scopedSlots
621
-
622
- const { content, suffixIcon, loading, prefixTooltip, suffixTooltip, suffixRender } = props
623
- const prefixIcon = props.prefixIcon || props.icon
624
- const prefixRender = props.prefixRender || props.iconRender
625
- const prefixTipOpts = $xeButton.computePrefixTipOpts
626
- const suffixTipOpts = $xeButton.computeSuffixTipOpts
627
- const prefixIconSlot = slots.prefix || slots.icon
628
- const suffixIconSlot = slots.suffix
629
- const defaultSlot = slots.default
630
- const contVNs: VNode[] = []
631
- if (prefixTooltip) {
632
- contVNs.push(
633
- $xeButton.renderTooltipIcon(h, prefixTipOpts, 'prefix')
634
- )
635
- }
636
- if (loading) {
637
- contVNs.push(
638
- h('i', {
639
- class: ['vxe-button--item vxe-button--loading-icon', getIcon().BUTTON_LOADING]
640
- })
641
- )
642
- } else if (prefixIconSlot) {
643
- contVNs.push(
644
- h('span', {
645
- class: 'vxe-button--item vxe-button--custom-prefix-icon'
646
- }, prefixIconSlot.call($xeButton, {}))
647
- )
648
- } else if (prefixRender) {
649
- const compConf = renderer.get(prefixRender.name)
650
- const pIconMethod = compConf ? compConf.renderButtonPrefix : null
651
- contVNs.push(
652
- h('span', {
653
- class: ['vxe-button--item vxe-button--custom-prefix-icon']
654
- }, pIconMethod ? getSlotVNs(pIconMethod.call($xeButton, h, prefixRender, { $button: $xeButton })) : [])
655
- )
656
- } else if (prefixIcon) {
657
- contVNs.push(
658
- h('i', {
659
- class: ['vxe-button--item vxe-button--prefix-icon', prefixIcon]
660
- })
661
- )
662
- }
663
-
664
- if (defaultSlot) {
665
- contVNs.push(
666
- h('span', {
667
- class: 'vxe-button--item vxe-button--content'
668
- }, defaultSlot.call($xeButton, {}))
669
- )
670
- } else if (content) {
671
- contVNs.push(
672
- h('span', {
673
- class: 'vxe-button--item vxe-button--content'
674
- }, getFuncText(content))
675
- )
676
- }
677
-
678
- if (suffixIconSlot) {
679
- contVNs.push(
680
- h('span', {
681
- class: 'vxe-button--item vxe-button--custom-suffix-icon'
682
- }, suffixIconSlot.call($xeButton, {}))
683
- )
684
- } else if (suffixRender) {
685
- const compConf = renderer.get(suffixRender.name)
686
- const sIconMethod = compConf ? compConf.renderButtonSuffix : null
687
- contVNs.push(
688
- h('span', {
689
- class: ['vxe-button--item vxe-button--custom-suffix-icon']
690
- }, sIconMethod ? getSlotVNs(sIconMethod.call($xeButton, h, suffixRender, { $button: $xeButton })) : [])
691
- )
692
- } else if (suffixIcon) {
693
- contVNs.push(
694
- h('i', {
695
- class: ['vxe-button--item vxe-button--suffix-icon', suffixIcon]
696
- })
697
- )
698
- }
699
- if (suffixTooltip) {
700
- contVNs.push(
701
- $xeButton.renderTooltipIcon(h, suffixTipOpts, 'suffix')
702
- )
703
- }
704
- return contVNs
705
- },
706
- renderVN (h: CreateElement): VNode {
707
- const $xeButton = this
708
- const props = $xeButton
709
- const slots = $xeButton.$scopedSlots
710
- const reactData = $xeButton.reactData
711
-
712
- const { className, trigger, title, routerLink, type, destroyOnClose, name, loading, shadow, showDropdownIcon } = props
713
- const { initialized, isAniVisible, visiblePanel } = reactData
714
- const isFormBtn = $xeButton.computeIsFormBtn
715
- const btnMode = $xeButton.computeBtnMode
716
- const btnStatus = $xeButton.computeBtnStatus
717
- const btnRound = $xeButton.computeBtnRound
718
- const btnCircle = $xeButton.computeBtnCircle
719
- const btnTransfer = $xeButton.computeBtnTransfer
720
- const btnAlign = $xeButton.computeBtnAlign
721
- const btnDisabled = $xeButton.computeBtnDisabled
722
- const permissionInfo = $xeButton.computePermissionInfo
723
- const downBtnList = $xeButton.computeDownBtnList
724
- const popupOpts = $xeButton.computePopupOpts
725
- const vSize = $xeButton.computeSize
726
- const dropdownsSlot = slots.dropdowns
727
- const ppClassName = popupOpts.className || props.popupClassName
728
-
729
- if (!permissionInfo.visible) {
730
- return renderEmptyElement($xeButton)
731
- }
732
- if (dropdownsSlot || downBtnList.length) {
733
- const btnOns: Record<string, any> = {
734
- contextmenu: $xeButton.contextmenuEvent
735
- }
736
- const panelOns: Record<string, any> = {}
737
- if (trigger === 'hover') {
738
- // hover 触发
739
- btnOns.mouseenter = $xeButton.mouseenterTargetEvent
740
- btnOns.mouseleave = $xeButton.mouseleaveTargetEvent
741
-
742
- panelOns.mouseenter = $xeButton.mouseenterDropdownEvent
743
- panelOns.mouseleave = $xeButton.mouseleaveDropdownEvent
744
- }
745
- return h('div', {
746
- ref: 'refElem',
747
- class: ['vxe-button--dropdown', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
748
- [`size--${vSize}`]: vSize,
749
- 'is--active': visiblePanel
750
- }]
751
- }, [
752
- routerLink
753
- ? h('router-link', {
754
- ref: 'refButton',
755
- class: ['vxe-button', 'vxe-button--link', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
756
- [`size--${vSize}`]: vSize,
757
- [`theme--${btnStatus}`]: btnStatus,
758
- 'is--round': btnRound,
759
- 'is--circle': btnCircle,
760
- 'is--shadow': shadow,
761
- 'is--disabled': btnDisabled || loading,
762
- 'is--loading': loading
763
- }],
764
- attrs: {
765
- title,
766
- name,
767
- type: isFormBtn ? type : 'button',
768
- disabled: btnDisabled || loading,
769
- custom: true,
770
- to: routerLink
771
- },
772
- on: {
773
- click: $xeButton.clickTargetEvent,
774
- ...btnOns
775
- }
776
- },
777
- $xeButton.renderContent(h).concat(showDropdownIcon
778
- ? [
779
- h('i', {
780
- class: `vxe-button--dropdown-arrow ${getIcon().BUTTON_DROPDOWN}`
781
- })
782
- ]
783
- : [])
784
- )
785
- : h('button', {
786
- ref: 'refButton',
787
- class: ['vxe-button', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
788
- [`size--${vSize}`]: vSize,
789
- [`theme--${btnStatus}`]: btnStatus,
790
- 'is--round': btnRound,
791
- 'is--circle': btnCircle,
792
- 'is--shadow': shadow,
793
- 'is--disabled': btnDisabled || loading,
794
- 'is--loading': loading
795
- }],
796
- attrs: {
797
- title,
798
- name,
799
- type: isFormBtn ? type : 'button',
800
- disabled: btnDisabled || loading
801
- },
802
- on: {
803
- click: $xeButton.clickTargetEvent,
804
- ...btnOns
805
- }
806
- }, $xeButton.renderContent(h).concat(showDropdownIcon
807
- ? [
808
- h('i', {
809
- class: `vxe-button--dropdown-arrow ${getIcon().BUTTON_DROPDOWN}`
810
- })
811
- ]
812
- : [])),
813
- h('div', {
814
- ref: 'refBtnPanel',
815
- class: ['vxe-button--dropdown-panel', ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $button: $xeButton }) : ppClassName) : '', {
816
- [`size--${vSize}`]: vSize,
817
- 'is--transfer': btnTransfer,
818
- 'ani--leave': isAniVisible,
819
- 'ani--enter': visiblePanel
820
- }],
821
- attrs: {
822
- placement: reactData.panelPlacement
823
- },
824
- style: reactData.panelStyle,
825
- on: panelOns
826
- }, initialized && (visiblePanel || isAniVisible)
827
- ? [
828
- dropdownsSlot
829
- ? h('div', {
830
- class: 'vxe-button--dropdown-wrapper',
831
- on: {
832
- mousedown: $xeButton.mousedownDropdownEvent,
833
- click: $xeButton.clickDropdownEvent
834
- }
835
- }, initialized && (destroyOnClose ? (visiblePanel || isAniVisible) : true) ? dropdownsSlot.call($xeButton, {}) : [])
836
- : h('div', {
837
- class: 'vxe-button--dropdown-wrapper'
838
- }, initialized && (destroyOnClose ? (visiblePanel || isAniVisible) : true)
839
- ? downBtnList.map((option, i) => {
840
- return h('vxe-button', {
841
- key: i,
842
- props: {
843
- type: option.type,
844
- mode: option.mode || btnMode,
845
- className: option.className,
846
- name: option.name,
847
- routerLink: option.routerLink,
848
- permissionCode: option.permissionCode,
849
- title: option.title,
850
- content: option.content,
851
- status: option.status,
852
- icon: option.icon,
853
- round: XEUtils.isBoolean(option.round) ? option.round : (btnMode === 'text' ? false : btnRound),
854
- circle: XEUtils.isBoolean(option.circle) ? option.circle : (btnMode === 'text' ? false : btnCircle),
855
- disabled: option.disabled,
856
- loading: option.loading,
857
- align: option.align
858
- },
859
- on: {
860
- click (params: VxeButtonDefines.ClickEventParams) {
861
- $xeButton.downBtnClickEvent(params, option)
862
- }
863
- }
864
- })
865
- })
866
- : [])
867
- ]
868
- : [])
869
- ])
870
- }
871
- if (routerLink) {
872
- return h('router-link', {
873
- ref: 'refButton',
874
- class: ['vxe-button', 'vxe-button--link', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
875
- [`size--${vSize}`]: vSize,
876
- [`theme--${btnStatus}`]: btnStatus,
877
- 'is--round': btnRound,
878
- 'is--circle': btnCircle,
879
- 'is--shadow': shadow,
880
- 'is--disabled': btnDisabled || loading,
881
- 'is--loading': loading
882
- }],
883
- props: {
884
- title,
885
- name,
886
- type: isFormBtn ? type : 'button',
887
- disabled: btnDisabled || loading,
888
- custom: true,
889
- to: routerLink
890
- },
891
- on: {
892
- click: $xeButton.clickEvent,
893
- mouseenter: $xeButton.mouseenterEvent,
894
- mouseleave: $xeButton.mouseleaveEvent,
895
- contextmenu: $xeButton.contextmenuEvent
896
- }
897
- }, $xeButton.renderContent(h))
898
- }
899
- return h('button', {
900
- ref: 'refButton',
901
- class: ['vxe-button', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
902
- [`size--${vSize}`]: vSize,
903
- [`theme--${btnStatus}`]: btnStatus,
904
- 'is--round': btnRound,
905
- 'is--circle': btnCircle,
906
- 'is--shadow': shadow,
907
- 'is--disabled': btnDisabled || loading,
908
- 'is--loading': loading
909
- }],
910
- attrs: {
911
- title,
912
- name,
913
- type: isFormBtn ? type : 'button',
914
- disabled: btnDisabled || loading
915
- },
916
- on: {
917
- click: $xeButton.clickEvent,
918
- mouseenter: $xeButton.mouseenterEvent,
919
- mouseleave: $xeButton.mouseleaveEvent,
920
- contextmenu: $xeButton.contextmenuEvent
921
- }
922
- }, $xeButton.renderContent(h))
923
- }
924
- },
925
- mounted () {
926
- const $xeButton = this
927
- const props = $xeButton
928
-
929
- if (props.type === 'text') {
930
- warnLog('vxe.error.delProp', ['[button] type=text', 'mode=text'])
931
- }
932
-
933
- globalEvents.on($xeButton, 'mousewheel', $xeButton.handleGlobalMousewheelEvent)
934
- globalEvents.on($xeButton, 'mousedown', $xeButton.handleGlobalMousedownEvent)
935
- globalEvents.on($xeButton, 'resize', $xeButton.handleGlobalResizeEvent)
936
- },
937
- beforeDestroy () {
938
- const $xeButton = this
939
-
940
- const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
941
- if (panelElem && panelElem.parentNode) {
942
- panelElem.parentNode.removeChild(panelElem)
943
- }
944
- },
945
- destroyed () {
946
- const $xeButton = this
947
-
948
- globalEvents.off($xeButton, 'mousewheel')
949
- globalEvents.off($xeButton, 'mousedown')
950
- globalEvents.off($xeButton, 'resize')
951
- },
952
- render (this: any, h) {
953
- return this.renderVN(h)
954
- }
955
- }) /* define-vxe-component end */
1
+ import { CreateElement, VNode, PropType } from 'vue'
2
+ import XEUtils from 'xe-utils'
3
+ import { getConfig, globalEvents, getIcon, createEvent, renderer, globalMixins, permission, renderEmptyElement } from '../../ui'
4
+ import { defineVxeComponent } from '../../ui/src/comp'
5
+ import { getEventTargetNode, updatePanelPlacement } from '../../ui/src/dom'
6
+ import { getFuncText, getLastZIndex, nextZIndex } from '../../ui/src/utils'
7
+ import { getSlotVNs, getEventCaseName } from '../../ui/src/vn'
8
+ import { warnLog } from '../../ui/src/log'
9
+ import VxeTooltipComponent from '../../tooltip'
10
+
11
+ import type { VxeButtonPropTypes, VxeButtonEmits, ButtonReactData, VxeButtonGroupConstructor, ButtonInternalData, VxeButtonDefines, VxeButtonGroupPrivateMethods, VxeFormConstructor, VxeDrawerConstructor, VxeDrawerMethods, VxeFormPrivateMethods, VxeModalConstructor, VxeModalMethods, VxeComponentPermissionInfo, VxeComponentSizeType, ValueOf, VxeTreeConstructor, VxeTreePrivateMethods } from '../../../types'
12
+ import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
13
+
14
+ export default /* define-vxe-component start */ defineVxeComponent({
15
+ name: 'VxeButton',
16
+ mixins: [
17
+ globalMixins.sizeMixin,
18
+ globalMixins.permissionMixin
19
+ ],
20
+ props: {
21
+ /**
22
+ * 按钮类型
23
+ */
24
+ type: String as PropType<VxeButtonPropTypes.Type>,
25
+ mode: String as PropType<VxeButtonPropTypes.Mode>,
26
+ className: [String, Function] as PropType<VxeButtonPropTypes.ClassName>,
27
+ popupClassName: [String, Function] as PropType<VxeButtonPropTypes.PopupClassName>,
28
+ /**
29
+ * 按钮尺寸
30
+ */
31
+ size: {
32
+ type: String as PropType<VxeButtonPropTypes.Size>,
33
+ default: () => getConfig().button.size || getConfig().size
34
+ },
35
+ zIndex: Number as PropType<VxeButtonPropTypes.ZIndex>,
36
+ /**
37
+ * 用来标识这一项
38
+ */
39
+ name: [String, Number] as PropType<VxeButtonPropTypes.Name>,
40
+ routerLink: Object as PropType<VxeButtonPropTypes.RouterLink>,
41
+ /**
42
+ * 权限码
43
+ */
44
+ permissionCode: [String, Number] as PropType<VxeButtonPropTypes.PermissionCode>,
45
+ /**
46
+ * 按钮内容
47
+ */
48
+ content: String as PropType<VxeButtonPropTypes.Content>,
49
+ /**
50
+ * 固定显示下拉面板的方向
51
+ */
52
+ placement: String as PropType<VxeButtonPropTypes.Placement>,
53
+ /**
54
+ * 按钮状态
55
+ */
56
+ status: String as PropType<VxeButtonPropTypes.Status>,
57
+ /**
58
+ * 标题
59
+ */
60
+ title: String as PropType<VxeButtonPropTypes.Title>,
61
+ shadow: Boolean as PropType<VxeButtonPropTypes.Shadow>,
62
+ /**
63
+ * 按钮的前缀图标,属于 prefix-icon 的简写
64
+ */
65
+ icon: String as PropType<VxeButtonPropTypes.Icon>,
66
+ iconRender: Object as PropType<VxeButtonPropTypes.IconRender>,
67
+ /**
68
+ * 按钮的前缀图标
69
+ */
70
+ prefixIcon: String as PropType<VxeButtonPropTypes.PrefixIcon>,
71
+ prefixRender: Object as PropType<VxeButtonPropTypes.PrefixRender>,
72
+ /**
73
+ * 按钮的后缀图标
74
+ */
75
+ suffixIcon: String as PropType<VxeButtonPropTypes.SuffixIcon>,
76
+ suffixRender: Object as PropType<VxeButtonPropTypes.SuffixRender>,
77
+ /**
78
+ * 圆角边框
79
+ */
80
+ round: Boolean as PropType<VxeButtonPropTypes.Round>,
81
+ /**
82
+ * 圆角按钮
83
+ */
84
+ circle: Boolean as PropType<VxeButtonPropTypes.Circle>,
85
+ /**
86
+ * 是否禁用
87
+ */
88
+ disabled: Boolean as PropType<VxeButtonPropTypes.Disabled>,
89
+ /**
90
+ * 是否加载中
91
+ */
92
+ loading: Boolean as PropType<VxeButtonPropTypes.Loading>,
93
+ trigger: {
94
+ type: String as PropType<VxeButtonPropTypes.Trigger>,
95
+ default: () => getConfig().button.trigger
96
+ },
97
+ align: String as PropType<VxeButtonPropTypes.Align>,
98
+ prefixTooltip: Object as PropType<VxeButtonPropTypes.PrefixTooltip>,
99
+ suffixTooltip: Object as PropType<VxeButtonPropTypes.SuffixTooltip>,
100
+ options: Array as PropType<VxeButtonPropTypes.Options>,
101
+ showDropdownIcon: {
102
+ type: Boolean,
103
+ default: () => getConfig().button.showDropdownIcon
104
+ },
105
+ /**
106
+ * 在下拉面板关闭时销毁内容
107
+ */
108
+ destroyOnClose: {
109
+ type: Boolean as PropType<VxeButtonPropTypes.DestroyOnClose>,
110
+ default: () => getConfig().button.destroyOnClose
111
+ },
112
+ popupConfig: Object as PropType<VxeButtonPropTypes.PopupConfig>,
113
+ /**
114
+ * 是否将弹框容器插入于 body 内
115
+ */
116
+ transfer: {
117
+ type: Boolean as PropType<VxeButtonPropTypes.Transfer>,
118
+ default: null
119
+ }
120
+ },
121
+ inject: {
122
+ $xeModal: {
123
+ default: null
124
+ },
125
+ $xeDrawer: {
126
+ default: null
127
+ },
128
+ $xeTable: {
129
+ default: null
130
+ },
131
+ $xeTree: {
132
+ default: null
133
+ },
134
+ $xeForm: {
135
+ default: null
136
+ },
137
+ $xeButtonGroup: {
138
+ default: null
139
+ }
140
+ },
141
+ data () {
142
+ const reactData: ButtonReactData = {
143
+ initialized: false,
144
+ visiblePanel: false,
145
+ isAniVisible: false,
146
+ isActivated: false,
147
+ panelIndex: 0,
148
+ panelStyle: {},
149
+ panelPlacement: ''
150
+ }
151
+ const internalData: ButtonInternalData = {
152
+ showTime: undefined
153
+ }
154
+ return {
155
+ xID: XEUtils.uniqueId(),
156
+ reactData,
157
+ internalData
158
+ }
159
+ },
160
+ computed: {
161
+ ...({} as {
162
+ computePermissionInfo(): VxeComponentPermissionInfo
163
+ computeSize(): VxeComponentSizeType
164
+ $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
165
+ $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
166
+ $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
167
+ $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
168
+ $xeTree(): (VxeTreeConstructor & VxeTreePrivateMethods) | null
169
+ $xeButtonGroup(): (VxeButtonGroupConstructor & VxeButtonGroupPrivateMethods)| null
170
+ }),
171
+ computeBtnTransfer () {
172
+ const $xeButton = this
173
+ const props = $xeButton
174
+ const $xeTable = $xeButton.$xeTable
175
+ const $xeTree = $xeButton.$xeTree
176
+ const $xeModal = $xeButton.$xeModal
177
+ const $xeDrawer = $xeButton.$xeDrawer
178
+ const $xeForm = $xeButton.$xeForm
179
+
180
+ const { transfer } = props
181
+ const popupOpts = $xeButton.computePopupOpts as VxeButtonPropTypes.PopupConfig
182
+ if (XEUtils.isBoolean(popupOpts.transfer)) {
183
+ return popupOpts.transfer
184
+ }
185
+ if (transfer === null) {
186
+ const globalTransfer = getConfig().button.transfer
187
+ if (XEUtils.isBoolean(globalTransfer)) {
188
+ return globalTransfer
189
+ }
190
+ if ($xeTable || $xeTree || $xeModal || $xeDrawer || $xeForm) {
191
+ return true
192
+ }
193
+ }
194
+ return transfer
195
+ },
196
+ computeBtnDisabled () {
197
+ const $xeButton = this
198
+ const props = $xeButton
199
+
200
+ const { disabled } = props
201
+ const permissionInfo = $xeButton.computePermissionInfo
202
+ return disabled || permissionInfo.disabled
203
+ },
204
+ computeIsFormBtn () {
205
+ const $xeButton = this
206
+ const props = $xeButton
207
+
208
+ const { type } = props
209
+ if (type) {
210
+ return ['submit', 'reset', 'button'].indexOf(type) > -1
211
+ }
212
+ return false
213
+ },
214
+ computeBtnMode () {
215
+ const $xeButton = this
216
+ const props = $xeButton
217
+
218
+ const { type, mode } = props
219
+ const $xeButtonGroup = $xeButton.$xeButtonGroup
220
+ if (mode === 'text' || type === 'text' || ($xeButtonGroup && $xeButtonGroup.mode === 'text')) {
221
+ return 'text'
222
+ }
223
+ return 'button'
224
+ },
225
+ computeBtnStatus () {
226
+ const $xeButton = this
227
+ const props = $xeButton
228
+
229
+ const { status } = props
230
+ const $xeButtonGroup = $xeButton.$xeButtonGroup
231
+ if (status) {
232
+ return status
233
+ }
234
+ if ($xeButtonGroup) {
235
+ return $xeButtonGroup.status
236
+ }
237
+ return ''
238
+ },
239
+ computeBtnRound () {
240
+ const $xeButton = this
241
+ const props = $xeButton
242
+
243
+ const { round } = props
244
+ const $xeButtonGroup = $xeButton.$xeButtonGroup
245
+ if (round) {
246
+ return round
247
+ }
248
+ if ($xeButtonGroup) {
249
+ return $xeButtonGroup.round
250
+ }
251
+ return false
252
+ },
253
+ computeBtnAlign () {
254
+ const $xeButton = this
255
+ const props = $xeButton
256
+
257
+ const { align } = props
258
+ const $xeButtonGroup = $xeButton.$xeButtonGroup
259
+ if (align) {
260
+ return align
261
+ }
262
+ if ($xeButtonGroup) {
263
+ return $xeButtonGroup.align
264
+ }
265
+ return false
266
+ },
267
+ computeBtnCircle () {
268
+ const $xeButton = this
269
+ const props = $xeButton
270
+
271
+ const { circle } = props
272
+ const $xeButtonGroup = $xeButton.$xeButtonGroup
273
+ if (circle) {
274
+ return circle
275
+ }
276
+ if ($xeButtonGroup) {
277
+ return $xeButtonGroup.circle
278
+ }
279
+ return false
280
+ },
281
+ computeDownBtnList () {
282
+ const $xeButton = this
283
+ const props = $xeButton
284
+
285
+ const { options } = props
286
+ if (options) {
287
+ return options.filter(item => {
288
+ const { permissionCode } = item
289
+ return !permissionCode || permission.checkVisible(permissionCode)
290
+ })
291
+ }
292
+ return []
293
+ },
294
+ computePopupOpts () {
295
+ const $xeButton = this
296
+ const props = $xeButton
297
+
298
+ return Object.assign({}, getConfig().button.popupConfig, props.popupConfig)
299
+ },
300
+ computePrefixTipOpts () {
301
+ const $xeButton = this
302
+ const props = $xeButton
303
+
304
+ return Object.assign({}, getConfig().button.prefixTooltip, props.prefixTooltip)
305
+ },
306
+ computeSuffixTipOpts () {
307
+ const $xeButton = this
308
+ const props = $xeButton
309
+
310
+ return Object.assign({}, getConfig().button.suffixTooltip, props.suffixTooltip)
311
+ }
312
+ },
313
+ methods: {
314
+ //
315
+ // methods
316
+ //
317
+ dispatchEvent (type: ValueOf<VxeButtonEmits>, params: Record<string, any>, evnt: Event | null) {
318
+ const $xeButton = this
319
+ $xeButton.$emit(getEventCaseName($xeButton, type), createEvent(evnt, { $button: $xeButton }, params))
320
+ },
321
+ openPanel () {
322
+ const $xeButton = this
323
+ const props = $xeButton
324
+ const reactData = $xeButton.reactData
325
+ const internalData = $xeButton.internalData
326
+
327
+ const { trigger } = props
328
+ const btnTransfer = $xeButton.computeBtnTransfer
329
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
330
+ if (panelElem) {
331
+ panelElem.dataset.active = 'Y'
332
+ if (!reactData.initialized) {
333
+ reactData.initialized = true
334
+ if (btnTransfer) {
335
+ document.body.appendChild(panelElem)
336
+ }
337
+ }
338
+ internalData.showTime = setTimeout(() => {
339
+ if (panelElem.dataset.active === 'Y') {
340
+ $xeButton.mouseenterDropdownEvent()
341
+ } else {
342
+ reactData.isAniVisible = false
343
+ }
344
+ }, trigger === 'click' ? 50 : 250)
345
+ }
346
+ return $xeButton.$nextTick()
347
+ },
348
+ closePanel () {
349
+ const $xeButton = this
350
+
351
+ return $xeButton.hidePanel()
352
+ },
353
+ hidePanel () {
354
+ const $xeButton = this
355
+ const reactData = $xeButton.reactData
356
+ const internalData = $xeButton.internalData
357
+
358
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
359
+ clearTimeout(internalData.showTime)
360
+ if (panelElem) {
361
+ panelElem.dataset.active = 'N'
362
+ setTimeout(() => {
363
+ if (panelElem.dataset.active !== 'Y') {
364
+ reactData.visiblePanel = false
365
+ setTimeout(() => {
366
+ if (panelElem.dataset.active !== 'Y') {
367
+ reactData.isAniVisible = false
368
+ }
369
+ }, 350)
370
+ }
371
+ }, 100)
372
+ } else {
373
+ reactData.isAniVisible = false
374
+ reactData.visiblePanel = false
375
+ }
376
+ return $xeButton.$nextTick()
377
+ },
378
+ focus () {
379
+ const $xeButton = this
380
+
381
+ const btnElem = $xeButton.$refs.refButton as HTMLElement | undefined
382
+ if (btnElem) {
383
+ btnElem.focus()
384
+ }
385
+ return $xeButton.$nextTick()
386
+ },
387
+ blur () {
388
+ const $xeButton = this
389
+
390
+ const btnElem = $xeButton.$refs.refButton as HTMLElement | undefined
391
+ if (btnElem) {
392
+ btnElem.blur()
393
+ }
394
+ return $xeButton.$nextTick()
395
+ },
396
+
397
+ //
398
+ // privateMethods
399
+ //
400
+ updateZindex () {
401
+ const $xeButton = this
402
+ const props = $xeButton
403
+ const reactData = $xeButton.reactData
404
+
405
+ const popupOpts = $xeButton.computePopupOpts
406
+ const customZIndex = popupOpts.zIndex || props.zIndex
407
+ if (customZIndex) {
408
+ reactData.panelIndex = XEUtils.toNumber(customZIndex)
409
+ } else if (reactData.panelIndex < getLastZIndex()) {
410
+ reactData.panelIndex = nextZIndex()
411
+ }
412
+ },
413
+ updatePlacement () {
414
+ const $xeButton = this
415
+ const props = $xeButton
416
+ const reactData = $xeButton.reactData
417
+
418
+ const { placement } = props
419
+ const { panelIndex } = reactData
420
+ const targetElem = $xeButton.$refs.refButton as HTMLElement | undefined
421
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
422
+ const btnTransfer = $xeButton.computeBtnTransfer
423
+ const popupOpts = $xeButton.computePopupOpts
424
+ const handleStyle = () => {
425
+ const ppObj = updatePanelPlacement(targetElem, panelElem, {
426
+ placement: popupOpts.placement || placement,
427
+ teleportTo: btnTransfer
428
+ })
429
+ const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
430
+ zIndex: panelIndex
431
+ })
432
+ reactData.panelStyle = panelStyle
433
+ reactData.panelPlacement = ppObj.placement
434
+ }
435
+ handleStyle()
436
+ return $xeButton.$nextTick().then(handleStyle)
437
+ },
438
+ clickEvent (evnt: Event) {
439
+ const $xeButton = this
440
+ const props = $xeButton
441
+ const $xeButtonGroup = $xeButton.$xeButtonGroup
442
+
443
+ if ($xeButtonGroup) {
444
+ $xeButtonGroup.handleClick({ name: props.name }, evnt)
445
+ }
446
+ $xeButton.dispatchEvent('click', { $event: evnt }, evnt)
447
+ },
448
+ downBtnClickEvent (params: VxeButtonDefines.ClickEventParams, option: VxeButtonDefines.DownButtonOption) {
449
+ const $xeButton = this
450
+
451
+ const { $event } = params
452
+ $xeButton.hidePanel()
453
+ $xeButton.dispatchEvent('dropdown-click', { name: option.name, option }, $event)
454
+ },
455
+ mousedownDropdownEvent (evnt: MouseEvent) {
456
+ const isLeftBtn = evnt.button === 0
457
+ if (isLeftBtn) {
458
+ evnt.stopPropagation()
459
+ }
460
+ },
461
+ clickDropdownEvent (evnt: Event) {
462
+ const $xeButton = this
463
+ const reactData = $xeButton.reactData
464
+
465
+ const dropdownElem = evnt.currentTarget
466
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
467
+ const { flag, targetElem } = getEventTargetNode(evnt, dropdownElem, 'vxe-button')
468
+ if (flag) {
469
+ if (panelElem) {
470
+ panelElem.dataset.active = 'N'
471
+ }
472
+ reactData.visiblePanel = false
473
+ setTimeout(() => {
474
+ if (!panelElem || panelElem.dataset.active !== 'Y') {
475
+ reactData.isAniVisible = false
476
+ }
477
+ }, 350)
478
+ $xeButton.dispatchEvent('dropdown-click', { name: targetElem.getAttribute('name'), option: null, $event: evnt }, evnt)
479
+ }
480
+ },
481
+ mouseenterDropdownEvent () {
482
+ const $xeButton = this
483
+ const reactData = $xeButton.reactData
484
+
485
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
486
+ if (panelElem) {
487
+ panelElem.dataset.active = 'Y'
488
+ reactData.isAniVisible = true
489
+ setTimeout(() => {
490
+ if (panelElem.dataset.active === 'Y') {
491
+ reactData.visiblePanel = true
492
+ $xeButton.updateZindex()
493
+ $xeButton.updatePlacement()
494
+ setTimeout(() => {
495
+ if (reactData.visiblePanel) {
496
+ $xeButton.updatePlacement()
497
+ }
498
+ }, 50)
499
+ }
500
+ }, 20)
501
+ }
502
+ },
503
+ mouseenterTargetEvent (evnt: MouseEvent) {
504
+ const $xeButton = this
505
+ const props = $xeButton
506
+
507
+ const { loading } = props
508
+ const btnDisabled = $xeButton.computeBtnDisabled
509
+ if (!(btnDisabled || loading)) {
510
+ $xeButton.openPanel()
511
+ $xeButton.mouseenterEvent(evnt)
512
+ }
513
+ },
514
+ mouseleaveTargetEvent (evnt: MouseEvent) {
515
+ const $xeButton = this
516
+
517
+ $xeButton.hidePanel()
518
+ $xeButton.mouseleaveEvent(evnt)
519
+ },
520
+ mouseenterEvent (evnt: MouseEvent) {
521
+ const $xeButton = this
522
+
523
+ $xeButton.dispatchEvent('mouseenter', {}, evnt)
524
+ },
525
+ mouseleaveEvent (evnt: MouseEvent) {
526
+ const $xeButton = this
527
+
528
+ $xeButton.dispatchEvent('mouseleave', {}, evnt)
529
+ },
530
+ contextmenuEvent (evnt: MouseEvent) {
531
+ const $xeButton = this
532
+
533
+ $xeButton.dispatchEvent('contextmenu', {}, evnt)
534
+ },
535
+ clickTargetEvent (evnt: MouseEvent) {
536
+ const $xeButton = this
537
+ const props = $xeButton
538
+ const reactData = $xeButton.reactData
539
+
540
+ const { loading } = props
541
+ const btnDisabled = $xeButton.computeBtnDisabled
542
+ if (!(btnDisabled || loading)) {
543
+ const { trigger } = props
544
+ if (trigger === 'click') {
545
+ if (reactData.visiblePanel) {
546
+ $xeButton.hidePanel()
547
+ } else {
548
+ $xeButton.openPanel()
549
+ }
550
+ }
551
+ $xeButton.clickEvent(evnt)
552
+ }
553
+ },
554
+ mouseleaveDropdownEvent () {
555
+ const $xeButton = this
556
+
557
+ $xeButton.hidePanel()
558
+ },
559
+ handleGlobalMousewheelEvent (evnt: Event) {
560
+ const $xeButton = this
561
+ const reactData = $xeButton.reactData
562
+
563
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
564
+ if (reactData.visiblePanel && !getEventTargetNode(evnt, panelElem).flag) {
565
+ $xeButton.hidePanel()
566
+ }
567
+ },
568
+ handleGlobalMousedownEvent (evnt: MouseEvent) {
569
+ const $xeButton = this
570
+ const reactData = $xeButton.reactData
571
+
572
+ const btnDisabled = $xeButton.computeBtnDisabled
573
+ const { visiblePanel } = reactData
574
+ if (!btnDisabled) {
575
+ const el = $xeButton.$refs.refElem
576
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
577
+ reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
578
+ if (visiblePanel && !reactData.isActivated) {
579
+ $xeButton.hidePanel()
580
+ }
581
+ }
582
+ },
583
+ handleGlobalResizeEvent () {
584
+ const $xeButton = this
585
+ const reactData = $xeButton.reactData
586
+
587
+ const { visiblePanel } = reactData
588
+ if (visiblePanel) {
589
+ $xeButton.updatePlacement()
590
+ }
591
+ },
592
+
593
+ //
594
+ // Render
595
+ //
596
+ renderTooltipIcon (h: CreateElement, tipOpts: VxeButtonPropTypes.PrefixTooltip | VxeButtonPropTypes.SuffixTooltip, type: 'prefix' | 'suffix') {
597
+ return h(VxeTooltipComponent, {
598
+ props: {
599
+ useHTML: tipOpts.useHTML,
600
+ content: tipOpts.content,
601
+ enterable: tipOpts.enterable,
602
+ theme: tipOpts.theme
603
+ },
604
+ scopedSlots: {
605
+ default: () => {
606
+ return h('span', {
607
+ class: `vxe-button--item vxe-button--tooltip-${type}-icon`
608
+ }, [
609
+ h('i', {
610
+ class: tipOpts.icon || getIcon().BUTTON_TOOLTIP_ICON
611
+ })
612
+ ])
613
+ }
614
+ }
615
+ })
616
+ },
617
+ renderContent (h: CreateElement) {
618
+ const $xeButton = this
619
+ const props = $xeButton
620
+ const slots = $xeButton.$scopedSlots
621
+
622
+ const { content, suffixIcon, loading, prefixTooltip, suffixTooltip, suffixRender } = props
623
+ const prefixIcon = props.prefixIcon || props.icon
624
+ const prefixRender = props.prefixRender || props.iconRender
625
+ const prefixTipOpts = $xeButton.computePrefixTipOpts
626
+ const suffixTipOpts = $xeButton.computeSuffixTipOpts
627
+ const prefixIconSlot = slots.prefix || slots.icon
628
+ const suffixIconSlot = slots.suffix
629
+ const defaultSlot = slots.default
630
+ const contVNs: VNode[] = []
631
+ if (prefixTooltip) {
632
+ contVNs.push(
633
+ $xeButton.renderTooltipIcon(h, prefixTipOpts, 'prefix')
634
+ )
635
+ }
636
+ if (loading) {
637
+ contVNs.push(
638
+ h('i', {
639
+ class: ['vxe-button--item vxe-button--loading-icon', getIcon().BUTTON_LOADING]
640
+ })
641
+ )
642
+ } else if (prefixIconSlot) {
643
+ contVNs.push(
644
+ h('span', {
645
+ class: 'vxe-button--item vxe-button--custom-prefix-icon'
646
+ }, prefixIconSlot.call($xeButton, {}))
647
+ )
648
+ } else if (prefixRender) {
649
+ const compConf = renderer.get(prefixRender.name)
650
+ const pIconMethod = compConf ? compConf.renderButtonPrefix : null
651
+ contVNs.push(
652
+ h('span', {
653
+ class: ['vxe-button--item vxe-button--custom-prefix-icon']
654
+ }, pIconMethod ? getSlotVNs(pIconMethod.call($xeButton, h, prefixRender, { $button: $xeButton })) : [])
655
+ )
656
+ } else if (prefixIcon) {
657
+ contVNs.push(
658
+ h('i', {
659
+ class: ['vxe-button--item vxe-button--prefix-icon', prefixIcon]
660
+ })
661
+ )
662
+ }
663
+
664
+ if (defaultSlot) {
665
+ contVNs.push(
666
+ h('span', {
667
+ class: 'vxe-button--item vxe-button--content'
668
+ }, defaultSlot.call($xeButton, {}))
669
+ )
670
+ } else if (content) {
671
+ contVNs.push(
672
+ h('span', {
673
+ class: 'vxe-button--item vxe-button--content'
674
+ }, getFuncText(content))
675
+ )
676
+ }
677
+
678
+ if (suffixIconSlot) {
679
+ contVNs.push(
680
+ h('span', {
681
+ class: 'vxe-button--item vxe-button--custom-suffix-icon'
682
+ }, suffixIconSlot.call($xeButton, {}))
683
+ )
684
+ } else if (suffixRender) {
685
+ const compConf = renderer.get(suffixRender.name)
686
+ const sIconMethod = compConf ? compConf.renderButtonSuffix : null
687
+ contVNs.push(
688
+ h('span', {
689
+ class: ['vxe-button--item vxe-button--custom-suffix-icon']
690
+ }, sIconMethod ? getSlotVNs(sIconMethod.call($xeButton, h, suffixRender, { $button: $xeButton })) : [])
691
+ )
692
+ } else if (suffixIcon) {
693
+ contVNs.push(
694
+ h('i', {
695
+ class: ['vxe-button--item vxe-button--suffix-icon', suffixIcon]
696
+ })
697
+ )
698
+ }
699
+ if (suffixTooltip) {
700
+ contVNs.push(
701
+ $xeButton.renderTooltipIcon(h, suffixTipOpts, 'suffix')
702
+ )
703
+ }
704
+ return contVNs
705
+ },
706
+ renderVN (h: CreateElement): VNode {
707
+ const $xeButton = this
708
+ const props = $xeButton
709
+ const slots = $xeButton.$scopedSlots
710
+ const reactData = $xeButton.reactData
711
+
712
+ const { className, trigger, title, routerLink, type, destroyOnClose, name, loading, shadow, showDropdownIcon } = props
713
+ const { initialized, isAniVisible, visiblePanel } = reactData
714
+ const isFormBtn = $xeButton.computeIsFormBtn
715
+ const btnMode = $xeButton.computeBtnMode
716
+ const btnStatus = $xeButton.computeBtnStatus
717
+ const btnRound = $xeButton.computeBtnRound
718
+ const btnCircle = $xeButton.computeBtnCircle
719
+ const btnTransfer = $xeButton.computeBtnTransfer
720
+ const btnAlign = $xeButton.computeBtnAlign
721
+ const btnDisabled = $xeButton.computeBtnDisabled
722
+ const permissionInfo = $xeButton.computePermissionInfo
723
+ const downBtnList = $xeButton.computeDownBtnList
724
+ const popupOpts = $xeButton.computePopupOpts
725
+ const vSize = $xeButton.computeSize
726
+ const dropdownsSlot = slots.dropdowns
727
+ const ppClassName = popupOpts.className || props.popupClassName
728
+
729
+ if (!permissionInfo.visible) {
730
+ return renderEmptyElement($xeButton)
731
+ }
732
+ if (dropdownsSlot || downBtnList.length) {
733
+ const btnOns: Record<string, any> = {
734
+ contextmenu: $xeButton.contextmenuEvent
735
+ }
736
+ const panelOns: Record<string, any> = {}
737
+ if (trigger === 'hover') {
738
+ // hover 触发
739
+ btnOns.mouseenter = $xeButton.mouseenterTargetEvent
740
+ btnOns.mouseleave = $xeButton.mouseleaveTargetEvent
741
+
742
+ panelOns.mouseenter = $xeButton.mouseenterDropdownEvent
743
+ panelOns.mouseleave = $xeButton.mouseleaveDropdownEvent
744
+ }
745
+ return h('div', {
746
+ ref: 'refElem',
747
+ class: ['vxe-button--dropdown', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
748
+ [`size--${vSize}`]: vSize,
749
+ 'is--active': visiblePanel
750
+ }]
751
+ }, [
752
+ routerLink
753
+ ? h('router-link', {
754
+ ref: 'refButton',
755
+ class: ['vxe-button', 'vxe-button--link', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
756
+ [`size--${vSize}`]: vSize,
757
+ [`theme--${btnStatus}`]: btnStatus,
758
+ 'is--round': btnRound,
759
+ 'is--circle': btnCircle,
760
+ 'is--shadow': shadow,
761
+ 'is--disabled': btnDisabled || loading,
762
+ 'is--loading': loading
763
+ }],
764
+ attrs: {
765
+ title,
766
+ name,
767
+ type: isFormBtn ? type : 'button',
768
+ disabled: btnDisabled || loading,
769
+ custom: true,
770
+ to: routerLink
771
+ },
772
+ on: {
773
+ click: $xeButton.clickTargetEvent,
774
+ ...btnOns
775
+ }
776
+ },
777
+ $xeButton.renderContent(h).concat(showDropdownIcon
778
+ ? [
779
+ h('i', {
780
+ class: `vxe-button--dropdown-arrow ${getIcon().BUTTON_DROPDOWN}`
781
+ })
782
+ ]
783
+ : [])
784
+ )
785
+ : h('button', {
786
+ ref: 'refButton',
787
+ class: ['vxe-button', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
788
+ [`size--${vSize}`]: vSize,
789
+ [`theme--${btnStatus}`]: btnStatus,
790
+ 'is--round': btnRound,
791
+ 'is--circle': btnCircle,
792
+ 'is--shadow': shadow,
793
+ 'is--disabled': btnDisabled || loading,
794
+ 'is--loading': loading
795
+ }],
796
+ attrs: {
797
+ title,
798
+ name,
799
+ type: isFormBtn ? type : 'button',
800
+ disabled: btnDisabled || loading
801
+ },
802
+ on: {
803
+ click: $xeButton.clickTargetEvent,
804
+ ...btnOns
805
+ }
806
+ }, $xeButton.renderContent(h).concat(showDropdownIcon
807
+ ? [
808
+ h('i', {
809
+ class: `vxe-button--dropdown-arrow ${getIcon().BUTTON_DROPDOWN}`
810
+ })
811
+ ]
812
+ : [])),
813
+ h('div', {
814
+ ref: 'refBtnPanel',
815
+ class: ['vxe-button--dropdown-panel', ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $button: $xeButton }) : ppClassName) : '', {
816
+ [`size--${vSize}`]: vSize,
817
+ 'is--transfer': btnTransfer,
818
+ 'ani--leave': isAniVisible,
819
+ 'ani--enter': visiblePanel
820
+ }],
821
+ attrs: {
822
+ placement: reactData.panelPlacement
823
+ },
824
+ style: reactData.panelStyle,
825
+ on: panelOns
826
+ }, initialized && (visiblePanel || isAniVisible)
827
+ ? [
828
+ dropdownsSlot
829
+ ? h('div', {
830
+ class: 'vxe-button--dropdown-wrapper',
831
+ on: {
832
+ mousedown: $xeButton.mousedownDropdownEvent,
833
+ click: $xeButton.clickDropdownEvent
834
+ }
835
+ }, initialized && (destroyOnClose ? (visiblePanel || isAniVisible) : true) ? dropdownsSlot.call($xeButton, {}) : [])
836
+ : h('div', {
837
+ class: 'vxe-button--dropdown-wrapper'
838
+ }, initialized && (destroyOnClose ? (visiblePanel || isAniVisible) : true)
839
+ ? downBtnList.map((option, i) => {
840
+ return h('vxe-button', {
841
+ key: i,
842
+ props: {
843
+ type: option.type,
844
+ mode: option.mode || btnMode,
845
+ className: option.className,
846
+ name: option.name,
847
+ routerLink: option.routerLink,
848
+ permissionCode: option.permissionCode,
849
+ title: option.title,
850
+ content: option.content,
851
+ status: option.status,
852
+ icon: option.icon,
853
+ round: XEUtils.isBoolean(option.round) ? option.round : (btnMode === 'text' ? false : btnRound),
854
+ circle: XEUtils.isBoolean(option.circle) ? option.circle : (btnMode === 'text' ? false : btnCircle),
855
+ disabled: option.disabled,
856
+ loading: option.loading,
857
+ align: option.align
858
+ },
859
+ on: {
860
+ click (params: VxeButtonDefines.ClickEventParams) {
861
+ $xeButton.downBtnClickEvent(params, option)
862
+ }
863
+ }
864
+ })
865
+ })
866
+ : [])
867
+ ]
868
+ : [])
869
+ ])
870
+ }
871
+ if (routerLink) {
872
+ return h('router-link', {
873
+ ref: 'refButton',
874
+ class: ['vxe-button', 'vxe-button--link', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
875
+ [`size--${vSize}`]: vSize,
876
+ [`theme--${btnStatus}`]: btnStatus,
877
+ 'is--round': btnRound,
878
+ 'is--circle': btnCircle,
879
+ 'is--shadow': shadow,
880
+ 'is--disabled': btnDisabled || loading,
881
+ 'is--loading': loading
882
+ }],
883
+ props: {
884
+ title,
885
+ name,
886
+ type: isFormBtn ? type : 'button',
887
+ disabled: btnDisabled || loading,
888
+ custom: true,
889
+ to: routerLink
890
+ },
891
+ on: {
892
+ click: $xeButton.clickEvent,
893
+ mouseenter: $xeButton.mouseenterEvent,
894
+ mouseleave: $xeButton.mouseleaveEvent,
895
+ contextmenu: $xeButton.contextmenuEvent
896
+ }
897
+ }, $xeButton.renderContent(h))
898
+ }
899
+ return h('button', {
900
+ ref: 'refButton',
901
+ class: ['vxe-button', `type--${btnMode}`, btnAlign ? `align--${btnAlign}` : '', className ? (XEUtils.isFunction(className) ? className({ $button: $xeButton }) : className) : '', {
902
+ [`size--${vSize}`]: vSize,
903
+ [`theme--${btnStatus}`]: btnStatus,
904
+ 'is--round': btnRound,
905
+ 'is--circle': btnCircle,
906
+ 'is--shadow': shadow,
907
+ 'is--disabled': btnDisabled || loading,
908
+ 'is--loading': loading
909
+ }],
910
+ attrs: {
911
+ title,
912
+ name,
913
+ type: isFormBtn ? type : 'button',
914
+ disabled: btnDisabled || loading
915
+ },
916
+ on: {
917
+ click: $xeButton.clickEvent,
918
+ mouseenter: $xeButton.mouseenterEvent,
919
+ mouseleave: $xeButton.mouseleaveEvent,
920
+ contextmenu: $xeButton.contextmenuEvent
921
+ }
922
+ }, $xeButton.renderContent(h))
923
+ }
924
+ },
925
+ mounted () {
926
+ const $xeButton = this
927
+ const props = $xeButton
928
+
929
+ if (props.type === 'text') {
930
+ warnLog('vxe.error.delProp', ['[button] type=text', 'mode=text'])
931
+ }
932
+
933
+ globalEvents.on($xeButton, 'mousewheel', $xeButton.handleGlobalMousewheelEvent)
934
+ globalEvents.on($xeButton, 'mousedown', $xeButton.handleGlobalMousedownEvent)
935
+ globalEvents.on($xeButton, 'resize', $xeButton.handleGlobalResizeEvent)
936
+ },
937
+ beforeDestroy () {
938
+ const $xeButton = this
939
+
940
+ const panelElem = $xeButton.$refs.refBtnPanel as HTMLElement | undefined
941
+ if (panelElem && panelElem.parentNode) {
942
+ panelElem.parentNode.removeChild(panelElem)
943
+ }
944
+ },
945
+ destroyed () {
946
+ const $xeButton = this
947
+
948
+ globalEvents.off($xeButton, 'mousewheel')
949
+ globalEvents.off($xeButton, 'mousedown')
950
+ globalEvents.off($xeButton, 'resize')
951
+ },
952
+ render (this: any, h) {
953
+ return this.renderVN(h)
954
+ }
955
+ }) /* define-vxe-component end */