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