vxe-pc-ui 4.14.6 → 4.14.7

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 (611) hide show
  1. package/LICENSE +21 -21
  2. package/README.en.md +72 -72
  3. package/README.ja-JP.md +72 -72
  4. package/README.md +364 -364
  5. package/README.zh-TW.md +73 -73
  6. package/es/checkbox/src/button.js +26 -5
  7. package/es/checkbox/src/checkbox.js +26 -5
  8. package/es/checkbox/src/group.js +23 -3
  9. package/es/checkbox/style.css +6 -3
  10. package/es/checkbox/style.min.css +1 -1
  11. package/es/language/ar-EG.js +4 -0
  12. package/es/language/de-DE.js +4 -0
  13. package/es/language/en-US.js +4 -0
  14. package/es/language/es-ES.js +4 -0
  15. package/es/language/fr-FR.js +4 -0
  16. package/es/language/hu-HU.js +4 -0
  17. package/es/language/hy-AM.js +4 -0
  18. package/es/language/id-ID.js +4 -0
  19. package/es/language/it-IT.js +4 -0
  20. package/es/language/ja-JP.js +4 -0
  21. package/es/language/ko-KR.js +4 -0
  22. package/es/language/ms-MY.js +4 -0
  23. package/es/language/nb-NO.js +4 -0
  24. package/es/language/pt-BR.js +4 -0
  25. package/es/language/ru-RU.js +4 -0
  26. package/es/language/th-TH.js +4 -0
  27. package/es/language/ug-CN.js +4 -0
  28. package/es/language/uk-UA.js +4 -0
  29. package/es/language/uz-UZ.js +4 -0
  30. package/es/language/vi-VN.js +4 -0
  31. package/es/language/zh-CHT.js +4 -0
  32. package/es/language/zh-CN.js +4 -0
  33. package/es/radio/src/button.js +27 -5
  34. package/es/radio/src/group.js +17 -2
  35. package/es/radio/src/radio.js +27 -5
  36. package/es/radio/style.css +5 -3
  37. package/es/radio/style.min.css +1 -1
  38. package/es/style.css +1 -1
  39. package/es/style.min.css +1 -1
  40. package/es/switch/src/switch.js +19 -11
  41. package/es/tree/style.css +11 -6
  42. package/es/tree/style.min.css +1 -1
  43. package/es/ui/index.js +1 -1
  44. package/es/ui/src/log.js +1 -1
  45. package/es/vxe-checkbox/style.css +6 -3
  46. package/es/vxe-checkbox/style.min.css +1 -1
  47. package/es/vxe-radio/style.css +5 -3
  48. package/es/vxe-radio/style.min.css +1 -1
  49. package/es/vxe-tree/style.css +11 -6
  50. package/es/vxe-tree/style.min.css +1 -1
  51. package/lib/checkbox/src/button.js +26 -3
  52. package/lib/checkbox/src/button.min.js +1 -1
  53. package/lib/checkbox/src/checkbox.js +26 -3
  54. package/lib/checkbox/src/checkbox.min.js +1 -1
  55. package/lib/checkbox/src/group.js +25 -3
  56. package/lib/checkbox/src/group.min.js +1 -1
  57. package/lib/checkbox/style/style.css +6 -3
  58. package/lib/checkbox/style/style.min.css +1 -1
  59. package/lib/index.umd.js +2446 -2376
  60. package/lib/index.umd.min.js +1 -1
  61. package/lib/language/ar-EG.js +4 -0
  62. package/lib/language/ar-EG.min.js +1 -1
  63. package/lib/language/ar-EG.umd.js +4 -0
  64. package/lib/language/de-DE.js +4 -0
  65. package/lib/language/de-DE.min.js +1 -1
  66. package/lib/language/de-DE.umd.js +4 -0
  67. package/lib/language/en-US.js +4 -0
  68. package/lib/language/en-US.min.js +1 -1
  69. package/lib/language/en-US.umd.js +4 -0
  70. package/lib/language/es-ES.js +4 -0
  71. package/lib/language/es-ES.min.js +1 -1
  72. package/lib/language/es-ES.umd.js +4 -0
  73. package/lib/language/fr-FR.js +4 -0
  74. package/lib/language/fr-FR.min.js +1 -1
  75. package/lib/language/fr-FR.umd.js +4 -0
  76. package/lib/language/hu-HU.js +4 -0
  77. package/lib/language/hu-HU.min.js +1 -1
  78. package/lib/language/hu-HU.umd.js +4 -0
  79. package/lib/language/hy-AM.js +4 -0
  80. package/lib/language/hy-AM.min.js +1 -1
  81. package/lib/language/hy-AM.umd.js +4 -0
  82. package/lib/language/id-ID.js +4 -0
  83. package/lib/language/id-ID.min.js +1 -1
  84. package/lib/language/id-ID.umd.js +4 -0
  85. package/lib/language/it-IT.js +4 -0
  86. package/lib/language/it-IT.min.js +1 -1
  87. package/lib/language/it-IT.umd.js +4 -0
  88. package/lib/language/ja-JP.js +4 -0
  89. package/lib/language/ja-JP.min.js +1 -1
  90. package/lib/language/ja-JP.umd.js +4 -0
  91. package/lib/language/ko-KR.js +4 -0
  92. package/lib/language/ko-KR.min.js +1 -1
  93. package/lib/language/ko-KR.umd.js +4 -0
  94. package/lib/language/ms-MY.js +4 -0
  95. package/lib/language/ms-MY.min.js +1 -1
  96. package/lib/language/ms-MY.umd.js +4 -0
  97. package/lib/language/nb-NO.js +4 -0
  98. package/lib/language/nb-NO.min.js +1 -1
  99. package/lib/language/nb-NO.umd.js +4 -0
  100. package/lib/language/pt-BR.js +4 -0
  101. package/lib/language/pt-BR.min.js +1 -1
  102. package/lib/language/pt-BR.umd.js +4 -0
  103. package/lib/language/ru-RU.js +4 -0
  104. package/lib/language/ru-RU.min.js +1 -1
  105. package/lib/language/ru-RU.umd.js +4 -0
  106. package/lib/language/th-TH.js +4 -0
  107. package/lib/language/th-TH.min.js +1 -1
  108. package/lib/language/th-TH.umd.js +4 -0
  109. package/lib/language/ug-CN.js +4 -0
  110. package/lib/language/ug-CN.min.js +1 -1
  111. package/lib/language/ug-CN.umd.js +4 -0
  112. package/lib/language/uk-UA.js +4 -0
  113. package/lib/language/uk-UA.min.js +1 -1
  114. package/lib/language/uk-UA.umd.js +4 -0
  115. package/lib/language/uz-UZ.js +4 -0
  116. package/lib/language/uz-UZ.min.js +1 -1
  117. package/lib/language/uz-UZ.umd.js +4 -0
  118. package/lib/language/vi-VN.js +4 -0
  119. package/lib/language/vi-VN.min.js +1 -1
  120. package/lib/language/vi-VN.umd.js +4 -0
  121. package/lib/language/zh-CHT.js +4 -0
  122. package/lib/language/zh-CHT.min.js +1 -1
  123. package/lib/language/zh-CHT.umd.js +4 -0
  124. package/lib/language/zh-CN.js +4 -0
  125. package/lib/language/zh-CN.min.js +1 -1
  126. package/lib/language/zh-CN.umd.js +4 -0
  127. package/lib/radio/src/button.js +27 -3
  128. package/lib/radio/src/button.min.js +1 -1
  129. package/lib/radio/src/group.js +19 -2
  130. package/lib/radio/src/group.min.js +1 -1
  131. package/lib/radio/src/radio.js +27 -3
  132. package/lib/radio/src/radio.min.js +1 -1
  133. package/lib/radio/style/style.css +5 -3
  134. package/lib/radio/style/style.min.css +1 -1
  135. package/lib/style.css +1 -1
  136. package/lib/style.min.css +1 -1
  137. package/lib/switch/src/switch.js +18 -10
  138. package/lib/switch/src/switch.min.js +1 -1
  139. package/lib/tree/style/style.css +11 -6
  140. package/lib/tree/style/style.min.css +1 -1
  141. package/lib/ui/index.js +1 -1
  142. package/lib/ui/index.min.js +1 -1
  143. package/lib/ui/src/log.js +1 -1
  144. package/lib/ui/src/log.min.js +1 -1
  145. package/lib/vxe-checkbox/style/style.css +6 -3
  146. package/lib/vxe-checkbox/style/style.min.css +1 -1
  147. package/lib/vxe-radio/style/style.css +5 -3
  148. package/lib/vxe-radio/style/style.min.css +1 -1
  149. package/lib/vxe-tree/style/style.css +11 -6
  150. package/lib/vxe-tree/style/style.min.css +1 -1
  151. package/package.json +88 -88
  152. package/packages/alert/index.ts +16 -16
  153. package/packages/alert/src/alert.ts +124 -124
  154. package/packages/anchor/index.ts +16 -16
  155. package/packages/anchor/src/anchor-link.ts +121 -121
  156. package/packages/anchor/src/anchor.ts +237 -237
  157. package/packages/anchor/src/util.ts +23 -23
  158. package/packages/anchor-link/index.ts +16 -16
  159. package/packages/avatar/index.ts +16 -16
  160. package/packages/avatar/src/avatar.ts +149 -149
  161. package/packages/backtop/index.ts +16 -16
  162. package/packages/backtop/src/backtop.ts +314 -314
  163. package/packages/badge/index.ts +16 -16
  164. package/packages/badge/src/badge.ts +100 -100
  165. package/packages/breadcrumb/index.ts +16 -16
  166. package/packages/breadcrumb/src/breadcrumb-item.ts +106 -106
  167. package/packages/breadcrumb/src/breadcrumb.ts +92 -92
  168. package/packages/breadcrumb-item/index.ts +16 -16
  169. package/packages/button/index.ts +16 -16
  170. package/packages/button/src/button-group.ts +110 -110
  171. package/packages/button/src/button.ts +841 -841
  172. package/packages/button-group/index.ts +16 -16
  173. package/packages/calendar/index.ts +16 -16
  174. package/packages/calendar/src/calendar.ts +1351 -1351
  175. package/packages/card/index.ts +16 -16
  176. package/packages/card/src/card.ts +175 -175
  177. package/packages/carousel/index.ts +16 -16
  178. package/packages/carousel/src/carousel-item.ts +102 -102
  179. package/packages/carousel/src/carousel.ts +414 -414
  180. package/packages/carousel/src/util.ts +21 -21
  181. package/packages/carousel-item/index.ts +16 -16
  182. package/packages/cascader/index.ts +16 -16
  183. package/packages/cascader/src/cascader.ts +741 -741
  184. package/packages/checkbox/index.ts +16 -16
  185. package/packages/checkbox/src/button.ts +165 -144
  186. package/packages/checkbox/src/checkbox.ts +176 -154
  187. package/packages/checkbox/src/group.ts +243 -222
  188. package/packages/checkbox-button/index.ts +16 -16
  189. package/packages/checkbox-group/index.ts +16 -16
  190. package/packages/col/index.ts +16 -16
  191. package/packages/collapse/index.ts +16 -16
  192. package/packages/collapse/src/collapse-pane.ts +114 -114
  193. package/packages/collapse/src/collapse.ts +284 -284
  194. package/packages/collapse/src/util.ts +21 -21
  195. package/packages/collapse-pane/index.ts +16 -16
  196. package/packages/color-picker/index.ts +16 -16
  197. package/packages/color-picker/src/color-picker.ts +1109 -1109
  198. package/packages/color-picker/src/util.ts +198 -198
  199. package/packages/components.ts +307 -307
  200. package/packages/context-menu/index.ts +54 -54
  201. package/packages/context-menu/src/context-menu.ts +681 -681
  202. package/packages/countdown/index.ts +16 -16
  203. package/packages/countdown/src/countdown.ts +262 -262
  204. package/packages/date-panel/index.ts +16 -16
  205. package/packages/date-panel/src/date-panel.ts +1809 -1809
  206. package/packages/date-panel/src/util.ts +244 -244
  207. package/packages/date-picker/index.ts +16 -16
  208. package/packages/date-picker/src/date-picker.ts +1071 -1071
  209. package/packages/date-range-picker/index.ts +16 -16
  210. package/packages/date-range-picker/src/date-range-picker.ts +1280 -1280
  211. package/packages/drawer/index.ts +77 -77
  212. package/packages/drawer/src/drawer.ts +657 -657
  213. package/packages/dynamics/index.ts +89 -89
  214. package/packages/empty/index.ts +16 -16
  215. package/packages/empty/src/empty.ts +100 -100
  216. package/packages/form/index.ts +16 -16
  217. package/packages/form/render/index.ts +598 -598
  218. package/packages/form/src/form-config-item.ts +72 -72
  219. package/packages/form/src/form-group.ts +86 -86
  220. package/packages/form/src/form-item.ts +174 -174
  221. package/packages/form/src/form.ts +987 -987
  222. package/packages/form/src/itemInfo.ts +80 -80
  223. package/packages/form/src/render.ts +387 -387
  224. package/packages/form/src/util.ts +93 -93
  225. package/packages/form-gather/index.ts +26 -26
  226. package/packages/form-group/index.ts +16 -16
  227. package/packages/form-item/index.ts +16 -16
  228. package/packages/icon/index.ts +16 -16
  229. package/packages/icon/src/icon.ts +75 -75
  230. package/packages/icon-picker/index.ts +16 -16
  231. package/packages/icon-picker/src/icon-picker.ts +626 -626
  232. package/packages/image/index.ts +16 -16
  233. package/packages/image/src/group.ts +153 -153
  234. package/packages/image/src/image.ts +298 -298
  235. package/packages/image/src/preview.ts +672 -672
  236. package/packages/image/src/util.ts +59 -59
  237. package/packages/image-group/index.ts +16 -16
  238. package/packages/image-preview/index.ts +19 -19
  239. package/packages/index.ts +4 -4
  240. package/packages/input/index.ts +16 -16
  241. package/packages/input/src/input.ts +2788 -2788
  242. package/packages/language/ar-EG.ts +844 -840
  243. package/packages/language/de-DE.ts +844 -840
  244. package/packages/language/en-US.ts +844 -840
  245. package/packages/language/es-ES.ts +844 -840
  246. package/packages/language/fr-FR.ts +844 -840
  247. package/packages/language/hu-HU.ts +844 -840
  248. package/packages/language/hy-AM.ts +844 -840
  249. package/packages/language/id-ID.ts +844 -840
  250. package/packages/language/it-IT.ts +844 -840
  251. package/packages/language/ja-JP.ts +844 -840
  252. package/packages/language/ko-KR.ts +844 -840
  253. package/packages/language/ms-MY.ts +844 -840
  254. package/packages/language/nb-NO.ts +844 -840
  255. package/packages/language/pt-BR.ts +844 -840
  256. package/packages/language/ru-RU.ts +844 -840
  257. package/packages/language/th-TH.ts +844 -840
  258. package/packages/language/ug-CN.ts +844 -840
  259. package/packages/language/uk-UA.ts +844 -840
  260. package/packages/language/uz-UZ.ts +844 -840
  261. package/packages/language/vi-VN.ts +844 -840
  262. package/packages/language/zh-CHT.ts +844 -840
  263. package/packages/language/zh-CN.ts +844 -840
  264. package/packages/language/zh-HK.ts +3 -3
  265. package/packages/language/zh-MO.ts +3 -3
  266. package/packages/language/zh-TC.ts +3 -3
  267. package/packages/language/zh-TW.ts +3 -3
  268. package/packages/layout-aside/index.ts +16 -16
  269. package/packages/layout-aside/src/layout-aside.ts +123 -123
  270. package/packages/layout-body/index.ts +16 -16
  271. package/packages/layout-body/src/layout-body.ts +142 -142
  272. package/packages/layout-container/index.ts +16 -16
  273. package/packages/layout-container/src/layout-container.ts +82 -82
  274. package/packages/layout-footer/index.ts +16 -16
  275. package/packages/layout-footer/src/layout-footer.ts +74 -74
  276. package/packages/layout-header/index.ts +16 -16
  277. package/packages/layout-header/src/layout-header.ts +73 -73
  278. package/packages/link/index.ts +16 -16
  279. package/packages/link/src/link.ts +161 -161
  280. package/packages/list/index.ts +16 -16
  281. package/packages/list/src/list.ts +442 -442
  282. package/packages/loading/index.ts +34 -34
  283. package/packages/loading/src/loading.ts +152 -152
  284. package/packages/mention/index.ts +16 -16
  285. package/packages/mention/src/mention.ts +71 -71
  286. package/packages/menu/index.ts +16 -16
  287. package/packages/menu/src/menu.ts +581 -581
  288. package/packages/modal/index.ts +136 -136
  289. package/packages/modal/src/modal.ts +1494 -1494
  290. package/packages/notice-bar/index.ts +16 -16
  291. package/packages/notice-bar/src/notice-bar.ts +181 -181
  292. package/packages/number-input/index.ts +16 -16
  293. package/packages/number-input/src/number-input.ts +1096 -1096
  294. package/packages/number-input/src/util.ts +12 -12
  295. package/packages/optgroup/index.ts +16 -16
  296. package/packages/option/index.ts +16 -16
  297. package/packages/pager/index.ts +16 -16
  298. package/packages/pager/src/pager.ts +769 -769
  299. package/packages/password-input/index.ts +16 -16
  300. package/packages/password-input/src/password-input.ts +378 -378
  301. package/packages/print/index.ts +18 -18
  302. package/packages/print/src/page-break.ts +92 -92
  303. package/packages/print/src/print.ts +272 -272
  304. package/packages/print/src/util.ts +284 -284
  305. package/packages/print-page-break/index.ts +16 -16
  306. package/packages/pulldown/index.ts +16 -16
  307. package/packages/pulldown/src/pulldown.ts +457 -457
  308. package/packages/radio/index.ts +16 -16
  309. package/packages/radio/src/button.ts +195 -173
  310. package/packages/radio/src/group.ts +229 -213
  311. package/packages/radio/src/radio.ts +203 -180
  312. package/packages/radio-button/index.ts +16 -16
  313. package/packages/radio-group/index.ts +16 -16
  314. package/packages/rate/index.ts +16 -16
  315. package/packages/rate/src/rate.ts +192 -192
  316. package/packages/result/index.ts +16 -16
  317. package/packages/result/src/result.ts +112 -112
  318. package/packages/row/index.ts +16 -16
  319. package/packages/row/src/col.ts +136 -136
  320. package/packages/row/src/row.ts +119 -119
  321. package/packages/segmented/index.ts +16 -16
  322. package/packages/segmented/src/segmented.ts +264 -264
  323. package/packages/select/index.ts +16 -16
  324. package/packages/select/src/optgroup.ts +49 -49
  325. package/packages/select/src/option-info.ts +20 -20
  326. package/packages/select/src/option.ts +47 -47
  327. package/packages/select/src/select.ts +1699 -1699
  328. package/packages/select/src/util.ts +47 -47
  329. package/packages/slider/index.ts +16 -16
  330. package/packages/slider/src/slider.ts +304 -304
  331. package/packages/split/index.ts +16 -16
  332. package/packages/split-pane/index.ts +17 -17
  333. package/packages/splitter/index.ts +16 -16
  334. package/packages/splitter/src/splitter-panel.ts +145 -145
  335. package/packages/splitter/src/splitter.ts +1009 -1009
  336. package/packages/splitter/src/util.ts +21 -21
  337. package/packages/splitter-panel/index.ts +16 -16
  338. package/packages/steps/index.ts +16 -16
  339. package/packages/steps/src/steps.ts +68 -68
  340. package/packages/switch/index.ts +16 -16
  341. package/packages/switch/src/switch.ts +245 -237
  342. package/packages/tab-pane/index.ts +16 -16
  343. package/packages/table-select/index.ts +16 -16
  344. package/packages/table-select/src/table-select.ts +800 -800
  345. package/packages/tabs/index.ts +16 -16
  346. package/packages/tabs/src/tab-pane.ts +117 -117
  347. package/packages/tabs/src/tabs.ts +940 -940
  348. package/packages/tabs/src/util.ts +21 -21
  349. package/packages/tag/index.ts +16 -16
  350. package/packages/tag/src/tag.ts +187 -187
  351. package/packages/text/index.ts +16 -16
  352. package/packages/text/src/text.ts +260 -260
  353. package/packages/text-ellipsis/index.ts +16 -16
  354. package/packages/text-ellipsis/src/text-ellipsis.ts +282 -282
  355. package/packages/textarea/index.ts +16 -16
  356. package/packages/textarea/src/textarea.ts +373 -373
  357. package/packages/timeline/index.ts +16 -16
  358. package/packages/timeline/src/timeline-item.ts +67 -67
  359. package/packages/timeline/src/timeline.ts +71 -71
  360. package/packages/timeline-item/index.ts +16 -16
  361. package/packages/tip/index.ts +19 -19
  362. package/packages/tip/src/tip.ts +129 -129
  363. package/packages/tooltip/index.ts +16 -16
  364. package/packages/tooltip/src/tooltip.ts +589 -589
  365. package/packages/tour/index.ts +16 -16
  366. package/packages/tour/src/tour.ts +71 -71
  367. package/packages/tree/index.ts +16 -16
  368. package/packages/tree/src/store.ts +14 -14
  369. package/packages/tree/src/tree.ts +2825 -2825
  370. package/packages/tree/src/util.ts +45 -45
  371. package/packages/tree-select/index.ts +16 -16
  372. package/packages/tree-select/src/tree-select.ts +979 -979
  373. package/packages/ui/index.ts +697 -697
  374. package/packages/ui/src/anime.ts +52 -52
  375. package/packages/ui/src/comp.ts +3 -3
  376. package/packages/ui/src/dom.ts +279 -279
  377. package/packages/ui/src/log.ts +6 -6
  378. package/packages/ui/src/utils.ts +49 -49
  379. package/packages/ui/src/vn.ts +39 -39
  380. package/packages/upload/index.ts +20 -20
  381. package/packages/upload/src/upload.ts +1919 -1919
  382. package/packages/upload/src/util.ts +109 -109
  383. package/packages/watermark/index.ts +31 -31
  384. package/packages/watermark/src/util.ts +176 -176
  385. package/packages/watermark/src/watermark.ts +168 -168
  386. package/styles/all.scss +90 -90
  387. package/styles/base.scss +16 -16
  388. package/styles/components/alert.scss +101 -101
  389. package/styles/components/anchor.scss +44 -44
  390. package/styles/components/avatar.scss +115 -115
  391. package/styles/components/backtop.scss +82 -82
  392. package/styles/components/badge.scss +45 -45
  393. package/styles/components/breadcrumb.scss +29 -29
  394. package/styles/components/button-group.scss +30 -30
  395. package/styles/components/button.scss +415 -415
  396. package/styles/components/calendar.scss +471 -471
  397. package/styles/components/card.scss +121 -121
  398. package/styles/components/carousel.scss +184 -184
  399. package/styles/components/cascader.scss +140 -140
  400. package/styles/components/checkbox-button.scss +57 -57
  401. package/styles/components/checkbox.scss +81 -81
  402. package/styles/components/collapse.scss +56 -56
  403. package/styles/components/color-picker.scss +409 -409
  404. package/styles/components/context-menu.scss +102 -102
  405. package/styles/components/countdown.scss +35 -35
  406. package/styles/components/date-panel.scss +505 -505
  407. package/styles/components/date-picker.scss +247 -247
  408. package/styles/components/date-range-picker.scss +252 -252
  409. package/styles/components/drawer.scss +298 -298
  410. package/styles/components/empty.scss +79 -79
  411. package/styles/components/form.scss +668 -668
  412. package/styles/components/icon-picker.scss +211 -211
  413. package/styles/components/icon.scss +1048 -1048
  414. package/styles/components/image-group.scss +2 -2
  415. package/styles/components/image-preview.scss +215 -215
  416. package/styles/components/image.scss +16 -16
  417. package/styles/components/input.scss +846 -846
  418. package/styles/components/layout-aside.scss +22 -22
  419. package/styles/components/layout-body.scss +14 -14
  420. package/styles/components/layout-container.scss +13 -13
  421. package/styles/components/layout-footer.scss +14 -14
  422. package/styles/components/layout-header.scss +11 -11
  423. package/styles/components/link.scss +115 -115
  424. package/styles/components/list.scss +40 -40
  425. package/styles/components/loading.scss +137 -137
  426. package/styles/components/menu.scss +150 -150
  427. package/styles/components/modal.scss +480 -480
  428. package/styles/components/notice-bar.scss +91 -91
  429. package/styles/components/number-input.scss +283 -283
  430. package/styles/components/old-icon.scss +4 -4
  431. package/styles/components/pager.scss +282 -282
  432. package/styles/components/password-input.scss +374 -374
  433. package/styles/components/print.scss +3 -3
  434. package/styles/components/pulldown.scss +75 -75
  435. package/styles/components/radio-button.scss +57 -57
  436. package/styles/components/radio.scss +79 -79
  437. package/styles/components/rate.scss +76 -76
  438. package/styles/components/result.scss +91 -91
  439. package/styles/components/row.scss +69 -69
  440. package/styles/components/segmented.scss +215 -215
  441. package/styles/components/select.scss +244 -244
  442. package/styles/components/slider.scss +139 -139
  443. package/styles/components/split.scss +1 -1
  444. package/styles/components/splitter.scss +318 -318
  445. package/styles/components/switch.scss +128 -128
  446. package/styles/components/table-select.scss +105 -105
  447. package/styles/components/tabs.scss +745 -745
  448. package/styles/components/tag.scss +184 -184
  449. package/styles/components/text-ellipsis.scss +130 -130
  450. package/styles/components/text.scss +123 -123
  451. package/styles/components/textarea.scss +106 -106
  452. package/styles/components/tip.scss +97 -97
  453. package/styles/components/tooltip.scss +141 -141
  454. package/styles/components/tree-select.scss +166 -166
  455. package/styles/components/tree.scss +294 -294
  456. package/styles/components/upload.scss +497 -497
  457. package/styles/components/watermark.scss +26 -26
  458. package/styles/helpers/baseMixin.scss +104 -95
  459. package/styles/helpers/baseVar.scss +3 -3
  460. package/styles/helpers/placement.scss +38 -38
  461. package/styles/theme/base.scss +214 -214
  462. package/styles/theme/dark.scss +119 -119
  463. package/styles/theme/light.scss +118 -118
  464. package/styles/variable.scss +111 -111
  465. package/types/all.d.ts +327 -327
  466. package/types/components/alert.d.ts +87 -87
  467. package/types/components/anchor-link.d.ts +91 -91
  468. package/types/components/anchor.d.ts +104 -104
  469. package/types/components/avatar.d.ts +88 -88
  470. package/types/components/backtop.d.ts +122 -122
  471. package/types/components/badge.d.ts +76 -76
  472. package/types/components/breadcrumb-item.d.ts +80 -80
  473. package/types/components/breadcrumb.d.ts +87 -87
  474. package/types/components/button-group.d.ts +120 -120
  475. package/types/components/button.d.ts +323 -323
  476. package/types/components/calendar.d.ts +264 -264
  477. package/types/components/card.d.ts +93 -93
  478. package/types/components/carousel-item.d.ts +75 -75
  479. package/types/components/carousel.d.ts +134 -134
  480. package/types/components/cascader.d.ts +263 -263
  481. package/types/components/checkbox-button.d.ts +103 -103
  482. package/types/components/checkbox-group.d.ts +146 -143
  483. package/types/components/checkbox.d.ts +123 -123
  484. package/types/components/col.d.ts +80 -80
  485. package/types/components/colgroup.d.ts +137 -137
  486. package/types/components/collapse-pane.d.ts +89 -89
  487. package/types/components/collapse.d.ts +121 -121
  488. package/types/components/color-picker.d.ts +176 -176
  489. package/types/components/column.d.ts +841 -841
  490. package/types/components/context-menu.d.ts +289 -289
  491. package/types/components/countdown.d.ts +112 -112
  492. package/types/components/date-panel.d.ts +280 -280
  493. package/types/components/date-picker.d.ts +332 -332
  494. package/types/components/date-range-picker.d.ts +352 -352
  495. package/types/components/drawer.d.ts +299 -299
  496. package/types/components/empty.d.ts +78 -78
  497. package/types/components/flow-design.d.ts +85 -85
  498. package/types/components/flow-view.d.ts +85 -85
  499. package/types/components/form-design.d.ts +376 -376
  500. package/types/components/form-gather.d.ts +124 -124
  501. package/types/components/form-group.d.ts +77 -77
  502. package/types/components/form-item.d.ts +411 -411
  503. package/types/components/form-view.d.ts +183 -183
  504. package/types/components/form.d.ts +468 -468
  505. package/types/components/gantt-module/gantt-view.d.ts +177 -177
  506. package/types/components/gantt-module/index.d.ts +1 -1
  507. package/types/components/gantt-plugins/extend-gantt-chart.d.ts +131 -131
  508. package/types/components/gantt-plugins/index.d.ts +1 -1
  509. package/types/components/gantt.d.ts +1194 -1194
  510. package/types/components/grid.d.ts +1040 -1040
  511. package/types/components/icon-picker.d.ts +196 -196
  512. package/types/components/icon.d.ts +87 -87
  513. package/types/components/image-group.d.ts +127 -127
  514. package/types/components/image-preview.d.ts +167 -167
  515. package/types/components/image.d.ts +173 -173
  516. package/types/components/input.d.ts +435 -435
  517. package/types/components/layout-aside.d.ts +80 -80
  518. package/types/components/layout-body.d.ts +91 -91
  519. package/types/components/layout-container.d.ts +73 -73
  520. package/types/components/layout-footer.d.ts +73 -73
  521. package/types/components/layout-header.d.ts +69 -69
  522. package/types/components/link.d.ts +111 -111
  523. package/types/components/list-design.d.ts +190 -190
  524. package/types/components/list-view.d.ts +199 -199
  525. package/types/components/list.d.ts +204 -204
  526. package/types/components/loading.d.ts +103 -103
  527. package/types/components/mention.d.ts +77 -77
  528. package/types/components/menu.d.ts +211 -211
  529. package/types/components/modal.d.ts +542 -542
  530. package/types/components/notice-bar.d.ts +102 -102
  531. package/types/components/number-input.d.ts +309 -309
  532. package/types/components/optgroup.d.ts +88 -88
  533. package/types/components/option.d.ts +103 -103
  534. package/types/components/pager.d.ts +335 -335
  535. package/types/components/password-input.d.ts +142 -142
  536. package/types/components/print-page-break.d.ts +69 -69
  537. package/types/components/print.d.ts +206 -206
  538. package/types/components/pulldown.d.ts +231 -231
  539. package/types/components/radio-button.d.ts +114 -114
  540. package/types/components/radio-group.d.ts +147 -144
  541. package/types/components/radio.d.ts +129 -129
  542. package/types/components/rate.d.ts +88 -88
  543. package/types/components/result.d.ts +84 -84
  544. package/types/components/row.d.ts +79 -79
  545. package/types/components/segmented.d.ts +123 -123
  546. package/types/components/select.d.ts +527 -527
  547. package/types/components/slider.d.ts +126 -126
  548. package/types/components/split-pane.d.ts +133 -133
  549. package/types/components/split.d.ts +312 -312
  550. package/types/components/splitter-panel.d.ts +105 -105
  551. package/types/components/splitter.d.ts +288 -288
  552. package/types/components/steps.d.ts +68 -68
  553. package/types/components/switch.d.ts +133 -133
  554. package/types/components/tab-pane.d.ts +114 -114
  555. package/types/components/table-module/custom.d.ts +123 -123
  556. package/types/components/table-module/edit.d.ts +243 -243
  557. package/types/components/table-module/export.d.ts +96 -96
  558. package/types/components/table-module/filter.d.ts +140 -140
  559. package/types/components/table-module/index.d.ts +7 -7
  560. package/types/components/table-module/keyboard.d.ts +26 -26
  561. package/types/components/table-module/menu.d.ts +28 -28
  562. package/types/components/table-module/validator.d.ts +53 -53
  563. package/types/components/table-plugins/extend-cell-area.d.ts +770 -770
  564. package/types/components/table-plugins/extend-pivot-table.d.ts +58 -58
  565. package/types/components/table-plugins/filters-combination.d.ts +15 -15
  566. package/types/components/table-plugins/filters-complex-input.d.ts +9 -9
  567. package/types/components/table-plugins/index.d.ts +4 -4
  568. package/types/components/table-select.d.ts +219 -219
  569. package/types/components/table.d.ts +7465 -7465
  570. package/types/components/tabs.d.ts +332 -332
  571. package/types/components/tag.d.ts +114 -114
  572. package/types/components/text-ellipsis.d.ts +112 -112
  573. package/types/components/text.d.ts +122 -122
  574. package/types/components/textarea.d.ts +247 -247
  575. package/types/components/timeline-item.d.ts +75 -75
  576. package/types/components/timeline.d.ts +77 -77
  577. package/types/components/tip.d.ts +83 -83
  578. package/types/components/toolbar.d.ts +336 -336
  579. package/types/components/tooltip.d.ts +180 -180
  580. package/types/components/tour.d.ts +77 -77
  581. package/types/components/tree-select.d.ts +310 -310
  582. package/types/components/tree.d.ts +843 -843
  583. package/types/components/upload.d.ts +437 -437
  584. package/types/components/watermark.d.ts +120 -120
  585. package/types/handles/form-design.d.ts +50 -50
  586. package/types/handles/index.d.ts +3 -3
  587. package/types/handles/list-design.d.ts +2 -2
  588. package/types/handles/table.d.ts +15 -15
  589. package/types/index.d.ts +8 -8
  590. package/types/ui/commands.d.ts +57 -57
  591. package/types/ui/formats.d.ts +62 -62
  592. package/types/ui/global-config.d.ts +254 -254
  593. package/types/ui/global-icon.d.ts +292 -292
  594. package/types/ui/hooks.d.ts +13 -13
  595. package/types/ui/index.d.ts +96 -96
  596. package/types/ui/interceptor.d.ts +52 -52
  597. package/types/ui/menus.d.ts +77 -77
  598. package/types/ui/renderer.d.ts +1041 -1041
  599. package/types/ui/validators.d.ts +38 -38
  600. /package/es/icon/{iconfont.1778317220469.ttf → iconfont.1778465063324.ttf} +0 -0
  601. /package/es/icon/{iconfont.1778317220469.woff → iconfont.1778465063324.woff} +0 -0
  602. /package/es/icon/{iconfont.1778317220469.woff2 → iconfont.1778465063324.woff2} +0 -0
  603. /package/es/{iconfont.1778317220469.ttf → iconfont.1778465063324.ttf} +0 -0
  604. /package/es/{iconfont.1778317220469.woff → iconfont.1778465063324.woff} +0 -0
  605. /package/es/{iconfont.1778317220469.woff2 → iconfont.1778465063324.woff2} +0 -0
  606. /package/lib/icon/style/{iconfont.1778317220469.ttf → iconfont.1778465063324.ttf} +0 -0
  607. /package/lib/icon/style/{iconfont.1778317220469.woff → iconfont.1778465063324.woff} +0 -0
  608. /package/lib/icon/style/{iconfont.1778317220469.woff2 → iconfont.1778465063324.woff2} +0 -0
  609. /package/lib/{iconfont.1778317220469.ttf → iconfont.1778465063324.ttf} +0 -0
  610. /package/lib/{iconfont.1778317220469.woff → iconfont.1778465063324.woff} +0 -0
  611. /package/lib/{iconfont.1778317220469.woff2 → iconfont.1778465063324.woff2} +0 -0
