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,1115 +1,1115 @@
1
- import { PropType, CreateElement, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { getConfig, getI18n, getIcon, globalEvents, createEvent, globalMixins, renderEmptyElement } from '../../ui'
5
- import { getEventTargetNode, updatePanelPlacement, toCssUnit } from '../../ui/src/dom'
6
- import { getLastZIndex, nextZIndex } from '../../ui/src/utils'
7
- import { deNodeValue } from '../../tree/src/util'
8
- import { errLog } from '../../ui/src/log'
9
- import VxeInputComponent from '../../input'
10
- import VxeButtonComponent from '../../button'
11
- import VxeTreeComponent from '../../tree'
12
- import { getSlotVNs } from '../../ui/src/vn'
13
-
14
- import type { TreeSelectReactData, VxeTreeSelectEmits, TreeSelectInternalData, VxeComponentSizeType, VxeButtonDefines, VxeTreeDefines, ValueOf, VxeComponentStyleType, VxeTreeSelectPropTypes, VxeFormDefines, VxeDrawerConstructor, VxeDrawerMethods, VxeFormConstructor, VxeFormPrivateMethods, VxeModalConstructor, VxeModalMethods, VxeInputConstructor, VxeTreeConstructor } from '../../../types'
15
- import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
16
-
17
- function getOptUniqueId () {
18
- return XEUtils.uniqueId('node_')
19
- }
20
-
21
- function createReactData (): TreeSelectReactData {
22
- return {
23
- initialized: false,
24
- searchValue: '',
25
- searchLoading: false,
26
- panelIndex: 0,
27
- panelStyle: {},
28
- panelPlacement: null,
29
- triggerFocusPanel: false,
30
- visiblePanel: false,
31
- isAniVisible: false,
32
- isActivated: false
33
- }
34
- }
35
-
36
- function createInternalData (): TreeSelectInternalData {
37
- return {
38
- // hpTimeout: undefined,
39
- fullOptionList: [],
40
- fullNodeMaps: {}
41
- }
42
- }
43
-
44
- export default /* define-vxe-component start */ defineVxeComponent({
45
- name: 'VxeTreeSelect',
46
- mixins: [
47
- globalMixins.sizeMixin
48
- ],
49
- model: {
50
- prop: 'value',
51
- event: 'modelValue'
52
- },
53
- props: {
54
- value: [String, Number, Array] as PropType<VxeTreeSelectPropTypes.ModelValue>,
55
- clearable: Boolean as PropType<VxeTreeSelectPropTypes.Clearable>,
56
- placeholder: {
57
- type: String as PropType<VxeTreeSelectPropTypes.Placeholder>,
58
- default: () => XEUtils.eqNull(getConfig().treeSelect.placeholder) ? getI18n('vxe.base.pleaseSelect') : getConfig().treeSelect.placeholder
59
- },
60
- readonly: {
61
- type: Boolean as PropType<VxeTreeSelectPropTypes.Readonly>,
62
- default: null
63
- },
64
- loading: Boolean as PropType<VxeTreeSelectPropTypes.Loading>,
65
- disabled: {
66
- type: Boolean as PropType<VxeTreeSelectPropTypes.Disabled>,
67
- default: null
68
- },
69
- filterable: Boolean as PropType<VxeTreeSelectPropTypes.Filterable>,
70
- filterConfig: Object as PropType<VxeTreeSelectPropTypes.FilterConfig>,
71
- multiple: Boolean as PropType<VxeTreeSelectPropTypes.Multiple>,
72
- className: [String, Function] as PropType<VxeTreeSelectPropTypes.ClassName>,
73
- /**
74
- * 已废弃,请使用 popupConfig.className
75
- * @deprecated
76
- */
77
- popupClassName: [String, Function] as PropType<VxeTreeSelectPropTypes.PopupClassName>,
78
- prefixIcon: String as PropType<VxeTreeSelectPropTypes.PrefixIcon>,
79
- placement: String as PropType<VxeTreeSelectPropTypes.Placement>,
80
- lazyOptions: Array as PropType<VxeTreeSelectPropTypes.LazyOptions>,
81
- options: Array as PropType<VxeTreeSelectPropTypes.Options>,
82
- optionProps: Object as PropType<VxeTreeSelectPropTypes.OptionProps>,
83
- /**
84
- * 已废弃,请使用 popupConfig.zIndex
85
- * @deprecated
86
- */
87
- zIndex: Number as PropType<VxeTreeSelectPropTypes.ZIndex>,
88
- size: {
89
- type: String as PropType<VxeTreeSelectPropTypes.Size>,
90
- default: () => getConfig().treeSelect.size || getConfig().size
91
- },
92
- remote: Boolean as PropType<VxeTreeSelectPropTypes.Remote>,
93
- remoteConfig: Function as PropType<VxeTreeSelectPropTypes.RemoteConfig>,
94
- popupConfig: Object as PropType<VxeTreeSelectPropTypes.PopupConfig>,
95
- treeConfig: Object as PropType<VxeTreeSelectPropTypes.TreeConfig>,
96
- menuConfig: Object as PropType<VxeTreeSelectPropTypes.MenuConfig>,
97
- virtualYConfig: Object as PropType<VxeTreeSelectPropTypes.VirtualYConfig>,
98
- autoClose: {
99
- type: Boolean as PropType<VxeTreeSelectPropTypes.AutoClose>,
100
- default: () => getConfig().treeSelect.autoClose
101
- },
102
- showTotalButoon: {
103
- type: Boolean as PropType<VxeTreeSelectPropTypes.ShowTotalButoon>,
104
- default: () => getConfig().treeSelect.showTotalButoon
105
- },
106
- showCheckedButoon: {
107
- type: Boolean as PropType<VxeTreeSelectPropTypes.ShowCheckedButoon>,
108
- default: () => getConfig().treeSelect.showCheckedButoon
109
- },
110
- showClearButton: {
111
- type: Boolean as PropType<VxeTreeSelectPropTypes.ShowClearButton>,
112
- default: () => getConfig().treeSelect.showClearButton
113
- },
114
- showExpandButton: {
115
- type: Boolean as PropType<VxeTreeSelectPropTypes.ShowExpandButton>,
116
- default: () => getConfig().treeSelect.showExpandButton
117
- },
118
- transfer: {
119
- type: Boolean as PropType<VxeTreeSelectPropTypes.Transfer>,
120
- default: null
121
- },
122
-
123
- /**
124
- * 已废弃,被 remote-config.queryMethod 替换
125
- * @deprecated
126
- */
127
- remoteMethod: Function as PropType<VxeTreeSelectPropTypes.RemoteMethod>
128
- },
129
- inject: {
130
- $xeModal: {
131
- default: null
132
- },
133
- $xeDrawer: {
134
- default: null
135
- },
136
- $xeTable: {
137
- default: null
138
- },
139
- $xeForm: {
140
- default: null
141
- },
142
- formItemInfo: {
143
- from: 'xeFormItemInfo',
144
- default: null
145
- }
146
- },
147
- provide () {
148
- const $xeTreeSelect = this
149
- return {
150
- $xeTreeSelect
151
- }
152
- },
153
- data () {
154
- const xID = XEUtils.uniqueId()
155
- const reactData = createReactData()
156
- const internalData = createInternalData()
157
- return {
158
- xID,
159
- reactData,
160
- internalData
161
- }
162
- },
163
- computed: {
164
- ...({} as {
165
- computeSize(): VxeComponentSizeType
166
- $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
167
- $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
168
- $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
169
- $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
170
- formItemInfo(): VxeFormDefines.ProvideItemInfo | null
171
- }),
172
- computeFormReadonly () {
173
- const $xeTreeSelect = this
174
- const props = $xeTreeSelect
175
- const $xeForm = $xeTreeSelect.$xeForm
176
-
177
- const { readonly } = props
178
- if (readonly === null) {
179
- if ($xeForm) {
180
- return $xeForm.readonly
181
- }
182
- return false
183
- }
184
- return readonly
185
- },
186
- computeIsDisabled () {
187
- const $xeTreeSelect = this
188
- const props = $xeTreeSelect
189
- const $xeForm = $xeTreeSelect.$xeForm
190
-
191
- const { disabled } = props
192
- if (disabled === null) {
193
- if ($xeForm) {
194
- return $xeForm.disabled
195
- }
196
- return false
197
- }
198
- return disabled
199
- },
200
- computeBtnTransfer () {
201
- const $xeTreeSelect = this
202
- const props = $xeTreeSelect
203
- const $xeTable = $xeTreeSelect.$xeTable
204
- const $xeModal = $xeTreeSelect.$xeModal
205
- const $xeDrawer = $xeTreeSelect.$xeDrawer
206
- const $xeForm = $xeTreeSelect.$xeForm
207
-
208
- const { transfer } = props
209
- const popupOpts = $xeTreeSelect.computePopupOpts as VxeTreeSelectPropTypes.PopupConfig
210
- if (XEUtils.isBoolean(popupOpts.transfer)) {
211
- return popupOpts.transfer
212
- }
213
- if (transfer === null) {
214
- const globalTransfer = getConfig().treeSelect.transfer
215
- if (XEUtils.isBoolean(globalTransfer)) {
216
- return globalTransfer
217
- }
218
- if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
219
- return true
220
- }
221
- }
222
- return transfer
223
- },
224
- computePopupOpts () {
225
- const $xeTreeSelect = this
226
- const props = $xeTreeSelect
227
-
228
- return Object.assign({}, getConfig().treeSelect.popupConfig, props.popupConfig)
229
- },
230
- computeTreeOpts () {
231
- const $xeTreeSelect = this
232
- const props = $xeTreeSelect
233
-
234
- return Object.assign({}, getConfig().treeSelect.treeConfig, props.treeConfig)
235
- },
236
- computeMenuOpts () {
237
- const $xeTreeSelect = this
238
- const props = $xeTreeSelect
239
-
240
- return Object.assign({}, getConfig().treeSelect.menuConfig, props.menuConfig)
241
- },
242
- computeTreeNodeOpts () {
243
- const $xeTreeSelect = this
244
-
245
- const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
246
- return Object.assign({ isHover: true }, treeOpts.nodeConfig)
247
- },
248
- computeTreeCheckboxOpts () {
249
- const $xeTreeSelect = this
250
-
251
- const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
252
- return Object.assign({
253
- showIcon: !!treeOpts.showCheckbox
254
- }, treeOpts.checkboxConfig, {
255
- trigger: 'node'
256
- })
257
- },
258
- computeTreeRadioOpts () {
259
- const $xeTreeSelect = this
260
-
261
- const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
262
- return Object.assign({
263
- showIcon: !!treeOpts.showRadio
264
- }, treeOpts.radioConfig, {
265
- trigger: 'node'
266
- })
267
- },
268
- computePropsOpts () {
269
- const $xeTreeSelect = this
270
- const props = $xeTreeSelect
271
-
272
- return Object.assign({}, props.optionProps)
273
- },
274
- computeNodeKeyField () {
275
- const $xeTreeSelect = this
276
-
277
- const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
278
- return treeOpts.keyField || 'id'
279
- },
280
- computeLabelField () {
281
- const $xeTreeSelect = this
282
-
283
- const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
284
- return propsOpts.label || 'label'
285
- },
286
- computeValueField () {
287
- const $xeTreeSelect = this
288
-
289
- const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
290
- return propsOpts.value || 'value'
291
- },
292
- computeChildrenField () {
293
- const $xeTreeSelect = this
294
-
295
- const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
296
- return propsOpts.children || 'children'
297
- },
298
- computeParentField () {
299
- const $xeTreeSelect = this
300
-
301
- const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
302
- return propsOpts.parent || 'parentField'
303
- },
304
- computeHasChildField () {
305
- const $xeTreeSelect = this
306
-
307
- const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
308
- return propsOpts.hasChild || 'hasChild'
309
- },
310
- computeVirtualYOpts () {
311
- const $xeTreeSelect = this
312
- const props = $xeTreeSelect
313
-
314
- return Object.assign({} as { gt: number }, getConfig().treeSelect.virtualYConfig, props.virtualYConfig)
315
- },
316
- computeRemoteOpts () {
317
- const $xeTreeSelect = this
318
- const props = $xeTreeSelect
319
-
320
- return Object.assign({}, getConfig().treeSelect.remoteConfig, props.remoteConfig)
321
- },
322
- computeFilterOpts () {
323
- const $xeTreeSelect = this
324
- const props = $xeTreeSelect
325
-
326
- const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
327
- return Object.assign({}, treeOpts.filterConfig, props.filterConfig)
328
- },
329
- computeSelectLabel () {
330
- const $xeTreeSelect = this
331
- const props = $xeTreeSelect
332
- const internalData = ($xeTreeSelect as any).internalData as TreeSelectInternalData
333
-
334
- const { value: modelValue, lazyOptions } = props
335
- const { fullNodeMaps } = internalData
336
- const valueField = $xeTreeSelect.computeValueField as string
337
- const labelField = $xeTreeSelect.computeLabelField as string
338
- const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
339
- return selectVals.map(val => {
340
- const cacheItem = fullNodeMaps[val]
341
- if (cacheItem) {
342
- return cacheItem.item[labelField]
343
- }
344
- if (lazyOptions) {
345
- const lazyItem = lazyOptions.find(item => item[valueField] === val)
346
- if (lazyItem) {
347
- return lazyItem[labelField]
348
- }
349
- }
350
- return val
351
- }).join(', ')
352
- },
353
- computePopupWrapperStyle () {
354
- const $xeTreeSelect = this
355
-
356
- const popupOpts = $xeTreeSelect.computePopupOpts
357
- const { height, width } = popupOpts
358
- const stys: VxeComponentStyleType = {}
359
- if (width) {
360
- stys.width = toCssUnit(width)
361
- }
362
- if (height) {
363
- stys.height = toCssUnit(height)
364
- stys.maxHeight = toCssUnit(height)
365
- }
366
- return stys
367
- }
368
- },
369
- methods: {
370
- //
371
- // Method
372
- //
373
- dispatchEvent (type: ValueOf<VxeTreeSelectEmits>, params: Record<string, any>, evnt: Event | null) {
374
- const $xeTreeSelect = this
375
- $xeTreeSelect.$emit(type, createEvent(evnt, { $treeSelect: $xeTreeSelect }, params))
376
- },
377
- emitModel (value: any) {
378
- const $xeTreeSelect = this
379
-
380
- const { _events } = $xeTreeSelect as any
381
- if (_events && _events.modelValue) {
382
- $xeTreeSelect.$emit('modelValue', value)
383
- } else {
384
- $xeTreeSelect.$emit('model-value', value)
385
- }
386
- },
387
- callSlot (slotFunc: ((params: any, h: CreateElement) => any) | string | null, params: any, h: CreateElement) {
388
- const $xeTreeSelect = this
389
- const slots = $xeTreeSelect.$scopedSlots
390
-
391
- if (slotFunc) {
392
- if (XEUtils.isString(slotFunc)) {
393
- slotFunc = slots[slotFunc] || null
394
- }
395
- if (XEUtils.isFunction(slotFunc)) {
396
- return getSlotVNs(slotFunc.call($xeTreeSelect, params, h))
397
- }
398
- }
399
- return []
400
- },
401
- getNodeid (option: any) {
402
- const $xeTreeSelect = this
403
-
404
- const nodeKeyField = $xeTreeSelect.computeNodeKeyField
405
- const nodeid = option[nodeKeyField]
406
- return nodeid ? encodeURIComponent(nodeid) : ''
407
- },
408
- cacheDataMap () {
409
- const $xeTreeSelect = this
410
- const props = $xeTreeSelect
411
- const internalData = $xeTreeSelect.internalData
412
-
413
- const { options } = props
414
- const nodeKeyField = $xeTreeSelect.computeNodeKeyField
415
- const childrenField = $xeTreeSelect.computeChildrenField
416
- const valueField = $xeTreeSelect.computeValueField
417
- const nodeMaps: Record<string, {
418
- item: any
419
- index: number
420
- items: any[]
421
- parent: any
422
- nodes: any[]
423
- }> = {}
424
- const keyMaps: Record<string, boolean> = {}
425
- XEUtils.eachTree(options, (item, index, items, path, parent, nodes) => {
426
- let nodeid = $xeTreeSelect.getNodeid(item)
427
- if (!nodeid) {
428
- nodeid = getOptUniqueId()
429
- }
430
- if (keyMaps[nodeid]) {
431
- errLog('vxe.error.repeatKey', [`[tree-select] ${nodeKeyField}`, nodeid])
432
- }
433
- keyMaps[nodeid] = true
434
- const value = item[valueField]
435
- if (nodeMaps[value]) {
436
- errLog('vxe.error.repeatKey', [`[tree-select] ${valueField}`, value])
437
- }
438
- nodeMaps[value] = { item, index, items, parent, nodes }
439
- }, { children: childrenField })
440
- internalData.fullOptionList = options || []
441
- internalData.fullNodeMaps = nodeMaps
442
- },
443
- updateZindex () {
444
- const $xeTreeSelect = this
445
- const props = $xeTreeSelect
446
- const reactData = $xeTreeSelect.reactData
447
-
448
- const popupOpts = $xeTreeSelect.computePopupOpts
449
- const customZIndex = popupOpts.zIndex || props.zIndex
450
- if (customZIndex) {
451
- reactData.panelIndex = XEUtils.toNumber(customZIndex)
452
- } else if (reactData.panelIndex < getLastZIndex()) {
453
- reactData.panelIndex = nextZIndex()
454
- }
455
- },
456
- updatePlacement () {
457
- const $xeTreeSelect = this
458
- const props = $xeTreeSelect
459
- const reactData = $xeTreeSelect.reactData
460
-
461
- const { placement } = props
462
- const { panelIndex } = reactData
463
- const targetElem = $xeTreeSelect.$refs.refElem as HTMLElement
464
- const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLDivElement
465
- const btnTransfer = $xeTreeSelect.computeBtnTransfer
466
- const popupOpts = $xeTreeSelect.computePopupOpts
467
- const handleStyle = () => {
468
- const ppObj = updatePanelPlacement(targetElem, panelElem, {
469
- placement: popupOpts.placement || placement,
470
- teleportTo: btnTransfer
471
- })
472
- const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
473
- zIndex: panelIndex
474
- })
475
- reactData.panelStyle = panelStyle
476
- reactData.panelPlacement = ppObj.placement
477
- }
478
- handleStyle()
479
- return $xeTreeSelect.$nextTick().then(handleStyle)
480
- },
481
- showOptionPanel () {
482
- const $xeTreeSelect = this
483
- const props = $xeTreeSelect
484
- const reactData = $xeTreeSelect.reactData
485
- const internalData = $xeTreeSelect.internalData
486
-
487
- const { loading, remote, filterable } = props
488
- const { fullOptionList } = internalData
489
- const isDisabled = $xeTreeSelect.computeIsDisabled
490
- const remoteOpts = $xeTreeSelect.computeRemoteOpts
491
- if (!loading && !isDisabled) {
492
- if (internalData.hpTimeout) {
493
- clearTimeout(internalData.hpTimeout)
494
- }
495
- if (!reactData.initialized) {
496
- reactData.initialized = true
497
- const btnTransfer = $xeTreeSelect.computeBtnTransfer
498
- const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement
499
- if (btnTransfer) {
500
- if (panelElem) {
501
- document.body.appendChild(panelElem)
502
- }
503
- }
504
- }
505
- reactData.isActivated = true
506
- reactData.isAniVisible = true
507
- if (filterable) {
508
- if (remote && remoteOpts.enabled && remoteOpts.autoLoad && !fullOptionList.length) {
509
- $xeTreeSelect.handleSearchEvent()
510
- }
511
- }
512
- setTimeout(() => {
513
- reactData.visiblePanel = true
514
- $xeTreeSelect.handleFocusSearch()
515
- $xeTreeSelect.updatePlacement()
516
- }, 10)
517
- $xeTreeSelect.updateZindex()
518
- $xeTreeSelect.updatePlacement()
519
- }
520
- },
521
- hideOptionPanel () {
522
- const $xeTreeSelect = this
523
- const reactData = $xeTreeSelect.reactData
524
- const internalData = $xeTreeSelect.internalData
525
-
526
- reactData.visiblePanel = false
527
- internalData.hpTimeout = setTimeout(() => {
528
- reactData.isAniVisible = false
529
- }, 350)
530
- },
531
- changeEvent (evnt: Event, selectValue: any, node: any) {
532
- const $xeTreeSelect = this
533
- const props = $xeTreeSelect
534
- const $xeForm = $xeTreeSelect.$xeForm
535
- const formItemInfo = $xeTreeSelect.formItemInfo
536
-
537
- const value = XEUtils.isArray(selectValue) ? selectValue.map(deNodeValue) : deNodeValue(selectValue)
538
- $xeTreeSelect.emitModel(value)
539
- if (value !== props.value) {
540
- $xeTreeSelect.dispatchEvent('change', { value, node, option: node }, evnt)
541
- // 自动更新校验状态
542
- if ($xeForm && formItemInfo) {
543
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
544
- }
545
- }
546
- },
547
- clearValueEvent (evnt: Event, selectValue: any) {
548
- const $xeTreeSelect = this
549
-
550
- $xeTreeSelect.changeEvent(evnt, selectValue, null)
551
- $xeTreeSelect.dispatchEvent('clear', { value: selectValue }, evnt)
552
- },
553
- clearEvent (params: any, evnt: Event) {
554
- const $xeTreeSelect = this
555
-
556
- $xeTreeSelect.clearValueEvent(evnt, null)
557
- $xeTreeSelect.hideOptionPanel()
558
- },
559
- allCheckedPanelEvent (params: VxeButtonDefines.ClickEventParams) {
560
- const $xeTreeSelect = this
561
- const props = $xeTreeSelect
562
-
563
- const { $event } = params
564
- const { multiple, autoClose } = props
565
- const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
566
- if (multiple) {
567
- if ($tree) {
568
- $tree.setAllCheckboxNode(true).then(({ checkNodeKeys, checkNodes }) => {
569
- $xeTreeSelect.changeEvent($event, checkNodeKeys, checkNodes[0])
570
- $xeTreeSelect.dispatchEvent('all-change', { value: checkNodeKeys }, $event)
571
- if (autoClose) {
572
- $xeTreeSelect.hideOptionPanel()
573
- }
574
- })
575
- }
576
- }
577
- },
578
- clearCheckedPanelEvent (params: VxeButtonDefines.ClickEventParams) {
579
- const $xeTreeSelect = this
580
- const props = $xeTreeSelect
581
-
582
- const { $event } = params
583
- const { multiple, autoClose } = props
584
- const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
585
- if ($tree) {
586
- const value = multiple ? [] : null
587
- $tree.clearCheckboxNode().then(() => {
588
- if (autoClose) {
589
- $xeTreeSelect.hideOptionPanel()
590
- }
591
- })
592
- $xeTreeSelect.changeEvent($event, value, null)
593
- $xeTreeSelect.dispatchEvent('clear', { value }, $event)
594
- }
595
- },
596
- allExpandPanelEvent () {
597
- const $xeTreeSelect = this
598
-
599
- const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
600
- if ($tree) {
601
- $tree.setAllExpandNode(true)
602
- }
603
- },
604
- clearExpandPanelEvent () {
605
- const $xeTreeSelect = this
606
-
607
- const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
608
- if ($tree) {
609
- $tree.clearAllExpandNode()
610
- }
611
- },
612
- handleGlobalMousewheelEvent (evnt: MouseEvent) {
613
- const $xeTreeSelect = this
614
- const reactData = $xeTreeSelect.reactData
615
-
616
- const { visiblePanel } = reactData
617
- const isDisabled = $xeTreeSelect.computeIsDisabled
618
- if (!isDisabled) {
619
- if (visiblePanel) {
620
- const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement
621
- if (getEventTargetNode(evnt, panelElem).flag) {
622
- $xeTreeSelect.updatePlacement()
623
- } else {
624
- $xeTreeSelect.hideOptionPanel()
625
- }
626
- }
627
- }
628
- },
629
- handleGlobalMousedownEvent (evnt: MouseEvent) {
630
- const $xeTreeSelect = this
631
- const reactData = $xeTreeSelect.reactData
632
-
633
- const { visiblePanel } = reactData
634
- const isDisabled = $xeTreeSelect.computeIsDisabled
635
- if (!isDisabled) {
636
- const el = $xeTreeSelect.$refs.refElem as HTMLElement
637
- const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement
638
- reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
639
- if (visiblePanel && !reactData.isActivated) {
640
- $xeTreeSelect.hideOptionPanel()
641
- }
642
- }
643
- },
644
- handleGlobalBlurEvent () {
645
- const $xeTreeSelect = this
646
- const reactData = $xeTreeSelect.reactData
647
-
648
- const { visiblePanel, isActivated } = reactData
649
- if (visiblePanel) {
650
- $xeTreeSelect.hideOptionPanel()
651
- }
652
- if (isActivated) {
653
- reactData.isActivated = false
654
- }
655
- if (visiblePanel || isActivated) {
656
- const $input = $xeTreeSelect.$refs.refInput as VxeInputConstructor
657
- if ($input) {
658
- $input.blur()
659
- }
660
- }
661
- },
662
- handleGlobalResizeEvent () {
663
- const $xeTreeSelect = this
664
- const reactData = $xeTreeSelect.reactData
665
-
666
- const { visiblePanel } = reactData
667
- if (visiblePanel) {
668
- $xeTreeSelect.updatePlacement()
669
- }
670
- },
671
- handleFocusSearch () {
672
- const $xeSelect = this
673
- const props = $xeSelect
674
-
675
- if (props.filterable) {
676
- $xeSelect.$nextTick(() => {
677
- const inpSearch = $xeSelect.$refs.refInpSearch as VxeInputConstructor
678
- if (inpSearch) {
679
- inpSearch.focus()
680
- }
681
- })
682
- }
683
- },
684
- focusEvent (evnt: FocusEvent) {
685
- const $xeTreeSelect = this
686
- const reactData = $xeTreeSelect.reactData
687
-
688
- const isDisabled = $xeTreeSelect.computeIsDisabled
689
- if (!isDisabled) {
690
- if (!reactData.visiblePanel) {
691
- reactData.triggerFocusPanel = true
692
- $xeTreeSelect.showOptionPanel()
693
- setTimeout(() => {
694
- reactData.triggerFocusPanel = false
695
- }, 150)
696
- }
697
- }
698
- $xeTreeSelect.dispatchEvent('focus', {}, evnt)
699
- },
700
- clickEvent (evnt: MouseEvent) {
701
- const $xeTreeSelect = this
702
-
703
- $xeTreeSelect.togglePanelEvent(evnt)
704
- $xeTreeSelect.dispatchEvent('click', {}, evnt)
705
- },
706
- blurEvent (evnt: FocusEvent) {
707
- const $xeTreeSelect = this
708
- const reactData = $xeTreeSelect.reactData
709
-
710
- reactData.isActivated = false
711
- $xeTreeSelect.dispatchEvent('blur', {}, evnt)
712
- },
713
- modelSearchEvent (value: string) {
714
- const $xeTreeSelect = this
715
- const reactData = $xeTreeSelect.reactData
716
-
717
- reactData.searchValue = value
718
- },
719
- handleSearchEvent () {
720
- const $xeTreeSelect = this
721
- const props = $xeTreeSelect
722
- const reactData = $xeTreeSelect.reactData
723
-
724
- const { value: modelValue, remote, remoteMethod } = props
725
- const { searchValue } = reactData
726
- const remoteOpts = $xeTreeSelect.computeRemoteOpts
727
- const queryMethod = remoteOpts.queryMethod || remoteMethod
728
- if (remote && queryMethod && remoteOpts.enabled) {
729
- reactData.searchLoading = true
730
- Promise.resolve(
731
- queryMethod({ $treeSelect: $xeTreeSelect, searchValue, value: modelValue })
732
- ).then(() => $xeTreeSelect.$nextTick())
733
- .catch(() => $xeTreeSelect.$nextTick())
734
- .finally(() => {
735
- reactData.searchLoading = false
736
- })
737
- }
738
- },
739
- togglePanelEvent (params: any) {
740
- const $xeTreeSelect = this
741
- const reactData = $xeTreeSelect.reactData
742
-
743
- const { $event } = params
744
- $event.preventDefault()
745
- if (reactData.triggerFocusPanel) {
746
- reactData.triggerFocusPanel = false
747
- } else {
748
- if (reactData.visiblePanel) {
749
- $xeTreeSelect.hideOptionPanel()
750
- } else {
751
- $xeTreeSelect.showOptionPanel()
752
- }
753
- }
754
- },
755
- nodeExpandEvent () {
756
- const $xeTreeSelect = this
757
-
758
- $xeTreeSelect.updatePlacement()
759
- },
760
- nodeClickEvent (params: VxeTreeDefines.NodeClickEventParams) {
761
- const $xeTreeSelect = this
762
-
763
- const { $event } = params
764
- $xeTreeSelect.dispatchEvent('node-click', params, $event)
765
- },
766
- radioChangeEvent (params: VxeTreeDefines.RadioChangeEventParams) {
767
- const $xeTreeSelect = this
768
-
769
- const { value, $event, node } = params
770
- $xeTreeSelect.changeEvent($event, value, node)
771
- $xeTreeSelect.hideOptionPanel()
772
- },
773
- checkboxChangeEvent (params: VxeTreeDefines.CheckboxChangeEventParams) {
774
- const $xeTreeSelect = this
775
-
776
- const { value, $event, node } = params
777
- $xeTreeSelect.changeEvent($event, value, node)
778
- },
779
- loadSuccessEvent () {
780
- const $xeTreeSelect = this
781
-
782
- $xeTreeSelect.cacheDataMap()
783
- },
784
-
785
- //
786
- // Render
787
- //
788
- renderVN (h: CreateElement): VNode {
789
- const $xeTreeSelect = this
790
- const props = $xeTreeSelect
791
- const slots = $xeTreeSelect.$scopedSlots
792
- const reactData = $xeTreeSelect.reactData
793
-
794
- const { className, value: modelValue, multiple, options, loading, menuConfig, filterable, showTotalButoon, showCheckedButoon, showClearButton, showExpandButton } = props
795
- const { initialized, isActivated, isAniVisible, visiblePanel, searchValue } = reactData
796
- const vSize = $xeTreeSelect.computeSize
797
- const isDisabled = $xeTreeSelect.computeIsDisabled
798
- const selectLabel = $xeTreeSelect.computeSelectLabel
799
- const btnTransfer = $xeTreeSelect.computeBtnTransfer
800
- const formReadonly = $xeTreeSelect.computeFormReadonly
801
- const popupWrapperStyle = $xeTreeSelect.computePopupWrapperStyle
802
- const headerSlot = slots.header
803
- const footerSlot = slots.footer
804
- const prefixSlot = slots.prefix
805
- const popupOpts = $xeTreeSelect.computePopupOpts
806
- const ppClassName = popupOpts.className || props.popupClassName
807
- if (formReadonly) {
808
- return h('div', {
809
- ref: 'refElem',
810
- class: ['vxe-tree-select--readonly', className]
811
- }, [
812
- h('span', {
813
- class: 'vxe-tree-select-label'
814
- }, selectLabel)
815
- ])
816
- }
817
- const treeOpts = $xeTreeSelect.computeTreeOpts
818
- const menuOpts = $xeTreeSelect.computeMenuOpts
819
- const treeNodeOpts = $xeTreeSelect.computeTreeNodeOpts
820
- const treeCheckboxOpts = $xeTreeSelect.computeTreeCheckboxOpts
821
- const treeRadioOpts = $xeTreeSelect.computeTreeRadioOpts
822
- const nodeKeyField = $xeTreeSelect.computeNodeKeyField
823
- const labelField = $xeTreeSelect.computeLabelField
824
- const valueField = $xeTreeSelect.computeValueField
825
- const childrenField = $xeTreeSelect.computeChildrenField
826
- const parentField = $xeTreeSelect.computeParentField
827
- const hasChildField = $xeTreeSelect.computeHasChildField
828
- const virtualYOpts = $xeTreeSelect.computeVirtualYOpts
829
- const filterOpts = $xeTreeSelect.computeFilterOpts
830
- const { slots: treeSlots } = treeOpts
831
- const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
832
- const treeScopedSlots: {
833
- icon?: (params: any) => VNode[]
834
- title?: (params: any) => VNode[]
835
- extra?: (params: any) => VNode[]
836
- } = {}
837
- if (treeSlots) {
838
- const { icon: treeIconSlot, title: treeTitleSlot, extra: treeExtraSlot } = treeSlots
839
- if (treeIconSlot) {
840
- treeScopedSlots.icon = (slotParams) => $xeTreeSelect.callSlot(treeIconSlot, slotParams, h) as VNode[]
841
- }
842
- if (treeTitleSlot) {
843
- treeScopedSlots.title = (slotParams) => $xeTreeSelect.callSlot(treeTitleSlot, slotParams, h) as VNode[]
844
- }
845
- if (treeExtraSlot) {
846
- treeScopedSlots.extra = (slotParams) => $xeTreeSelect.callSlot(treeExtraSlot, slotParams, h) as VNode[]
847
- }
848
- }
849
- return h('div', {
850
- ref: 'refElem',
851
- class: ['vxe-tree-select', className ? (XEUtils.isFunction(className) ? className({ $treeSelect: $xeTreeSelect }) : className) : '', {
852
- [`size--${vSize}`]: vSize,
853
- 'is--filterable': filterable,
854
- 'is--visible': visiblePanel,
855
- 'is--disabled': isDisabled,
856
- 'is--loading': loading,
857
- 'is--active': isActivated
858
- }]
859
- }, [
860
- h(VxeInputComponent, {
861
- ref: 'refInput',
862
- props: {
863
- clearable: props.clearable,
864
- placeholder: props.placeholder,
865
- editable: false,
866
- disabled: isDisabled,
867
- type: 'text',
868
- prefixIcon: props.prefixIcon,
869
- suffixIcon: loading ? getIcon().TREE_SELECT_LOADED : (visiblePanel ? getIcon().TREE_SELECT_OPEN : getIcon().TREE_SELECT_CLOSE),
870
- value: loading ? getI18n('vxe.select.loadingText') : selectLabel,
871
- title: selectLabel
872
- },
873
- on: {
874
- clear: $xeTreeSelect.clearEvent,
875
- click: $xeTreeSelect.clickEvent,
876
- focus: $xeTreeSelect.focusEvent,
877
- blur: $xeTreeSelect.blurEvent,
878
- 'suffix-click': $xeTreeSelect.togglePanelEvent
879
- },
880
- scopedSlots: prefixSlot
881
- ? {
882
- prefix: () => prefixSlot({})
883
- }
884
- : {}
885
- }),
886
- h('div', {
887
- ref: 'refOptionPanel',
888
- class: ['vxe-table--ignore-clear vxe-tree-select--panel', ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $treeSelect: $xeTreeSelect }) : ppClassName) : '', {
889
- [`size--${vSize}`]: vSize,
890
- 'is--transfer': btnTransfer,
891
- 'ani--leave': !loading && isAniVisible,
892
- 'ani--enter': !loading && visiblePanel
893
- }],
894
- attrs: {
895
- placement: reactData.panelPlacement
896
- },
897
- style: reactData.panelStyle
898
- }, initialized
899
- ? [
900
- h('div', {
901
- class: 'vxe-tree-select--panel-wrapper'
902
- }, [
903
- filterable
904
- ? h('div', {
905
- class: 'vxe-tree-select--panel-search'
906
- }, [
907
- h(VxeInputComponent, {
908
- ref: 'refInpSearch',
909
- class: 'vxe-tree-select-search--input',
910
- props: {
911
- value: searchValue,
912
- title: selectLabel,
913
- clearable: true,
914
- disabled: false,
915
- readonly: false,
916
- placeholder: getI18n('vxe.treeSelect.search'),
917
- prefixIcon: getIcon().INPUT_SEARCH
918
- },
919
- on: {
920
- 'model-value': $xeTreeSelect.modelSearchEvent
921
- }
922
- })
923
- ])
924
- : renderEmptyElement($xeTreeSelect),
925
- showTotalButoon || (showCheckedButoon && multiple) || showClearButton || showExpandButton || headerSlot
926
- ? h('div', {
927
- class: 'vxe-tree-select--panel-header'
928
- }, headerSlot
929
- ? headerSlot({})
930
- : [
931
- h('div', {
932
- class: 'vxe-tree-select--header-button'
933
- }, [
934
- showCheckedButoon && showClearButton
935
- ? h('div', {
936
- class: 'vxe-tree-select--selected-btns'
937
- }, [
938
- (showCheckedButoon && multiple)
939
- ? h(VxeButtonComponent, {
940
- props: {
941
- content: getI18n('vxe.treeSelect.allChecked'),
942
- mode: 'text'
943
- },
944
- on: {
945
- click: $xeTreeSelect.allCheckedPanelEvent
946
- }
947
- })
948
- : renderEmptyElement($xeTreeSelect),
949
- showClearButton
950
- ? h(VxeButtonComponent, {
951
- props: {
952
- content: getI18n('vxe.treeSelect.clearChecked'),
953
- mode: 'text'
954
- },
955
- on: {
956
- click: $xeTreeSelect.clearCheckedPanelEvent
957
- }
958
- })
959
- : renderEmptyElement($xeTreeSelect)
960
- ])
961
- : renderEmptyElement($xeTreeSelect),
962
- showExpandButton && showExpandButton
963
- ? h('div', {
964
- class: 'vxe-tree-select--expand-btns'
965
- }, [
966
- showExpandButton
967
- ? h(VxeButtonComponent, {
968
- props: {
969
- content: getI18n('vxe.treeSelect.allExpand'),
970
- mode: 'text'
971
- },
972
- on: {
973
- click: $xeTreeSelect.allExpandPanelEvent
974
- }
975
- })
976
- : renderEmptyElement($xeTreeSelect),
977
- showExpandButton
978
- ? h(VxeButtonComponent, {
979
- props: {
980
- content: getI18n('vxe.treeSelect.clearExpand'),
981
- mode: 'text'
982
- },
983
- on: {
984
- click: $xeTreeSelect.clearExpandPanelEvent
985
- }
986
- })
987
- : renderEmptyElement($xeTreeSelect)
988
- ])
989
- : renderEmptyElement($xeTreeSelect)
990
- ])
991
- ])
992
- : renderEmptyElement($xeTreeSelect),
993
- h('div', {
994
- class: 'vxe-tree-select--panel-body'
995
- }, [
996
- h('div', {
997
- ref: 'refTreeWrapper',
998
- class: 'vxe-tree-select-tree--wrapper',
999
- style: popupWrapperStyle
1000
- }, [
1001
- h(VxeTreeComponent, {
1002
- ref: 'refTree',
1003
- class: 'vxe-tree-select--tree',
1004
- props: {
1005
- data: options,
1006
- height: popupOpts.height ? '100%' : treeOpts.height,
1007
- minHeight: treeOpts.minHeight,
1008
- maxHeight: popupOpts.height ? '' : treeOpts.maxHeight,
1009
- autoResize: true,
1010
- indent: treeOpts.indent,
1011
- showRadio: !multiple,
1012
- radioConfig: treeRadioOpts,
1013
- checkNodeKey: multiple ? null : modelValue,
1014
- showCheckbox: !!multiple,
1015
- checkNodeKeys: multiple ? modelValue : null,
1016
- checkboxConfig: treeCheckboxOpts,
1017
- titleField: labelField,
1018
- valueField: valueField,
1019
- keyField: nodeKeyField,
1020
- childrenField: treeOpts.childrenField || childrenField,
1021
- parentField: treeOpts.parentField || parentField,
1022
- hasChildField: treeOpts.hasChildField || hasChildField,
1023
- accordion: treeOpts.accordion,
1024
- expandAll: treeOpts.expandAll,
1025
- expandNodeKeys: treeOpts.expandNodeKeys,
1026
- nodeConfig: treeNodeOpts,
1027
- lazy: treeOpts.lazy,
1028
- loadMethod: treeOpts.loadMethod,
1029
- toggleMethod: treeOpts.toggleMethod,
1030
- transform: treeOpts.transform,
1031
- trigger: treeOpts.trigger,
1032
- showIcon: treeOpts.showIcon,
1033
- showLine: treeOpts.showLine,
1034
- iconOpen: treeOpts.iconOpen,
1035
- iconLoaded: treeOpts.iconLoaded,
1036
- iconClose: treeOpts.iconClose,
1037
- filterValue: searchValue,
1038
- filterConfig: filterOpts,
1039
- menuConfig: menuConfig ? menuOpts : undefined,
1040
- virtualYConfig: virtualYOpts
1041
- },
1042
- on: {
1043
- 'node-expand': $xeTreeSelect.nodeExpandEvent,
1044
- 'node-click': $xeTreeSelect.nodeClickEvent,
1045
- 'radio-change': $xeTreeSelect.radioChangeEvent,
1046
- 'checkbox-change': $xeTreeSelect.checkboxChangeEvent,
1047
- 'load-success': $xeTreeSelect.loadSuccessEvent
1048
- },
1049
- scopedSlots: treeScopedSlots
1050
- })
1051
- ])
1052
- ]),
1053
- footerSlot || showTotalButoon
1054
- ? h('div', {
1055
- class: 'vxe-tree-select--panel-footer'
1056
- }, footerSlot
1057
- ? footerSlot({})
1058
- : [
1059
- h('div', {
1060
- class: 'vxe-tree-select--footer-button'
1061
- }, [
1062
- showTotalButoon
1063
- ? h('div', {
1064
- class: 'vxe-tree-select--total-btns'
1065
- }, getI18n('vxe.treeSelect.total', [selectVals.length]))
1066
- : renderEmptyElement($xeTreeSelect)
1067
- ])
1068
- ])
1069
- : renderEmptyElement($xeTreeSelect)
1070
- ])
1071
- ]
1072
- : [])
1073
- ])
1074
- }
1075
- },
1076
- watch: {
1077
- options () {
1078
- const $xeTreeSelect = this
1079
-
1080
- $xeTreeSelect.cacheDataMap()
1081
- }
1082
- },
1083
- created () {
1084
- const $xeTreeSelect = this
1085
-
1086
- $xeTreeSelect.cacheDataMap()
1087
- },
1088
- mounted () {
1089
- const $xeTreeSelect = this
1090
-
1091
- globalEvents.on($xeTreeSelect, 'mousewheel', $xeTreeSelect.handleGlobalMousewheelEvent)
1092
- globalEvents.on($xeTreeSelect, 'mousedown', $xeTreeSelect.handleGlobalMousedownEvent)
1093
- globalEvents.on($xeTreeSelect, 'blur', $xeTreeSelect.handleGlobalBlurEvent)
1094
- globalEvents.on($xeTreeSelect, 'resize', $xeTreeSelect.handleGlobalResizeEvent)
1095
- },
1096
- beforeDestroy () {
1097
- const $xeTreeSelect = this
1098
- const reactData = $xeTreeSelect.reactData
1099
- const internalData = $xeTreeSelect.internalData
1100
-
1101
- const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement | undefined
1102
- if (panelElem && panelElem.parentNode) {
1103
- panelElem.parentNode.removeChild(panelElem)
1104
- }
1105
- globalEvents.off($xeTreeSelect, 'mousewheel')
1106
- globalEvents.off($xeTreeSelect, 'mousedown')
1107
- globalEvents.off($xeTreeSelect, 'blur')
1108
- globalEvents.off($xeTreeSelect, 'resize')
1109
- XEUtils.assign(reactData, createReactData())
1110
- XEUtils.assign(internalData, createInternalData())
1111
- },
1112
- render (this: any, h) {
1113
- return this.renderVN(h)
1114
- }
1115
- }) /* 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, getI18n, getIcon, globalEvents, createEvent, globalMixins, renderEmptyElement } from '../../ui'
5
+ import { getEventTargetNode, updatePanelPlacement, toCssUnit } from '../../ui/src/dom'
6
+ import { getLastZIndex, nextZIndex } from '../../ui/src/utils'
7
+ import { deNodeValue } from '../../tree/src/util'
8
+ import { errLog } from '../../ui/src/log'
9
+ import VxeInputComponent from '../../input'
10
+ import VxeButtonComponent from '../../button'
11
+ import VxeTreeComponent from '../../tree'
12
+ import { getSlotVNs } from '../../ui/src/vn'
13
+
14
+ import type { TreeSelectReactData, VxeTreeSelectEmits, TreeSelectInternalData, VxeComponentSizeType, VxeButtonDefines, VxeTreeDefines, ValueOf, VxeComponentStyleType, VxeTreeSelectPropTypes, VxeFormDefines, VxeDrawerConstructor, VxeDrawerMethods, VxeFormConstructor, VxeFormPrivateMethods, VxeModalConstructor, VxeModalMethods, VxeInputConstructor, VxeTreeConstructor } from '../../../types'
15
+ import type { VxeTableConstructor, VxeTablePrivateMethods } from '../../../types/components/table'
16
+
17
+ function getOptUniqueId () {
18
+ return XEUtils.uniqueId('node_')
19
+ }
20
+
21
+ function createReactData (): TreeSelectReactData {
22
+ return {
23
+ initialized: false,
24
+ searchValue: '',
25
+ searchLoading: false,
26
+ panelIndex: 0,
27
+ panelStyle: {},
28
+ panelPlacement: null,
29
+ triggerFocusPanel: false,
30
+ visiblePanel: false,
31
+ isAniVisible: false,
32
+ isActivated: false
33
+ }
34
+ }
35
+
36
+ function createInternalData (): TreeSelectInternalData {
37
+ return {
38
+ // hpTimeout: undefined,
39
+ fullOptionList: [],
40
+ fullNodeMaps: {}
41
+ }
42
+ }
43
+
44
+ export default /* define-vxe-component start */ defineVxeComponent({
45
+ name: 'VxeTreeSelect',
46
+ mixins: [
47
+ globalMixins.sizeMixin
48
+ ],
49
+ model: {
50
+ prop: 'value',
51
+ event: 'modelValue'
52
+ },
53
+ props: {
54
+ value: [String, Number, Array] as PropType<VxeTreeSelectPropTypes.ModelValue>,
55
+ clearable: Boolean as PropType<VxeTreeSelectPropTypes.Clearable>,
56
+ placeholder: {
57
+ type: String as PropType<VxeTreeSelectPropTypes.Placeholder>,
58
+ default: () => XEUtils.eqNull(getConfig().treeSelect.placeholder) ? getI18n('vxe.base.pleaseSelect') : getConfig().treeSelect.placeholder
59
+ },
60
+ readonly: {
61
+ type: Boolean as PropType<VxeTreeSelectPropTypes.Readonly>,
62
+ default: null
63
+ },
64
+ loading: Boolean as PropType<VxeTreeSelectPropTypes.Loading>,
65
+ disabled: {
66
+ type: Boolean as PropType<VxeTreeSelectPropTypes.Disabled>,
67
+ default: null
68
+ },
69
+ filterable: Boolean as PropType<VxeTreeSelectPropTypes.Filterable>,
70
+ filterConfig: Object as PropType<VxeTreeSelectPropTypes.FilterConfig>,
71
+ multiple: Boolean as PropType<VxeTreeSelectPropTypes.Multiple>,
72
+ className: [String, Function] as PropType<VxeTreeSelectPropTypes.ClassName>,
73
+ /**
74
+ * 已废弃,请使用 popupConfig.className
75
+ * @deprecated
76
+ */
77
+ popupClassName: [String, Function] as PropType<VxeTreeSelectPropTypes.PopupClassName>,
78
+ prefixIcon: String as PropType<VxeTreeSelectPropTypes.PrefixIcon>,
79
+ placement: String as PropType<VxeTreeSelectPropTypes.Placement>,
80
+ lazyOptions: Array as PropType<VxeTreeSelectPropTypes.LazyOptions>,
81
+ options: Array as PropType<VxeTreeSelectPropTypes.Options>,
82
+ optionProps: Object as PropType<VxeTreeSelectPropTypes.OptionProps>,
83
+ /**
84
+ * 已废弃,请使用 popupConfig.zIndex
85
+ * @deprecated
86
+ */
87
+ zIndex: Number as PropType<VxeTreeSelectPropTypes.ZIndex>,
88
+ size: {
89
+ type: String as PropType<VxeTreeSelectPropTypes.Size>,
90
+ default: () => getConfig().treeSelect.size || getConfig().size
91
+ },
92
+ remote: Boolean as PropType<VxeTreeSelectPropTypes.Remote>,
93
+ remoteConfig: Function as PropType<VxeTreeSelectPropTypes.RemoteConfig>,
94
+ popupConfig: Object as PropType<VxeTreeSelectPropTypes.PopupConfig>,
95
+ treeConfig: Object as PropType<VxeTreeSelectPropTypes.TreeConfig>,
96
+ menuConfig: Object as PropType<VxeTreeSelectPropTypes.MenuConfig>,
97
+ virtualYConfig: Object as PropType<VxeTreeSelectPropTypes.VirtualYConfig>,
98
+ autoClose: {
99
+ type: Boolean as PropType<VxeTreeSelectPropTypes.AutoClose>,
100
+ default: () => getConfig().treeSelect.autoClose
101
+ },
102
+ showTotalButoon: {
103
+ type: Boolean as PropType<VxeTreeSelectPropTypes.ShowTotalButoon>,
104
+ default: () => getConfig().treeSelect.showTotalButoon
105
+ },
106
+ showCheckedButoon: {
107
+ type: Boolean as PropType<VxeTreeSelectPropTypes.ShowCheckedButoon>,
108
+ default: () => getConfig().treeSelect.showCheckedButoon
109
+ },
110
+ showClearButton: {
111
+ type: Boolean as PropType<VxeTreeSelectPropTypes.ShowClearButton>,
112
+ default: () => getConfig().treeSelect.showClearButton
113
+ },
114
+ showExpandButton: {
115
+ type: Boolean as PropType<VxeTreeSelectPropTypes.ShowExpandButton>,
116
+ default: () => getConfig().treeSelect.showExpandButton
117
+ },
118
+ transfer: {
119
+ type: Boolean as PropType<VxeTreeSelectPropTypes.Transfer>,
120
+ default: null
121
+ },
122
+
123
+ /**
124
+ * 已废弃,被 remote-config.queryMethod 替换
125
+ * @deprecated
126
+ */
127
+ remoteMethod: Function as PropType<VxeTreeSelectPropTypes.RemoteMethod>
128
+ },
129
+ inject: {
130
+ $xeModal: {
131
+ default: null
132
+ },
133
+ $xeDrawer: {
134
+ default: null
135
+ },
136
+ $xeTable: {
137
+ default: null
138
+ },
139
+ $xeForm: {
140
+ default: null
141
+ },
142
+ formItemInfo: {
143
+ from: 'xeFormItemInfo',
144
+ default: null
145
+ }
146
+ },
147
+ provide () {
148
+ const $xeTreeSelect = this
149
+ return {
150
+ $xeTreeSelect
151
+ }
152
+ },
153
+ data () {
154
+ const xID = XEUtils.uniqueId()
155
+ const reactData = createReactData()
156
+ const internalData = createInternalData()
157
+ return {
158
+ xID,
159
+ reactData,
160
+ internalData
161
+ }
162
+ },
163
+ computed: {
164
+ ...({} as {
165
+ computeSize(): VxeComponentSizeType
166
+ $xeModal(): (VxeModalConstructor & VxeModalMethods) | null
167
+ $xeDrawer(): (VxeDrawerConstructor & VxeDrawerMethods) | null
168
+ $xeTable(): (VxeTableConstructor & VxeTablePrivateMethods) | null
169
+ $xeForm(): (VxeFormConstructor & VxeFormPrivateMethods) | null
170
+ formItemInfo(): VxeFormDefines.ProvideItemInfo | null
171
+ }),
172
+ computeFormReadonly () {
173
+ const $xeTreeSelect = this
174
+ const props = $xeTreeSelect
175
+ const $xeForm = $xeTreeSelect.$xeForm
176
+
177
+ const { readonly } = props
178
+ if (readonly === null) {
179
+ if ($xeForm) {
180
+ return $xeForm.readonly
181
+ }
182
+ return false
183
+ }
184
+ return readonly
185
+ },
186
+ computeIsDisabled () {
187
+ const $xeTreeSelect = this
188
+ const props = $xeTreeSelect
189
+ const $xeForm = $xeTreeSelect.$xeForm
190
+
191
+ const { disabled } = props
192
+ if (disabled === null) {
193
+ if ($xeForm) {
194
+ return $xeForm.disabled
195
+ }
196
+ return false
197
+ }
198
+ return disabled
199
+ },
200
+ computeBtnTransfer () {
201
+ const $xeTreeSelect = this
202
+ const props = $xeTreeSelect
203
+ const $xeTable = $xeTreeSelect.$xeTable
204
+ const $xeModal = $xeTreeSelect.$xeModal
205
+ const $xeDrawer = $xeTreeSelect.$xeDrawer
206
+ const $xeForm = $xeTreeSelect.$xeForm
207
+
208
+ const { transfer } = props
209
+ const popupOpts = $xeTreeSelect.computePopupOpts as VxeTreeSelectPropTypes.PopupConfig
210
+ if (XEUtils.isBoolean(popupOpts.transfer)) {
211
+ return popupOpts.transfer
212
+ }
213
+ if (transfer === null) {
214
+ const globalTransfer = getConfig().treeSelect.transfer
215
+ if (XEUtils.isBoolean(globalTransfer)) {
216
+ return globalTransfer
217
+ }
218
+ if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
219
+ return true
220
+ }
221
+ }
222
+ return transfer
223
+ },
224
+ computePopupOpts () {
225
+ const $xeTreeSelect = this
226
+ const props = $xeTreeSelect
227
+
228
+ return Object.assign({}, getConfig().treeSelect.popupConfig, props.popupConfig)
229
+ },
230
+ computeTreeOpts () {
231
+ const $xeTreeSelect = this
232
+ const props = $xeTreeSelect
233
+
234
+ return Object.assign({}, getConfig().treeSelect.treeConfig, props.treeConfig)
235
+ },
236
+ computeMenuOpts () {
237
+ const $xeTreeSelect = this
238
+ const props = $xeTreeSelect
239
+
240
+ return Object.assign({}, getConfig().treeSelect.menuConfig, props.menuConfig)
241
+ },
242
+ computeTreeNodeOpts () {
243
+ const $xeTreeSelect = this
244
+
245
+ const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
246
+ return Object.assign({ isHover: true }, treeOpts.nodeConfig)
247
+ },
248
+ computeTreeCheckboxOpts () {
249
+ const $xeTreeSelect = this
250
+
251
+ const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
252
+ return Object.assign({
253
+ showIcon: !!treeOpts.showCheckbox
254
+ }, treeOpts.checkboxConfig, {
255
+ trigger: 'node'
256
+ })
257
+ },
258
+ computeTreeRadioOpts () {
259
+ const $xeTreeSelect = this
260
+
261
+ const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
262
+ return Object.assign({
263
+ showIcon: !!treeOpts.showRadio
264
+ }, treeOpts.radioConfig, {
265
+ trigger: 'node'
266
+ })
267
+ },
268
+ computePropsOpts () {
269
+ const $xeTreeSelect = this
270
+ const props = $xeTreeSelect
271
+
272
+ return Object.assign({}, props.optionProps)
273
+ },
274
+ computeNodeKeyField () {
275
+ const $xeTreeSelect = this
276
+
277
+ const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
278
+ return treeOpts.keyField || 'id'
279
+ },
280
+ computeLabelField () {
281
+ const $xeTreeSelect = this
282
+
283
+ const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
284
+ return propsOpts.label || 'label'
285
+ },
286
+ computeValueField () {
287
+ const $xeTreeSelect = this
288
+
289
+ const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
290
+ return propsOpts.value || 'value'
291
+ },
292
+ computeChildrenField () {
293
+ const $xeTreeSelect = this
294
+
295
+ const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
296
+ return propsOpts.children || 'children'
297
+ },
298
+ computeParentField () {
299
+ const $xeTreeSelect = this
300
+
301
+ const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
302
+ return propsOpts.parent || 'parentField'
303
+ },
304
+ computeHasChildField () {
305
+ const $xeTreeSelect = this
306
+
307
+ const propsOpts = $xeTreeSelect.computePropsOpts as VxeTreeSelectPropTypes.OptionProps
308
+ return propsOpts.hasChild || 'hasChild'
309
+ },
310
+ computeVirtualYOpts () {
311
+ const $xeTreeSelect = this
312
+ const props = $xeTreeSelect
313
+
314
+ return Object.assign({} as { gt: number }, getConfig().treeSelect.virtualYConfig, props.virtualYConfig)
315
+ },
316
+ computeRemoteOpts () {
317
+ const $xeTreeSelect = this
318
+ const props = $xeTreeSelect
319
+
320
+ return Object.assign({}, getConfig().treeSelect.remoteConfig, props.remoteConfig)
321
+ },
322
+ computeFilterOpts () {
323
+ const $xeTreeSelect = this
324
+ const props = $xeTreeSelect
325
+
326
+ const treeOpts = $xeTreeSelect.computeTreeOpts as VxeTreeSelectPropTypes.TreeConfig
327
+ return Object.assign({}, treeOpts.filterConfig, props.filterConfig)
328
+ },
329
+ computeSelectLabel () {
330
+ const $xeTreeSelect = this
331
+ const props = $xeTreeSelect
332
+ const internalData = ($xeTreeSelect as any).internalData as TreeSelectInternalData
333
+
334
+ const { value: modelValue, lazyOptions } = props
335
+ const { fullNodeMaps } = internalData
336
+ const valueField = $xeTreeSelect.computeValueField as string
337
+ const labelField = $xeTreeSelect.computeLabelField as string
338
+ const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
339
+ return selectVals.map(val => {
340
+ const cacheItem = fullNodeMaps[val]
341
+ if (cacheItem) {
342
+ return cacheItem.item[labelField]
343
+ }
344
+ if (lazyOptions) {
345
+ const lazyItem = lazyOptions.find(item => item[valueField] === val)
346
+ if (lazyItem) {
347
+ return lazyItem[labelField]
348
+ }
349
+ }
350
+ return val
351
+ }).join(', ')
352
+ },
353
+ computePopupWrapperStyle () {
354
+ const $xeTreeSelect = this
355
+
356
+ const popupOpts = $xeTreeSelect.computePopupOpts
357
+ const { height, width } = popupOpts
358
+ const stys: VxeComponentStyleType = {}
359
+ if (width) {
360
+ stys.width = toCssUnit(width)
361
+ }
362
+ if (height) {
363
+ stys.height = toCssUnit(height)
364
+ stys.maxHeight = toCssUnit(height)
365
+ }
366
+ return stys
367
+ }
368
+ },
369
+ methods: {
370
+ //
371
+ // Method
372
+ //
373
+ dispatchEvent (type: ValueOf<VxeTreeSelectEmits>, params: Record<string, any>, evnt: Event | null) {
374
+ const $xeTreeSelect = this
375
+ $xeTreeSelect.$emit(type, createEvent(evnt, { $treeSelect: $xeTreeSelect }, params))
376
+ },
377
+ emitModel (value: any) {
378
+ const $xeTreeSelect = this
379
+
380
+ const { _events } = $xeTreeSelect as any
381
+ if (_events && _events.modelValue) {
382
+ $xeTreeSelect.$emit('modelValue', value)
383
+ } else {
384
+ $xeTreeSelect.$emit('model-value', value)
385
+ }
386
+ },
387
+ callSlot (slotFunc: ((params: any, h: CreateElement) => any) | string | null, params: any, h: CreateElement) {
388
+ const $xeTreeSelect = this
389
+ const slots = $xeTreeSelect.$scopedSlots
390
+
391
+ if (slotFunc) {
392
+ if (XEUtils.isString(slotFunc)) {
393
+ slotFunc = slots[slotFunc] || null
394
+ }
395
+ if (XEUtils.isFunction(slotFunc)) {
396
+ return getSlotVNs(slotFunc.call($xeTreeSelect, params, h))
397
+ }
398
+ }
399
+ return []
400
+ },
401
+ getNodeid (option: any) {
402
+ const $xeTreeSelect = this
403
+
404
+ const nodeKeyField = $xeTreeSelect.computeNodeKeyField
405
+ const nodeid = option[nodeKeyField]
406
+ return nodeid ? encodeURIComponent(nodeid) : ''
407
+ },
408
+ cacheDataMap () {
409
+ const $xeTreeSelect = this
410
+ const props = $xeTreeSelect
411
+ const internalData = $xeTreeSelect.internalData
412
+
413
+ const { options } = props
414
+ const nodeKeyField = $xeTreeSelect.computeNodeKeyField
415
+ const childrenField = $xeTreeSelect.computeChildrenField
416
+ const valueField = $xeTreeSelect.computeValueField
417
+ const nodeMaps: Record<string, {
418
+ item: any
419
+ index: number
420
+ items: any[]
421
+ parent: any
422
+ nodes: any[]
423
+ }> = {}
424
+ const keyMaps: Record<string, boolean> = {}
425
+ XEUtils.eachTree(options, (item, index, items, path, parent, nodes) => {
426
+ let nodeid = $xeTreeSelect.getNodeid(item)
427
+ if (!nodeid) {
428
+ nodeid = getOptUniqueId()
429
+ }
430
+ if (keyMaps[nodeid]) {
431
+ errLog('vxe.error.repeatKey', [`[tree-select] ${nodeKeyField}`, nodeid])
432
+ }
433
+ keyMaps[nodeid] = true
434
+ const value = item[valueField]
435
+ if (nodeMaps[value]) {
436
+ errLog('vxe.error.repeatKey', [`[tree-select] ${valueField}`, value])
437
+ }
438
+ nodeMaps[value] = { item, index, items, parent, nodes }
439
+ }, { children: childrenField })
440
+ internalData.fullOptionList = options || []
441
+ internalData.fullNodeMaps = nodeMaps
442
+ },
443
+ updateZindex () {
444
+ const $xeTreeSelect = this
445
+ const props = $xeTreeSelect
446
+ const reactData = $xeTreeSelect.reactData
447
+
448
+ const popupOpts = $xeTreeSelect.computePopupOpts
449
+ const customZIndex = popupOpts.zIndex || props.zIndex
450
+ if (customZIndex) {
451
+ reactData.panelIndex = XEUtils.toNumber(customZIndex)
452
+ } else if (reactData.panelIndex < getLastZIndex()) {
453
+ reactData.panelIndex = nextZIndex()
454
+ }
455
+ },
456
+ updatePlacement () {
457
+ const $xeTreeSelect = this
458
+ const props = $xeTreeSelect
459
+ const reactData = $xeTreeSelect.reactData
460
+
461
+ const { placement } = props
462
+ const { panelIndex } = reactData
463
+ const targetElem = $xeTreeSelect.$refs.refElem as HTMLElement
464
+ const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLDivElement
465
+ const btnTransfer = $xeTreeSelect.computeBtnTransfer
466
+ const popupOpts = $xeTreeSelect.computePopupOpts
467
+ const handleStyle = () => {
468
+ const ppObj = updatePanelPlacement(targetElem, panelElem, {
469
+ placement: popupOpts.placement || placement,
470
+ teleportTo: btnTransfer
471
+ })
472
+ const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
473
+ zIndex: panelIndex
474
+ })
475
+ reactData.panelStyle = panelStyle
476
+ reactData.panelPlacement = ppObj.placement
477
+ }
478
+ handleStyle()
479
+ return $xeTreeSelect.$nextTick().then(handleStyle)
480
+ },
481
+ showOptionPanel () {
482
+ const $xeTreeSelect = this
483
+ const props = $xeTreeSelect
484
+ const reactData = $xeTreeSelect.reactData
485
+ const internalData = $xeTreeSelect.internalData
486
+
487
+ const { loading, remote, filterable } = props
488
+ const { fullOptionList } = internalData
489
+ const isDisabled = $xeTreeSelect.computeIsDisabled
490
+ const remoteOpts = $xeTreeSelect.computeRemoteOpts
491
+ if (!loading && !isDisabled) {
492
+ if (internalData.hpTimeout) {
493
+ clearTimeout(internalData.hpTimeout)
494
+ }
495
+ if (!reactData.initialized) {
496
+ reactData.initialized = true
497
+ const btnTransfer = $xeTreeSelect.computeBtnTransfer
498
+ const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement
499
+ if (btnTransfer) {
500
+ if (panelElem) {
501
+ document.body.appendChild(panelElem)
502
+ }
503
+ }
504
+ }
505
+ reactData.isActivated = true
506
+ reactData.isAniVisible = true
507
+ if (filterable) {
508
+ if (remote && remoteOpts.enabled && remoteOpts.autoLoad && !fullOptionList.length) {
509
+ $xeTreeSelect.handleSearchEvent()
510
+ }
511
+ }
512
+ setTimeout(() => {
513
+ reactData.visiblePanel = true
514
+ $xeTreeSelect.handleFocusSearch()
515
+ $xeTreeSelect.updatePlacement()
516
+ }, 10)
517
+ $xeTreeSelect.updateZindex()
518
+ $xeTreeSelect.updatePlacement()
519
+ }
520
+ },
521
+ hideOptionPanel () {
522
+ const $xeTreeSelect = this
523
+ const reactData = $xeTreeSelect.reactData
524
+ const internalData = $xeTreeSelect.internalData
525
+
526
+ reactData.visiblePanel = false
527
+ internalData.hpTimeout = setTimeout(() => {
528
+ reactData.isAniVisible = false
529
+ }, 350)
530
+ },
531
+ changeEvent (evnt: Event, selectValue: any, node: any) {
532
+ const $xeTreeSelect = this
533
+ const props = $xeTreeSelect
534
+ const $xeForm = $xeTreeSelect.$xeForm
535
+ const formItemInfo = $xeTreeSelect.formItemInfo
536
+
537
+ const value = XEUtils.isArray(selectValue) ? selectValue.map(deNodeValue) : deNodeValue(selectValue)
538
+ $xeTreeSelect.emitModel(value)
539
+ if (value !== props.value) {
540
+ $xeTreeSelect.dispatchEvent('change', { value, node, option: node }, evnt)
541
+ // 自动更新校验状态
542
+ if ($xeForm && formItemInfo) {
543
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
544
+ }
545
+ }
546
+ },
547
+ clearValueEvent (evnt: Event, selectValue: any) {
548
+ const $xeTreeSelect = this
549
+
550
+ $xeTreeSelect.changeEvent(evnt, selectValue, null)
551
+ $xeTreeSelect.dispatchEvent('clear', { value: selectValue }, evnt)
552
+ },
553
+ clearEvent (params: any, evnt: Event) {
554
+ const $xeTreeSelect = this
555
+
556
+ $xeTreeSelect.clearValueEvent(evnt, null)
557
+ $xeTreeSelect.hideOptionPanel()
558
+ },
559
+ allCheckedPanelEvent (params: VxeButtonDefines.ClickEventParams) {
560
+ const $xeTreeSelect = this
561
+ const props = $xeTreeSelect
562
+
563
+ const { $event } = params
564
+ const { multiple, autoClose } = props
565
+ const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
566
+ if (multiple) {
567
+ if ($tree) {
568
+ $tree.setAllCheckboxNode(true).then(({ checkNodeKeys, checkNodes }) => {
569
+ $xeTreeSelect.changeEvent($event, checkNodeKeys, checkNodes[0])
570
+ $xeTreeSelect.dispatchEvent('all-change', { value: checkNodeKeys }, $event)
571
+ if (autoClose) {
572
+ $xeTreeSelect.hideOptionPanel()
573
+ }
574
+ })
575
+ }
576
+ }
577
+ },
578
+ clearCheckedPanelEvent (params: VxeButtonDefines.ClickEventParams) {
579
+ const $xeTreeSelect = this
580
+ const props = $xeTreeSelect
581
+
582
+ const { $event } = params
583
+ const { multiple, autoClose } = props
584
+ const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
585
+ if ($tree) {
586
+ const value = multiple ? [] : null
587
+ $tree.clearCheckboxNode().then(() => {
588
+ if (autoClose) {
589
+ $xeTreeSelect.hideOptionPanel()
590
+ }
591
+ })
592
+ $xeTreeSelect.changeEvent($event, value, null)
593
+ $xeTreeSelect.dispatchEvent('clear', { value }, $event)
594
+ }
595
+ },
596
+ allExpandPanelEvent () {
597
+ const $xeTreeSelect = this
598
+
599
+ const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
600
+ if ($tree) {
601
+ $tree.setAllExpandNode(true)
602
+ }
603
+ },
604
+ clearExpandPanelEvent () {
605
+ const $xeTreeSelect = this
606
+
607
+ const $tree = $xeTreeSelect.$refs.refTree as VxeTreeConstructor
608
+ if ($tree) {
609
+ $tree.clearAllExpandNode()
610
+ }
611
+ },
612
+ handleGlobalMousewheelEvent (evnt: MouseEvent) {
613
+ const $xeTreeSelect = this
614
+ const reactData = $xeTreeSelect.reactData
615
+
616
+ const { visiblePanel } = reactData
617
+ const isDisabled = $xeTreeSelect.computeIsDisabled
618
+ if (!isDisabled) {
619
+ if (visiblePanel) {
620
+ const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement
621
+ if (getEventTargetNode(evnt, panelElem).flag) {
622
+ $xeTreeSelect.updatePlacement()
623
+ } else {
624
+ $xeTreeSelect.hideOptionPanel()
625
+ }
626
+ }
627
+ }
628
+ },
629
+ handleGlobalMousedownEvent (evnt: MouseEvent) {
630
+ const $xeTreeSelect = this
631
+ const reactData = $xeTreeSelect.reactData
632
+
633
+ const { visiblePanel } = reactData
634
+ const isDisabled = $xeTreeSelect.computeIsDisabled
635
+ if (!isDisabled) {
636
+ const el = $xeTreeSelect.$refs.refElem as HTMLElement
637
+ const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement
638
+ reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
639
+ if (visiblePanel && !reactData.isActivated) {
640
+ $xeTreeSelect.hideOptionPanel()
641
+ }
642
+ }
643
+ },
644
+ handleGlobalBlurEvent () {
645
+ const $xeTreeSelect = this
646
+ const reactData = $xeTreeSelect.reactData
647
+
648
+ const { visiblePanel, isActivated } = reactData
649
+ if (visiblePanel) {
650
+ $xeTreeSelect.hideOptionPanel()
651
+ }
652
+ if (isActivated) {
653
+ reactData.isActivated = false
654
+ }
655
+ if (visiblePanel || isActivated) {
656
+ const $input = $xeTreeSelect.$refs.refInput as VxeInputConstructor
657
+ if ($input) {
658
+ $input.blur()
659
+ }
660
+ }
661
+ },
662
+ handleGlobalResizeEvent () {
663
+ const $xeTreeSelect = this
664
+ const reactData = $xeTreeSelect.reactData
665
+
666
+ const { visiblePanel } = reactData
667
+ if (visiblePanel) {
668
+ $xeTreeSelect.updatePlacement()
669
+ }
670
+ },
671
+ handleFocusSearch () {
672
+ const $xeSelect = this
673
+ const props = $xeSelect
674
+
675
+ if (props.filterable) {
676
+ $xeSelect.$nextTick(() => {
677
+ const inpSearch = $xeSelect.$refs.refInpSearch as VxeInputConstructor
678
+ if (inpSearch) {
679
+ inpSearch.focus()
680
+ }
681
+ })
682
+ }
683
+ },
684
+ focusEvent (evnt: FocusEvent) {
685
+ const $xeTreeSelect = this
686
+ const reactData = $xeTreeSelect.reactData
687
+
688
+ const isDisabled = $xeTreeSelect.computeIsDisabled
689
+ if (!isDisabled) {
690
+ if (!reactData.visiblePanel) {
691
+ reactData.triggerFocusPanel = true
692
+ $xeTreeSelect.showOptionPanel()
693
+ setTimeout(() => {
694
+ reactData.triggerFocusPanel = false
695
+ }, 150)
696
+ }
697
+ }
698
+ $xeTreeSelect.dispatchEvent('focus', {}, evnt)
699
+ },
700
+ clickEvent (evnt: MouseEvent) {
701
+ const $xeTreeSelect = this
702
+
703
+ $xeTreeSelect.togglePanelEvent(evnt)
704
+ $xeTreeSelect.dispatchEvent('click', {}, evnt)
705
+ },
706
+ blurEvent (evnt: FocusEvent) {
707
+ const $xeTreeSelect = this
708
+ const reactData = $xeTreeSelect.reactData
709
+
710
+ reactData.isActivated = false
711
+ $xeTreeSelect.dispatchEvent('blur', {}, evnt)
712
+ },
713
+ modelSearchEvent (value: string) {
714
+ const $xeTreeSelect = this
715
+ const reactData = $xeTreeSelect.reactData
716
+
717
+ reactData.searchValue = value
718
+ },
719
+ handleSearchEvent () {
720
+ const $xeTreeSelect = this
721
+ const props = $xeTreeSelect
722
+ const reactData = $xeTreeSelect.reactData
723
+
724
+ const { value: modelValue, remote, remoteMethod } = props
725
+ const { searchValue } = reactData
726
+ const remoteOpts = $xeTreeSelect.computeRemoteOpts
727
+ const queryMethod = remoteOpts.queryMethod || remoteMethod
728
+ if (remote && queryMethod && remoteOpts.enabled) {
729
+ reactData.searchLoading = true
730
+ Promise.resolve(
731
+ queryMethod({ $treeSelect: $xeTreeSelect, searchValue, value: modelValue })
732
+ ).then(() => $xeTreeSelect.$nextTick())
733
+ .catch(() => $xeTreeSelect.$nextTick())
734
+ .finally(() => {
735
+ reactData.searchLoading = false
736
+ })
737
+ }
738
+ },
739
+ togglePanelEvent (params: any) {
740
+ const $xeTreeSelect = this
741
+ const reactData = $xeTreeSelect.reactData
742
+
743
+ const { $event } = params
744
+ $event.preventDefault()
745
+ if (reactData.triggerFocusPanel) {
746
+ reactData.triggerFocusPanel = false
747
+ } else {
748
+ if (reactData.visiblePanel) {
749
+ $xeTreeSelect.hideOptionPanel()
750
+ } else {
751
+ $xeTreeSelect.showOptionPanel()
752
+ }
753
+ }
754
+ },
755
+ nodeExpandEvent () {
756
+ const $xeTreeSelect = this
757
+
758
+ $xeTreeSelect.updatePlacement()
759
+ },
760
+ nodeClickEvent (params: VxeTreeDefines.NodeClickEventParams) {
761
+ const $xeTreeSelect = this
762
+
763
+ const { $event } = params
764
+ $xeTreeSelect.dispatchEvent('node-click', params, $event)
765
+ },
766
+ radioChangeEvent (params: VxeTreeDefines.RadioChangeEventParams) {
767
+ const $xeTreeSelect = this
768
+
769
+ const { value, $event, node } = params
770
+ $xeTreeSelect.changeEvent($event, value, node)
771
+ $xeTreeSelect.hideOptionPanel()
772
+ },
773
+ checkboxChangeEvent (params: VxeTreeDefines.CheckboxChangeEventParams) {
774
+ const $xeTreeSelect = this
775
+
776
+ const { value, $event, node } = params
777
+ $xeTreeSelect.changeEvent($event, value, node)
778
+ },
779
+ loadSuccessEvent () {
780
+ const $xeTreeSelect = this
781
+
782
+ $xeTreeSelect.cacheDataMap()
783
+ },
784
+
785
+ //
786
+ // Render
787
+ //
788
+ renderVN (h: CreateElement): VNode {
789
+ const $xeTreeSelect = this
790
+ const props = $xeTreeSelect
791
+ const slots = $xeTreeSelect.$scopedSlots
792
+ const reactData = $xeTreeSelect.reactData
793
+
794
+ const { className, value: modelValue, multiple, options, loading, menuConfig, filterable, showTotalButoon, showCheckedButoon, showClearButton, showExpandButton } = props
795
+ const { initialized, isActivated, isAniVisible, visiblePanel, searchValue } = reactData
796
+ const vSize = $xeTreeSelect.computeSize
797
+ const isDisabled = $xeTreeSelect.computeIsDisabled
798
+ const selectLabel = $xeTreeSelect.computeSelectLabel
799
+ const btnTransfer = $xeTreeSelect.computeBtnTransfer
800
+ const formReadonly = $xeTreeSelect.computeFormReadonly
801
+ const popupWrapperStyle = $xeTreeSelect.computePopupWrapperStyle
802
+ const headerSlot = slots.header
803
+ const footerSlot = slots.footer
804
+ const prefixSlot = slots.prefix
805
+ const popupOpts = $xeTreeSelect.computePopupOpts
806
+ const ppClassName = popupOpts.className || props.popupClassName
807
+ if (formReadonly) {
808
+ return h('div', {
809
+ ref: 'refElem',
810
+ class: ['vxe-tree-select--readonly', className]
811
+ }, [
812
+ h('span', {
813
+ class: 'vxe-tree-select-label'
814
+ }, selectLabel)
815
+ ])
816
+ }
817
+ const treeOpts = $xeTreeSelect.computeTreeOpts
818
+ const menuOpts = $xeTreeSelect.computeMenuOpts
819
+ const treeNodeOpts = $xeTreeSelect.computeTreeNodeOpts
820
+ const treeCheckboxOpts = $xeTreeSelect.computeTreeCheckboxOpts
821
+ const treeRadioOpts = $xeTreeSelect.computeTreeRadioOpts
822
+ const nodeKeyField = $xeTreeSelect.computeNodeKeyField
823
+ const labelField = $xeTreeSelect.computeLabelField
824
+ const valueField = $xeTreeSelect.computeValueField
825
+ const childrenField = $xeTreeSelect.computeChildrenField
826
+ const parentField = $xeTreeSelect.computeParentField
827
+ const hasChildField = $xeTreeSelect.computeHasChildField
828
+ const virtualYOpts = $xeTreeSelect.computeVirtualYOpts
829
+ const filterOpts = $xeTreeSelect.computeFilterOpts
830
+ const { slots: treeSlots } = treeOpts
831
+ const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
832
+ const treeScopedSlots: {
833
+ icon?: (params: any) => VNode[]
834
+ title?: (params: any) => VNode[]
835
+ extra?: (params: any) => VNode[]
836
+ } = {}
837
+ if (treeSlots) {
838
+ const { icon: treeIconSlot, title: treeTitleSlot, extra: treeExtraSlot } = treeSlots
839
+ if (treeIconSlot) {
840
+ treeScopedSlots.icon = (slotParams) => $xeTreeSelect.callSlot(treeIconSlot, slotParams, h) as VNode[]
841
+ }
842
+ if (treeTitleSlot) {
843
+ treeScopedSlots.title = (slotParams) => $xeTreeSelect.callSlot(treeTitleSlot, slotParams, h) as VNode[]
844
+ }
845
+ if (treeExtraSlot) {
846
+ treeScopedSlots.extra = (slotParams) => $xeTreeSelect.callSlot(treeExtraSlot, slotParams, h) as VNode[]
847
+ }
848
+ }
849
+ return h('div', {
850
+ ref: 'refElem',
851
+ class: ['vxe-tree-select', className ? (XEUtils.isFunction(className) ? className({ $treeSelect: $xeTreeSelect }) : className) : '', {
852
+ [`size--${vSize}`]: vSize,
853
+ 'is--filterable': filterable,
854
+ 'is--visible': visiblePanel,
855
+ 'is--disabled': isDisabled,
856
+ 'is--loading': loading,
857
+ 'is--active': isActivated
858
+ }]
859
+ }, [
860
+ h(VxeInputComponent, {
861
+ ref: 'refInput',
862
+ props: {
863
+ clearable: props.clearable,
864
+ placeholder: props.placeholder,
865
+ editable: false,
866
+ disabled: isDisabled,
867
+ type: 'text',
868
+ prefixIcon: props.prefixIcon,
869
+ suffixIcon: loading ? getIcon().TREE_SELECT_LOADED : (visiblePanel ? getIcon().TREE_SELECT_OPEN : getIcon().TREE_SELECT_CLOSE),
870
+ value: loading ? getI18n('vxe.select.loadingText') : selectLabel,
871
+ title: selectLabel
872
+ },
873
+ on: {
874
+ clear: $xeTreeSelect.clearEvent,
875
+ click: $xeTreeSelect.clickEvent,
876
+ focus: $xeTreeSelect.focusEvent,
877
+ blur: $xeTreeSelect.blurEvent,
878
+ 'suffix-click': $xeTreeSelect.togglePanelEvent
879
+ },
880
+ scopedSlots: prefixSlot
881
+ ? {
882
+ prefix: () => prefixSlot({})
883
+ }
884
+ : {}
885
+ }),
886
+ h('div', {
887
+ ref: 'refOptionPanel',
888
+ class: ['vxe-table--ignore-clear vxe-tree-select--panel', ppClassName ? (XEUtils.isFunction(ppClassName) ? ppClassName({ $treeSelect: $xeTreeSelect }) : ppClassName) : '', {
889
+ [`size--${vSize}`]: vSize,
890
+ 'is--transfer': btnTransfer,
891
+ 'ani--leave': !loading && isAniVisible,
892
+ 'ani--enter': !loading && visiblePanel
893
+ }],
894
+ attrs: {
895
+ placement: reactData.panelPlacement
896
+ },
897
+ style: reactData.panelStyle
898
+ }, initialized
899
+ ? [
900
+ h('div', {
901
+ class: 'vxe-tree-select--panel-wrapper'
902
+ }, [
903
+ filterable
904
+ ? h('div', {
905
+ class: 'vxe-tree-select--panel-search'
906
+ }, [
907
+ h(VxeInputComponent, {
908
+ ref: 'refInpSearch',
909
+ class: 'vxe-tree-select-search--input',
910
+ props: {
911
+ value: searchValue,
912
+ title: selectLabel,
913
+ clearable: true,
914
+ disabled: false,
915
+ readonly: false,
916
+ placeholder: getI18n('vxe.treeSelect.search'),
917
+ prefixIcon: getIcon().INPUT_SEARCH
918
+ },
919
+ on: {
920
+ 'model-value': $xeTreeSelect.modelSearchEvent
921
+ }
922
+ })
923
+ ])
924
+ : renderEmptyElement($xeTreeSelect),
925
+ showTotalButoon || (showCheckedButoon && multiple) || showClearButton || showExpandButton || headerSlot
926
+ ? h('div', {
927
+ class: 'vxe-tree-select--panel-header'
928
+ }, headerSlot
929
+ ? headerSlot({})
930
+ : [
931
+ h('div', {
932
+ class: 'vxe-tree-select--header-button'
933
+ }, [
934
+ showCheckedButoon && showClearButton
935
+ ? h('div', {
936
+ class: 'vxe-tree-select--selected-btns'
937
+ }, [
938
+ (showCheckedButoon && multiple)
939
+ ? h(VxeButtonComponent, {
940
+ props: {
941
+ content: getI18n('vxe.treeSelect.allChecked'),
942
+ mode: 'text'
943
+ },
944
+ on: {
945
+ click: $xeTreeSelect.allCheckedPanelEvent
946
+ }
947
+ })
948
+ : renderEmptyElement($xeTreeSelect),
949
+ showClearButton
950
+ ? h(VxeButtonComponent, {
951
+ props: {
952
+ content: getI18n('vxe.treeSelect.clearChecked'),
953
+ mode: 'text'
954
+ },
955
+ on: {
956
+ click: $xeTreeSelect.clearCheckedPanelEvent
957
+ }
958
+ })
959
+ : renderEmptyElement($xeTreeSelect)
960
+ ])
961
+ : renderEmptyElement($xeTreeSelect),
962
+ showExpandButton && showExpandButton
963
+ ? h('div', {
964
+ class: 'vxe-tree-select--expand-btns'
965
+ }, [
966
+ showExpandButton
967
+ ? h(VxeButtonComponent, {
968
+ props: {
969
+ content: getI18n('vxe.treeSelect.allExpand'),
970
+ mode: 'text'
971
+ },
972
+ on: {
973
+ click: $xeTreeSelect.allExpandPanelEvent
974
+ }
975
+ })
976
+ : renderEmptyElement($xeTreeSelect),
977
+ showExpandButton
978
+ ? h(VxeButtonComponent, {
979
+ props: {
980
+ content: getI18n('vxe.treeSelect.clearExpand'),
981
+ mode: 'text'
982
+ },
983
+ on: {
984
+ click: $xeTreeSelect.clearExpandPanelEvent
985
+ }
986
+ })
987
+ : renderEmptyElement($xeTreeSelect)
988
+ ])
989
+ : renderEmptyElement($xeTreeSelect)
990
+ ])
991
+ ])
992
+ : renderEmptyElement($xeTreeSelect),
993
+ h('div', {
994
+ class: 'vxe-tree-select--panel-body'
995
+ }, [
996
+ h('div', {
997
+ ref: 'refTreeWrapper',
998
+ class: 'vxe-tree-select-tree--wrapper',
999
+ style: popupWrapperStyle
1000
+ }, [
1001
+ h(VxeTreeComponent, {
1002
+ ref: 'refTree',
1003
+ class: 'vxe-tree-select--tree',
1004
+ props: {
1005
+ data: options,
1006
+ height: popupOpts.height ? '100%' : treeOpts.height,
1007
+ minHeight: treeOpts.minHeight,
1008
+ maxHeight: popupOpts.height ? '' : treeOpts.maxHeight,
1009
+ autoResize: true,
1010
+ indent: treeOpts.indent,
1011
+ showRadio: !multiple,
1012
+ radioConfig: treeRadioOpts,
1013
+ checkNodeKey: multiple ? null : modelValue,
1014
+ showCheckbox: !!multiple,
1015
+ checkNodeKeys: multiple ? modelValue : null,
1016
+ checkboxConfig: treeCheckboxOpts,
1017
+ titleField: labelField,
1018
+ valueField: valueField,
1019
+ keyField: nodeKeyField,
1020
+ childrenField: treeOpts.childrenField || childrenField,
1021
+ parentField: treeOpts.parentField || parentField,
1022
+ hasChildField: treeOpts.hasChildField || hasChildField,
1023
+ accordion: treeOpts.accordion,
1024
+ expandAll: treeOpts.expandAll,
1025
+ expandNodeKeys: treeOpts.expandNodeKeys,
1026
+ nodeConfig: treeNodeOpts,
1027
+ lazy: treeOpts.lazy,
1028
+ loadMethod: treeOpts.loadMethod,
1029
+ toggleMethod: treeOpts.toggleMethod,
1030
+ transform: treeOpts.transform,
1031
+ trigger: treeOpts.trigger,
1032
+ showIcon: treeOpts.showIcon,
1033
+ showLine: treeOpts.showLine,
1034
+ iconOpen: treeOpts.iconOpen,
1035
+ iconLoaded: treeOpts.iconLoaded,
1036
+ iconClose: treeOpts.iconClose,
1037
+ filterValue: searchValue,
1038
+ filterConfig: filterOpts,
1039
+ menuConfig: menuConfig ? menuOpts : undefined,
1040
+ virtualYConfig: virtualYOpts
1041
+ },
1042
+ on: {
1043
+ 'node-expand': $xeTreeSelect.nodeExpandEvent,
1044
+ 'node-click': $xeTreeSelect.nodeClickEvent,
1045
+ 'radio-change': $xeTreeSelect.radioChangeEvent,
1046
+ 'checkbox-change': $xeTreeSelect.checkboxChangeEvent,
1047
+ 'load-success': $xeTreeSelect.loadSuccessEvent
1048
+ },
1049
+ scopedSlots: treeScopedSlots
1050
+ })
1051
+ ])
1052
+ ]),
1053
+ footerSlot || showTotalButoon
1054
+ ? h('div', {
1055
+ class: 'vxe-tree-select--panel-footer'
1056
+ }, footerSlot
1057
+ ? footerSlot({})
1058
+ : [
1059
+ h('div', {
1060
+ class: 'vxe-tree-select--footer-button'
1061
+ }, [
1062
+ showTotalButoon
1063
+ ? h('div', {
1064
+ class: 'vxe-tree-select--total-btns'
1065
+ }, getI18n('vxe.treeSelect.total', [selectVals.length]))
1066
+ : renderEmptyElement($xeTreeSelect)
1067
+ ])
1068
+ ])
1069
+ : renderEmptyElement($xeTreeSelect)
1070
+ ])
1071
+ ]
1072
+ : [])
1073
+ ])
1074
+ }
1075
+ },
1076
+ watch: {
1077
+ options () {
1078
+ const $xeTreeSelect = this
1079
+
1080
+ $xeTreeSelect.cacheDataMap()
1081
+ }
1082
+ },
1083
+ created () {
1084
+ const $xeTreeSelect = this
1085
+
1086
+ $xeTreeSelect.cacheDataMap()
1087
+ },
1088
+ mounted () {
1089
+ const $xeTreeSelect = this
1090
+
1091
+ globalEvents.on($xeTreeSelect, 'mousewheel', $xeTreeSelect.handleGlobalMousewheelEvent)
1092
+ globalEvents.on($xeTreeSelect, 'mousedown', $xeTreeSelect.handleGlobalMousedownEvent)
1093
+ globalEvents.on($xeTreeSelect, 'blur', $xeTreeSelect.handleGlobalBlurEvent)
1094
+ globalEvents.on($xeTreeSelect, 'resize', $xeTreeSelect.handleGlobalResizeEvent)
1095
+ },
1096
+ beforeDestroy () {
1097
+ const $xeTreeSelect = this
1098
+ const reactData = $xeTreeSelect.reactData
1099
+ const internalData = $xeTreeSelect.internalData
1100
+
1101
+ const panelElem = $xeTreeSelect.$refs.refOptionPanel as HTMLElement | undefined
1102
+ if (panelElem && panelElem.parentNode) {
1103
+ panelElem.parentNode.removeChild(panelElem)
1104
+ }
1105
+ globalEvents.off($xeTreeSelect, 'mousewheel')
1106
+ globalEvents.off($xeTreeSelect, 'mousedown')
1107
+ globalEvents.off($xeTreeSelect, 'blur')
1108
+ globalEvents.off($xeTreeSelect, 'resize')
1109
+ XEUtils.assign(reactData, createReactData())
1110
+ XEUtils.assign(internalData, createInternalData())
1111
+ },
1112
+ render (this: any, h) {
1113
+ return this.renderVN(h)
1114
+ }
1115
+ }) /* define-vxe-component end */