vxe-pc-ui 4.14.4 → 4.14.6

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 (480) 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/tree/src/tree.js +31 -2
  7. package/es/tree-select/src/tree-select.js +2 -0
  8. package/es/ui/index.js +1 -1
  9. package/es/ui/src/log.js +1 -1
  10. package/lib/index.umd.js +2359 -2257
  11. package/lib/index.umd.min.js +1 -1
  12. package/lib/tree/src/tree.js +27 -2
  13. package/lib/tree/src/tree.min.js +1 -1
  14. package/lib/tree-select/src/tree-select.js +2 -0
  15. package/lib/tree-select/src/tree-select.min.js +1 -1
  16. package/lib/ui/index.js +1 -1
  17. package/lib/ui/index.min.js +1 -1
  18. package/lib/ui/src/log.js +1 -1
  19. package/lib/ui/src/log.min.js +1 -1
  20. package/package.json +88 -88
  21. package/packages/alert/index.ts +16 -16
  22. package/packages/alert/src/alert.ts +124 -124
  23. package/packages/anchor/index.ts +16 -16
  24. package/packages/anchor/src/anchor-link.ts +121 -121
  25. package/packages/anchor/src/anchor.ts +237 -237
  26. package/packages/anchor/src/util.ts +23 -23
  27. package/packages/anchor-link/index.ts +16 -16
  28. package/packages/avatar/index.ts +16 -16
  29. package/packages/avatar/src/avatar.ts +149 -149
  30. package/packages/backtop/index.ts +16 -16
  31. package/packages/backtop/src/backtop.ts +314 -314
  32. package/packages/badge/index.ts +16 -16
  33. package/packages/badge/src/badge.ts +100 -100
  34. package/packages/breadcrumb/index.ts +16 -16
  35. package/packages/breadcrumb/src/breadcrumb-item.ts +106 -106
  36. package/packages/breadcrumb/src/breadcrumb.ts +92 -92
  37. package/packages/breadcrumb-item/index.ts +16 -16
  38. package/packages/button/index.ts +16 -16
  39. package/packages/button/src/button-group.ts +110 -110
  40. package/packages/button/src/button.ts +841 -841
  41. package/packages/button-group/index.ts +16 -16
  42. package/packages/calendar/index.ts +16 -16
  43. package/packages/calendar/src/calendar.ts +1351 -1351
  44. package/packages/card/index.ts +16 -16
  45. package/packages/card/src/card.ts +175 -175
  46. package/packages/carousel/index.ts +16 -16
  47. package/packages/carousel/src/carousel-item.ts +102 -102
  48. package/packages/carousel/src/carousel.ts +414 -414
  49. package/packages/carousel/src/util.ts +21 -21
  50. package/packages/carousel-item/index.ts +16 -16
  51. package/packages/cascader/index.ts +16 -16
  52. package/packages/cascader/src/cascader.ts +741 -741
  53. package/packages/checkbox/index.ts +16 -16
  54. package/packages/checkbox/src/button.ts +144 -144
  55. package/packages/checkbox/src/checkbox.ts +154 -154
  56. package/packages/checkbox/src/group.ts +222 -222
  57. package/packages/checkbox-button/index.ts +16 -16
  58. package/packages/checkbox-group/index.ts +16 -16
  59. package/packages/col/index.ts +16 -16
  60. package/packages/collapse/index.ts +16 -16
  61. package/packages/collapse/src/collapse-pane.ts +114 -114
  62. package/packages/collapse/src/collapse.ts +284 -284
  63. package/packages/collapse/src/util.ts +21 -21
  64. package/packages/collapse-pane/index.ts +16 -16
  65. package/packages/color-picker/index.ts +16 -16
  66. package/packages/color-picker/src/color-picker.ts +1109 -1109
  67. package/packages/color-picker/src/util.ts +198 -198
  68. package/packages/components.ts +307 -307
  69. package/packages/context-menu/index.ts +54 -54
  70. package/packages/context-menu/src/context-menu.ts +681 -681
  71. package/packages/countdown/index.ts +16 -16
  72. package/packages/countdown/src/countdown.ts +262 -262
  73. package/packages/date-panel/index.ts +16 -16
  74. package/packages/date-panel/src/date-panel.ts +1809 -1809
  75. package/packages/date-panel/src/util.ts +244 -244
  76. package/packages/date-picker/index.ts +16 -16
  77. package/packages/date-picker/src/date-picker.ts +1071 -1071
  78. package/packages/date-range-picker/index.ts +16 -16
  79. package/packages/date-range-picker/src/date-range-picker.ts +1280 -1280
  80. package/packages/drawer/index.ts +77 -77
  81. package/packages/drawer/src/drawer.ts +657 -657
  82. package/packages/dynamics/index.ts +89 -89
  83. package/packages/empty/index.ts +16 -16
  84. package/packages/empty/src/empty.ts +100 -100
  85. package/packages/form/index.ts +16 -16
  86. package/packages/form/render/index.ts +598 -598
  87. package/packages/form/src/form-config-item.ts +72 -72
  88. package/packages/form/src/form-group.ts +86 -86
  89. package/packages/form/src/form-item.ts +174 -174
  90. package/packages/form/src/form.ts +987 -987
  91. package/packages/form/src/itemInfo.ts +80 -80
  92. package/packages/form/src/render.ts +387 -387
  93. package/packages/form/src/util.ts +93 -93
  94. package/packages/form-gather/index.ts +26 -26
  95. package/packages/form-group/index.ts +16 -16
  96. package/packages/form-item/index.ts +16 -16
  97. package/packages/icon/index.ts +16 -16
  98. package/packages/icon/src/icon.ts +75 -75
  99. package/packages/icon-picker/index.ts +16 -16
  100. package/packages/icon-picker/src/icon-picker.ts +626 -626
  101. package/packages/image/index.ts +16 -16
  102. package/packages/image/src/group.ts +153 -153
  103. package/packages/image/src/image.ts +298 -298
  104. package/packages/image/src/preview.ts +672 -672
  105. package/packages/image/src/util.ts +59 -59
  106. package/packages/image-group/index.ts +16 -16
  107. package/packages/image-preview/index.ts +19 -19
  108. package/packages/index.ts +4 -4
  109. package/packages/input/index.ts +16 -16
  110. package/packages/input/src/input.ts +2788 -2788
  111. package/packages/language/ar-EG.ts +840 -840
  112. package/packages/language/de-DE.ts +840 -840
  113. package/packages/language/en-US.ts +840 -840
  114. package/packages/language/es-ES.ts +840 -840
  115. package/packages/language/fr-FR.ts +840 -840
  116. package/packages/language/hu-HU.ts +840 -840
  117. package/packages/language/hy-AM.ts +840 -840
  118. package/packages/language/id-ID.ts +840 -840
  119. package/packages/language/it-IT.ts +840 -840
  120. package/packages/language/ja-JP.ts +840 -840
  121. package/packages/language/ko-KR.ts +840 -840
  122. package/packages/language/ms-MY.ts +840 -840
  123. package/packages/language/nb-NO.ts +840 -840
  124. package/packages/language/pt-BR.ts +840 -840
  125. package/packages/language/ru-RU.ts +840 -840
  126. package/packages/language/th-TH.ts +840 -840
  127. package/packages/language/ug-CN.ts +840 -840
  128. package/packages/language/uk-UA.ts +840 -840
  129. package/packages/language/uz-UZ.ts +840 -840
  130. package/packages/language/vi-VN.ts +840 -840
  131. package/packages/language/zh-CHT.ts +840 -840
  132. package/packages/language/zh-CN.ts +840 -840
  133. package/packages/language/zh-HK.ts +3 -3
  134. package/packages/language/zh-MO.ts +3 -3
  135. package/packages/language/zh-TC.ts +3 -3
  136. package/packages/language/zh-TW.ts +3 -3
  137. package/packages/layout-aside/index.ts +16 -16
  138. package/packages/layout-aside/src/layout-aside.ts +123 -123
  139. package/packages/layout-body/index.ts +16 -16
  140. package/packages/layout-body/src/layout-body.ts +142 -142
  141. package/packages/layout-container/index.ts +16 -16
  142. package/packages/layout-container/src/layout-container.ts +82 -82
  143. package/packages/layout-footer/index.ts +16 -16
  144. package/packages/layout-footer/src/layout-footer.ts +74 -74
  145. package/packages/layout-header/index.ts +16 -16
  146. package/packages/layout-header/src/layout-header.ts +73 -73
  147. package/packages/link/index.ts +16 -16
  148. package/packages/link/src/link.ts +161 -161
  149. package/packages/list/index.ts +16 -16
  150. package/packages/list/src/list.ts +442 -442
  151. package/packages/loading/index.ts +34 -34
  152. package/packages/loading/src/loading.ts +152 -152
  153. package/packages/mention/index.ts +16 -16
  154. package/packages/mention/src/mention.ts +71 -71
  155. package/packages/menu/index.ts +16 -16
  156. package/packages/menu/src/menu.ts +581 -581
  157. package/packages/modal/index.ts +136 -136
  158. package/packages/modal/src/modal.ts +1494 -1494
  159. package/packages/notice-bar/index.ts +16 -16
  160. package/packages/notice-bar/src/notice-bar.ts +181 -181
  161. package/packages/number-input/index.ts +16 -16
  162. package/packages/number-input/src/number-input.ts +1096 -1096
  163. package/packages/number-input/src/util.ts +12 -12
  164. package/packages/optgroup/index.ts +16 -16
  165. package/packages/option/index.ts +16 -16
  166. package/packages/pager/index.ts +16 -16
  167. package/packages/pager/src/pager.ts +769 -769
  168. package/packages/password-input/index.ts +16 -16
  169. package/packages/password-input/src/password-input.ts +378 -378
  170. package/packages/print/index.ts +18 -18
  171. package/packages/print/src/page-break.ts +92 -92
  172. package/packages/print/src/print.ts +272 -272
  173. package/packages/print/src/util.ts +284 -284
  174. package/packages/print-page-break/index.ts +16 -16
  175. package/packages/pulldown/index.ts +16 -16
  176. package/packages/pulldown/src/pulldown.ts +457 -457
  177. package/packages/radio/index.ts +16 -16
  178. package/packages/radio/src/button.ts +173 -173
  179. package/packages/radio/src/group.ts +213 -213
  180. package/packages/radio/src/radio.ts +180 -180
  181. package/packages/radio-button/index.ts +16 -16
  182. package/packages/radio-group/index.ts +16 -16
  183. package/packages/rate/index.ts +16 -16
  184. package/packages/rate/src/rate.ts +192 -192
  185. package/packages/result/index.ts +16 -16
  186. package/packages/result/src/result.ts +112 -112
  187. package/packages/row/index.ts +16 -16
  188. package/packages/row/src/col.ts +136 -136
  189. package/packages/row/src/row.ts +119 -119
  190. package/packages/segmented/index.ts +16 -16
  191. package/packages/segmented/src/segmented.ts +264 -264
  192. package/packages/select/index.ts +16 -16
  193. package/packages/select/src/optgroup.ts +49 -49
  194. package/packages/select/src/option-info.ts +20 -20
  195. package/packages/select/src/option.ts +47 -47
  196. package/packages/select/src/select.ts +1699 -1699
  197. package/packages/select/src/util.ts +47 -47
  198. package/packages/slider/index.ts +16 -16
  199. package/packages/slider/src/slider.ts +304 -304
  200. package/packages/split/index.ts +16 -16
  201. package/packages/split-pane/index.ts +17 -17
  202. package/packages/splitter/index.ts +16 -16
  203. package/packages/splitter/src/splitter-panel.ts +145 -145
  204. package/packages/splitter/src/splitter.ts +1009 -1009
  205. package/packages/splitter/src/util.ts +21 -21
  206. package/packages/splitter-panel/index.ts +16 -16
  207. package/packages/steps/index.ts +16 -16
  208. package/packages/steps/src/steps.ts +68 -68
  209. package/packages/switch/index.ts +16 -16
  210. package/packages/switch/src/switch.ts +237 -237
  211. package/packages/tab-pane/index.ts +16 -16
  212. package/packages/table-select/index.ts +16 -16
  213. package/packages/table-select/src/table-select.ts +800 -800
  214. package/packages/tabs/index.ts +16 -16
  215. package/packages/tabs/src/tab-pane.ts +117 -117
  216. package/packages/tabs/src/tabs.ts +940 -940
  217. package/packages/tabs/src/util.ts +21 -21
  218. package/packages/tag/index.ts +16 -16
  219. package/packages/tag/src/tag.ts +187 -187
  220. package/packages/text/index.ts +16 -16
  221. package/packages/text/src/text.ts +260 -260
  222. package/packages/text-ellipsis/index.ts +16 -16
  223. package/packages/text-ellipsis/src/text-ellipsis.ts +282 -282
  224. package/packages/textarea/index.ts +16 -16
  225. package/packages/textarea/src/textarea.ts +373 -373
  226. package/packages/timeline/index.ts +16 -16
  227. package/packages/timeline/src/timeline-item.ts +67 -67
  228. package/packages/timeline/src/timeline.ts +71 -71
  229. package/packages/timeline-item/index.ts +16 -16
  230. package/packages/tip/index.ts +19 -19
  231. package/packages/tip/src/tip.ts +129 -129
  232. package/packages/tooltip/index.ts +16 -16
  233. package/packages/tooltip/src/tooltip.ts +589 -589
  234. package/packages/tour/index.ts +16 -16
  235. package/packages/tour/src/tour.ts +71 -71
  236. package/packages/tree/index.ts +16 -16
  237. package/packages/tree/src/store.ts +14 -14
  238. package/packages/tree/src/tree.ts +2825 -2795
  239. package/packages/tree/src/util.ts +45 -45
  240. package/packages/tree-select/index.ts +16 -16
  241. package/packages/tree-select/src/tree-select.ts +979 -977
  242. package/packages/ui/index.ts +697 -697
  243. package/packages/ui/src/anime.ts +52 -52
  244. package/packages/ui/src/comp.ts +3 -3
  245. package/packages/ui/src/dom.ts +279 -279
  246. package/packages/ui/src/log.ts +6 -6
  247. package/packages/ui/src/utils.ts +49 -49
  248. package/packages/ui/src/vn.ts +39 -39
  249. package/packages/upload/index.ts +20 -20
  250. package/packages/upload/src/upload.ts +1919 -1919
  251. package/packages/upload/src/util.ts +109 -109
  252. package/packages/watermark/index.ts +31 -31
  253. package/packages/watermark/src/util.ts +176 -176
  254. package/packages/watermark/src/watermark.ts +168 -168
  255. package/styles/all.scss +90 -90
  256. package/styles/base.scss +16 -16
  257. package/styles/components/alert.scss +101 -101
  258. package/styles/components/anchor.scss +44 -44
  259. package/styles/components/avatar.scss +115 -115
  260. package/styles/components/backtop.scss +82 -82
  261. package/styles/components/badge.scss +45 -45
  262. package/styles/components/breadcrumb.scss +29 -29
  263. package/styles/components/button-group.scss +30 -30
  264. package/styles/components/button.scss +415 -415
  265. package/styles/components/calendar.scss +471 -471
  266. package/styles/components/card.scss +121 -121
  267. package/styles/components/carousel.scss +184 -184
  268. package/styles/components/cascader.scss +140 -140
  269. package/styles/components/checkbox-button.scss +57 -57
  270. package/styles/components/checkbox.scss +81 -81
  271. package/styles/components/collapse.scss +56 -56
  272. package/styles/components/color-picker.scss +409 -409
  273. package/styles/components/context-menu.scss +102 -102
  274. package/styles/components/countdown.scss +35 -35
  275. package/styles/components/date-panel.scss +505 -505
  276. package/styles/components/date-picker.scss +247 -247
  277. package/styles/components/date-range-picker.scss +252 -252
  278. package/styles/components/drawer.scss +298 -298
  279. package/styles/components/empty.scss +79 -79
  280. package/styles/components/form.scss +668 -668
  281. package/styles/components/icon-picker.scss +211 -211
  282. package/styles/components/icon.scss +1048 -1048
  283. package/styles/components/image-group.scss +2 -2
  284. package/styles/components/image-preview.scss +215 -215
  285. package/styles/components/image.scss +16 -16
  286. package/styles/components/input.scss +846 -846
  287. package/styles/components/layout-aside.scss +22 -22
  288. package/styles/components/layout-body.scss +14 -14
  289. package/styles/components/layout-container.scss +13 -13
  290. package/styles/components/layout-footer.scss +14 -14
  291. package/styles/components/layout-header.scss +11 -11
  292. package/styles/components/link.scss +115 -115
  293. package/styles/components/list.scss +40 -40
  294. package/styles/components/loading.scss +137 -137
  295. package/styles/components/menu.scss +150 -150
  296. package/styles/components/modal.scss +480 -480
  297. package/styles/components/notice-bar.scss +91 -91
  298. package/styles/components/number-input.scss +283 -283
  299. package/styles/components/old-icon.scss +4 -4
  300. package/styles/components/pager.scss +282 -282
  301. package/styles/components/password-input.scss +374 -374
  302. package/styles/components/print.scss +3 -3
  303. package/styles/components/pulldown.scss +75 -75
  304. package/styles/components/radio-button.scss +57 -57
  305. package/styles/components/radio.scss +79 -79
  306. package/styles/components/rate.scss +76 -76
  307. package/styles/components/result.scss +91 -91
  308. package/styles/components/row.scss +69 -69
  309. package/styles/components/segmented.scss +215 -215
  310. package/styles/components/select.scss +244 -244
  311. package/styles/components/slider.scss +139 -139
  312. package/styles/components/split.scss +1 -1
  313. package/styles/components/splitter.scss +318 -318
  314. package/styles/components/switch.scss +128 -128
  315. package/styles/components/table-select.scss +105 -105
  316. package/styles/components/tabs.scss +745 -745
  317. package/styles/components/tag.scss +184 -184
  318. package/styles/components/text-ellipsis.scss +130 -130
  319. package/styles/components/text.scss +123 -123
  320. package/styles/components/textarea.scss +106 -106
  321. package/styles/components/tip.scss +97 -97
  322. package/styles/components/tooltip.scss +141 -141
  323. package/styles/components/tree-select.scss +166 -166
  324. package/styles/components/tree.scss +294 -294
  325. package/styles/components/upload.scss +497 -497
  326. package/styles/components/watermark.scss +26 -26
  327. package/styles/helpers/baseMixin.scss +95 -95
  328. package/styles/helpers/baseVar.scss +3 -3
  329. package/styles/helpers/placement.scss +38 -38
  330. package/styles/theme/base.scss +214 -214
  331. package/styles/theme/dark.scss +119 -119
  332. package/styles/theme/light.scss +118 -118
  333. package/styles/variable.scss +111 -111
  334. package/types/all.d.ts +327 -327
  335. package/types/components/alert.d.ts +87 -87
  336. package/types/components/anchor-link.d.ts +91 -91
  337. package/types/components/anchor.d.ts +104 -104
  338. package/types/components/avatar.d.ts +88 -88
  339. package/types/components/backtop.d.ts +122 -122
  340. package/types/components/badge.d.ts +76 -76
  341. package/types/components/breadcrumb-item.d.ts +80 -80
  342. package/types/components/breadcrumb.d.ts +87 -87
  343. package/types/components/button-group.d.ts +120 -120
  344. package/types/components/button.d.ts +323 -323
  345. package/types/components/calendar.d.ts +264 -264
  346. package/types/components/card.d.ts +93 -93
  347. package/types/components/carousel-item.d.ts +75 -75
  348. package/types/components/carousel.d.ts +134 -134
  349. package/types/components/cascader.d.ts +263 -263
  350. package/types/components/checkbox-button.d.ts +103 -103
  351. package/types/components/checkbox-group.d.ts +143 -143
  352. package/types/components/checkbox.d.ts +123 -123
  353. package/types/components/col.d.ts +80 -80
  354. package/types/components/colgroup.d.ts +137 -137
  355. package/types/components/collapse-pane.d.ts +89 -89
  356. package/types/components/collapse.d.ts +121 -121
  357. package/types/components/color-picker.d.ts +176 -176
  358. package/types/components/column.d.ts +841 -841
  359. package/types/components/context-menu.d.ts +289 -289
  360. package/types/components/countdown.d.ts +112 -112
  361. package/types/components/date-panel.d.ts +280 -280
  362. package/types/components/date-picker.d.ts +332 -332
  363. package/types/components/date-range-picker.d.ts +352 -352
  364. package/types/components/drawer.d.ts +299 -299
  365. package/types/components/empty.d.ts +78 -78
  366. package/types/components/flow-design.d.ts +85 -85
  367. package/types/components/flow-view.d.ts +85 -85
  368. package/types/components/form-design.d.ts +376 -376
  369. package/types/components/form-gather.d.ts +124 -124
  370. package/types/components/form-group.d.ts +77 -77
  371. package/types/components/form-item.d.ts +411 -411
  372. package/types/components/form-view.d.ts +183 -183
  373. package/types/components/form.d.ts +468 -468
  374. package/types/components/gantt-module/gantt-view.d.ts +177 -177
  375. package/types/components/gantt-module/index.d.ts +1 -1
  376. package/types/components/gantt-plugins/extend-gantt-chart.d.ts +131 -131
  377. package/types/components/gantt-plugins/index.d.ts +1 -1
  378. package/types/components/gantt.d.ts +1194 -1185
  379. package/types/components/grid.d.ts +1040 -1040
  380. package/types/components/icon-picker.d.ts +196 -196
  381. package/types/components/icon.d.ts +87 -87
  382. package/types/components/image-group.d.ts +127 -127
  383. package/types/components/image-preview.d.ts +167 -167
  384. package/types/components/image.d.ts +173 -173
  385. package/types/components/input.d.ts +435 -435
  386. package/types/components/layout-aside.d.ts +80 -80
  387. package/types/components/layout-body.d.ts +91 -91
  388. package/types/components/layout-container.d.ts +73 -73
  389. package/types/components/layout-footer.d.ts +73 -73
  390. package/types/components/layout-header.d.ts +69 -69
  391. package/types/components/link.d.ts +111 -111
  392. package/types/components/list-design.d.ts +190 -190
  393. package/types/components/list-view.d.ts +199 -199
  394. package/types/components/list.d.ts +204 -204
  395. package/types/components/loading.d.ts +103 -103
  396. package/types/components/mention.d.ts +77 -77
  397. package/types/components/menu.d.ts +211 -211
  398. package/types/components/modal.d.ts +542 -542
  399. package/types/components/notice-bar.d.ts +102 -102
  400. package/types/components/number-input.d.ts +309 -309
  401. package/types/components/optgroup.d.ts +88 -88
  402. package/types/components/option.d.ts +103 -103
  403. package/types/components/pager.d.ts +335 -335
  404. package/types/components/password-input.d.ts +142 -142
  405. package/types/components/print-page-break.d.ts +69 -69
  406. package/types/components/print.d.ts +206 -206
  407. package/types/components/pulldown.d.ts +231 -231
  408. package/types/components/radio-button.d.ts +114 -114
  409. package/types/components/radio-group.d.ts +144 -144
  410. package/types/components/radio.d.ts +129 -129
  411. package/types/components/rate.d.ts +88 -88
  412. package/types/components/result.d.ts +84 -84
  413. package/types/components/row.d.ts +79 -79
  414. package/types/components/segmented.d.ts +123 -123
  415. package/types/components/select.d.ts +527 -527
  416. package/types/components/slider.d.ts +126 -126
  417. package/types/components/split-pane.d.ts +133 -133
  418. package/types/components/split.d.ts +312 -312
  419. package/types/components/splitter-panel.d.ts +105 -105
  420. package/types/components/splitter.d.ts +288 -288
  421. package/types/components/steps.d.ts +68 -68
  422. package/types/components/switch.d.ts +133 -133
  423. package/types/components/tab-pane.d.ts +114 -114
  424. package/types/components/table-module/custom.d.ts +123 -123
  425. package/types/components/table-module/edit.d.ts +243 -243
  426. package/types/components/table-module/export.d.ts +96 -96
  427. package/types/components/table-module/filter.d.ts +140 -140
  428. package/types/components/table-module/index.d.ts +7 -7
  429. package/types/components/table-module/keyboard.d.ts +26 -26
  430. package/types/components/table-module/menu.d.ts +28 -28
  431. package/types/components/table-module/validator.d.ts +53 -53
  432. package/types/components/table-plugins/extend-cell-area.d.ts +770 -770
  433. package/types/components/table-plugins/extend-pivot-table.d.ts +58 -58
  434. package/types/components/table-plugins/filters-combination.d.ts +15 -15
  435. package/types/components/table-plugins/filters-complex-input.d.ts +9 -9
  436. package/types/components/table-plugins/index.d.ts +4 -4
  437. package/types/components/table-select.d.ts +219 -219
  438. package/types/components/table.d.ts +7465 -7465
  439. package/types/components/tabs.d.ts +332 -332
  440. package/types/components/tag.d.ts +114 -114
  441. package/types/components/text-ellipsis.d.ts +112 -112
  442. package/types/components/text.d.ts +122 -122
  443. package/types/components/textarea.d.ts +247 -247
  444. package/types/components/timeline-item.d.ts +75 -75
  445. package/types/components/timeline.d.ts +77 -77
  446. package/types/components/tip.d.ts +83 -83
  447. package/types/components/toolbar.d.ts +336 -336
  448. package/types/components/tooltip.d.ts +180 -180
  449. package/types/components/tour.d.ts +77 -77
  450. package/types/components/tree-select.d.ts +310 -310
  451. package/types/components/tree.d.ts +843 -833
  452. package/types/components/upload.d.ts +437 -437
  453. package/types/components/watermark.d.ts +120 -120
  454. package/types/handles/form-design.d.ts +50 -50
  455. package/types/handles/index.d.ts +3 -3
  456. package/types/handles/list-design.d.ts +2 -2
  457. package/types/handles/table.d.ts +15 -15
  458. package/types/index.d.ts +8 -8
  459. package/types/ui/commands.d.ts +57 -57
  460. package/types/ui/formats.d.ts +62 -62
  461. package/types/ui/global-config.d.ts +254 -254
  462. package/types/ui/global-icon.d.ts +292 -292
  463. package/types/ui/hooks.d.ts +13 -13
  464. package/types/ui/index.d.ts +96 -96
  465. package/types/ui/interceptor.d.ts +52 -52
  466. package/types/ui/menus.d.ts +77 -77
  467. package/types/ui/renderer.d.ts +1041 -1041
  468. package/types/ui/validators.d.ts +38 -38
  469. /package/es/icon/{iconfont.1778169084473.ttf → iconfont.1778317220469.ttf} +0 -0
  470. /package/es/icon/{iconfont.1778169084473.woff → iconfont.1778317220469.woff} +0 -0
  471. /package/es/icon/{iconfont.1778169084473.woff2 → iconfont.1778317220469.woff2} +0 -0
  472. /package/es/{iconfont.1778169084473.ttf → iconfont.1778317220469.ttf} +0 -0
  473. /package/es/{iconfont.1778169084473.woff → iconfont.1778317220469.woff} +0 -0
  474. /package/es/{iconfont.1778169084473.woff2 → iconfont.1778317220469.woff2} +0 -0
  475. /package/lib/icon/style/{iconfont.1778169084473.ttf → iconfont.1778317220469.ttf} +0 -0
  476. /package/lib/icon/style/{iconfont.1778169084473.woff → iconfont.1778317220469.woff} +0 -0
  477. /package/lib/icon/style/{iconfont.1778169084473.woff2 → iconfont.1778317220469.woff2} +0 -0
  478. /package/lib/{iconfont.1778169084473.ttf → iconfont.1778317220469.ttf} +0 -0
  479. /package/lib/{iconfont.1778169084473.woff → iconfont.1778317220469.woff} +0 -0
  480. /package/lib/{iconfont.1778169084473.woff2 → iconfont.1778317220469.woff2} +0 -0
