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,752 +1,752 @@
1
- import { PropType, CreateElement, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { getConfig, getIcon, getI18n, globalEvents, renderer, createEvent, globalMixins, GLOBAL_EVENT_KEYS, renderEmptyElement } from '../../ui'
5
- import { getEventTargetNode, updatePanelPlacement } from '../../ui/src/dom'
6
- import { getLastZIndex, nextZIndex, getFuncText } from '../../ui/src/utils'
7
- import { getSlotVNs } from '../../ui/src/vn'
8
-
9
- import type { VxeIconPickerPropTypes, IconPickerInternalData, ValueOf, IconPickerReactData, VxeInputConstructor, VxeComponentSizeType, VxeIconPickerEmits, VxeIconPickerDefines, VxeDrawerConstructor, VxeDrawerMethods, VxeFormDefines, VxeFormConstructor, VxeFormPrivateMethods, VxeModalConstructor, VxeModalMethods } from '../../../types'
10
- import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
11
-
12
- export default /* define-vxe-component start */ defineVxeComponent({
13
- name: 'VxeIconPicker',
14
- mixins: [
15
- globalMixins.sizeMixin
16
- ],
17
- model: {
18
- prop: 'value',
19
- event: 'modelValue'
20
- },
21
- props: {
22
- value: String as PropType<VxeIconPickerPropTypes.ModelValue>,
23
- placeholder: String as PropType<VxeIconPickerPropTypes.Placeholder>,
24
- clearable: Boolean as PropType<VxeIconPickerPropTypes.Clearable>,
25
- size: {
26
- type: String as PropType<VxeIconPickerPropTypes.Size>,
27
- default: () => getConfig().iconPicker.size || getConfig().size
28
- },
29
- className: [String, Function] as PropType<VxeIconPickerPropTypes.ClassName>,
30
- /**
31
- * 已废弃,请使用 popupConfig.className
32
- * @deprecated
33
- */
34
- popupClassName: [String, Function] as PropType<VxeIconPickerPropTypes.PopupClassName>,
35
- showIconTitle: {
36
- type: Boolean as PropType<VxeIconPickerPropTypes.ShowIconTitle>,
37
- default: () => getConfig().iconPicker.showIconTitle
38
- },
39
- readonly: {
40
- type: Boolean as PropType<VxeIconPickerPropTypes.Readonly>,
41
- default: null
42
- },
43
- disabled: {
44
- type: Boolean as PropType<VxeIconPickerPropTypes.Disabled>,
45
- default: null
46
- },
47
- icons: Array as PropType<VxeIconPickerPropTypes.Icons>,
48
- placement: String as PropType<VxeIconPickerPropTypes.Placement>,
49
- popupConfig: Object as PropType<VxeIconPickerPropTypes.PopupConfig>,
50
- transfer: {
51
- type: Boolean as PropType<VxeIconPickerPropTypes.Transfer>,
52
- default: null
53
- }
54
- },
55
- inject: {
56
- $xeModal: {
57
- default: null
58
- },
59
- $xeDrawer: {
60
- default: null
61
- },
62
- $xeTable: {
63
- default: null
64
- },
65
- $xeForm: {
66
- default: null
67
- },
68
- formItemInfo: {
69
- from: 'xeFormItemInfo',
70
- default: null
71
- }
72
- },
73
- provide () {
74
- const $xeIconPicker = this
75
- return {
76
- $xeIconPicker
77
- }
78
- },
79
- data () {
80
- const reactData: IconPickerReactData = {
81
- initialized: false,
82
- selectIcon: '',
83
- panelIndex: 0,
84
- panelStyle: {},
85
- panelPlacement: null,
86
- visiblePanel: false,
87
- isAniVisible: false,
88
- isActivated: false
89
- }
90
- const internalData: IconPickerInternalData = {
91
- hpTimeout: undefined
92
- }
93
- return {
94
- xID: XEUtils.uniqueId(),
95
- reactData,
96
- internalData
97
- }
98
- },
99
- computed: {
100
- ...({} as {
101
- computeSize(): VxeComponentSizeType
102
- $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
103
- $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
104
- $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
105
- $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
106
- formItemInfo(): VxeFormDefines.ProvideItemInfo | null
107
- }),
108
- computeFormReadonly () {
109
- const $xeIconPicker = this
110
- const props = $xeIconPicker
111
- const $xeForm = $xeIconPicker.$xeForm
112
-
113
- const { readonly } = props
114
- if (readonly === null) {
115
- if ($xeForm) {
116
- return $xeForm.readonly
117
- }
118
- return false
119
- }
120
- return readonly
121
- },
122
- computeIsDisabled () {
123
- const $xeIconPicker = this
124
- const props = $xeIconPicker
125
- const $xeForm = $xeIconPicker.$xeForm
126
-
127
- const { disabled } = props
128
- if (disabled === null) {
129
- if ($xeForm) {
130
- return $xeForm.disabled
131
- }
132
- return false
133
- }
134
- return disabled
135
- },
136
- computeBtnTransfer () {
137
- const $xeIconPicker = this
138
- const props = $xeIconPicker
139
- const $xeTable = $xeIconPicker.$xeTable
140
- const $xeModal = $xeIconPicker.$xeModal
141
- const $xeDrawer = $xeIconPicker.$xeDrawer
142
- const $xeForm = $xeIconPicker.$xeForm
143
-
144
- const { transfer } = props
145
- const popupOpts = $xeIconPicker.computePopupOpts as VxeIconPickerPropTypes.PopupConfig
146
- if (XEUtils.isBoolean(popupOpts.transfer)) {
147
- return popupOpts.transfer
148
- }
149
- if (transfer === null) {
150
- const globalTransfer = getConfig().iconPicker.transfer
151
- if (XEUtils.isBoolean(globalTransfer)) {
152
- return globalTransfer
153
- }
154
- if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
155
- return true
156
- }
157
- }
158
- return transfer
159
- },
160
- computeInpPlaceholder () {
161
- const $xeIconPicker = this
162
- const props = $xeIconPicker
163
-
164
- const { placeholder } = props
165
- if (placeholder) {
166
- return getFuncText(placeholder)
167
- }
168
- const globalPlaceholder = getConfig().select.placeholder
169
- if (globalPlaceholder) {
170
- return getFuncText(globalPlaceholder)
171
- }
172
- return getI18n('vxe.base.pleaseSelect')
173
- },
174
- computeIconList () {
175
- const $xeIconPicker = this
176
- const props = $xeIconPicker
177
-
178
- let { icons } = props
179
- if (!icons || !icons.length) {
180
- icons = getConfig().iconPicker.icons || []
181
- }
182
- return icons.map(item => {
183
- if (XEUtils.isString(item)) {
184
- return {
185
- title: item,
186
- icon: `vxe-icon-${`${item || ''}`.replace(/^vxe-icon-/, '')}`
187
- }
188
- }
189
- return {
190
- title: `${item.title || ''}`,
191
- icon: item.icon || '',
192
- iconRender: item.iconRender
193
- }
194
- })
195
- },
196
- computePopupOpts () {
197
- const $xeIconPicker = this
198
- const props = $xeIconPicker
199
-
200
- return Object.assign({}, getConfig().iconPicker.popupConfig, props.popupConfig)
201
- },
202
- computeIconGroupList () {
203
- const $xeIconPicker = this
204
-
205
- const iconList = $xeIconPicker.computeIconList as {
206
- title: string
207
- icon: string
208
- iconRender: VxeIconPickerDefines.OptionIconRender
209
- }[]
210
- return XEUtils.chunk(iconList, 4)
211
- },
212
- computeSelectIconItem () {
213
- const $xeIconPicker = this
214
- const reactData = ($xeIconPicker as any).reactData
215
-
216
- const { selectIcon } = reactData
217
- const iconList = $xeIconPicker.computeIconList as {
218
- title: string
219
- icon: string
220
- iconRender: VxeIconPickerDefines.OptionIconRender
221
- }[]
222
- return selectIcon ? iconList.find(item => item.icon === selectIcon) : null
223
- }
224
- },
225
- methods: {
226
- //
227
- // Method
228
- //
229
- dispatchEvent (type: ValueOf<VxeIconPickerEmits>, params: Record<string, any>, evnt: Event | null) {
230
- const $xeIconPicker = this
231
- $xeIconPicker.$emit(type, createEvent(evnt, { $iconPicker: $xeIconPicker }, params))
232
- },
233
- emitModel (value: any) {
234
- const $xeIconPicker = this
235
-
236
- const { _events } = $xeIconPicker as any
237
- if (_events && _events.modelValue) {
238
- $xeIconPicker.$emit('modelValue', value)
239
- } else {
240
- $xeIconPicker.$emit('model-value', value)
241
- }
242
- },
243
- isPanelVisible () {
244
- const $xeIconPicker = this
245
- const reactData = $xeIconPicker.reactData
246
-
247
- return reactData.visiblePanel
248
- },
249
- togglePanel () {
250
- const $xeIconPicker = this
251
- const reactData = $xeIconPicker.reactData
252
-
253
- if (reactData.visiblePanel) {
254
- $xeIconPicker.hideOptionPanel()
255
- } else {
256
- $xeIconPicker.showOptionPanel()
257
- }
258
- return $xeIconPicker.$nextTick()
259
- },
260
- hidePanel () {
261
- const $xeIconPicker = this
262
- const reactData = $xeIconPicker.reactData
263
-
264
- if (reactData.visiblePanel) {
265
- $xeIconPicker.hideOptionPanel()
266
- }
267
- return $xeIconPicker.$nextTick()
268
- },
269
- showPanel () {
270
- const $xeIconPicker = this
271
- const reactData = $xeIconPicker.reactData
272
-
273
- if (!reactData.visiblePanel) {
274
- $xeIconPicker.showOptionPanel()
275
- }
276
- return $xeIconPicker.$nextTick()
277
- },
278
- focus () {
279
- const $xeIconPicker = this
280
- const reactData = $xeIconPicker.reactData
281
-
282
- const $input = $xeIconPicker.$refs.refInput as HTMLInputElement
283
- reactData.isActivated = true
284
- $input.blur()
285
- return $xeIconPicker.$nextTick()
286
- },
287
- blur () {
288
- const $xeIconPicker = this
289
- const reactData = $xeIconPicker.reactData
290
-
291
- const $input = $xeIconPicker.$refs.refInput as HTMLInputElement
292
- $input.blur()
293
- reactData.isActivated = false
294
- return $xeIconPicker.$nextTick()
295
- },
296
- updateZindex () {
297
- const $xeIconPicker = this
298
- const reactData = $xeIconPicker.reactData
299
-
300
- if (reactData.panelIndex < getLastZIndex()) {
301
- reactData.panelIndex = nextZIndex()
302
- }
303
- },
304
- updatePlacement () {
305
- const $xeIconPicker = this
306
- const props = $xeIconPicker
307
- const reactData = $xeIconPicker.reactData
308
-
309
- const { placement } = props
310
- const { panelIndex } = reactData
311
- const targetElem = $xeIconPicker.$refs.refElem as HTMLElement
312
- const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLDivElement
313
- const btnTransfer = $xeIconPicker.computeBtnTransfer
314
- const popupOpts = $xeIconPicker.computePopupOpts
315
- const handleStyle = () => {
316
- const ppObj = updatePanelPlacement(targetElem, panelElem, {
317
- placement: popupOpts.placement || placement,
318
- teleportTo: btnTransfer
319
- })
320
- const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
321
- zIndex: panelIndex
322
- })
323
- reactData.panelStyle = panelStyle
324
- reactData.panelPlacement = ppObj.placement
325
- }
326
- handleStyle()
327
- return $xeIconPicker.$nextTick().then(handleStyle)
328
- },
329
- showOptionPanel () {
330
- const $xeIconPicker = this
331
- const reactData = $xeIconPicker.reactData
332
- const internalData = $xeIconPicker.internalData
333
-
334
- const { hpTimeout } = internalData
335
- const isDisabled = $xeIconPicker.computeIsDisabled
336
- if (!isDisabled) {
337
- if (hpTimeout) {
338
- clearTimeout(hpTimeout)
339
- internalData.hpTimeout = undefined
340
- }
341
- const btnTransfer = $xeIconPicker.computeBtnTransfer
342
- const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement
343
- if (!reactData.initialized) {
344
- reactData.initialized = true
345
- if (btnTransfer) {
346
- if (panelElem) {
347
- document.body.appendChild(panelElem)
348
- }
349
- }
350
- }
351
- reactData.isActivated = true
352
- reactData.isAniVisible = true
353
- setTimeout(() => {
354
- reactData.visiblePanel = true
355
- $xeIconPicker.updatePlacement()
356
- }, 10)
357
- $xeIconPicker.updateZindex()
358
- $xeIconPicker.updatePlacement()
359
- }
360
- },
361
- hideOptionPanel () {
362
- const $xeIconPicker = this
363
- const reactData = $xeIconPicker.reactData
364
- const internalData = $xeIconPicker.internalData
365
-
366
- reactData.visiblePanel = false
367
- internalData.hpTimeout = setTimeout(() => {
368
- reactData.isAniVisible = false
369
- }, 350)
370
- },
371
- changeEvent (evnt: Event, selectValue: any) {
372
- const $xeIconPicker = this
373
- const props = $xeIconPicker
374
- const reactData = $xeIconPicker.reactData
375
- const $xeForm = $xeIconPicker.$xeForm
376
- const formItemInfo = $xeIconPicker.formItemInfo
377
-
378
- reactData.selectIcon = selectValue
379
- if (selectValue !== props.value) {
380
- $xeIconPicker.emitModel(selectValue)
381
- $xeIconPicker.dispatchEvent('change', { value: selectValue }, evnt)
382
- // 自动更新校验状态
383
- if ($xeForm && formItemInfo) {
384
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, selectValue)
385
- }
386
- }
387
- },
388
- focusEvent () {
389
- const $xeIconPicker = this
390
- const reactData = $xeIconPicker.reactData
391
-
392
- const isDisabled = $xeIconPicker.computeIsDisabled
393
- if (!isDisabled) {
394
- if (!reactData.visiblePanel) {
395
- $xeIconPicker.showOptionPanel()
396
- }
397
- }
398
- },
399
- blurEvent () {
400
- const $xeIconPicker = this
401
- const reactData = $xeIconPicker.reactData
402
-
403
- reactData.isActivated = false
404
- },
405
- clearValueEvent (evnt: Event, selectValue: any) {
406
- const $xeIconPicker = this
407
-
408
- $xeIconPicker.changeEvent(evnt, selectValue)
409
- $xeIconPicker.dispatchEvent('clear', { value: selectValue }, evnt)
410
- },
411
- clearEvent (params: any, evnt: Event) {
412
- const $xeIconPicker = this
413
-
414
- $xeIconPicker.clearValueEvent(evnt, null)
415
- $xeIconPicker.hideOptionPanel()
416
- },
417
- togglePanelEvent (evnt: MouseEvent) {
418
- const $xeIconPicker = this
419
- const reactData = $xeIconPicker.reactData
420
-
421
- evnt.preventDefault()
422
- if (reactData.visiblePanel) {
423
- $xeIconPicker.hideOptionPanel()
424
- } else {
425
- $xeIconPicker.showOptionPanel()
426
- }
427
- },
428
- clickEvent (evnt: MouseEvent) {
429
- const $xeIconPicker = this
430
-
431
- $xeIconPicker.togglePanelEvent(evnt)
432
- $xeIconPicker.dispatchEvent('click', {}, evnt)
433
- },
434
- handleGlobalMousewheelEvent (evnt: MouseEvent) {
435
- const $xeIconPicker = this
436
- const reactData = $xeIconPicker.reactData
437
-
438
- const { visiblePanel } = reactData
439
- const isDisabled = $xeIconPicker.computeIsDisabled
440
- if (!isDisabled) {
441
- if (visiblePanel) {
442
- const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement
443
- if (getEventTargetNode(evnt, panelElem).flag) {
444
- $xeIconPicker.updatePlacement()
445
- } else {
446
- $xeIconPicker.hideOptionPanel()
447
- }
448
- }
449
- }
450
- },
451
- handleGlobalMousedownEvent (evnt: MouseEvent) {
452
- const $xeIconPicker = this
453
- const reactData = $xeIconPicker.reactData
454
-
455
- const { visiblePanel } = reactData
456
- const isDisabled = $xeIconPicker.computeIsDisabled
457
- if (!isDisabled) {
458
- const el = $xeIconPicker.$refs.refElem as HTMLElement
459
- const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement
460
- reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
461
- if (visiblePanel && !reactData.isActivated) {
462
- $xeIconPicker.hideOptionPanel()
463
- }
464
- }
465
- },
466
- handleGlobalKeydownEvent (evnt: KeyboardEvent) {
467
- const $xeIconPicker = this
468
- const props = $xeIconPicker
469
- const reactData = $xeIconPicker.reactData
470
-
471
- const { clearable } = props
472
- const { visiblePanel } = reactData
473
- const isDisabled = $xeIconPicker.computeIsDisabled
474
- if (!isDisabled) {
475
- const isTab = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.TAB)
476
- const isEnter = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ENTER)
477
- const isEsc = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ESCAPE)
478
- const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
479
- const isDwArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
480
- const isDel = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.DELETE)
481
- const isSpacebar = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.SPACEBAR)
482
- if (isTab) {
483
- reactData.isActivated = false
484
- }
485
- if (visiblePanel) {
486
- if (isEsc || isTab) {
487
- $xeIconPicker.hideOptionPanel()
488
- } else if (isEnter) {
489
- evnt.preventDefault()
490
- evnt.stopPropagation()
491
- // changeOptionEvent(evnt, currentValue, currentOption)
492
- } else if (isUpArrow || isDwArrow) {
493
- evnt.preventDefault()
494
- // let { firstOption, offsetOption } = findOffsetOption(currentValue, isUpArrow)
495
- // if (!offsetOption && !findVisibleOption(currentValue)) {
496
- // offsetOption = firstOption
497
- // }
498
- // setCurrentOption(offsetOption)
499
- // scrollToOption(offsetOption, isDwArrow)
500
- } else if (isSpacebar) {
501
- evnt.preventDefault()
502
- }
503
- } else if ((isUpArrow || isDwArrow || isEnter || isSpacebar) && reactData.isActivated) {
504
- evnt.preventDefault()
505
- $xeIconPicker.showOptionPanel()
506
- }
507
- if (reactData.isActivated) {
508
- if (isDel && clearable) {
509
- $xeIconPicker.clearValueEvent(evnt, null)
510
- }
511
- }
512
- }
513
- },
514
- handleGlobalBlurEvent () {
515
- const $xeIconPicker = this
516
- const reactData = $xeIconPicker.reactData
517
-
518
- const { visiblePanel, isActivated } = reactData
519
- if (visiblePanel) {
520
- $xeIconPicker.hideOptionPanel()
521
- }
522
- if (isActivated) {
523
- reactData.isActivated = false
524
- }
525
- if (visiblePanel || isActivated) {
526
- const $input = $xeIconPicker.$refs.refInput as VxeInputConstructor
527
- if ($input) {
528
- $input.blur()
529
- }
530
- }
531
- },
532
- handleClickIconEvent (evnt: MouseEvent, item: VxeIconPickerDefines.IconItemObj) {
533
- const $xeIconPicker = this
534
-
535
- const value = item.icon
536
- $xeIconPicker.changeEvent(evnt, value)
537
- $xeIconPicker.hideOptionPanel()
538
- },
539
-
540
- //
541
- // Render
542
- //
543
- renderIconWrapper (h: CreateElement) {
544
- const $xeIconPicker = this
545
- const props = $xeIconPicker
546
- const reactData = $xeIconPicker.reactData
547
-
548
- const { showIconTitle } = props
549
- const { selectIcon } = reactData
550
- const iconGroupList = $xeIconPicker.computeIconGroupList
551
- const isDisabled = $xeIconPicker.computeIsDisabled
552
-
553
- return h('div', {
554
- class: 'vxe-ico-picker--list-wrapper'
555
- }, iconGroupList.map(list => {
556
- return h('div', {
557
- class: 'vxe-ico-picker--list'
558
- }, list.map(item => {
559
- const { iconRender } = item
560
- const compConf = iconRender ? renderer.get(iconRender.name) : null
561
- const oIconMethod = compConf ? compConf.renderIconPickerOptionIcon : null
562
- return h('div', {
563
- class: ['vxe-ico-picker--item', {
564
- 'is--selected': selectIcon === item.icon
565
- }],
566
- on: {
567
- click (evnt: MouseEvent) {
568
- if (!isDisabled) {
569
- $xeIconPicker.handleClickIconEvent(evnt, item)
570
- }
571
- }
572
- }
573
- }, [
574
- h('div', {
575
- class: 'vxe-ico-picker--item-icon'
576
- }, oIconMethod && iconRender
577
- ? getSlotVNs(oIconMethod.call($xeIconPicker, h, iconRender, { $iconPicker: $xeIconPicker, option: item }))
578
- : [
579
- h('i', {
580
- class: item.icon || ''
581
- })
582
- ]),
583
- showIconTitle
584
- ? h('div', {
585
- class: 'vxe-ico-picker--item-title'
586
- }, `${item.title || ''}`)
587
- : renderEmptyElement($xeIconPicker)
588
- ])
589
- }))
590
- }))
591
- },
592
- renderIconView (h: CreateElement) {
593
- const $xeIconPicker = this
594
- const reactData = $xeIconPicker.reactData
595
-
596
- const { selectIcon } = reactData
597
- const selectIconItem = $xeIconPicker.computeSelectIconItem
598
- if (selectIconItem) {
599
- const { iconRender } = selectIconItem
600
- const compConf = iconRender ? renderer.get(iconRender.name) : null
601
- const oIconMethod = compConf ? compConf.renderIconPickerOptionIcon : null
602
- if (oIconMethod && iconRender) {
603
- return h('div', {
604
- key: 'inc',
605
- class: 'vxe-ico-picker--icon'
606
- }, getSlotVNs(oIconMethod.call($xeIconPicker, h, iconRender, { $iconPicker: $xeIconPicker, option: selectIconItem })))
607
- }
608
- }
609
- return h('div', {
610
- key: 'ind',
611
- class: 'vxe-ico-picker--icon'
612
- }, [
613
- h('i', {
614
- class: selectIcon
615
- })
616
- ])
617
- },
618
- renderVN (h: CreateElement): VNode {
619
- const $xeIconPicker = this
620
- const props = $xeIconPicker
621
- const reactData = $xeIconPicker.reactData
622
-
623
- const { className, clearable } = props
624
- const { initialized, isActivated, isAniVisible, visiblePanel, selectIcon } = reactData
625
- const vSize = $xeIconPicker.computeSize
626
- const isDisabled = $xeIconPicker.computeIsDisabled
627
- const btnTransfer = $xeIconPicker.computeBtnTransfer
628
- const formReadonly = $xeIconPicker.computeFormReadonly
629
- const inpPlaceholder = $xeIconPicker.computeInpPlaceholder
630
- const popupOpts = $xeIconPicker.computePopupOpts
631
- const ppClassName = popupOpts.className || props.popupClassName
632
-
633
- if (formReadonly) {
634
- return h('div', {
635
- ref: 'refElem',
636
- class: ['vxe-ico-picker--readonly', className]
637
- }, [
638
- h('i', {
639
- class: selectIcon
640
- })
641
- ])
642
- }
643
- return h('div', {
644
- ref: 'refElem',
645
- class: ['vxe-ico-picker', className ? (XEUtils.isFunction(className) ? className({ $iconPicker: $xeIconPicker }) : className) : '', {
646
- [`size--${vSize}`]: vSize,
647
- 'show--clear': clearable && !isDisabled && !!selectIcon,
648
- 'is--visible': visiblePanel,
649
- 'is--disabled': isDisabled,
650
- 'is--active': isActivated
651
- }]
652
- }, [
653
- h('div', {
654
- class: 'vxe-ico-picker--inner',
655
- on: {
656
- click: $xeIconPicker.clickEvent
657
- }
658
- }, [
659
- h('input', {
660
- ref: 'refInput',
661
- class: 'vxe-ico-picker--input',
662
- on: {
663
- focus: $xeIconPicker.focusEvent,
664
- blur: $xeIconPicker.blurEvent
665
- }
666
- }),
667
- selectIcon
668
- ? $xeIconPicker.renderIconView(h)
669
- : h('div', {
670
- class: 'vxe-ico-picker--placeholder'
671
- }, inpPlaceholder),
672
- h('div', {
673
- class: 'vxe-ico-picker--suffix'
674
- }, [
675
- h('div', {
676
- class: 'vxe-ico-picker--clear-icon',
677
- on: {
678
- click: $xeIconPicker.clearEvent
679
- }
680
- }, [
681
- h('i', {
682
- class: getIcon().INPUT_CLEAR
683
- })
684
- ]),
685
- h('div', {
686
- class: 'vxe-ico-picker--suffix-icon'
687
- }, [
688
- h('i', {
689
- class: visiblePanel ? getIcon().ICON_PICKER_OPEN : getIcon().ICON_PICKER_CLOSE
690
- })
691
- ])
692
- ])
693
- ]),
694
- h('div', {
695
- ref: 'refOptionPanel',
696
- class: ['vxe-table--ignore-clear vxe-ico-picker--panel', ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $iconPicker: $xeIconPicker }) : ppClassName) : '', {
697
- [`size--${vSize}`]: vSize,
698
- 'is--transfer': btnTransfer,
699
- 'ani--leave': isAniVisible,
700
- 'ani--enter': visiblePanel
701
- }],
702
- attrs: {
703
- placement: reactData.panelPlacement
704
- },
705
- style: reactData.panelStyle
706
- }, [
707
- initialized && (visiblePanel || isAniVisible)
708
- ? h('div', {
709
- class: 'vxe-ico-picker--panel-wrapper'
710
- }, [
711
- $xeIconPicker.renderIconWrapper(h)
712
- ])
713
- : renderEmptyElement($xeIconPicker)
714
- ])
715
- ])
716
- }
717
- },
718
- watch: {
719
- value (val) {
720
- const $xeIconPicker = this
721
- const reactData = $xeIconPicker.reactData
722
-
723
- reactData.selectIcon = `${val || ''}`
724
- }
725
- },
726
- created () {
727
- const $xeIconPicker = this
728
- const props = $xeIconPicker
729
- const reactData = $xeIconPicker.reactData
730
-
731
- reactData.selectIcon = `${props.value || ''}`
732
- globalEvents.on($xeIconPicker, 'mousewheel', $xeIconPicker.handleGlobalMousewheelEvent)
733
- globalEvents.on($xeIconPicker, 'mousedown', $xeIconPicker.handleGlobalMousedownEvent)
734
- globalEvents.on($xeIconPicker, 'keydown', $xeIconPicker.handleGlobalKeydownEvent)
735
- globalEvents.on($xeIconPicker, 'blur', $xeIconPicker.handleGlobalBlurEvent)
736
- },
737
- beforeDestroy () {
738
- const $xeIconPicker = this
739
-
740
- const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement | undefined
741
- if (panelElem && panelElem.parentNode) {
742
- panelElem.parentNode.removeChild(panelElem)
743
- }
744
- globalEvents.off($xeIconPicker, 'mousewheel')
745
- globalEvents.off($xeIconPicker, 'mousedown')
746
- globalEvents.off($xeIconPicker, 'keydown')
747
- globalEvents.off($xeIconPicker, 'blur')
748
- },
749
- render (this: any, h) {
750
- return this.renderVN(h)
751
- }
752
- }) /* define-vxe-component end */
1
+ import { PropType, CreateElement, VNode } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { getConfig, getIcon, getI18n, globalEvents, renderer, createEvent, globalMixins, GLOBAL_EVENT_KEYS, renderEmptyElement } from '../../ui'
5
+ import { getEventTargetNode, updatePanelPlacement } from '../../ui/src/dom'
6
+ import { getLastZIndex, nextZIndex, getFuncText } from '../../ui/src/utils'
7
+ import { getSlotVNs } from '../../ui/src/vn'
8
+
9
+ import type { VxeIconPickerPropTypes, IconPickerInternalData, ValueOf, IconPickerReactData, VxeInputConstructor, VxeComponentSizeType, VxeIconPickerEmits, VxeIconPickerDefines, VxeDrawerConstructor, VxeDrawerMethods, VxeFormDefines, VxeFormConstructor, VxeFormPrivateMethods, VxeModalConstructor, VxeModalMethods } from '../../../types'
10
+ import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
11
+
12
+ export default /* define-vxe-component start */ defineVxeComponent({
13
+ name: 'VxeIconPicker',
14
+ mixins: [
15
+ globalMixins.sizeMixin
16
+ ],
17
+ model: {
18
+ prop: 'value',
19
+ event: 'modelValue'
20
+ },
21
+ props: {
22
+ value: String as PropType<VxeIconPickerPropTypes.ModelValue>,
23
+ placeholder: String as PropType<VxeIconPickerPropTypes.Placeholder>,
24
+ clearable: Boolean as PropType<VxeIconPickerPropTypes.Clearable>,
25
+ size: {
26
+ type: String as PropType<VxeIconPickerPropTypes.Size>,
27
+ default: () => getConfig().iconPicker.size || getConfig().size
28
+ },
29
+ className: [String, Function] as PropType<VxeIconPickerPropTypes.ClassName>,
30
+ /**
31
+ * 已废弃,请使用 popupConfig.className
32
+ * @deprecated
33
+ */
34
+ popupClassName: [String, Function] as PropType<VxeIconPickerPropTypes.PopupClassName>,
35
+ showIconTitle: {
36
+ type: Boolean as PropType<VxeIconPickerPropTypes.ShowIconTitle>,
37
+ default: () => getConfig().iconPicker.showIconTitle
38
+ },
39
+ readonly: {
40
+ type: Boolean as PropType<VxeIconPickerPropTypes.Readonly>,
41
+ default: null
42
+ },
43
+ disabled: {
44
+ type: Boolean as PropType<VxeIconPickerPropTypes.Disabled>,
45
+ default: null
46
+ },
47
+ icons: Array as PropType<VxeIconPickerPropTypes.Icons>,
48
+ placement: String as PropType<VxeIconPickerPropTypes.Placement>,
49
+ popupConfig: Object as PropType<VxeIconPickerPropTypes.PopupConfig>,
50
+ transfer: {
51
+ type: Boolean as PropType<VxeIconPickerPropTypes.Transfer>,
52
+ default: null
53
+ }
54
+ },
55
+ inject: {
56
+ $xeModal: {
57
+ default: null
58
+ },
59
+ $xeDrawer: {
60
+ default: null
61
+ },
62
+ $xeTable: {
63
+ default: null
64
+ },
65
+ $xeForm: {
66
+ default: null
67
+ },
68
+ formItemInfo: {
69
+ from: 'xeFormItemInfo',
70
+ default: null
71
+ }
72
+ },
73
+ provide () {
74
+ const $xeIconPicker = this
75
+ return {
76
+ $xeIconPicker
77
+ }
78
+ },
79
+ data () {
80
+ const reactData: IconPickerReactData = {
81
+ initialized: false,
82
+ selectIcon: '',
83
+ panelIndex: 0,
84
+ panelStyle: {},
85
+ panelPlacement: null,
86
+ visiblePanel: false,
87
+ isAniVisible: false,
88
+ isActivated: false
89
+ }
90
+ const internalData: IconPickerInternalData = {
91
+ hpTimeout: undefined
92
+ }
93
+ return {
94
+ xID: XEUtils.uniqueId(),
95
+ reactData,
96
+ internalData
97
+ }
98
+ },
99
+ computed: {
100
+ ...({} as {
101
+ computeSize(): VxeComponentSizeType
102
+ $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
103
+ $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
104
+ $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
105
+ $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
106
+ formItemInfo(): VxeFormDefines.ProvideItemInfo | null
107
+ }),
108
+ computeFormReadonly () {
109
+ const $xeIconPicker = this
110
+ const props = $xeIconPicker
111
+ const $xeForm = $xeIconPicker.$xeForm
112
+
113
+ const { readonly } = props
114
+ if (readonly === null) {
115
+ if ($xeForm) {
116
+ return $xeForm.readonly
117
+ }
118
+ return false
119
+ }
120
+ return readonly
121
+ },
122
+ computeIsDisabled () {
123
+ const $xeIconPicker = this
124
+ const props = $xeIconPicker
125
+ const $xeForm = $xeIconPicker.$xeForm
126
+
127
+ const { disabled } = props
128
+ if (disabled === null) {
129
+ if ($xeForm) {
130
+ return $xeForm.disabled
131
+ }
132
+ return false
133
+ }
134
+ return disabled
135
+ },
136
+ computeBtnTransfer () {
137
+ const $xeIconPicker = this
138
+ const props = $xeIconPicker
139
+ const $xeTable = $xeIconPicker.$xeTable
140
+ const $xeModal = $xeIconPicker.$xeModal
141
+ const $xeDrawer = $xeIconPicker.$xeDrawer
142
+ const $xeForm = $xeIconPicker.$xeForm
143
+
144
+ const { transfer } = props
145
+ const popupOpts = $xeIconPicker.computePopupOpts as VxeIconPickerPropTypes.PopupConfig
146
+ if (XEUtils.isBoolean(popupOpts.transfer)) {
147
+ return popupOpts.transfer
148
+ }
149
+ if (transfer === null) {
150
+ const globalTransfer = getConfig().iconPicker.transfer
151
+ if (XEUtils.isBoolean(globalTransfer)) {
152
+ return globalTransfer
153
+ }
154
+ if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
155
+ return true
156
+ }
157
+ }
158
+ return transfer
159
+ },
160
+ computeInpPlaceholder () {
161
+ const $xeIconPicker = this
162
+ const props = $xeIconPicker
163
+
164
+ const { placeholder } = props
165
+ if (placeholder) {
166
+ return getFuncText(placeholder)
167
+ }
168
+ const globalPlaceholder = getConfig().select.placeholder
169
+ if (globalPlaceholder) {
170
+ return getFuncText(globalPlaceholder)
171
+ }
172
+ return getI18n('vxe.base.pleaseSelect')
173
+ },
174
+ computeIconList () {
175
+ const $xeIconPicker = this
176
+ const props = $xeIconPicker
177
+
178
+ let { icons } = props
179
+ if (!icons || !icons.length) {
180
+ icons = getConfig().iconPicker.icons || []
181
+ }
182
+ return icons.map(item => {
183
+ if (XEUtils.isString(item)) {
184
+ return {
185
+ title: item,
186
+ icon: `vxe-icon-${`${item || ''}`.replace(/^vxe-icon-/, '')}`
187
+ }
188
+ }
189
+ return {
190
+ title: `${item.title || ''}`,
191
+ icon: item.icon || '',
192
+ iconRender: item.iconRender
193
+ }
194
+ })
195
+ },
196
+ computePopupOpts () {
197
+ const $xeIconPicker = this
198
+ const props = $xeIconPicker
199
+
200
+ return Object.assign({}, getConfig().iconPicker.popupConfig, props.popupConfig)
201
+ },
202
+ computeIconGroupList () {
203
+ const $xeIconPicker = this
204
+
205
+ const iconList = $xeIconPicker.computeIconList as {
206
+ title: string
207
+ icon: string
208
+ iconRender: VxeIconPickerDefines.OptionIconRender
209
+ }[]
210
+ return XEUtils.chunk(iconList, 4)
211
+ },
212
+ computeSelectIconItem () {
213
+ const $xeIconPicker = this
214
+ const reactData = ($xeIconPicker as any).reactData
215
+
216
+ const { selectIcon } = reactData
217
+ const iconList = $xeIconPicker.computeIconList as {
218
+ title: string
219
+ icon: string
220
+ iconRender: VxeIconPickerDefines.OptionIconRender
221
+ }[]
222
+ return selectIcon ? iconList.find(item => item.icon === selectIcon) : null
223
+ }
224
+ },
225
+ methods: {
226
+ //
227
+ // Method
228
+ //
229
+ dispatchEvent (type: ValueOf<VxeIconPickerEmits>, params: Record<string, any>, evnt: Event | null) {
230
+ const $xeIconPicker = this
231
+ $xeIconPicker.$emit(type, createEvent(evnt, { $iconPicker: $xeIconPicker }, params))
232
+ },
233
+ emitModel (value: any) {
234
+ const $xeIconPicker = this
235
+
236
+ const { _events } = $xeIconPicker as any
237
+ if (_events && _events.modelValue) {
238
+ $xeIconPicker.$emit('modelValue', value)
239
+ } else {
240
+ $xeIconPicker.$emit('model-value', value)
241
+ }
242
+ },
243
+ isPanelVisible () {
244
+ const $xeIconPicker = this
245
+ const reactData = $xeIconPicker.reactData
246
+
247
+ return reactData.visiblePanel
248
+ },
249
+ togglePanel () {
250
+ const $xeIconPicker = this
251
+ const reactData = $xeIconPicker.reactData
252
+
253
+ if (reactData.visiblePanel) {
254
+ $xeIconPicker.hideOptionPanel()
255
+ } else {
256
+ $xeIconPicker.showOptionPanel()
257
+ }
258
+ return $xeIconPicker.$nextTick()
259
+ },
260
+ hidePanel () {
261
+ const $xeIconPicker = this
262
+ const reactData = $xeIconPicker.reactData
263
+
264
+ if (reactData.visiblePanel) {
265
+ $xeIconPicker.hideOptionPanel()
266
+ }
267
+ return $xeIconPicker.$nextTick()
268
+ },
269
+ showPanel () {
270
+ const $xeIconPicker = this
271
+ const reactData = $xeIconPicker.reactData
272
+
273
+ if (!reactData.visiblePanel) {
274
+ $xeIconPicker.showOptionPanel()
275
+ }
276
+ return $xeIconPicker.$nextTick()
277
+ },
278
+ focus () {
279
+ const $xeIconPicker = this
280
+ const reactData = $xeIconPicker.reactData
281
+
282
+ const $input = $xeIconPicker.$refs.refInput as HTMLInputElement
283
+ reactData.isActivated = true
284
+ $input.blur()
285
+ return $xeIconPicker.$nextTick()
286
+ },
287
+ blur () {
288
+ const $xeIconPicker = this
289
+ const reactData = $xeIconPicker.reactData
290
+
291
+ const $input = $xeIconPicker.$refs.refInput as HTMLInputElement
292
+ $input.blur()
293
+ reactData.isActivated = false
294
+ return $xeIconPicker.$nextTick()
295
+ },
296
+ updateZindex () {
297
+ const $xeIconPicker = this
298
+ const reactData = $xeIconPicker.reactData
299
+
300
+ if (reactData.panelIndex < getLastZIndex()) {
301
+ reactData.panelIndex = nextZIndex()
302
+ }
303
+ },
304
+ updatePlacement () {
305
+ const $xeIconPicker = this
306
+ const props = $xeIconPicker
307
+ const reactData = $xeIconPicker.reactData
308
+
309
+ const { placement } = props
310
+ const { panelIndex } = reactData
311
+ const targetElem = $xeIconPicker.$refs.refElem as HTMLElement
312
+ const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLDivElement
313
+ const btnTransfer = $xeIconPicker.computeBtnTransfer
314
+ const popupOpts = $xeIconPicker.computePopupOpts
315
+ const handleStyle = () => {
316
+ const ppObj = updatePanelPlacement(targetElem, panelElem, {
317
+ placement: popupOpts.placement || placement,
318
+ teleportTo: btnTransfer
319
+ })
320
+ const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
321
+ zIndex: panelIndex
322
+ })
323
+ reactData.panelStyle = panelStyle
324
+ reactData.panelPlacement = ppObj.placement
325
+ }
326
+ handleStyle()
327
+ return $xeIconPicker.$nextTick().then(handleStyle)
328
+ },
329
+ showOptionPanel () {
330
+ const $xeIconPicker = this
331
+ const reactData = $xeIconPicker.reactData
332
+ const internalData = $xeIconPicker.internalData
333
+
334
+ const { hpTimeout } = internalData
335
+ const isDisabled = $xeIconPicker.computeIsDisabled
336
+ if (!isDisabled) {
337
+ if (hpTimeout) {
338
+ clearTimeout(hpTimeout)
339
+ internalData.hpTimeout = undefined
340
+ }
341
+ const btnTransfer = $xeIconPicker.computeBtnTransfer
342
+ const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement
343
+ if (!reactData.initialized) {
344
+ reactData.initialized = true
345
+ if (btnTransfer) {
346
+ if (panelElem) {
347
+ document.body.appendChild(panelElem)
348
+ }
349
+ }
350
+ }
351
+ reactData.isActivated = true
352
+ reactData.isAniVisible = true
353
+ setTimeout(() => {
354
+ reactData.visiblePanel = true
355
+ $xeIconPicker.updatePlacement()
356
+ }, 10)
357
+ $xeIconPicker.updateZindex()
358
+ $xeIconPicker.updatePlacement()
359
+ }
360
+ },
361
+ hideOptionPanel () {
362
+ const $xeIconPicker = this
363
+ const reactData = $xeIconPicker.reactData
364
+ const internalData = $xeIconPicker.internalData
365
+
366
+ reactData.visiblePanel = false
367
+ internalData.hpTimeout = setTimeout(() => {
368
+ reactData.isAniVisible = false
369
+ }, 350)
370
+ },
371
+ changeEvent (evnt: Event, selectValue: any) {
372
+ const $xeIconPicker = this
373
+ const props = $xeIconPicker
374
+ const reactData = $xeIconPicker.reactData
375
+ const $xeForm = $xeIconPicker.$xeForm
376
+ const formItemInfo = $xeIconPicker.formItemInfo
377
+
378
+ reactData.selectIcon = selectValue
379
+ if (selectValue !== props.value) {
380
+ $xeIconPicker.emitModel(selectValue)
381
+ $xeIconPicker.dispatchEvent('change', { value: selectValue }, evnt)
382
+ // 自动更新校验状态
383
+ if ($xeForm && formItemInfo) {
384
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, selectValue)
385
+ }
386
+ }
387
+ },
388
+ focusEvent () {
389
+ const $xeIconPicker = this
390
+ const reactData = $xeIconPicker.reactData
391
+
392
+ const isDisabled = $xeIconPicker.computeIsDisabled
393
+ if (!isDisabled) {
394
+ if (!reactData.visiblePanel) {
395
+ $xeIconPicker.showOptionPanel()
396
+ }
397
+ }
398
+ },
399
+ blurEvent () {
400
+ const $xeIconPicker = this
401
+ const reactData = $xeIconPicker.reactData
402
+
403
+ reactData.isActivated = false
404
+ },
405
+ clearValueEvent (evnt: Event, selectValue: any) {
406
+ const $xeIconPicker = this
407
+
408
+ $xeIconPicker.changeEvent(evnt, selectValue)
409
+ $xeIconPicker.dispatchEvent('clear', { value: selectValue }, evnt)
410
+ },
411
+ clearEvent (params: any, evnt: Event) {
412
+ const $xeIconPicker = this
413
+
414
+ $xeIconPicker.clearValueEvent(evnt, null)
415
+ $xeIconPicker.hideOptionPanel()
416
+ },
417
+ togglePanelEvent (evnt: MouseEvent) {
418
+ const $xeIconPicker = this
419
+ const reactData = $xeIconPicker.reactData
420
+
421
+ evnt.preventDefault()
422
+ if (reactData.visiblePanel) {
423
+ $xeIconPicker.hideOptionPanel()
424
+ } else {
425
+ $xeIconPicker.showOptionPanel()
426
+ }
427
+ },
428
+ clickEvent (evnt: MouseEvent) {
429
+ const $xeIconPicker = this
430
+
431
+ $xeIconPicker.togglePanelEvent(evnt)
432
+ $xeIconPicker.dispatchEvent('click', {}, evnt)
433
+ },
434
+ handleGlobalMousewheelEvent (evnt: MouseEvent) {
435
+ const $xeIconPicker = this
436
+ const reactData = $xeIconPicker.reactData
437
+
438
+ const { visiblePanel } = reactData
439
+ const isDisabled = $xeIconPicker.computeIsDisabled
440
+ if (!isDisabled) {
441
+ if (visiblePanel) {
442
+ const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement
443
+ if (getEventTargetNode(evnt, panelElem).flag) {
444
+ $xeIconPicker.updatePlacement()
445
+ } else {
446
+ $xeIconPicker.hideOptionPanel()
447
+ }
448
+ }
449
+ }
450
+ },
451
+ handleGlobalMousedownEvent (evnt: MouseEvent) {
452
+ const $xeIconPicker = this
453
+ const reactData = $xeIconPicker.reactData
454
+
455
+ const { visiblePanel } = reactData
456
+ const isDisabled = $xeIconPicker.computeIsDisabled
457
+ if (!isDisabled) {
458
+ const el = $xeIconPicker.$refs.refElem as HTMLElement
459
+ const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement
460
+ reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
461
+ if (visiblePanel && !reactData.isActivated) {
462
+ $xeIconPicker.hideOptionPanel()
463
+ }
464
+ }
465
+ },
466
+ handleGlobalKeydownEvent (evnt: KeyboardEvent) {
467
+ const $xeIconPicker = this
468
+ const props = $xeIconPicker
469
+ const reactData = $xeIconPicker.reactData
470
+
471
+ const { clearable } = props
472
+ const { visiblePanel } = reactData
473
+ const isDisabled = $xeIconPicker.computeIsDisabled
474
+ if (!isDisabled) {
475
+ const isTab = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.TAB)
476
+ const isEnter = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ENTER)
477
+ const isEsc = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ESCAPE)
478
+ const isUpArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_UP)
479
+ const isDwArrow = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ARROW_DOWN)
480
+ const isDel = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.DELETE)
481
+ const isSpacebar = globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.SPACEBAR)
482
+ if (isTab) {
483
+ reactData.isActivated = false
484
+ }
485
+ if (visiblePanel) {
486
+ if (isEsc || isTab) {
487
+ $xeIconPicker.hideOptionPanel()
488
+ } else if (isEnter) {
489
+ evnt.preventDefault()
490
+ evnt.stopPropagation()
491
+ // changeOptionEvent(evnt, currentValue, currentOption)
492
+ } else if (isUpArrow || isDwArrow) {
493
+ evnt.preventDefault()
494
+ // let { firstOption, offsetOption } = findOffsetOption(currentValue, isUpArrow)
495
+ // if (!offsetOption && !findVisibleOption(currentValue)) {
496
+ // offsetOption = firstOption
497
+ // }
498
+ // setCurrentOption(offsetOption)
499
+ // scrollToOption(offsetOption, isDwArrow)
500
+ } else if (isSpacebar) {
501
+ evnt.preventDefault()
502
+ }
503
+ } else if ((isUpArrow || isDwArrow || isEnter || isSpacebar) && reactData.isActivated) {
504
+ evnt.preventDefault()
505
+ $xeIconPicker.showOptionPanel()
506
+ }
507
+ if (reactData.isActivated) {
508
+ if (isDel && clearable) {
509
+ $xeIconPicker.clearValueEvent(evnt, null)
510
+ }
511
+ }
512
+ }
513
+ },
514
+ handleGlobalBlurEvent () {
515
+ const $xeIconPicker = this
516
+ const reactData = $xeIconPicker.reactData
517
+
518
+ const { visiblePanel, isActivated } = reactData
519
+ if (visiblePanel) {
520
+ $xeIconPicker.hideOptionPanel()
521
+ }
522
+ if (isActivated) {
523
+ reactData.isActivated = false
524
+ }
525
+ if (visiblePanel || isActivated) {
526
+ const $input = $xeIconPicker.$refs.refInput as VxeInputConstructor
527
+ if ($input) {
528
+ $input.blur()
529
+ }
530
+ }
531
+ },
532
+ handleClickIconEvent (evnt: MouseEvent, item: VxeIconPickerDefines.IconItemObj) {
533
+ const $xeIconPicker = this
534
+
535
+ const value = item.icon
536
+ $xeIconPicker.changeEvent(evnt, value)
537
+ $xeIconPicker.hideOptionPanel()
538
+ },
539
+
540
+ //
541
+ // Render
542
+ //
543
+ renderIconWrapper (h: CreateElement) {
544
+ const $xeIconPicker = this
545
+ const props = $xeIconPicker
546
+ const reactData = $xeIconPicker.reactData
547
+
548
+ const { showIconTitle } = props
549
+ const { selectIcon } = reactData
550
+ const iconGroupList = $xeIconPicker.computeIconGroupList
551
+ const isDisabled = $xeIconPicker.computeIsDisabled
552
+
553
+ return h('div', {
554
+ class: 'vxe-ico-picker--list-wrapper'
555
+ }, iconGroupList.map(list => {
556
+ return h('div', {
557
+ class: 'vxe-ico-picker--list'
558
+ }, list.map(item => {
559
+ const { iconRender } = item
560
+ const compConf = iconRender ? renderer.get(iconRender.name) : null
561
+ const oIconMethod = compConf ? compConf.renderIconPickerOptionIcon : null
562
+ return h('div', {
563
+ class: ['vxe-ico-picker--item', {
564
+ 'is--selected': selectIcon === item.icon
565
+ }],
566
+ on: {
567
+ click (evnt: MouseEvent) {
568
+ if (!isDisabled) {
569
+ $xeIconPicker.handleClickIconEvent(evnt, item)
570
+ }
571
+ }
572
+ }
573
+ }, [
574
+ h('div', {
575
+ class: 'vxe-ico-picker--item-icon'
576
+ }, oIconMethod && iconRender
577
+ ? getSlotVNs(oIconMethod.call($xeIconPicker, h, iconRender, { $iconPicker: $xeIconPicker, option: item }))
578
+ : [
579
+ h('i', {
580
+ class: item.icon || ''
581
+ })
582
+ ]),
583
+ showIconTitle
584
+ ? h('div', {
585
+ class: 'vxe-ico-picker--item-title'
586
+ }, `${item.title || ''}`)
587
+ : renderEmptyElement($xeIconPicker)
588
+ ])
589
+ }))
590
+ }))
591
+ },
592
+ renderIconView (h: CreateElement) {
593
+ const $xeIconPicker = this
594
+ const reactData = $xeIconPicker.reactData
595
+
596
+ const { selectIcon } = reactData
597
+ const selectIconItem = $xeIconPicker.computeSelectIconItem
598
+ if (selectIconItem) {
599
+ const { iconRender } = selectIconItem
600
+ const compConf = iconRender ? renderer.get(iconRender.name) : null
601
+ const oIconMethod = compConf ? compConf.renderIconPickerOptionIcon : null
602
+ if (oIconMethod && iconRender) {
603
+ return h('div', {
604
+ key: 'inc',
605
+ class: 'vxe-ico-picker--icon'
606
+ }, getSlotVNs(oIconMethod.call($xeIconPicker, h, iconRender, { $iconPicker: $xeIconPicker, option: selectIconItem })))
607
+ }
608
+ }
609
+ return h('div', {
610
+ key: 'ind',
611
+ class: 'vxe-ico-picker--icon'
612
+ }, [
613
+ h('i', {
614
+ class: selectIcon
615
+ })
616
+ ])
617
+ },
618
+ renderVN (h: CreateElement): VNode {
619
+ const $xeIconPicker = this
620
+ const props = $xeIconPicker
621
+ const reactData = $xeIconPicker.reactData
622
+
623
+ const { className, clearable } = props
624
+ const { initialized, isActivated, isAniVisible, visiblePanel, selectIcon } = reactData
625
+ const vSize = $xeIconPicker.computeSize
626
+ const isDisabled = $xeIconPicker.computeIsDisabled
627
+ const btnTransfer = $xeIconPicker.computeBtnTransfer
628
+ const formReadonly = $xeIconPicker.computeFormReadonly
629
+ const inpPlaceholder = $xeIconPicker.computeInpPlaceholder
630
+ const popupOpts = $xeIconPicker.computePopupOpts
631
+ const ppClassName = popupOpts.className || props.popupClassName
632
+
633
+ if (formReadonly) {
634
+ return h('div', {
635
+ ref: 'refElem',
636
+ class: ['vxe-ico-picker--readonly', className]
637
+ }, [
638
+ h('i', {
639
+ class: selectIcon
640
+ })
641
+ ])
642
+ }
643
+ return h('div', {
644
+ ref: 'refElem',
645
+ class: ['vxe-ico-picker', className ? (XEUtils.isFunction(className) ? className({ $iconPicker: $xeIconPicker }) : className) : '', {
646
+ [`size--${vSize}`]: vSize,
647
+ 'show--clear': clearable && !isDisabled && !!selectIcon,
648
+ 'is--visible': visiblePanel,
649
+ 'is--disabled': isDisabled,
650
+ 'is--active': isActivated
651
+ }]
652
+ }, [
653
+ h('div', {
654
+ class: 'vxe-ico-picker--inner',
655
+ on: {
656
+ click: $xeIconPicker.clickEvent
657
+ }
658
+ }, [
659
+ h('input', {
660
+ ref: 'refInput',
661
+ class: 'vxe-ico-picker--input',
662
+ on: {
663
+ focus: $xeIconPicker.focusEvent,
664
+ blur: $xeIconPicker.blurEvent
665
+ }
666
+ }),
667
+ selectIcon
668
+ ? $xeIconPicker.renderIconView(h)
669
+ : h('div', {
670
+ class: 'vxe-ico-picker--placeholder'
671
+ }, inpPlaceholder),
672
+ h('div', {
673
+ class: 'vxe-ico-picker--suffix'
674
+ }, [
675
+ h('div', {
676
+ class: 'vxe-ico-picker--clear-icon',
677
+ on: {
678
+ click: $xeIconPicker.clearEvent
679
+ }
680
+ }, [
681
+ h('i', {
682
+ class: getIcon().INPUT_CLEAR
683
+ })
684
+ ]),
685
+ h('div', {
686
+ class: 'vxe-ico-picker--suffix-icon'
687
+ }, [
688
+ h('i', {
689
+ class: visiblePanel ? getIcon().ICON_PICKER_OPEN : getIcon().ICON_PICKER_CLOSE
690
+ })
691
+ ])
692
+ ])
693
+ ]),
694
+ h('div', {
695
+ ref: 'refOptionPanel',
696
+ class: ['vxe-table--ignore-clear vxe-ico-picker--panel', ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $iconPicker: $xeIconPicker }) : ppClassName) : '', {
697
+ [`size--${vSize}`]: vSize,
698
+ 'is--transfer': btnTransfer,
699
+ 'ani--leave': isAniVisible,
700
+ 'ani--enter': visiblePanel
701
+ }],
702
+ attrs: {
703
+ placement: reactData.panelPlacement
704
+ },
705
+ style: reactData.panelStyle
706
+ }, [
707
+ initialized && (visiblePanel || isAniVisible)
708
+ ? h('div', {
709
+ class: 'vxe-ico-picker--panel-wrapper'
710
+ }, [
711
+ $xeIconPicker.renderIconWrapper(h)
712
+ ])
713
+ : renderEmptyElement($xeIconPicker)
714
+ ])
715
+ ])
716
+ }
717
+ },
718
+ watch: {
719
+ value (val) {
720
+ const $xeIconPicker = this
721
+ const reactData = $xeIconPicker.reactData
722
+
723
+ reactData.selectIcon = `${val || ''}`
724
+ }
725
+ },
726
+ created () {
727
+ const $xeIconPicker = this
728
+ const props = $xeIconPicker
729
+ const reactData = $xeIconPicker.reactData
730
+
731
+ reactData.selectIcon = `${props.value || ''}`
732
+ globalEvents.on($xeIconPicker, 'mousewheel', $xeIconPicker.handleGlobalMousewheelEvent)
733
+ globalEvents.on($xeIconPicker, 'mousedown', $xeIconPicker.handleGlobalMousedownEvent)
734
+ globalEvents.on($xeIconPicker, 'keydown', $xeIconPicker.handleGlobalKeydownEvent)
735
+ globalEvents.on($xeIconPicker, 'blur', $xeIconPicker.handleGlobalBlurEvent)
736
+ },
737
+ beforeDestroy () {
738
+ const $xeIconPicker = this
739
+
740
+ const panelElem = $xeIconPicker.$refs.refOptionPanel as HTMLElement | undefined
741
+ if (panelElem && panelElem.parentNode) {
742
+ panelElem.parentNode.removeChild(panelElem)
743
+ }
744
+ globalEvents.off($xeIconPicker, 'mousewheel')
745
+ globalEvents.off($xeIconPicker, 'mousedown')
746
+ globalEvents.off($xeIconPicker, 'keydown')
747
+ globalEvents.off($xeIconPicker, 'blur')
748
+ },
749
+ render (this: any, h) {
750
+ return this.renderVN(h)
751
+ }
752
+ }) /* define-vxe-component end */