@@ -1,741 +1,741 @@
1
- import { ref, computed, h, PropType, nextTick, inject, provide, reactive, Teleport, onMounted, onUnmounted, watch } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import { getConfig, getI18n, getIcon, globalEvents, createEvent, useSize, renderEmptyElement } from '../../ui'
4
- import { getEventTargetNode, updatePanelPlacement, toCssUnit } from '../../ui/src/dom'
5
- import { getLastZIndex, nextZIndex } from '../../ui/src/utils'
6
- import { deNodeValue } from '../../tree/src/util'
7
- import { errLog } from '../../ui/src/log'
8
- import XEUtils from 'xe-utils'
9
- import VxeInputComponent from '../../input/src/input'
10
- import VxeButtonComponent from '../../button/src/button'
11
-
12
- import type { CascaderReactData, VxeCascaderEmits, CascaderInternalData, VxeButtonEvents, ValueOf, VxeComponentStyleType, CascaderPrivateRef, CascaderPrivateMethods, CascaderMethods, VxeCascaderPrivateComputed, VxeCascaderPropTypes, VxeCascaderConstructor, VxeFormDefines, VxeDrawerConstructor, VxeDrawerMethods, VxeCascaderPrivateMethods, VxeFormConstructor, VxeFormPrivateMethods, VxeInputConstructor, VxeModalConstructor, VxeModalMethods, 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 defineVxeComponent({
28
- name: 'VxeCascader',
29
- props: {
30
- modelValue: [String, Number, Array] as PropType<VxeCascaderPropTypes.ModelValue>,
31
- clearable: Boolean as PropType<VxeCascaderPropTypes.Clearable>,
32
- placeholder: {
33
- type: String as PropType<VxeCascaderPropTypes.Placeholder>,
34
- default: () => XEUtils.eqNull(getConfig().cascader.placeholder) ? getI18n('vxe.base.pleaseSelect') : getConfig().cascader.placeholder
35
- },
36
- readonly: {
37
- type: Boolean as PropType<VxeCascaderPropTypes.Readonly>,
38
- default: null
39
- },
40
- loading: Boolean as PropType<VxeCascaderPropTypes.Loading>,
41
- disabled: {
42
- type: Boolean as PropType<VxeCascaderPropTypes.Disabled>,
43
- default: null
44
- },
45
- filterable: Boolean as PropType<VxeCascaderPropTypes.Filterable>,
46
- filterConfig: Object as PropType<VxeCascaderPropTypes.FilterConfig>,
47
- multiple: Boolean as PropType<VxeCascaderPropTypes.Multiple>,
48
- className: [String, Function] as PropType<VxeCascaderPropTypes.ClassName>,
49
- prefixIcon: String as PropType<VxeCascaderPropTypes.PrefixIcon>,
50
- placement: String as PropType<VxeCascaderPropTypes.Placement>,
51
- transform: Boolean as PropType<VxeCascaderPropTypes.Transform>,
52
- lazyOptions: Array as PropType<VxeCascaderPropTypes.LazyOptions>,
53
- options: Array as PropType<VxeCascaderPropTypes.Options>,
54
- optionProps: Object as PropType<VxeCascaderPropTypes.OptionProps>,
55
- zIndex: Number as PropType<VxeCascaderPropTypes.ZIndex>,
56
- size: {
57
- type: String as PropType<VxeCascaderPropTypes.Size>,
58
- default: () => getConfig().cascader.size || getConfig().size
59
- },
60
- remote: Boolean as PropType<VxeCascaderPropTypes.Remote>,
61
- remoteConfig: Function as PropType<VxeCascaderPropTypes.RemoteConfig>,
62
- popupConfig: Object as PropType<VxeCascaderPropTypes.PopupConfig>,
63
- autoClose: {
64
- type: Boolean as PropType<VxeCascaderPropTypes.AutoClose>,
65
- default: () => getConfig().cascader.autoClose
66
- },
67
- showTotalButoon: {
68
- type: Boolean as PropType<VxeCascaderPropTypes.ShowTotalButoon>,
69
- default: () => getConfig().cascader.showTotalButoon
70
- },
71
- showCheckedButoon: {
72
- type: Boolean as PropType<VxeCascaderPropTypes.ShowCheckedButoon>,
73
- default: () => getConfig().cascader.showCheckedButoon
74
- },
75
- showClearButton: {
76
- type: Boolean as PropType<VxeCascaderPropTypes.ShowClearButton>,
77
- default: () => getConfig().cascader.showClearButton
78
- },
79
- transfer: {
80
- type: Boolean as PropType<VxeCascaderPropTypes.Transfer>,
81
- default: null
82
- },
83
-
84
- /**
85
- * 已废弃,被 remote-config.queryMethod 替换
86
- * @deprecated
87
- */
88
- remoteMethod: Function as PropType<VxeCascaderPropTypes.RemoteMethod>
89
- },
90
- emits: [
91
- 'update:modelValue',
92
- 'change',
93
- 'all-change',
94
- 'clear',
95
- 'blur',
96
- 'focus',
97
- 'click',
98
- 'node-click'
99
- ] as VxeCascaderEmits,
100
- setup (props, context) {
101
- const { emit, slots } = context
102
-
103
- const $xeModal = inject<(VxeModalConstructor & VxeModalMethods)| null>('$xeModal', null)
104
- const $xeDrawer = inject<(VxeDrawerConstructor & VxeDrawerMethods) | null>('$xeDrawer', null)
105
- const $xeTable = inject<(VxeTableConstructor & VxeTablePrivateMethods) | null>('$xeTable', null)
106
- const $xeForm = inject<(VxeFormConstructor & VxeFormPrivateMethods) | null>('$xeForm', null)
107
- const formItemInfo = inject<VxeFormDefines.ProvideItemInfo | null>('xeFormItemInfo', null)
108
-
109
- const xID = XEUtils.uniqueId()
110
-
111
- const { computeSize } = useSize(props)
112
-
113
- const refElem = ref<HTMLDivElement>()
114
- const refInput = ref<VxeInputConstructor>()
115
- const refInpSearch = ref<VxeInputConstructor>()
116
- const refTreeWrapper = ref<HTMLDivElement>()
117
- const refOptionPanel = ref<HTMLDivElement>()
118
- const refTree = ref<VxeTreeConstructor>()
119
-
120
- const reactData = reactive<CascaderReactData>({
121
- initialized: false,
122
- searchValue: '',
123
- searchLoading: false,
124
- panelIndex: 0,
125
- panelStyle: {},
126
- panelPlacement: null,
127
- triggerFocusPanel: false,
128
- visiblePanel: false,
129
- isAniVisible: false,
130
- isActivated: false
131
- })
132
-
133
- const internalData = createInternalData()
134
-
135
- const refMaps: CascaderPrivateRef = {
136
- refElem
137
- }
138
-
139
- const computeFormReadonly = computed(() => {
140
- const { readonly } = props
141
- if (readonly === null) {
142
- if ($xeForm) {
143
- return $xeForm.props.readonly
144
- }
145
- return false
146
- }
147
- return readonly
148
- })
149
-
150
- const computeIsDisabled = computed(() => {
151
- const { disabled } = props
152
- if (disabled === null) {
153
- if ($xeForm) {
154
- return $xeForm.props.disabled
155
- }
156
- return false
157
- }
158
- return disabled
159
- })
160
-
161
- const computeBtnTransfer = computed(() => {
162
- const { transfer } = props
163
- if (transfer === null) {
164
- const globalTransfer = getConfig().select.transfer
165
- if (XEUtils.isBoolean(globalTransfer)) {
166
- return globalTransfer
167
- }
168
- if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
169
- return true
170
- }
171
- }
172
- return transfer
173
- })
174
-
175
- const computePopupOpts = computed(() => {
176
- return Object.assign({}, getConfig().cascader.popupConfig, props.popupConfig)
177
- })
178
-
179
- const computePropsOpts = computed(() => {
180
- return props.optionProps || {}
181
- })
182
-
183
- const computeNodeKeyField = computed(() => {
184
- const valueField = computeValueField.value
185
- return valueField
186
- })
187
-
188
- const computeLabelField = computed(() => {
189
- const propsOpts = computePropsOpts.value
190
- return propsOpts.label || 'label'
191
- })
192
-
193
- const computeValueField = computed(() => {
194
- const propsOpts = computePropsOpts.value
195
- return propsOpts.value || 'value'
196
- })
197
-
198
- const computeChildrenField = computed(() => {
199
- const propsOpts = computePropsOpts.value
200
- return propsOpts.children || 'children'
201
- })
202
-
203
- const computeRemoteOpts = computed(() => {
204
- return Object.assign({}, getConfig().cascader.remoteConfig, props.remoteConfig)
205
- })
206
-
207
- const computeSelectLabel = computed(() => {
208
- const { modelValue, lazyOptions } = props
209
- const { fullNodeMaps } = internalData
210
- const valueField = computeValueField.value
211
- const labelField = computeLabelField.value
212
- const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
213
- return selectVals.map(val => {
214
- const cacheItem = fullNodeMaps[val]
215
- if (cacheItem) {
216
- return cacheItem.item[labelField]
217
- }
218
- if (lazyOptions) {
219
- const lazyItem = lazyOptions.find(item => item[valueField] === val)
220
- if (lazyItem) {
221
- return lazyItem[labelField]
222
- }
223
- }
224
- return val
225
- }).join(', ')
226
- })
227
-
228
- const computePopupWrapperStyle = computed(() => {
229
- const popupOpts = computePopupOpts.value
230
- const { height, width } = popupOpts
231
- const stys: VxeComponentStyleType = {}
232
- if (width) {
233
- stys.width = toCssUnit(width)
234
- }
235
- if (height) {
236
- stys.height = toCssUnit(height)
237
- stys.maxHeight = toCssUnit(height)
238
- }
239
- return stys
240
- })
241
-
242
- const computeMaps: VxeCascaderPrivateComputed = {
243
- }
244
-
245
- const $xeCascader = {
246
- xID,
247
- props,
248
- context,
249
- reactData,
250
- internalData,
251
-
252
- getRefMaps: () => refMaps,
253
- getComputeMaps: () => computeMaps
254
- } as unknown as VxeCascaderConstructor & VxeCascaderPrivateMethods
255
-
256
- const dispatchEvent = (type: ValueOf<VxeCascaderEmits>, params: Record<string, any>, evnt: Event | null) => {
257
- emit(type, createEvent(evnt, { $cascader: $xeCascader }, params))
258
- }
259
-
260
- const emitModel = (value: any) => {
261
- emit('update:modelValue', value)
262
- }
263
-
264
- const cascaderMethods: CascaderMethods = {
265
- dispatchEvent
266
- }
267
-
268
- const getNodeid = (option: any) => {
269
- const nodeKeyField = computeNodeKeyField.value
270
- const nodeid = option[nodeKeyField]
271
- return nodeid ? encodeURIComponent(nodeid) : ''
272
- }
273
-
274
- const cacheDataMap = () => {
275
- const { transform, options } = props
276
- const nodeKeyField = computeNodeKeyField.value
277
- const childrenField = computeChildrenField.value
278
- const valueField = computeValueField.value
279
- const nodeMaps: Record<string, {
280
- item: any
281
- index: number
282
- items: any[]
283
- parent: any
284
- nodes: any[]
285
- }> = {}
286
- const keyMaps: Record<string, boolean> = {}
287
- const handleOptNode = (item: any, index: number, items: any[], path: string[], parent: any, nodes: any[]) => {
288
- let nodeid = getNodeid(item)
289
- if (!nodeid) {
290
- nodeid = getOptUniqueId()
291
- }
292
- if (keyMaps[nodeid]) {
293
- errLog('vxe.error.repeatKey', [`[tree-select] ${nodeKeyField}`, nodeid])
294
- }
295
- keyMaps[nodeid] = true
296
- const value = item[valueField]
297
- if (nodeMaps[value]) {
298
- errLog('vxe.error.repeatKey', [`[tree-select] ${valueField}`, value])
299
- }
300
- nodeMaps[value] = { item, index, items, parent, nodes }
301
- }
302
- if (options) {
303
- if (transform) {
304
- options.forEach((item, index, items) => {
305
- handleOptNode(item, index, items, [], null, [])
306
- })
307
- } else {
308
- XEUtils.eachTree(options, handleOptNode, { children: childrenField })
309
- }
310
- }
311
- internalData.fullOptionList = options || []
312
- internalData.fullNodeMaps = nodeMaps
313
- }
314
-
315
- const updateZindex = () => {
316
- const { zIndex } = props
317
- if (zIndex) {
318
- reactData.panelIndex = zIndex
319
- } else if (reactData.panelIndex < getLastZIndex()) {
320
- reactData.panelIndex = nextZIndex()
321
- }
322
- }
323
-
324
- const updatePlacement = () => {
325
- const { placement } = props
326
- const { panelIndex } = reactData
327
- const targetElem = refElem.value
328
- const panelElem = refOptionPanel.value
329
- const btnTransfer = computeBtnTransfer.value
330
- const popupOpts = computePopupOpts.value
331
- const handleStyle = () => {
332
- const ppObj = updatePanelPlacement(targetElem, panelElem, {
333
- placement: popupOpts.placement || placement,
334
- defaultPlacement: popupOpts.defaultPlacement,
335
- teleportTo: btnTransfer
336
- })
337
- const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
338
- zIndex: panelIndex
339
- })
340
- reactData.panelStyle = panelStyle
341
- reactData.panelPlacement = ppObj.placement
342
- }
343
- handleStyle()
344
- return nextTick().then(handleStyle)
345
- }
346
-
347
- const showOptionPanel = () => {
348
- const { loading, remote, filterable } = props
349
- const { fullOptionList } = internalData
350
- const isDisabled = computeIsDisabled.value
351
- const remoteOpts = computeRemoteOpts.value
352
- if (!loading && !isDisabled) {
353
- clearTimeout(internalData.hpTimeout)
354
- if (!reactData.initialized) {
355
- reactData.initialized = true
356
- }
357
- reactData.isActivated = true
358
- reactData.isAniVisible = true
359
- if (filterable) {
360
- if (remote && remoteOpts.enabled && remoteOpts.autoLoad && !fullOptionList.length) {
361
- handleSearchEvent()
362
- }
363
- }
364
- setTimeout(() => {
365
- reactData.visiblePanel = true
366
- handleFocusSearch()
367
- }, 10)
368
- updateZindex()
369
- updatePlacement()
370
- }
371
- }
372
-
373
- const hideOptionPanel = () => {
374
- reactData.visiblePanel = false
375
- internalData.hpTimeout = setTimeout(() => {
376
- reactData.isAniVisible = false
377
- }, 350)
378
- }
379
-
380
- const changeEvent = (evnt: Event, selectValue: any, node: any) => {
381
- const value = XEUtils.isArray(selectValue) ? selectValue.map(deNodeValue) : deNodeValue(selectValue)
382
- emitModel(value)
383
- if (value !== props.modelValue) {
384
- dispatchEvent('change', { value, node, option: node }, evnt)
385
- // 自动更新校验状态
386
- if ($xeForm && formItemInfo) {
387
- $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
388
- }
389
- }
390
- }
391
-
392
- const clearValueEvent = (evnt: Event, selectValue: any) => {
393
- changeEvent(evnt, selectValue, null)
394
- dispatchEvent('clear', { value: selectValue }, evnt)
395
- }
396
-
397
- const clearEvent = (params: any, evnt: Event) => {
398
- clearValueEvent(evnt, null)
399
- hideOptionPanel()
400
- }
401
-
402
- const allCheckedPanelEvent: VxeButtonEvents.Click = (params) => {
403
- const { $event } = params
404
- const { multiple, autoClose } = props
405
- const $tree = refTree.value
406
- if (multiple) {
407
- if ($tree) {
408
- $tree.setAllCheckboxNode(true).then(({ checkNodeKeys, checkNodes }) => {
409
- changeEvent($event, checkNodeKeys, checkNodes[0])
410
- dispatchEvent('all-change', { value: checkNodeKeys }, $event)
411
- if (autoClose) {
412
- hideOptionPanel()
413
- }
414
- })
415
- }
416
- }
417
- }
418
-
419
- const clearCheckedPanelEvent: VxeButtonEvents.Click = (params) => {
420
- const { $event } = params
421
- const { multiple, autoClose } = props
422
- const $tree = refTree.value
423
- if ($tree) {
424
- const value = multiple ? [] : null
425
- $tree.clearCheckboxNode().then(() => {
426
- if (autoClose) {
427
- hideOptionPanel()
428
- }
429
- })
430
- changeEvent($event, value, null)
431
- dispatchEvent('clear', { value }, $event)
432
- }
433
- }
434
-
435
- const handleGlobalMousewheelEvent = (evnt: MouseEvent) => {
436
- const { visiblePanel } = reactData
437
- const isDisabled = computeIsDisabled.value
438
- if (!isDisabled) {
439
- if (visiblePanel) {
440
- const panelElem = refOptionPanel.value
441
- if (getEventTargetNode(evnt, panelElem).flag) {
442
- updatePlacement()
443
- } else {
444
- hideOptionPanel()
445
- }
446
- }
447
- }
448
- }
449
-
450
- const handleGlobalMousedownEvent = (evnt: MouseEvent) => {
451
- const { visiblePanel } = reactData
452
- const isDisabled = computeIsDisabled.value
453
- if (!isDisabled) {
454
- const el = refElem.value
455
- const panelElem = refOptionPanel.value
456
- reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
457
- if (visiblePanel && !reactData.isActivated) {
458
- hideOptionPanel()
459
- }
460
- }
461
- }
462
-
463
- const handleGlobalBlurEvent = () => {
464
- const { visiblePanel, isActivated } = reactData
465
- if (visiblePanel) {
466
- hideOptionPanel()
467
- }
468
- if (isActivated) {
469
- reactData.isActivated = false
470
- }
471
- if (visiblePanel || isActivated) {
472
- const $input = refInput.value
473
- if ($input) {
474
- $input.blur()
475
- }
476
- }
477
- }
478
-
479
- const handleGlobalResizeEvent = () => {
480
- const { visiblePanel } = reactData
481
- if (visiblePanel) {
482
- updatePlacement()
483
- }
484
- }
485
-
486
- const handleFocusSearch = () => {
487
- if (props.filterable) {
488
- nextTick(() => {
489
- const inpSearch = refInpSearch.value
490
- if (inpSearch) {
491
- inpSearch.focus()
492
- }
493
- })
494
- }
495
- }
496
-
497
- const focusEvent = (evnt: FocusEvent) => {
498
- const isDisabled = computeIsDisabled.value
499
- if (!isDisabled) {
500
- if (!reactData.visiblePanel) {
501
- reactData.triggerFocusPanel = true
502
- showOptionPanel()
503
- setTimeout(() => {
504
- reactData.triggerFocusPanel = false
505
- }, 150)
506
- }
507
- }
508
- dispatchEvent('focus', {}, evnt)
509
- }
510
-
511
- const clickEvent = (evnt: MouseEvent) => {
512
- togglePanelEvent(evnt)
513
- dispatchEvent('click', {}, evnt)
514
- }
515
-
516
- const blurEvent = (evnt: FocusEvent) => {
517
- reactData.isActivated = false
518
- dispatchEvent('blur', {}, evnt)
519
- }
520
-
521
- const modelSearchEvent = (value: string) => {
522
- reactData.searchValue = value
523
- }
524
-
525
- const handleSearchEvent = () => {
526
- const { modelValue, remote, remoteMethod } = props
527
- const { searchValue } = reactData
528
- const remoteOpts = computeRemoteOpts.value
529
- const queryMethod = remoteOpts.queryMethod || remoteMethod
530
- if (remote && queryMethod && remoteOpts.enabled) {
531
- reactData.searchLoading = true
532
- Promise.resolve(
533
- queryMethod({ $cascader: $xeCascader, searchValue, value: modelValue })
534
- ).then(() => nextTick())
535
- .catch(() => nextTick())
536
- .finally(() => {
537
- reactData.searchLoading = false
538
- })
539
- }
540
- }
541
-
542
- const togglePanelEvent = (params: any) => {
543
- const { $event } = params
544
- $event.preventDefault()
545
- if (reactData.triggerFocusPanel) {
546
- reactData.triggerFocusPanel = false
547
- } else {
548
- if (reactData.visiblePanel) {
549
- hideOptionPanel()
550
- } else {
551
- showOptionPanel()
552
- }
553
- }
554
- }
555
-
556
- const cascaderPrivateMethods: CascaderPrivateMethods = {
557
- }
558
-
559
- Object.assign($xeCascader, cascaderMethods, cascaderPrivateMethods)
560
-
561
- const renderVN = () => {
562
- const { className, modelValue, multiple, loading, filterable, showTotalButoon, showCheckedButoon, showClearButton } = props
563
- const { initialized, isActivated, isAniVisible, visiblePanel, searchValue } = reactData
564
- const vSize = computeSize.value
565
- const isDisabled = computeIsDisabled.value
566
- const selectLabel = computeSelectLabel.value
567
- const btnTransfer = computeBtnTransfer.value
568
- const formReadonly = computeFormReadonly.value
569
- const popupWrapperStyle = computePopupWrapperStyle.value
570
- const headerSlot = slots.header
571
- const footerSlot = slots.footer
572
- const prefixSlot = slots.prefix
573
- const popupOpts = computePopupOpts.value
574
- const popupClassName = popupOpts.className
575
-
576
- if (formReadonly) {
577
- return h('div', {
578
- ref: refElem,
579
- class: ['vxe-cascader--readonly', className]
580
- }, [
581
- h('span', {
582
- class: 'vxe-cascader-label'
583
- }, selectLabel)
584
- ])
585
- }
586
- const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
587
- return h('div', {
588
- ref: refElem,
589
- class: ['vxe-cascader', className ? (XEUtils.isFunction(className) ? className({ $cascader: $xeCascader }) : className) : '', {
590
- [`size--${vSize}`]: vSize,
591
- 'is--filterable': filterable,
592
- 'is--visible': visiblePanel,
593
- 'is--disabled': isDisabled,
594
- 'is--loading': loading,
595
- 'is--active': isActivated
596
- }]
597
- }, [
598
- h(VxeInputComponent, {
599
- ref: refInput,
600
- clearable: props.clearable,
601
- placeholder: loading ? getI18n('vxe.select.loadingText') : props.placeholder,
602
- editable: false,
603
- disabled: isDisabled,
604
- type: 'text',
605
- prefixIcon: props.prefixIcon,
606
- suffixIcon: loading ? getIcon().TREE_SELECT_LOADED : (visiblePanel ? getIcon().TREE_SELECT_OPEN : getIcon().TREE_SELECT_CLOSE),
607
- modelValue: loading ? '' : selectLabel,
608
- title: selectLabel,
609
- onClear: clearEvent,
610
- onClick: clickEvent,
611
- onFocus: focusEvent,
612
- onBlur: blurEvent,
613
- onSuffixClick: togglePanelEvent
614
- }, prefixSlot
615
- ? {
616
- prefix: () => prefixSlot({})
617
- }
618
- : {}),
619
- h(Teleport, {
620
- to: 'body',
621
- disabled: btnTransfer ? !initialized : true
622
- }, [
623
- h('div', {
624
- ref: refOptionPanel,
625
- class: ['vxe-table--ignore-clear vxe-cascader--panel', popupClassName ? (XEUtils.isFunction(popupClassName) ? popupClassName({ $cascader: $xeCascader }) : popupClassName) : '', {
626
- [`size--${vSize}`]: vSize,
627
- 'is--transfer': btnTransfer,
628
- 'ani--leave': !loading && isAniVisible,
629
- 'ani--enter': !loading && visiblePanel
630
- }],
631
- placement: reactData.panelPlacement,
632
- style: reactData.panelStyle
633
- }, initialized
634
- ? [
635
- h('div', {
636
- class: 'vxe-cascader--panel-wrapper'
637
- }, [
638
- filterable
639
- ? h('div', {
640
- class: 'vxe-cascader--panel-search'
641
- }, [
642
- h(VxeInputComponent, {
643
- ref: refInpSearch,
644
- class: 'vxe-cascader-search--input',
645
- modelValue: searchValue,
646
- clearable: true,
647
- disabled: false,
648
- readonly: false,
649
- placeholder: getI18n('vxe.cascader.search'),
650
- prefixIcon: getIcon().INPUT_SEARCH,
651
- 'onUpdate:modelValue': modelSearchEvent
652
- })
653
- ])
654
- : renderEmptyElement($xeCascader),
655
- showTotalButoon || (showCheckedButoon && multiple) || showClearButton || headerSlot
656
- ? h('div', {
657
- class: 'vxe-cascader--panel-header'
658
- }, headerSlot
659
- ? headerSlot({})
660
- : [
661
- h('div', {
662
- class: 'vxe-cascader--header-button'
663
- }, [
664
- showTotalButoon
665
- ? h('div', {
666
- class: 'vxe-cascader--header-total'
667
- }, getI18n('vxe.cascader.total', [selectVals.length]))
668
- : renderEmptyElement($xeCascader),
669
- h('div', {
670
- class: 'vxe-cascader--header-btns'
671
- }, [
672
- (showCheckedButoon && multiple)
673
- ? h(VxeButtonComponent, {
674
- content: getI18n('vxe.cascader.allChecked'),
675
- mode: 'text',
676
- onClick: allCheckedPanelEvent
677
- })
678
- : renderEmptyElement($xeCascader),
679
- showClearButton
680
- ? h(VxeButtonComponent, {
681
- content: getI18n('vxe.cascader.clearChecked'),
682
- mode: 'text',
683
- onClick: clearCheckedPanelEvent
684
- })
685
- : renderEmptyElement($xeCascader)
686
- ])
687
- ])
688
- ])
689
- : renderEmptyElement($xeCascader),
690
- h('div', {
691
- class: 'vxe-cascader--panel-body'
692
- }, [
693
- h('div', {
694
- ref: refTreeWrapper,
695
- class: 'vxe-cascader-tree--wrapper',
696
- style: popupWrapperStyle
697
- }, [])
698
- ]),
699
- footerSlot
700
- ? h('div', {
701
- class: 'vxe-cascader--panel-footer'
702
- }, footerSlot({}))
703
- : renderEmptyElement($xeCascader)
704
- ])
705
- ]
706
- : [])
707
- ])
708
- ])
709
- }
710
-
711
- watch(() => props.options, () => {
712
- cacheDataMap()
713
- })
714
-
715
- cacheDataMap()
716
-
717
- onMounted(() => {
718
- globalEvents.on($xeCascader, 'mousewheel', handleGlobalMousewheelEvent)
719
- globalEvents.on($xeCascader, 'mousedown', handleGlobalMousedownEvent)
720
- globalEvents.on($xeCascader, 'blur', handleGlobalBlurEvent)
721
- globalEvents.on($xeCascader, 'resize', handleGlobalResizeEvent)
722
- })
723
-
724
- onUnmounted(() => {
725
- globalEvents.off($xeCascader, 'mousewheel')
726
- globalEvents.off($xeCascader, 'mousedown')
727
- globalEvents.off($xeCascader, 'blur')
728
- globalEvents.off($xeCascader, 'resize')
729
- XEUtils.assign(internalData, createInternalData())
730
- })
731
-
732
- provide('$xeCascader', $xeCascader)
733
-
734
- $xeCascader.renderVN = renderVN
735
-
736
- return $xeCascader
737
- },
738
- render () {
739
- return this.renderVN()
740
- }
741
- })
1
+ import { ref, computed, h, PropType, nextTick, inject, provide, reactive, Teleport, onMounted, onUnmounted, watch } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import { getConfig, getI18n, getIcon, globalEvents, createEvent, useSize, renderEmptyElement } from '../../ui'
4
+ import { getEventTargetNode, updatePanelPlacement, toCssUnit } from '../../ui/src/dom'
5
+ import { getLastZIndex, nextZIndex } from '../../ui/src/utils'
6
+ import { deNodeValue } from '../../tree/src/util'
7
+ import { errLog } from '../../ui/src/log'
8
+ import XEUtils from 'xe-utils'
9
+ import VxeInputComponent from '../../input/src/input'
10
+ import VxeButtonComponent from '../../button/src/button'
11
+
12
+ import type { CascaderReactData, VxeCascaderEmits, CascaderInternalData, VxeButtonEvents, ValueOf, VxeComponentStyleType, CascaderPrivateRef, CascaderPrivateMethods, CascaderMethods, VxeCascaderPrivateComputed, VxeCascaderPropTypes, VxeCascaderConstructor, VxeFormDefines, VxeDrawerConstructor, VxeDrawerMethods, VxeCascaderPrivateMethods, VxeFormConstructor, VxeFormPrivateMethods, VxeInputConstructor, VxeModalConstructor, VxeModalMethods, 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 defineVxeComponent({
28
+ name: 'VxeCascader',
29
+ props: {
30
+ modelValue: [String, Number, Array] as PropType<VxeCascaderPropTypes.ModelValue>,
31
+ clearable: Boolean as PropType<VxeCascaderPropTypes.Clearable>,
32
+ placeholder: {
33
+ type: String as PropType<VxeCascaderPropTypes.Placeholder>,
34
+ default: () => XEUtils.eqNull(getConfig().cascader.placeholder) ? getI18n('vxe.base.pleaseSelect') : getConfig().cascader.placeholder
35
+ },
36
+ readonly: {
37
+ type: Boolean as PropType<VxeCascaderPropTypes.Readonly>,
38
+ default: null
39
+ },
40
+ loading: Boolean as PropType<VxeCascaderPropTypes.Loading>,
41
+ disabled: {
42
+ type: Boolean as PropType<VxeCascaderPropTypes.Disabled>,
43
+ default: null
44
+ },
45
+ filterable: Boolean as PropType<VxeCascaderPropTypes.Filterable>,
46
+ filterConfig: Object as PropType<VxeCascaderPropTypes.FilterConfig>,
47
+ multiple: Boolean as PropType<VxeCascaderPropTypes.Multiple>,
48
+ className: [String, Function] as PropType<VxeCascaderPropTypes.ClassName>,
49
+ prefixIcon: String as PropType<VxeCascaderPropTypes.PrefixIcon>,
50
+ placement: String as PropType<VxeCascaderPropTypes.Placement>,
51
+ transform: Boolean as PropType<VxeCascaderPropTypes.Transform>,
52
+ lazyOptions: Array as PropType<VxeCascaderPropTypes.LazyOptions>,
53
+ options: Array as PropType<VxeCascaderPropTypes.Options>,
54
+ optionProps: Object as PropType<VxeCascaderPropTypes.OptionProps>,
55
+ zIndex: Number as PropType<VxeCascaderPropTypes.ZIndex>,
56
+ size: {
57
+ type: String as PropType<VxeCascaderPropTypes.Size>,
58
+ default: () => getConfig().cascader.size || getConfig().size
59
+ },
60
+ remote: Boolean as PropType<VxeCascaderPropTypes.Remote>,
61
+ remoteConfig: Function as PropType<VxeCascaderPropTypes.RemoteConfig>,
62
+ popupConfig: Object as PropType<VxeCascaderPropTypes.PopupConfig>,
63
+ autoClose: {
64
+ type: Boolean as PropType<VxeCascaderPropTypes.AutoClose>,
65
+ default: () => getConfig().cascader.autoClose
66
+ },
67
+ showTotalButoon: {
68
+ type: Boolean as PropType<VxeCascaderPropTypes.ShowTotalButoon>,
69
+ default: () => getConfig().cascader.showTotalButoon
70
+ },
71
+ showCheckedButoon: {
72
+ type: Boolean as PropType<VxeCascaderPropTypes.ShowCheckedButoon>,
73
+ default: () => getConfig().cascader.showCheckedButoon
74
+ },
75
+ showClearButton: {
76
+ type: Boolean as PropType<VxeCascaderPropTypes.ShowClearButton>,
77
+ default: () => getConfig().cascader.showClearButton
78
+ },
79
+ transfer: {
80
+ type: Boolean as PropType<VxeCascaderPropTypes.Transfer>,
81
+ default: null
82
+ },
83
+
84
+ /**
85
+ * 已废弃,被 remote-config.queryMethod 替换
86
+ * @deprecated
87
+ */
88
+ remoteMethod: Function as PropType<VxeCascaderPropTypes.RemoteMethod>
89
+ },
90
+ emits: [
91
+ 'update:modelValue',
92
+ 'change',
93
+ 'all-change',
94
+ 'clear',
95
+ 'blur',
96
+ 'focus',
97
+ 'click',
98
+ 'node-click'
99
+ ] as VxeCascaderEmits,
100
+ setup (props, context) {
101
+ const { emit, slots } = context
102
+
103
+ const $xeModal = inject<(VxeModalConstructor & VxeModalMethods)| null>('$xeModal', null)
104
+ const $xeDrawer = inject<(VxeDrawerConstructor & VxeDrawerMethods) | null>('$xeDrawer', null)
105
+ const $xeTable = inject<(VxeTableConstructor & VxeTablePrivateMethods) | null>('$xeTable', null)
106
+ const $xeForm = inject<(VxeFormConstructor & VxeFormPrivateMethods) | null>('$xeForm', null)
107
+ const formItemInfo = inject<VxeFormDefines.ProvideItemInfo | null>('xeFormItemInfo', null)
108
+
109
+ const xID = XEUtils.uniqueId()
110
+
111
+ const { computeSize } = useSize(props)
112
+
113
+ const refElem = ref<HTMLDivElement>()
114
+ const refInput = ref<VxeInputConstructor>()
115
+ const refInpSearch = ref<VxeInputConstructor>()
116
+ const refTreeWrapper = ref<HTMLDivElement>()
117
+ const refOptionPanel = ref<HTMLDivElement>()
118
+ const refTree = ref<VxeTreeConstructor>()
119
+
120
+ const reactData = reactive<CascaderReactData>({
121
+ initialized: false,
122
+ searchValue: '',
123
+ searchLoading: false,
124
+ panelIndex: 0,
125
+ panelStyle: {},
126
+ panelPlacement: null,
127
+ triggerFocusPanel: false,
128
+ visiblePanel: false,
129
+ isAniVisible: false,
130
+ isActivated: false
131
+ })
132
+
133
+ const internalData = createInternalData()
134
+
135
+ const refMaps: CascaderPrivateRef = {
136
+ refElem
137
+ }
138
+
139
+ const computeFormReadonly = computed(() => {
140
+ const { readonly } = props
141
+ if (readonly === null) {
142
+ if ($xeForm) {
143
+ return $xeForm.props.readonly
144
+ }
145
+ return false
146
+ }
147
+ return readonly
148
+ })
149
+
150
+ const computeIsDisabled = computed(() => {
151
+ const { disabled } = props
152
+ if (disabled === null) {
153
+ if ($xeForm) {
154
+ return $xeForm.props.disabled
155
+ }
156
+ return false
157
+ }
158
+ return disabled
159
+ })
160
+
161
+ const computeBtnTransfer = computed(() => {
162
+ const { transfer } = props
163
+ if (transfer === null) {
164
+ const globalTransfer = getConfig().select.transfer
165
+ if (XEUtils.isBoolean(globalTransfer)) {
166
+ return globalTransfer
167
+ }
168
+ if ($xeTable || $xeModal || $xeDrawer || $xeForm) {
169
+ return true
170
+ }
171
+ }
172
+ return transfer
173
+ })
174
+
175
+ const computePopupOpts = computed(() => {
176
+ return Object.assign({}, getConfig().cascader.popupConfig, props.popupConfig)
177
+ })
178
+
179
+ const computePropsOpts = computed(() => {
180
+ return props.optionProps || {}
181
+ })
182
+
183
+ const computeNodeKeyField = computed(() => {
184
+ const valueField = computeValueField.value
185
+ return valueField
186
+ })
187
+
188
+ const computeLabelField = computed(() => {
189
+ const propsOpts = computePropsOpts.value
190
+ return propsOpts.label || 'label'
191
+ })
192
+
193
+ const computeValueField = computed(() => {
194
+ const propsOpts = computePropsOpts.value
195
+ return propsOpts.value || 'value'
196
+ })
197
+
198
+ const computeChildrenField = computed(() => {
199
+ const propsOpts = computePropsOpts.value
200
+ return propsOpts.children || 'children'
201
+ })
202
+
203
+ const computeRemoteOpts = computed(() => {
204
+ return Object.assign({}, getConfig().cascader.remoteConfig, props.remoteConfig)
205
+ })
206
+
207
+ const computeSelectLabel = computed(() => {
208
+ const { modelValue, lazyOptions } = props
209
+ const { fullNodeMaps } = internalData
210
+ const valueField = computeValueField.value
211
+ const labelField = computeLabelField.value
212
+ const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
213
+ return selectVals.map(val => {
214
+ const cacheItem = fullNodeMaps[val]
215
+ if (cacheItem) {
216
+ return cacheItem.item[labelField]
217
+ }
218
+ if (lazyOptions) {
219
+ const lazyItem = lazyOptions.find(item => item[valueField] === val)
220
+ if (lazyItem) {
221
+ return lazyItem[labelField]
222
+ }
223
+ }
224
+ return val
225
+ }).join(', ')
226
+ })
227
+
228
+ const computePopupWrapperStyle = computed(() => {
229
+ const popupOpts = computePopupOpts.value
230
+ const { height, width } = popupOpts
231
+ const stys: VxeComponentStyleType = {}
232
+ if (width) {
233
+ stys.width = toCssUnit(width)
234
+ }
235
+ if (height) {
236
+ stys.height = toCssUnit(height)
237
+ stys.maxHeight = toCssUnit(height)
238
+ }
239
+ return stys
240
+ })
241
+
242
+ const computeMaps: VxeCascaderPrivateComputed = {
243
+ }
244
+
245
+ const $xeCascader = {
246
+ xID,
247
+ props,
248
+ context,
249
+ reactData,
250
+ internalData,
251
+
252
+ getRefMaps: () => refMaps,
253
+ getComputeMaps: () => computeMaps
254
+ } as unknown as VxeCascaderConstructor & VxeCascaderPrivateMethods
255
+
256
+ const dispatchEvent = (type: ValueOf<VxeCascaderEmits>, params: Record<string, any>, evnt: Event | null) => {
257
+ emit(type, createEvent(evnt, { $cascader: $xeCascader }, params))
258
+ }
259
+
260
+ const emitModel = (value: any) => {
261
+ emit('update:modelValue', value)
262
+ }
263
+
264
+ const cascaderMethods: CascaderMethods = {
265
+ dispatchEvent
266
+ }
267
+
268
+ const getNodeid = (option: any) => {
269
+ const nodeKeyField = computeNodeKeyField.value
270
+ const nodeid = option[nodeKeyField]
271
+ return nodeid ? encodeURIComponent(nodeid) : ''
272
+ }
273
+
274
+ const cacheDataMap = () => {
275
+ const { transform, options } = props
276
+ const nodeKeyField = computeNodeKeyField.value
277
+ const childrenField = computeChildrenField.value
278
+ const valueField = computeValueField.value
279
+ const nodeMaps: Record<string, {
280
+ item: any
281
+ index: number
282
+ items: any[]
283
+ parent: any
284
+ nodes: any[]
285
+ }> = {}
286
+ const keyMaps: Record<string, boolean> = {}
287
+ const handleOptNode = (item: any, index: number, items: any[], path: string[], parent: any, nodes: any[]) => {
288
+ let nodeid = getNodeid(item)
289
+ if (!nodeid) {
290
+ nodeid = getOptUniqueId()
291
+ }
292
+ if (keyMaps[nodeid]) {
293
+ errLog('vxe.error.repeatKey', [`[tree-select] ${nodeKeyField}`, nodeid])
294
+ }
295
+ keyMaps[nodeid] = true
296
+ const value = item[valueField]
297
+ if (nodeMaps[value]) {
298
+ errLog('vxe.error.repeatKey', [`[tree-select] ${valueField}`, value])
299
+ }
300
+ nodeMaps[value] = { item, index, items, parent, nodes }
301
+ }
302
+ if (options) {
303
+ if (transform) {
304
+ options.forEach((item, index, items) => {
305
+ handleOptNode(item, index, items, [], null, [])
306
+ })
307
+ } else {
308
+ XEUtils.eachTree(options, handleOptNode, { children: childrenField })
309
+ }
310
+ }
311
+ internalData.fullOptionList = options || []
312
+ internalData.fullNodeMaps = nodeMaps
313
+ }
314
+
315
+ const updateZindex = () => {
316
+ const { zIndex } = props
317
+ if (zIndex) {
318
+ reactData.panelIndex = zIndex
319
+ } else if (reactData.panelIndex < getLastZIndex()) {
320
+ reactData.panelIndex = nextZIndex()
321
+ }
322
+ }
323
+
324
+ const updatePlacement = () => {
325
+ const { placement } = props
326
+ const { panelIndex } = reactData
327
+ const targetElem = refElem.value
328
+ const panelElem = refOptionPanel.value
329
+ const btnTransfer = computeBtnTransfer.value
330
+ const popupOpts = computePopupOpts.value
331
+ const handleStyle = () => {
332
+ const ppObj = updatePanelPlacement(targetElem, panelElem, {
333
+ placement: popupOpts.placement || placement,
334
+ defaultPlacement: popupOpts.defaultPlacement,
335
+ teleportTo: btnTransfer
336
+ })
337
+ const panelStyle: { [key: string]: string | number } = Object.assign(ppObj.style, {
338
+ zIndex: panelIndex
339
+ })
340
+ reactData.panelStyle = panelStyle
341
+ reactData.panelPlacement = ppObj.placement
342
+ }
343
+ handleStyle()
344
+ return nextTick().then(handleStyle)
345
+ }
346
+
347
+ const showOptionPanel = () => {
348
+ const { loading, remote, filterable } = props
349
+ const { fullOptionList } = internalData
350
+ const isDisabled = computeIsDisabled.value
351
+ const remoteOpts = computeRemoteOpts.value
352
+ if (!loading && !isDisabled) {
353
+ clearTimeout(internalData.hpTimeout)
354
+ if (!reactData.initialized) {
355
+ reactData.initialized = true
356
+ }
357
+ reactData.isActivated = true
358
+ reactData.isAniVisible = true
359
+ if (filterable) {
360
+ if (remote && remoteOpts.enabled && remoteOpts.autoLoad && !fullOptionList.length) {
361
+ handleSearchEvent()
362
+ }
363
+ }
364
+ setTimeout(() => {
365
+ reactData.visiblePanel = true
366
+ handleFocusSearch()
367
+ }, 10)
368
+ updateZindex()
369
+ updatePlacement()
370
+ }
371
+ }
372
+
373
+ const hideOptionPanel = () => {
374
+ reactData.visiblePanel = false
375
+ internalData.hpTimeout = setTimeout(() => {
376
+ reactData.isAniVisible = false
377
+ }, 350)
378
+ }
379
+
380
+ const changeEvent = (evnt: Event, selectValue: any, node: any) => {
381
+ const value = XEUtils.isArray(selectValue) ? selectValue.map(deNodeValue) : deNodeValue(selectValue)
382
+ emitModel(value)
383
+ if (value !== props.modelValue) {
384
+ dispatchEvent('change', { value, node, option: node }, evnt)
385
+ // 自动更新校验状态
386
+ if ($xeForm && formItemInfo) {
387
+ $xeForm.triggerItemEvent(evnt, formItemInfo.itemConfig.field, value)
388
+ }
389
+ }
390
+ }
391
+
392
+ const clearValueEvent = (evnt: Event, selectValue: any) => {
393
+ changeEvent(evnt, selectValue, null)
394
+ dispatchEvent('clear', { value: selectValue }, evnt)
395
+ }
396
+
397
+ const clearEvent = (params: any, evnt: Event) => {
398
+ clearValueEvent(evnt, null)
399
+ hideOptionPanel()
400
+ }
401
+
402
+ const allCheckedPanelEvent: VxeButtonEvents.Click = (params) => {
403
+ const { $event } = params
404
+ const { multiple, autoClose } = props
405
+ const $tree = refTree.value
406
+ if (multiple) {
407
+ if ($tree) {
408
+ $tree.setAllCheckboxNode(true).then(({ checkNodeKeys, checkNodes }) => {
409
+ changeEvent($event, checkNodeKeys, checkNodes[0])
410
+ dispatchEvent('all-change', { value: checkNodeKeys }, $event)
411
+ if (autoClose) {
412
+ hideOptionPanel()
413
+ }
414
+ })
415
+ }
416
+ }
417
+ }
418
+
419
+ const clearCheckedPanelEvent: VxeButtonEvents.Click = (params) => {
420
+ const { $event } = params
421
+ const { multiple, autoClose } = props
422
+ const $tree = refTree.value
423
+ if ($tree) {
424
+ const value = multiple ? [] : null
425
+ $tree.clearCheckboxNode().then(() => {
426
+ if (autoClose) {
427
+ hideOptionPanel()
428
+ }
429
+ })
430
+ changeEvent($event, value, null)
431
+ dispatchEvent('clear', { value }, $event)
432
+ }
433
+ }
434
+
435
+ const handleGlobalMousewheelEvent = (evnt: MouseEvent) => {
436
+ const { visiblePanel } = reactData
437
+ const isDisabled = computeIsDisabled.value
438
+ if (!isDisabled) {
439
+ if (visiblePanel) {
440
+ const panelElem = refOptionPanel.value
441
+ if (getEventTargetNode(evnt, panelElem).flag) {
442
+ updatePlacement()
443
+ } else {
444
+ hideOptionPanel()
445
+ }
446
+ }
447
+ }
448
+ }
449
+
450
+ const handleGlobalMousedownEvent = (evnt: MouseEvent) => {
451
+ const { visiblePanel } = reactData
452
+ const isDisabled = computeIsDisabled.value
453
+ if (!isDisabled) {
454
+ const el = refElem.value
455
+ const panelElem = refOptionPanel.value
456
+ reactData.isActivated = getEventTargetNode(evnt, el).flag || getEventTargetNode(evnt, panelElem).flag
457
+ if (visiblePanel && !reactData.isActivated) {
458
+ hideOptionPanel()
459
+ }
460
+ }
461
+ }
462
+
463
+ const handleGlobalBlurEvent = () => {
464
+ const { visiblePanel, isActivated } = reactData
465
+ if (visiblePanel) {
466
+ hideOptionPanel()
467
+ }
468
+ if (isActivated) {
469
+ reactData.isActivated = false
470
+ }
471
+ if (visiblePanel || isActivated) {
472
+ const $input = refInput.value
473
+ if ($input) {
474
+ $input.blur()
475
+ }
476
+ }
477
+ }
478
+
479
+ const handleGlobalResizeEvent = () => {
480
+ const { visiblePanel } = reactData
481
+ if (visiblePanel) {
482
+ updatePlacement()
483
+ }
484
+ }
485
+
486
+ const handleFocusSearch = () => {
487
+ if (props.filterable) {
488
+ nextTick(() => {
489
+ const inpSearch = refInpSearch.value
490
+ if (inpSearch) {
491
+ inpSearch.focus()
492
+ }
493
+ })
494
+ }
495
+ }
496
+
497
+ const focusEvent = (evnt: FocusEvent) => {
498
+ const isDisabled = computeIsDisabled.value
499
+ if (!isDisabled) {
500
+ if (!reactData.visiblePanel) {
501
+ reactData.triggerFocusPanel = true
502
+ showOptionPanel()
503
+ setTimeout(() => {
504
+ reactData.triggerFocusPanel = false
505
+ }, 150)
506
+ }
507
+ }
508
+ dispatchEvent('focus', {}, evnt)
509
+ }
510
+
511
+ const clickEvent = (evnt: MouseEvent) => {
512
+ togglePanelEvent(evnt)
513
+ dispatchEvent('click', {}, evnt)
514
+ }
515
+
516
+ const blurEvent = (evnt: FocusEvent) => {
517
+ reactData.isActivated = false
518
+ dispatchEvent('blur', {}, evnt)
519
+ }
520
+
521
+ const modelSearchEvent = (value: string) => {
522
+ reactData.searchValue = value
523
+ }
524
+
525
+ const handleSearchEvent = () => {
526
+ const { modelValue, remote, remoteMethod } = props
527
+ const { searchValue } = reactData
528
+ const remoteOpts = computeRemoteOpts.value
529
+ const queryMethod = remoteOpts.queryMethod || remoteMethod
530
+ if (remote && queryMethod && remoteOpts.enabled) {
531
+ reactData.searchLoading = true
532
+ Promise.resolve(
533
+ queryMethod({ $cascader: $xeCascader, searchValue, value: modelValue })
534
+ ).then(() => nextTick())
535
+ .catch(() => nextTick())
536
+ .finally(() => {
537
+ reactData.searchLoading = false
538
+ })
539
+ }
540
+ }
541
+
542
+ const togglePanelEvent = (params: any) => {
543
+ const { $event } = params
544
+ $event.preventDefault()
545
+ if (reactData.triggerFocusPanel) {
546
+ reactData.triggerFocusPanel = false
547
+ } else {
548
+ if (reactData.visiblePanel) {
549
+ hideOptionPanel()
550
+ } else {
551
+ showOptionPanel()
552
+ }
553
+ }
554
+ }
555
+
556
+ const cascaderPrivateMethods: CascaderPrivateMethods = {
557
+ }
558
+
559
+ Object.assign($xeCascader, cascaderMethods, cascaderPrivateMethods)
560
+
561
+ const renderVN = () => {
562
+ const { className, modelValue, multiple, loading, filterable, showTotalButoon, showCheckedButoon, showClearButton } = props
563
+ const { initialized, isActivated, isAniVisible, visiblePanel, searchValue } = reactData
564
+ const vSize = computeSize.value
565
+ const isDisabled = computeIsDisabled.value
566
+ const selectLabel = computeSelectLabel.value
567
+ const btnTransfer = computeBtnTransfer.value
568
+ const formReadonly = computeFormReadonly.value
569
+ const popupWrapperStyle = computePopupWrapperStyle.value
570
+ const headerSlot = slots.header
571
+ const footerSlot = slots.footer
572
+ const prefixSlot = slots.prefix
573
+ const popupOpts = computePopupOpts.value
574
+ const popupClassName = popupOpts.className
575
+
576
+ if (formReadonly) {
577
+ return h('div', {
578
+ ref: refElem,
579
+ class: ['vxe-cascader--readonly', className]
580
+ }, [
581
+ h('span', {
582
+ class: 'vxe-cascader-label'
583
+ }, selectLabel)
584
+ ])
585
+ }
586
+ const selectVals = XEUtils.eqNull(modelValue) ? [] : (XEUtils.isArray(modelValue) ? modelValue : [modelValue])
587
+ return h('div', {
588
+ ref: refElem,
589
+ class: ['vxe-cascader', className ? (XEUtils.isFunction(className) ? className({ $cascader: $xeCascader }) : className) : '', {
590
+ [`size--${vSize}`]: vSize,
591
+ 'is--filterable': filterable,
592
+ 'is--visible': visiblePanel,
593
+ 'is--disabled': isDisabled,
594
+ 'is--loading': loading,
595
+ 'is--active': isActivated
596
+ }]
597
+ }, [
598
+ h(VxeInputComponent, {
599
+ ref: refInput,
600
+ clearable: props.clearable,
601
+ placeholder: loading ? getI18n('vxe.select.loadingText') : props.placeholder,
602
+ editable: false,
603
+ disabled: isDisabled,
604
+ type: 'text',
605
+ prefixIcon: props.prefixIcon,
606
+ suffixIcon: loading ? getIcon().TREE_SELECT_LOADED : (visiblePanel ? getIcon().TREE_SELECT_OPEN : getIcon().TREE_SELECT_CLOSE),
607
+ modelValue: loading ? '' : selectLabel,
608
+ title: selectLabel,
609
+ onClear: clearEvent,
610
+ onClick: clickEvent,
611
+ onFocus: focusEvent,
612
+ onBlur: blurEvent,
613
+ onSuffixClick: togglePanelEvent
614
+ }, prefixSlot
615
+ ? {
616
+ prefix: () => prefixSlot({})
617
+ }
618
+ : {}),
619
+ h(Teleport, {
620
+ to: 'body',
621
+ disabled: btnTransfer ? !initialized : true
622
+ }, [
623
+ h('div', {
624
+ ref: refOptionPanel,
625
+ class: ['vxe-table--ignore-clear vxe-cascader--panel', popupClassName ? (XEUtils.isFunction(popupClassName) ? popupClassName({ $cascader: $xeCascader }) : popupClassName) : '', {
626
+ [`size--${vSize}`]: vSize,
627
+ 'is--transfer': btnTransfer,
628
+ 'ani--leave': !loading && isAniVisible,
629
+ 'ani--enter': !loading && visiblePanel
630
+ }],
631
+ placement: reactData.panelPlacement,
632
+ style: reactData.panelStyle
633
+ }, initialized
634
+ ? [
635
+ h('div', {
636
+ class: 'vxe-cascader--panel-wrapper'
637
+ }, [
638
+ filterable
639
+ ? h('div', {
640
+ class: 'vxe-cascader--panel-search'
641
+ }, [
642
+ h(VxeInputComponent, {
643
+ ref: refInpSearch,
644
+ class: 'vxe-cascader-search--input',
645
+ modelValue: searchValue,
646
+ clearable: true,
647
+ disabled: false,
648
+ readonly: false,
649
+ placeholder: getI18n('vxe.cascader.search'),
650
+ prefixIcon: getIcon().INPUT_SEARCH,
651
+ 'onUpdate:modelValue': modelSearchEvent
652
+ })
653
+ ])
654
+ : renderEmptyElement($xeCascader),
655
+ showTotalButoon || (showCheckedButoon && multiple) || showClearButton || headerSlot
656
+ ? h('div', {
657
+ class: 'vxe-cascader--panel-header'
658
+ }, headerSlot
659
+ ? headerSlot({})
660
+ : [
661
+ h('div', {
662
+ class: 'vxe-cascader--header-button'
663
+ }, [
664
+ showTotalButoon
665
+ ? h('div', {
666
+ class: 'vxe-cascader--header-total'
667
+ }, getI18n('vxe.cascader.total', [selectVals.length]))
668
+ : renderEmptyElement($xeCascader),
669
+ h('div', {
670
+ class: 'vxe-cascader--header-btns'
671
+ }, [
672
+ (showCheckedButoon && multiple)
673
+ ? h(VxeButtonComponent, {
674
+ content: getI18n('vxe.cascader.allChecked'),
675
+ mode: 'text',
676
+ onClick: allCheckedPanelEvent
677
+ })
678
+ : renderEmptyElement($xeCascader),
679
+ showClearButton
680
+ ? h(VxeButtonComponent, {
681
+ content: getI18n('vxe.cascader.clearChecked'),
682
+ mode: 'text',
683
+ onClick: clearCheckedPanelEvent
684
+ })
685
+ : renderEmptyElement($xeCascader)
686
+ ])
687
+ ])
688
+ ])
689
+ : renderEmptyElement($xeCascader),
690
+ h('div', {
691
+ class: 'vxe-cascader--panel-body'
692
+ }, [
693
+ h('div', {
694
+ ref: refTreeWrapper,
695
+ class: 'vxe-cascader-tree--wrapper',
696
+ style: popupWrapperStyle
697
+ }, [])
698
+ ]),
699
+ footerSlot
700
+ ? h('div', {
701
+ class: 'vxe-cascader--panel-footer'
702
+ }, footerSlot({}))
703
+ : renderEmptyElement($xeCascader)
704
+ ])
705
+ ]
706
+ : [])
707
+ ])
708
+ ])
709
+ }
710
+
711
+ watch(() => props.options, () => {
712
+ cacheDataMap()
713
+ })
714
+
715
+ cacheDataMap()
716
+
717
+ onMounted(() => {
718
+ globalEvents.on($xeCascader, 'mousewheel', handleGlobalMousewheelEvent)
719
+ globalEvents.on($xeCascader, 'mousedown', handleGlobalMousedownEvent)
720
+ globalEvents.on($xeCascader, 'blur', handleGlobalBlurEvent)
721
+ globalEvents.on($xeCascader, 'resize', handleGlobalResizeEvent)
722
+ })
723
+
724
+ onUnmounted(() => {
725
+ globalEvents.off($xeCascader, 'mousewheel')
726
+ globalEvents.off($xeCascader, 'mousedown')
727
+ globalEvents.off($xeCascader, 'blur')
728
+ globalEvents.off($xeCascader, 'resize')
729
+ XEUtils.assign(internalData, createInternalData())
730
+ })
731
+
732
+ provide('$xeCascader', $xeCascader)
733
+
734
+ $xeCascader.renderVN = renderVN
735
+
736
+ return $xeCascader
737
+ },
738
+ render () {
739
+ return this.renderVN()
740
+ }
741
+ })