@@ -1,598 +1,598 @@
1
- import { h, resolveComponent, ComponentOptions } from 'vue'
2
- import XEUtils from 'xe-utils'
3
- import { renderer, getComponent } from '../../ui'
4
- import { getOnName, getModelEvent, getChangeEvent } from '../../ui/src/vn'
5
- import { errLog } from '../../ui/src/log'
6
-
7
- import type { VxeGlobalRendererHandles, VxeFormConstructor, VxeFormPrivateMethods } from '../../../types'
8
-
9
- const componentDefaultModelProp = 'modelValue'
10
-
11
- /**
12
- * 已废弃
13
- * @deprecated
14
- */
15
- function getOldComponentName (name: string | undefined) {
16
- return `vxe-${`${name || ''}`.replace('$', '')}`
17
- }
18
-
19
- function getDefaultComponent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions) {
20
- const { name } = renderOpts
21
- return getComponent(name as any) || resolveComponent(`${name}`)
22
- }
23
-
24
- /**
25
- * 已废弃
26
- * @deprecated
27
- */
28
- function getOldComponent ({ name }: VxeGlobalRendererHandles.RenderFormItemContentOptions) {
29
- return resolveComponent(getOldComponentName(name)) as ComponentOptions
30
- }
31
-
32
- function getNativeAttrs (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions) {
33
- let { name, attrs } = renderOpts
34
- if (name === 'input') {
35
- attrs = Object.assign({ type: 'text' }, attrs)
36
- }
37
- return attrs
38
- }
39
-
40
- function getComponentFormItemProps (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: any, value: any, defaultProps?: any) {
41
- return XEUtils.assign({}, defaultProps, renderOpts.props, { [componentDefaultModelProp]: value })
42
- }
43
-
44
- /**
45
- * 原生事件处理
46
- * @param renderOpts
47
- * @param params
48
- * @param modelFunc
49
- * @param changeFunc
50
- */
51
- function getNativeElementOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: any, modelFunc?: any, changeFunc?: any) {
52
- const { events } = renderOpts
53
- const modelEvent = getModelEvent(renderOpts)
54
- const changeEvent = getChangeEvent(renderOpts)
55
- const isSameEvent = changeEvent === modelEvent
56
- const ons: any = {}
57
- if (events) {
58
- XEUtils.objectEach(events, (func, key: any) => {
59
- ons[getOnName(key)] = function (...args: any[]) {
60
- func(params, ...args)
61
- }
62
- })
63
- }
64
- if (modelFunc) {
65
- ons[getOnName(modelEvent)] = function (targetEvnt: any) {
66
- modelFunc(targetEvnt)
67
- if (isSameEvent && changeFunc) {
68
- changeFunc(targetEvnt)
69
- }
70
- if (events && events[modelEvent]) {
71
- events[modelEvent](params, targetEvnt)
72
- }
73
- }
74
- }
75
- if (!isSameEvent && changeFunc) {
76
- ons[getOnName(changeEvent)] = function (...args: any[]) {
77
- changeFunc(...args)
78
- if (events && events[changeEvent]) {
79
- events[changeEvent](params, ...args)
80
- }
81
- }
82
- }
83
- return ons
84
- }
85
-
86
- /**
87
- * 组件事件处理
88
- * @param renderOpts
89
- * @param params
90
- * @param modelFunc
91
- * @param changeFunc
92
- */
93
- function getComponentOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams, eFns?: {
94
- model: (cellValue: any) => void
95
- change?: (...args: any[]) => void
96
- }, eventOns?: Record<string, any>) {
97
- const { events } = renderOpts
98
- const { model: modelFunc, change: changeFunc } = eFns || {}
99
- const modelEvent = getModelEvent(renderOpts)
100
- const changeEvent = getChangeEvent(renderOpts)
101
- const ons: any = {}
102
- XEUtils.objectEach(events, (func, key: any) => {
103
- ons[getOnName(key)] = function (...args: any[]) {
104
- if (!XEUtils.isFunction(func)) {
105
- errLog('vxe.error.errFunc', [`[form] ${func}`])
106
- }
107
- func(params, ...args)
108
- }
109
- })
110
- if (modelFunc) {
111
- ons[getOnName(modelEvent)] = function (targetEvnt: any) {
112
- modelFunc(targetEvnt)
113
- if (events && events[modelEvent]) {
114
- events[modelEvent](params, targetEvnt)
115
- }
116
- }
117
- }
118
- if (changeFunc) {
119
- ons[getOnName(changeEvent)] = function (...args: any[]) {
120
- changeFunc(...args)
121
- if (events && events[changeEvent]) {
122
- events[changeEvent](params, ...args)
123
- }
124
- }
125
- }
126
- return eventOns ? Object.assign(ons, eventOns) : ons
127
- }
128
-
129
- function getItemOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
130
- const { $form, data, field } = params
131
- return getComponentOns(renderOpts, params, {
132
- model (value) {
133
- // 处理 model 值双向绑定
134
- XEUtils.set(data, field, value)
135
- },
136
- change () {
137
- // 处理 change 事件相关逻辑
138
- $form.updateStatus(params)
139
- if (renderOpts.changeToSubmit) {
140
- ($form as VxeFormConstructor & VxeFormPrivateMethods).handleSubmitEvent(new Event('change'))
141
- }
142
- }
143
- })
144
- }
145
-
146
- function getNativeItemOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
147
- const { $form, data, field } = params
148
- return getNativeElementOns(renderOpts, params, (evnt: any) => {
149
- // 处理 model 值双向绑定
150
- const itemValue = evnt.target.value
151
- XEUtils.set(data, field, itemValue)
152
- }, () => {
153
- // 处理 change 事件相关逻辑
154
- $form.updateStatus(params)
155
- })
156
- }
157
-
158
- function renderNativeOptgroup (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams, renderOptionsMethods: any) {
159
- const { optionGroups, optionGroupProps = {} } = renderOpts
160
- const groupOptions = optionGroupProps.options || 'options'
161
- const groupLabel = optionGroupProps.label || 'label'
162
- if (optionGroups) {
163
- return optionGroups.map((group: any, gIndex: any) => {
164
- return h('optgroup', {
165
- key: gIndex,
166
- label: group[groupLabel]
167
- }, renderOptionsMethods(group[groupOptions], renderOpts, params))
168
- })
169
- }
170
- return []
171
- }
172
-
173
- /**
174
- * 渲染表单-项
175
- * 用于渲染原生的标签
176
- */
177
- function nativeItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
178
- const { data, field } = params
179
- const { name } = renderOpts
180
- const attrs = getNativeAttrs(renderOpts)
181
- const itemValue = XEUtils.get(data, field)
182
- return [
183
- h(`${name}`, {
184
- class: `vxe-default-${name}`,
185
- ...attrs,
186
- value: attrs && name === 'input' && (attrs.type === 'submit' || attrs.type === 'reset') ? null : itemValue,
187
- ...getNativeItemOns(renderOpts, params)
188
- })
189
- ]
190
- }
191
-
192
- function defaultItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
193
- const { data, field } = params
194
- const itemValue = XEUtils.get(data, field)
195
- return [
196
- h(getDefaultComponent(renderOpts), {
197
- ...getComponentFormItemProps(renderOpts, params, itemValue),
198
- ...getItemOns(renderOpts, params)
199
- })
200
- ]
201
- }
202
-
203
- /**
204
- * 已废弃
205
- * @deprecated
206
- */
207
- function oldItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
208
- const { data, field } = params
209
- const itemValue = XEUtils.get(data, field)
210
- return [
211
- h(getOldComponent(renderOpts), {
212
- ...getComponentFormItemProps(renderOpts, params, itemValue),
213
- ...getItemOns(renderOpts, params)
214
- })
215
- ]
216
- }
217
-
218
- /**
219
- * 已废弃
220
- * @deprecated
221
- */
222
- function oldButtonItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
223
- return [
224
- h(resolveComponent('vxe-button'), {
225
- ...getComponentFormItemProps(renderOpts, params, null),
226
- ...getComponentOns(renderOpts, params)
227
- })
228
- ]
229
- }
230
-
231
- /**
232
- * 已废弃
233
- * @deprecated
234
- */
235
- function oldButtonsItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
236
- const { children } = renderOpts
237
- return children ? children.map((childRenderOpts: any) => oldButtonItemRender(childRenderOpts, params)[0]) : []
238
- }
239
-
240
- /**
241
- * 渲染原生的 select 标签
242
- */
243
- function renderNativeFormOptions (options: any, renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
244
- const { data, field } = params
245
- const { optionProps = {} } = renderOpts
246
- const labelProp = optionProps.label || 'label'
247
- const valueProp = optionProps.value || 'value'
248
- const disabledProp = optionProps.disabled || 'disabled'
249
- const cellValue = XEUtils.get(data, field)
250
- if (options) {
251
- return options.map((item: any, oIndex: any) => {
252
- return h('option', {
253
- key: oIndex,
254
- value: item[valueProp],
255
- disabled: item[disabledProp],
256
- /* eslint-disable eqeqeq */
257
- selected: item[valueProp] == cellValue
258
- }, item[labelProp])
259
- })
260
- }
261
- return []
262
- }
263
-
264
- /**
265
- * 渲染表单-项
266
- */
267
- function defaultFormItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
268
- const { data, field } = params
269
- const itemValue = XEUtils.get(data, field)
270
- return [
271
- h(getDefaultComponent(renderOpts), {
272
- ...getComponentFormItemProps(renderOpts, params, itemValue),
273
- ...getItemOns(renderOpts, params)
274
- })
275
- ]
276
- }
277
-
278
- function formItemRadioAndCheckboxRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
279
- const { options, optionProps } = renderOpts
280
- const { data, field } = params
281
- const itemValue = XEUtils.get(data, field)
282
- return [
283
- h(getDefaultComponent(renderOpts), {
284
- options,
285
- optionProps,
286
- ...getComponentFormItemProps(renderOpts, params, itemValue),
287
- ...getItemOns(renderOpts, params)
288
- })
289
- ]
290
- }
291
-
292
- /**
293
- * 已废弃
294
- * @deprecated
295
- */
296
- function oldFormItemRadioAndCheckboxRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
297
- const { name, options, optionProps = {} } = renderOpts
298
- const { data, field } = params
299
- const labelProp = optionProps.label || 'label'
300
- const valueProp = optionProps.value || 'value'
301
- const disabledProp = optionProps.disabled || 'disabled'
302
- const itemValue = XEUtils.get(data, field)
303
- const compName = getOldComponentName(name)
304
- // 如果是分组
305
- if (options) {
306
- return [
307
- h(resolveComponent(`${compName}-group`) as ComponentOptions, {
308
- ...getComponentFormItemProps(renderOpts, params, itemValue),
309
- ...getItemOns(renderOpts, params)
310
- }, {
311
- default: () => {
312
- return options.map((item, index) => {
313
- return h(resolveComponent(compName) as ComponentOptions, {
314
- key: index,
315
- label: item[valueProp],
316
- content: item[labelProp],
317
- disabled: item[disabledProp]
318
- })
319
- })
320
- }
321
- })
322
- ]
323
- }
324
- return [
325
- h(resolveComponent(compName) as ComponentOptions, {
326
- ...getComponentFormItemProps(renderOpts, params, itemValue),
327
- ...getItemOns(renderOpts, params)
328
- })
329
- ]
330
- }
331
-
332
- /**
333
- * 表单 - 渲染器
334
- */
335
- renderer.mixin({
336
- input: {
337
- formItemAutoFocus: 'input',
338
- renderFormItemContent: nativeItemRender
339
- },
340
- textarea: {
341
- formItemAutoFocus: 'textarea',
342
- renderFormItemContent: nativeItemRender
343
- },
344
- select: {
345
- formItemAutoFocus: 'input',
346
- renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
347
- return [
348
- h('select', {
349
- class: 'vxe-default-select',
350
- ...getNativeAttrs(renderOpts),
351
- ...getNativeItemOns(renderOpts, params)
352
- },
353
- renderOpts.optionGroups ? renderNativeOptgroup(renderOpts, params, renderNativeFormOptions) : renderNativeFormOptions(renderOpts.options, renderOpts, params))
354
- ]
355
- }
356
- },
357
- VxeInput: {
358
- formItemAutoFocus: 'input',
359
- renderFormItemContent: defaultItemRender
360
- },
361
- VxeNumberInput: {
362
- formItemAutoFocus: 'input',
363
- renderFormItemContent: defaultItemRender
364
- },
365
- VxePasswordInput: {
366
- formItemAutoFocus: 'input',
367
- renderFormItemContent: defaultItemRender
368
- },
369
- VxeTextarea: {
370
- formItemAutoFocus: 'textarea',
371
- renderFormItemContent: defaultItemRender
372
- },
373
- VxeDatePicker: {
374
- formItemAutoFocus: 'input',
375
- renderFormItemContent: defaultItemRender
376
- },
377
- VxeDateRangePicker: {
378
- formItemAutoFocus: 'input',
379
- renderFormItemContent (renderOpts, params) {
380
- const { startField, endField } = renderOpts
381
- const { $form, data, field } = params
382
- const itemValue = XEUtils.get(data, field)
383
- const seProps: Record<string, any> = {}
384
- const seOs: Record<string, any> = {}
385
- if (startField && endField) {
386
- seProps.startValue = XEUtils.get(data, startField)
387
- seProps.endValue = XEUtils.get(data, endField)
388
- seOs['onUpdate:startValue'] = (value: any) => {
389
- if (startField) {
390
- XEUtils.set(data, startField, value)
391
- }
392
- }
393
- seOs['onUpdate:endValue'] = (value: any) => {
394
- if (endField) {
395
- XEUtils.set(data, endField, value)
396
- }
397
- }
398
- }
399
- return [
400
- h(getDefaultComponent(renderOpts), {
401
- ...getComponentFormItemProps(renderOpts, params, itemValue, seProps),
402
- ...getComponentOns(renderOpts, params, {
403
- model (value: any) {
404
- // 处理 model 值双向绑定
405
- XEUtils.set(data, field, value)
406
- },
407
- change ({ $event, isFinish }) {
408
- // 处理 change 事件相关逻辑
409
- $form.updateStatus(params)
410
- if (renderOpts.changeToSubmit && isFinish) {
411
- ($form as VxeFormConstructor & VxeFormPrivateMethods).handleSubmitEvent($event)
412
- }
413
- }
414
- }, seOs)
415
- })
416
- ]
417
- }
418
- },
419
- VxeButton: {
420
- renderFormItemContent: defaultFormItemRender
421
- },
422
- VxeButtonGroup: {
423
- renderFormItemContent (renderOpts, params) {
424
- const { options } = renderOpts
425
- const { data, field } = params
426
- const itemValue = XEUtils.get(data, field)
427
- return [
428
- h(getDefaultComponent(renderOpts), {
429
- options,
430
- ...getComponentFormItemProps(renderOpts, params, itemValue),
431
- ...getItemOns(renderOpts, params)
432
- })
433
- ]
434
- }
435
- },
436
- VxeSelect: {
437
- formItemAutoFocus: 'input',
438
- renderFormItemContent (renderOpts, params) {
439
- const { data, field } = params
440
- const { options, optionProps, optionGroups, optionGroupProps } = renderOpts
441
- const itemValue = XEUtils.get(data, field)
442
- return [
443
- h(getDefaultComponent(renderOpts), {
444
- ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps, optionGroups, optionGroupProps }),
445
- ...getItemOns(renderOpts, params)
446
- })
447
- ]
448
- }
449
- },
450
- VxeTreeSelect: {
451
- formItemAutoFocus: 'input',
452
- renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
453
- const { data, field } = params
454
- const { options, optionProps } = renderOpts
455
- const itemValue = XEUtils.get(data, field)
456
- return [
457
- h(getDefaultComponent(renderOpts), {
458
- ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps }),
459
- ...getItemOns(renderOpts, params)
460
- })
461
- ]
462
- }
463
- },
464
- VxeTableSelect: {
465
- formItemAutoFocus: 'input',
466
- renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
467
- const { data, field } = params
468
- const { options, optionProps } = renderOpts
469
- const itemValue = XEUtils.get(data, field)
470
- return [
471
- h(getDefaultComponent(renderOpts), {
472
- ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps }),
473
- ...getItemOns(renderOpts, params)
474
- })
475
- ]
476
- }
477
- },
478
- VxeColorPicker: {
479
- formItemAutoFocus: 'input',
480
- renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
481
- const { data, field } = params
482
- const { options } = renderOpts
483
- const itemValue = XEUtils.get(data, field)
484
- return [
485
- h(getDefaultComponent(renderOpts), {
486
- ...getComponentFormItemProps(renderOpts, params, itemValue, { colors: options }),
487
- ...getItemOns(renderOpts, params)
488
- })
489
- ]
490
- }
491
- },
492
- VxeIconPicker: {
493
- formItemAutoFocus: 'input',
494
- renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
495
- const { data, field } = params
496
- const { options } = renderOpts
497
- const itemValue = XEUtils.get(data, field)
498
- return [
499
- h(getDefaultComponent(renderOpts), {
500
- ...getComponentFormItemProps(renderOpts, params, itemValue, { icons: options }),
501
- ...getItemOns(renderOpts, params)
502
- })
503
- ]
504
- }
505
- },
506
- VxeRadio: {
507
- renderFormItemContent: defaultFormItemRender
508
- },
509
- VxeRadioGroup: {
510
- renderFormItemContent: formItemRadioAndCheckboxRender
511
- },
512
- VxeCheckbox: {
513
- renderFormItemContent: defaultFormItemRender
514
- },
515
- VxeCheckboxGroup: {
516
- renderFormItemContent: formItemRadioAndCheckboxRender
517
- },
518
- VxeSwitch: {
519
- renderFormItemContent: defaultItemRender
520
- },
521
- VxeRate: {
522
- renderFormItemContent: defaultItemRender
523
- },
524
- VxeSlider: {
525
- renderFormItemContent: defaultItemRender
526
- },
527
- VxeImage: {
528
- renderFormItemContent (renderOpts, params) {
529
- const { data, field } = params
530
- const { props } = renderOpts
531
- const itemValue = XEUtils.get(data, field)
532
- return [
533
- h(getDefaultComponent(renderOpts), {
534
- ...props,
535
- src: itemValue,
536
- ...getItemOns(renderOpts, params)
537
- })
538
- ]
539
- }
540
- },
541
- VxeImageGroup: {
542
- renderFormItemContent (renderOpts, params) {
543
- const { data, field } = params
544
- const { props } = renderOpts
545
- const itemValue = XEUtils.get(data, field)
546
- return [
547
- h(getDefaultComponent(renderOpts), {
548
- ...props,
549
- urlList: itemValue,
550
- ...getItemOns(renderOpts, params)
551
- })
552
- ]
553
- }
554
- },
555
- VxeUpload: {
556
- renderFormItemContent: defaultItemRender
557
- },
558
-
559
- // 以下已废弃
560
- $input: {
561
- formItemAutoFocus: 'input',
562
- renderFormItemContent: oldItemRender
563
- },
564
- $textarea: {
565
- formItemAutoFocus: 'textarea',
566
- renderFormItemContent: oldItemRender
567
- },
568
- $button: {
569
- renderFormItemContent: oldButtonItemRender
570
- },
571
- $buttons: {
572
- renderFormItemContent: oldButtonsItemRender
573
- },
574
- $select: {
575
- formItemAutoFocus: 'input',
576
- renderFormItemContent (renderOpts, params) {
577
- const { data, field } = params
578
- const { options, optionProps, optionGroups, optionGroupProps } = renderOpts
579
- const itemValue = XEUtils.get(data, field)
580
- return [
581
- h(getOldComponent(renderOpts), {
582
- ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps, optionGroups, optionGroupProps }),
583
- ...getItemOns(renderOpts, params)
584
- })
585
- ]
586
- }
587
- },
588
- $radio: {
589
- renderFormItemContent: oldFormItemRadioAndCheckboxRender
590
- },
591
- $checkbox: {
592
- renderFormItemContent: oldFormItemRadioAndCheckboxRender
593
- },
594
- $switch: {
595
- renderFormItemContent: oldItemRender
596
- }
597
- // 以上已废弃
598
- })
1
+ import { h, resolveComponent, ComponentOptions } from 'vue'
2
+ import XEUtils from 'xe-utils'
3
+ import { renderer, getComponent } from '../../ui'
4
+ import { getOnName, getModelEvent, getChangeEvent } from '../../ui/src/vn'
5
+ import { errLog } from '../../ui/src/log'
6
+
7
+ import type { VxeGlobalRendererHandles, VxeFormConstructor, VxeFormPrivateMethods } from '../../../types'
8
+
9
+ const componentDefaultModelProp = 'modelValue'
10
+
11
+ /**
12
+ * 已废弃
13
+ * @deprecated
14
+ */
15
+ function getOldComponentName (name: string | undefined) {
16
+ return `vxe-${`${name || ''}`.replace('$', '')}`
17
+ }
18
+
19
+ function getDefaultComponent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions) {
20
+ const { name } = renderOpts
21
+ return getComponent(name as any) || resolveComponent(`${name}`)
22
+ }
23
+
24
+ /**
25
+ * 已废弃
26
+ * @deprecated
27
+ */
28
+ function getOldComponent ({ name }: VxeGlobalRendererHandles.RenderFormItemContentOptions) {
29
+ return resolveComponent(getOldComponentName(name)) as ComponentOptions
30
+ }
31
+
32
+ function getNativeAttrs (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions) {
33
+ let { name, attrs } = renderOpts
34
+ if (name === 'input') {
35
+ attrs = Object.assign({ type: 'text' }, attrs)
36
+ }
37
+ return attrs
38
+ }
39
+
40
+ function getComponentFormItemProps (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: any, value: any, defaultProps?: any) {
41
+ return XEUtils.assign({}, defaultProps, renderOpts.props, { [componentDefaultModelProp]: value })
42
+ }
43
+
44
+ /**
45
+ * 原生事件处理
46
+ * @param renderOpts
47
+ * @param params
48
+ * @param modelFunc
49
+ * @param changeFunc
50
+ */
51
+ function getNativeElementOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: any, modelFunc?: any, changeFunc?: any) {
52
+ const { events } = renderOpts
53
+ const modelEvent = getModelEvent(renderOpts)
54
+ const changeEvent = getChangeEvent(renderOpts)
55
+ const isSameEvent = changeEvent === modelEvent
56
+ const ons: any = {}
57
+ if (events) {
58
+ XEUtils.objectEach(events, (func, key: any) => {
59
+ ons[getOnName(key)] = function (...args: any[]) {
60
+ func(params, ...args)
61
+ }
62
+ })
63
+ }
64
+ if (modelFunc) {
65
+ ons[getOnName(modelEvent)] = function (targetEvnt: any) {
66
+ modelFunc(targetEvnt)
67
+ if (isSameEvent && changeFunc) {
68
+ changeFunc(targetEvnt)
69
+ }
70
+ if (events && events[modelEvent]) {
71
+ events[modelEvent](params, targetEvnt)
72
+ }
73
+ }
74
+ }
75
+ if (!isSameEvent && changeFunc) {
76
+ ons[getOnName(changeEvent)] = function (...args: any[]) {
77
+ changeFunc(...args)
78
+ if (events && events[changeEvent]) {
79
+ events[changeEvent](params, ...args)
80
+ }
81
+ }
82
+ }
83
+ return ons
84
+ }
85
+
86
+ /**
87
+ * 组件事件处理
88
+ * @param renderOpts
89
+ * @param params
90
+ * @param modelFunc
91
+ * @param changeFunc
92
+ */
93
+ function getComponentOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams, eFns?: {
94
+ model: (cellValue: any) => void
95
+ change?: (...args: any[]) => void
96
+ }, eventOns?: Record<string, any>) {
97
+ const { events } = renderOpts
98
+ const { model: modelFunc, change: changeFunc } = eFns || {}
99
+ const modelEvent = getModelEvent(renderOpts)
100
+ const changeEvent = getChangeEvent(renderOpts)
101
+ const ons: any = {}
102
+ XEUtils.objectEach(events, (func, key: any) => {
103
+ ons[getOnName(key)] = function (...args: any[]) {
104
+ if (!XEUtils.isFunction(func)) {
105
+ errLog('vxe.error.errFunc', [`[form] ${func}`])
106
+ }
107
+ func(params, ...args)
108
+ }
109
+ })
110
+ if (modelFunc) {
111
+ ons[getOnName(modelEvent)] = function (targetEvnt: any) {
112
+ modelFunc(targetEvnt)
113
+ if (events && events[modelEvent]) {
114
+ events[modelEvent](params, targetEvnt)
115
+ }
116
+ }
117
+ }
118
+ if (changeFunc) {
119
+ ons[getOnName(changeEvent)] = function (...args: any[]) {
120
+ changeFunc(...args)
121
+ if (events && events[changeEvent]) {
122
+ events[changeEvent](params, ...args)
123
+ }
124
+ }
125
+ }
126
+ return eventOns ? Object.assign(ons, eventOns) : ons
127
+ }
128
+
129
+ function getItemOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
130
+ const { $form, data, field } = params
131
+ return getComponentOns(renderOpts, params, {
132
+ model (value) {
133
+ // 处理 model 值双向绑定
134
+ XEUtils.set(data, field, value)
135
+ },
136
+ change () {
137
+ // 处理 change 事件相关逻辑
138
+ $form.updateStatus(params)
139
+ if (renderOpts.changeToSubmit) {
140
+ ($form as VxeFormConstructor & VxeFormPrivateMethods).handleSubmitEvent(new Event('change'))
141
+ }
142
+ }
143
+ })
144
+ }
145
+
146
+ function getNativeItemOns (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
147
+ const { $form, data, field } = params
148
+ return getNativeElementOns(renderOpts, params, (evnt: any) => {
149
+ // 处理 model 值双向绑定
150
+ const itemValue = evnt.target.value
151
+ XEUtils.set(data, field, itemValue)
152
+ }, () => {
153
+ // 处理 change 事件相关逻辑
154
+ $form.updateStatus(params)
155
+ })
156
+ }
157
+
158
+ function renderNativeOptgroup (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams, renderOptionsMethods: any) {
159
+ const { optionGroups, optionGroupProps = {} } = renderOpts
160
+ const groupOptions = optionGroupProps.options || 'options'
161
+ const groupLabel = optionGroupProps.label || 'label'
162
+ if (optionGroups) {
163
+ return optionGroups.map((group: any, gIndex: any) => {
164
+ return h('optgroup', {
165
+ key: gIndex,
166
+ label: group[groupLabel]
167
+ }, renderOptionsMethods(group[groupOptions], renderOpts, params))
168
+ })
169
+ }
170
+ return []
171
+ }
172
+
173
+ /**
174
+ * 渲染表单-项
175
+ * 用于渲染原生的标签
176
+ */
177
+ function nativeItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
178
+ const { data, field } = params
179
+ const { name } = renderOpts
180
+ const attrs = getNativeAttrs(renderOpts)
181
+ const itemValue = XEUtils.get(data, field)
182
+ return [
183
+ h(`${name}`, {
184
+ class: `vxe-default-${name}`,
185
+ ...attrs,
186
+ value: attrs && name === 'input' && (attrs.type === 'submit' || attrs.type === 'reset') ? null : itemValue,
187
+ ...getNativeItemOns(renderOpts, params)
188
+ })
189
+ ]
190
+ }
191
+
192
+ function defaultItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
193
+ const { data, field } = params
194
+ const itemValue = XEUtils.get(data, field)
195
+ return [
196
+ h(getDefaultComponent(renderOpts), {
197
+ ...getComponentFormItemProps(renderOpts, params, itemValue),
198
+ ...getItemOns(renderOpts, params)
199
+ })
200
+ ]
201
+ }
202
+
203
+ /**
204
+ * 已废弃
205
+ * @deprecated
206
+ */
207
+ function oldItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
208
+ const { data, field } = params
209
+ const itemValue = XEUtils.get(data, field)
210
+ return [
211
+ h(getOldComponent(renderOpts), {
212
+ ...getComponentFormItemProps(renderOpts, params, itemValue),
213
+ ...getItemOns(renderOpts, params)
214
+ })
215
+ ]
216
+ }
217
+
218
+ /**
219
+ * 已废弃
220
+ * @deprecated
221
+ */
222
+ function oldButtonItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
223
+ return [
224
+ h(resolveComponent('vxe-button'), {
225
+ ...getComponentFormItemProps(renderOpts, params, null),
226
+ ...getComponentOns(renderOpts, params)
227
+ })
228
+ ]
229
+ }
230
+
231
+ /**
232
+ * 已废弃
233
+ * @deprecated
234
+ */
235
+ function oldButtonsItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
236
+ const { children } = renderOpts
237
+ return children ? children.map((childRenderOpts: any) => oldButtonItemRender(childRenderOpts, params)[0]) : []
238
+ }
239
+
240
+ /**
241
+ * 渲染原生的 select 标签
242
+ */
243
+ function renderNativeFormOptions (options: any, renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
244
+ const { data, field } = params
245
+ const { optionProps = {} } = renderOpts
246
+ const labelProp = optionProps.label || 'label'
247
+ const valueProp = optionProps.value || 'value'
248
+ const disabledProp = optionProps.disabled || 'disabled'
249
+ const cellValue = XEUtils.get(data, field)
250
+ if (options) {
251
+ return options.map((item: any, oIndex: any) => {
252
+ return h('option', {
253
+ key: oIndex,
254
+ value: item[valueProp],
255
+ disabled: item[disabledProp],
256
+ /* eslint-disable eqeqeq */
257
+ selected: item[valueProp] == cellValue
258
+ }, item[labelProp])
259
+ })
260
+ }
261
+ return []
262
+ }
263
+
264
+ /**
265
+ * 渲染表单-项
266
+ */
267
+ function defaultFormItemRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
268
+ const { data, field } = params
269
+ const itemValue = XEUtils.get(data, field)
270
+ return [
271
+ h(getDefaultComponent(renderOpts), {
272
+ ...getComponentFormItemProps(renderOpts, params, itemValue),
273
+ ...getItemOns(renderOpts, params)
274
+ })
275
+ ]
276
+ }
277
+
278
+ function formItemRadioAndCheckboxRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
279
+ const { options, optionProps } = renderOpts
280
+ const { data, field } = params
281
+ const itemValue = XEUtils.get(data, field)
282
+ return [
283
+ h(getDefaultComponent(renderOpts), {
284
+ options,
285
+ optionProps,
286
+ ...getComponentFormItemProps(renderOpts, params, itemValue),
287
+ ...getItemOns(renderOpts, params)
288
+ })
289
+ ]
290
+ }
291
+
292
+ /**
293
+ * 已废弃
294
+ * @deprecated
295
+ */
296
+ function oldFormItemRadioAndCheckboxRender (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
297
+ const { name, options, optionProps = {} } = renderOpts
298
+ const { data, field } = params
299
+ const labelProp = optionProps.label || 'label'
300
+ const valueProp = optionProps.value || 'value'
301
+ const disabledProp = optionProps.disabled || 'disabled'
302
+ const itemValue = XEUtils.get(data, field)
303
+ const compName = getOldComponentName(name)
304
+ // 如果是分组
305
+ if (options) {
306
+ return [
307
+ h(resolveComponent(`${compName}-group`) as ComponentOptions, {
308
+ ...getComponentFormItemProps(renderOpts, params, itemValue),
309
+ ...getItemOns(renderOpts, params)
310
+ }, {
311
+ default: () => {
312
+ return options.map((item, index) => {
313
+ return h(resolveComponent(compName) as ComponentOptions, {
314
+ key: index,
315
+ label: item[valueProp],
316
+ content: item[labelProp],
317
+ disabled: item[disabledProp]
318
+ })
319
+ })
320
+ }
321
+ })
322
+ ]
323
+ }
324
+ return [
325
+ h(resolveComponent(compName) as ComponentOptions, {
326
+ ...getComponentFormItemProps(renderOpts, params, itemValue),
327
+ ...getItemOns(renderOpts, params)
328
+ })
329
+ ]
330
+ }
331
+
332
+ /**
333
+ * 表单 - 渲染器
334
+ */
335
+ renderer.mixin({
336
+ input: {
337
+ formItemAutoFocus: 'input',
338
+ renderFormItemContent: nativeItemRender
339
+ },
340
+ textarea: {
341
+ formItemAutoFocus: 'textarea',
342
+ renderFormItemContent: nativeItemRender
343
+ },
344
+ select: {
345
+ formItemAutoFocus: 'input',
346
+ renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
347
+ return [
348
+ h('select', {
349
+ class: 'vxe-default-select',
350
+ ...getNativeAttrs(renderOpts),
351
+ ...getNativeItemOns(renderOpts, params)
352
+ },
353
+ renderOpts.optionGroups ? renderNativeOptgroup(renderOpts, params, renderNativeFormOptions) : renderNativeFormOptions(renderOpts.options, renderOpts, params))
354
+ ]
355
+ }
356
+ },
357
+ VxeInput: {
358
+ formItemAutoFocus: 'input',
359
+ renderFormItemContent: defaultItemRender
360
+ },
361
+ VxeNumberInput: {
362
+ formItemAutoFocus: 'input',
363
+ renderFormItemContent: defaultItemRender
364
+ },
365
+ VxePasswordInput: {
366
+ formItemAutoFocus: 'input',
367
+ renderFormItemContent: defaultItemRender
368
+ },
369
+ VxeTextarea: {
370
+ formItemAutoFocus: 'textarea',
371
+ renderFormItemContent: defaultItemRender
372
+ },
373
+ VxeDatePicker: {
374
+ formItemAutoFocus: 'input',
375
+ renderFormItemContent: defaultItemRender
376
+ },
377
+ VxeDateRangePicker: {
378
+ formItemAutoFocus: 'input',
379
+ renderFormItemContent (renderOpts, params) {
380
+ const { startField, endField } = renderOpts
381
+ const { $form, data, field } = params
382
+ const itemValue = XEUtils.get(data, field)
383
+ const seProps: Record<string, any> = {}
384
+ const seOs: Record<string, any> = {}
385
+ if (startField && endField) {
386
+ seProps.startValue = XEUtils.get(data, startField)
387
+ seProps.endValue = XEUtils.get(data, endField)
388
+ seOs['onUpdate:startValue'] = (value: any) => {
389
+ if (startField) {
390
+ XEUtils.set(data, startField, value)
391
+ }
392
+ }
393
+ seOs['onUpdate:endValue'] = (value: any) => {
394
+ if (endField) {
395
+ XEUtils.set(data, endField, value)
396
+ }
397
+ }
398
+ }
399
+ return [
400
+ h(getDefaultComponent(renderOpts), {
401
+ ...getComponentFormItemProps(renderOpts, params, itemValue, seProps),
402
+ ...getComponentOns(renderOpts, params, {
403
+ model (value: any) {
404
+ // 处理 model 值双向绑定
405
+ XEUtils.set(data, field, value)
406
+ },
407
+ change ({ $event, isFinish }) {
408
+ // 处理 change 事件相关逻辑
409
+ $form.updateStatus(params)
410
+ if (renderOpts.changeToSubmit && isFinish) {
411
+ ($form as VxeFormConstructor & VxeFormPrivateMethods).handleSubmitEvent($event)
412
+ }
413
+ }
414
+ }, seOs)
415
+ })
416
+ ]
417
+ }
418
+ },
419
+ VxeButton: {
420
+ renderFormItemContent: defaultFormItemRender
421
+ },
422
+ VxeButtonGroup: {
423
+ renderFormItemContent (renderOpts, params) {
424
+ const { options } = renderOpts
425
+ const { data, field } = params
426
+ const itemValue = XEUtils.get(data, field)
427
+ return [
428
+ h(getDefaultComponent(renderOpts), {
429
+ options,
430
+ ...getComponentFormItemProps(renderOpts, params, itemValue),
431
+ ...getItemOns(renderOpts, params)
432
+ })
433
+ ]
434
+ }
435
+ },
436
+ VxeSelect: {
437
+ formItemAutoFocus: 'input',
438
+ renderFormItemContent (renderOpts, params) {
439
+ const { data, field } = params
440
+ const { options, optionProps, optionGroups, optionGroupProps } = renderOpts
441
+ const itemValue = XEUtils.get(data, field)
442
+ return [
443
+ h(getDefaultComponent(renderOpts), {
444
+ ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps, optionGroups, optionGroupProps }),
445
+ ...getItemOns(renderOpts, params)
446
+ })
447
+ ]
448
+ }
449
+ },
450
+ VxeTreeSelect: {
451
+ formItemAutoFocus: 'input',
452
+ renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
453
+ const { data, field } = params
454
+ const { options, optionProps } = renderOpts
455
+ const itemValue = XEUtils.get(data, field)
456
+ return [
457
+ h(getDefaultComponent(renderOpts), {
458
+ ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps }),
459
+ ...getItemOns(renderOpts, params)
460
+ })
461
+ ]
462
+ }
463
+ },
464
+ VxeTableSelect: {
465
+ formItemAutoFocus: 'input',
466
+ renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
467
+ const { data, field } = params
468
+ const { options, optionProps } = renderOpts
469
+ const itemValue = XEUtils.get(data, field)
470
+ return [
471
+ h(getDefaultComponent(renderOpts), {
472
+ ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps }),
473
+ ...getItemOns(renderOpts, params)
474
+ })
475
+ ]
476
+ }
477
+ },
478
+ VxeColorPicker: {
479
+ formItemAutoFocus: 'input',
480
+ renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
481
+ const { data, field } = params
482
+ const { options } = renderOpts
483
+ const itemValue = XEUtils.get(data, field)
484
+ return [
485
+ h(getDefaultComponent(renderOpts), {
486
+ ...getComponentFormItemProps(renderOpts, params, itemValue, { colors: options }),
487
+ ...getItemOns(renderOpts, params)
488
+ })
489
+ ]
490
+ }
491
+ },
492
+ VxeIconPicker: {
493
+ formItemAutoFocus: 'input',
494
+ renderFormItemContent (renderOpts: VxeGlobalRendererHandles.RenderFormItemContentOptions, params: VxeGlobalRendererHandles.RenderFormItemContentParams) {
495
+ const { data, field } = params
496
+ const { options } = renderOpts
497
+ const itemValue = XEUtils.get(data, field)
498
+ return [
499
+ h(getDefaultComponent(renderOpts), {
500
+ ...getComponentFormItemProps(renderOpts, params, itemValue, { icons: options }),
501
+ ...getItemOns(renderOpts, params)
502
+ })
503
+ ]
504
+ }
505
+ },
506
+ VxeRadio: {
507
+ renderFormItemContent: defaultFormItemRender
508
+ },
509
+ VxeRadioGroup: {
510
+ renderFormItemContent: formItemRadioAndCheckboxRender
511
+ },
512
+ VxeCheckbox: {
513
+ renderFormItemContent: defaultFormItemRender
514
+ },
515
+ VxeCheckboxGroup: {
516
+ renderFormItemContent: formItemRadioAndCheckboxRender
517
+ },
518
+ VxeSwitch: {
519
+ renderFormItemContent: defaultItemRender
520
+ },
521
+ VxeRate: {
522
+ renderFormItemContent: defaultItemRender
523
+ },
524
+ VxeSlider: {
525
+ renderFormItemContent: defaultItemRender
526
+ },
527
+ VxeImage: {
528
+ renderFormItemContent (renderOpts, params) {
529
+ const { data, field } = params
530
+ const { props } = renderOpts
531
+ const itemValue = XEUtils.get(data, field)
532
+ return [
533
+ h(getDefaultComponent(renderOpts), {
534
+ ...props,
535
+ src: itemValue,
536
+ ...getItemOns(renderOpts, params)
537
+ })
538
+ ]
539
+ }
540
+ },
541
+ VxeImageGroup: {
542
+ renderFormItemContent (renderOpts, params) {
543
+ const { data, field } = params
544
+ const { props } = renderOpts
545
+ const itemValue = XEUtils.get(data, field)
546
+ return [
547
+ h(getDefaultComponent(renderOpts), {
548
+ ...props,
549
+ urlList: itemValue,
550
+ ...getItemOns(renderOpts, params)
551
+ })
552
+ ]
553
+ }
554
+ },
555
+ VxeUpload: {
556
+ renderFormItemContent: defaultItemRender
557
+ },
558
+
559
+ // 以下已废弃
560
+ $input: {
561
+ formItemAutoFocus: 'input',
562
+ renderFormItemContent: oldItemRender
563
+ },
564
+ $textarea: {
565
+ formItemAutoFocus: 'textarea',
566
+ renderFormItemContent: oldItemRender
567
+ },
568
+ $button: {
569
+ renderFormItemContent: oldButtonItemRender
570
+ },
571
+ $buttons: {
572
+ renderFormItemContent: oldButtonsItemRender
573
+ },
574
+ $select: {
575
+ formItemAutoFocus: 'input',
576
+ renderFormItemContent (renderOpts, params) {
577
+ const { data, field } = params
578
+ const { options, optionProps, optionGroups, optionGroupProps } = renderOpts
579
+ const itemValue = XEUtils.get(data, field)
580
+ return [
581
+ h(getOldComponent(renderOpts), {
582
+ ...getComponentFormItemProps(renderOpts, params, itemValue, { options, optionProps, optionGroups, optionGroupProps }),
583
+ ...getItemOns(renderOpts, params)
584
+ })
585
+ ]
586
+ }
587
+ },
588
+ $radio: {
589
+ renderFormItemContent: oldFormItemRadioAndCheckboxRender
590
+ },
591
+ $checkbox: {
592
+ renderFormItemContent: oldFormItemRadioAndCheckboxRender
593
+ },
594
+ $switch: {
595
+ renderFormItemContent: oldItemRender
596
+ }
597
+ // 以上已废弃
598
+ })