vxe-pc-ui 3.13.11 → 3.13.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (674) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +134 -134
  3. package/es/icon/style.css +1 -1
  4. package/es/style.css +1 -1
  5. package/es/style.min.css +1 -1
  6. package/es/tag/style.css +1 -3
  7. package/es/tag/style.min.css +1 -1
  8. package/es/ui/index.js +1 -1
  9. package/es/ui/src/log.js +1 -1
  10. package/es/vxe-tag/style.css +1 -3
  11. package/es/vxe-tag/style.min.css +1 -1
  12. package/lib/components.js +2 -1
  13. package/lib/components.min.js +1 -1
  14. package/lib/drawer/index.js +2 -1
  15. package/lib/drawer/index.min.js +1 -1
  16. package/lib/icon/style/style.css +1 -1
  17. package/lib/icon/style/style.min.css +1 -1
  18. package/lib/index.common.js +2 -1
  19. package/lib/index.umd.js +7962 -8834
  20. package/lib/index.umd.min.js +1 -1
  21. package/lib/modal/index.js +2 -1
  22. package/lib/modal/index.min.js +1 -1
  23. package/lib/style.css +1 -1
  24. package/lib/style.min.css +1 -1
  25. package/lib/tag/style/style.css +1 -3
  26. package/lib/tag/style/style.min.css +1 -1
  27. package/lib/ui/index.js +1 -1
  28. package/lib/ui/index.min.js +1 -1
  29. package/lib/ui/src/log.js +1 -1
  30. package/lib/ui/src/log.min.js +1 -1
  31. package/lib/vxe-alert/index.js +2 -1
  32. package/lib/vxe-alert/index.min.js +1 -1
  33. package/lib/vxe-anchor/index.js +2 -1
  34. package/lib/vxe-anchor/index.min.js +1 -1
  35. package/lib/vxe-anchor-link/index.js +2 -1
  36. package/lib/vxe-anchor-link/index.min.js +1 -1
  37. package/lib/vxe-avatar/index.js +2 -1
  38. package/lib/vxe-avatar/index.min.js +1 -1
  39. package/lib/vxe-backtop/index.js +2 -1
  40. package/lib/vxe-backtop/index.min.js +1 -1
  41. package/lib/vxe-badge/index.js +2 -1
  42. package/lib/vxe-badge/index.min.js +1 -1
  43. package/lib/vxe-breadcrumb/index.js +2 -1
  44. package/lib/vxe-breadcrumb/index.min.js +1 -1
  45. package/lib/vxe-breadcrumb-item/index.js +2 -1
  46. package/lib/vxe-breadcrumb-item/index.min.js +1 -1
  47. package/lib/vxe-button/index.js +2 -1
  48. package/lib/vxe-button/index.min.js +1 -1
  49. package/lib/vxe-button-group/index.js +2 -1
  50. package/lib/vxe-button-group/index.min.js +1 -1
  51. package/lib/vxe-calendar/index.js +2 -1
  52. package/lib/vxe-calendar/index.min.js +1 -1
  53. package/lib/vxe-card/index.js +2 -1
  54. package/lib/vxe-card/index.min.js +1 -1
  55. package/lib/vxe-carousel/index.js +2 -1
  56. package/lib/vxe-carousel/index.min.js +1 -1
  57. package/lib/vxe-carousel-item/index.js +2 -1
  58. package/lib/vxe-carousel-item/index.min.js +1 -1
  59. package/lib/vxe-cascader/index.js +2 -1
  60. package/lib/vxe-cascader/index.min.js +1 -1
  61. package/lib/vxe-checkbox/index.js +2 -1
  62. package/lib/vxe-checkbox/index.min.js +1 -1
  63. package/lib/vxe-checkbox-button/index.js +2 -1
  64. package/lib/vxe-checkbox-button/index.min.js +1 -1
  65. package/lib/vxe-checkbox-group/index.js +2 -1
  66. package/lib/vxe-checkbox-group/index.min.js +1 -1
  67. package/lib/vxe-col/index.js +2 -1
  68. package/lib/vxe-col/index.min.js +1 -1
  69. package/lib/vxe-collapse/index.js +2 -1
  70. package/lib/vxe-collapse/index.min.js +1 -1
  71. package/lib/vxe-collapse-pane/index.js +2 -1
  72. package/lib/vxe-collapse-pane/index.min.js +1 -1
  73. package/lib/vxe-color-picker/index.js +2 -1
  74. package/lib/vxe-color-picker/index.min.js +1 -1
  75. package/lib/vxe-context-menu/index.js +2 -1
  76. package/lib/vxe-context-menu/index.min.js +1 -1
  77. package/lib/vxe-countdown/index.js +2 -1
  78. package/lib/vxe-countdown/index.min.js +1 -1
  79. package/lib/vxe-date-panel/index.js +2 -1
  80. package/lib/vxe-date-panel/index.min.js +1 -1
  81. package/lib/vxe-date-picker/index.js +2 -1
  82. package/lib/vxe-date-picker/index.min.js +1 -1
  83. package/lib/vxe-date-range-picker/index.js +2 -1
  84. package/lib/vxe-date-range-picker/index.min.js +1 -1
  85. package/lib/vxe-drawer/index.js +2 -1
  86. package/lib/vxe-drawer/index.min.js +1 -1
  87. package/lib/vxe-empty/index.js +2 -1
  88. package/lib/vxe-empty/index.min.js +1 -1
  89. package/lib/vxe-form/index.js +2 -1
  90. package/lib/vxe-form/index.min.js +1 -1
  91. package/lib/vxe-form-gather/index.js +2 -1
  92. package/lib/vxe-form-gather/index.min.js +1 -1
  93. package/lib/vxe-form-group/index.js +2 -1
  94. package/lib/vxe-form-group/index.min.js +1 -1
  95. package/lib/vxe-form-item/index.js +2 -1
  96. package/lib/vxe-form-item/index.min.js +1 -1
  97. package/lib/vxe-icon/index.js +2 -1
  98. package/lib/vxe-icon/index.min.js +1 -1
  99. package/lib/vxe-icon-picker/index.js +2 -1
  100. package/lib/vxe-icon-picker/index.min.js +1 -1
  101. package/lib/vxe-image/index.js +2 -1
  102. package/lib/vxe-image/index.min.js +1 -1
  103. package/lib/vxe-image-group/index.js +2 -1
  104. package/lib/vxe-image-group/index.min.js +1 -1
  105. package/lib/vxe-image-preview/index.js +2 -1
  106. package/lib/vxe-image-preview/index.min.js +1 -1
  107. package/lib/vxe-input/index.js +2 -1
  108. package/lib/vxe-input/index.min.js +1 -1
  109. package/lib/vxe-layout-aside/index.js +2 -1
  110. package/lib/vxe-layout-aside/index.min.js +1 -1
  111. package/lib/vxe-layout-body/index.js +2 -1
  112. package/lib/vxe-layout-body/index.min.js +1 -1
  113. package/lib/vxe-layout-container/index.js +2 -1
  114. package/lib/vxe-layout-container/index.min.js +1 -1
  115. package/lib/vxe-layout-footer/index.js +2 -1
  116. package/lib/vxe-layout-footer/index.min.js +1 -1
  117. package/lib/vxe-layout-header/index.js +2 -1
  118. package/lib/vxe-layout-header/index.min.js +1 -1
  119. package/lib/vxe-link/index.js +2 -1
  120. package/lib/vxe-link/index.min.js +1 -1
  121. package/lib/vxe-list/index.js +2 -1
  122. package/lib/vxe-list/index.min.js +1 -1
  123. package/lib/vxe-loading/index.js +2 -1
  124. package/lib/vxe-loading/index.min.js +1 -1
  125. package/lib/vxe-mention/index.js +2 -1
  126. package/lib/vxe-mention/index.min.js +1 -1
  127. package/lib/vxe-menu/index.js +2 -1
  128. package/lib/vxe-menu/index.min.js +1 -1
  129. package/lib/vxe-modal/index.js +2 -1
  130. package/lib/vxe-modal/index.min.js +1 -1
  131. package/lib/vxe-notice-bar/index.js +2 -1
  132. package/lib/vxe-notice-bar/index.min.js +1 -1
  133. package/lib/vxe-number-input/index.js +2 -1
  134. package/lib/vxe-number-input/index.min.js +1 -1
  135. package/lib/vxe-optgroup/index.js +2 -1
  136. package/lib/vxe-optgroup/index.min.js +1 -1
  137. package/lib/vxe-option/index.js +2 -1
  138. package/lib/vxe-option/index.min.js +1 -1
  139. package/lib/vxe-pager/index.js +2 -1
  140. package/lib/vxe-pager/index.min.js +1 -1
  141. package/lib/vxe-password-input/index.js +2 -1
  142. package/lib/vxe-password-input/index.min.js +1 -1
  143. package/lib/vxe-print/index.js +2 -1
  144. package/lib/vxe-print/index.min.js +1 -1
  145. package/lib/vxe-print-page-break/index.js +2 -1
  146. package/lib/vxe-print-page-break/index.min.js +1 -1
  147. package/lib/vxe-pulldown/index.js +2 -1
  148. package/lib/vxe-pulldown/index.min.js +1 -1
  149. package/lib/vxe-radio/index.js +2 -1
  150. package/lib/vxe-radio/index.min.js +1 -1
  151. package/lib/vxe-radio-button/index.js +2 -1
  152. package/lib/vxe-radio-button/index.min.js +1 -1
  153. package/lib/vxe-radio-group/index.js +2 -1
  154. package/lib/vxe-radio-group/index.min.js +1 -1
  155. package/lib/vxe-rate/index.js +2 -1
  156. package/lib/vxe-rate/index.min.js +1 -1
  157. package/lib/vxe-result/index.js +2 -1
  158. package/lib/vxe-result/index.min.js +1 -1
  159. package/lib/vxe-row/index.js +2 -1
  160. package/lib/vxe-row/index.min.js +1 -1
  161. package/lib/vxe-segmented/index.js +2 -1
  162. package/lib/vxe-segmented/index.min.js +1 -1
  163. package/lib/vxe-select/index.js +2 -1
  164. package/lib/vxe-select/index.min.js +1 -1
  165. package/lib/vxe-slider/index.js +2 -1
  166. package/lib/vxe-slider/index.min.js +1 -1
  167. package/lib/vxe-split/index.js +2 -1
  168. package/lib/vxe-split/index.min.js +1 -1
  169. package/lib/vxe-split-pane/index.js +2 -1
  170. package/lib/vxe-split-pane/index.min.js +1 -1
  171. package/lib/vxe-splitter/index.js +2 -1
  172. package/lib/vxe-splitter/index.min.js +1 -1
  173. package/lib/vxe-splitter-panel/index.js +2 -1
  174. package/lib/vxe-splitter-panel/index.min.js +1 -1
  175. package/lib/vxe-steps/index.js +2 -1
  176. package/lib/vxe-steps/index.min.js +1 -1
  177. package/lib/vxe-switch/index.js +2 -1
  178. package/lib/vxe-switch/index.min.js +1 -1
  179. package/lib/vxe-tab-pane/index.js +2 -1
  180. package/lib/vxe-tab-pane/index.min.js +1 -1
  181. package/lib/vxe-table-select/index.js +2 -1
  182. package/lib/vxe-table-select/index.min.js +1 -1
  183. package/lib/vxe-tabs/index.js +2 -1
  184. package/lib/vxe-tabs/index.min.js +1 -1
  185. package/lib/vxe-tag/index.js +2 -1
  186. package/lib/vxe-tag/index.min.js +1 -1
  187. package/lib/vxe-tag/style/style.css +1 -3
  188. package/lib/vxe-tag/style/style.min.css +1 -1
  189. package/lib/vxe-text/index.js +2 -1
  190. package/lib/vxe-text/index.min.js +1 -1
  191. package/lib/vxe-text-ellipsis/index.js +2 -1
  192. package/lib/vxe-text-ellipsis/index.min.js +1 -1
  193. package/lib/vxe-textarea/index.js +2 -1
  194. package/lib/vxe-textarea/index.min.js +1 -1
  195. package/lib/vxe-timeline/index.js +2 -1
  196. package/lib/vxe-timeline/index.min.js +1 -1
  197. package/lib/vxe-timeline-item/index.js +2 -1
  198. package/lib/vxe-timeline-item/index.min.js +1 -1
  199. package/lib/vxe-tip/index.js +2 -1
  200. package/lib/vxe-tip/index.min.js +1 -1
  201. package/lib/vxe-tooltip/index.js +2 -1
  202. package/lib/vxe-tooltip/index.min.js +1 -1
  203. package/lib/vxe-tour/index.js +2 -1
  204. package/lib/vxe-tour/index.min.js +1 -1
  205. package/lib/vxe-tree/index.js +2 -1
  206. package/lib/vxe-tree/index.min.js +1 -1
  207. package/lib/vxe-tree-select/index.js +2 -1
  208. package/lib/vxe-tree-select/index.min.js +1 -1
  209. package/lib/vxe-u-i/index.js +2 -1
  210. package/lib/vxe-u-i/index.min.js +1 -1
  211. package/lib/vxe-ui/index.js +2 -1
  212. package/lib/vxe-ui/index.min.js +1 -1
  213. package/lib/vxe-upload/index.js +2 -1
  214. package/lib/vxe-upload/index.min.js +1 -1
  215. package/lib/vxe-watermark/index.js +2 -1
  216. package/lib/vxe-watermark/index.min.js +1 -1
  217. package/package.json +89 -89
  218. package/packages/alert/index.ts +16 -16
  219. package/packages/alert/src/alert.ts +106 -106
  220. package/packages/anchor/index.ts +16 -16
  221. package/packages/anchor/src/anchor-link.ts +158 -158
  222. package/packages/anchor/src/anchor.ts +267 -267
  223. package/packages/anchor/src/util.ts +23 -23
  224. package/packages/anchor-link/index.ts +16 -16
  225. package/packages/avatar/index.ts +16 -16
  226. package/packages/avatar/src/avatar.ts +141 -141
  227. package/packages/backtop/index.ts +16 -16
  228. package/packages/backtop/src/backtop.ts +330 -330
  229. package/packages/badge/index.ts +16 -16
  230. package/packages/badge/src/badge.ts +87 -87
  231. package/packages/breadcrumb/index.ts +16 -16
  232. package/packages/breadcrumb/src/breadcrumb-item.ts +118 -118
  233. package/packages/breadcrumb/src/breadcrumb.ts +89 -89
  234. package/packages/breadcrumb-item/index.ts +16 -16
  235. package/packages/button/index.ts +16 -16
  236. package/packages/button/src/button-group.ts +113 -113
  237. package/packages/button/src/button.ts +955 -955
  238. package/packages/button-group/index.ts +16 -16
  239. package/packages/calendar/index.ts +16 -16
  240. package/packages/calendar/src/calendar.ts +1527 -1527
  241. package/packages/card/index.ts +16 -16
  242. package/packages/card/src/card.ts +162 -162
  243. package/packages/carousel/index.ts +16 -16
  244. package/packages/carousel/src/carousel-item.ts +117 -117
  245. package/packages/carousel/src/carousel.ts +460 -460
  246. package/packages/carousel/src/util.ts +21 -21
  247. package/packages/carousel-item/index.ts +16 -16
  248. package/packages/cascader/index.ts +16 -16
  249. package/packages/cascader/src/cascader.ts +941 -941
  250. package/packages/checkbox/index.ts +16 -16
  251. package/packages/checkbox/src/button.ts +185 -185
  252. package/packages/checkbox/src/checkbox.ts +189 -189
  253. package/packages/checkbox/src/group.ts +259 -259
  254. package/packages/checkbox-button/index.ts +16 -16
  255. package/packages/checkbox-group/index.ts +16 -16
  256. package/packages/col/index.ts +16 -16
  257. package/packages/collapse/index.ts +16 -16
  258. package/packages/collapse/src/collapse-pane.ts +136 -136
  259. package/packages/collapse/src/collapse.ts +259 -259
  260. package/packages/collapse/src/util.ts +21 -21
  261. package/packages/collapse-pane/index.ts +16 -16
  262. package/packages/color-picker/index.ts +16 -16
  263. package/packages/color-picker/src/color-picker.ts +1277 -1277
  264. package/packages/color-picker/src/util.ts +198 -198
  265. package/packages/components.ts +307 -307
  266. package/packages/context-menu/index.ts +54 -54
  267. package/packages/context-menu/src/context-menu.ts +709 -709
  268. package/packages/countdown/index.ts +16 -16
  269. package/packages/countdown/src/countdown.ts +276 -276
  270. package/packages/date-panel/index.ts +16 -16
  271. package/packages/date-panel/src/date-panel.ts +2024 -2024
  272. package/packages/date-panel/src/util.ts +244 -244
  273. package/packages/date-picker/index.ts +17 -17
  274. package/packages/date-picker/src/date-picker.ts +1238 -1238
  275. package/packages/date-range-picker/index.ts +16 -16
  276. package/packages/date-range-picker/src/date-range-picker.ts +1466 -1466
  277. package/packages/drawer/index.ts +87 -87
  278. package/packages/drawer/src/drawer.ts +767 -767
  279. package/packages/dynamics/index.ts +125 -125
  280. package/packages/empty/index.ts +16 -16
  281. package/packages/empty/src/empty.ts +80 -80
  282. package/packages/form/index.ts +16 -16
  283. package/packages/form/render/index.ts +617 -617
  284. package/packages/form/src/form-config-item.ts +86 -86
  285. package/packages/form/src/form-group.ts +125 -125
  286. package/packages/form/src/form-item.ts +217 -217
  287. package/packages/form/src/form.ts +1032 -1032
  288. package/packages/form/src/itemInfo.ts +80 -80
  289. package/packages/form/src/render.ts +398 -398
  290. package/packages/form/src/util.ts +92 -92
  291. package/packages/form-gather/index.ts +18 -18
  292. package/packages/form-group/index.ts +16 -16
  293. package/packages/form-item/index.ts +16 -16
  294. package/packages/icon/index.ts +16 -16
  295. package/packages/icon/src/icon.ts +75 -75
  296. package/packages/icon-picker/index.ts +16 -16
  297. package/packages/icon-picker/src/icon-picker.ts +752 -752
  298. package/packages/image/index.ts +16 -16
  299. package/packages/image/src/group.ts +162 -162
  300. package/packages/image/src/image.ts +286 -286
  301. package/packages/image/src/preview.ts +737 -737
  302. package/packages/image/src/util.ts +62 -62
  303. package/packages/image-group/index.ts +16 -16
  304. package/packages/image-preview/index.ts +19 -19
  305. package/packages/index.ts +8 -8
  306. package/packages/input/index.ts +16 -16
  307. package/packages/input/src/input.ts +3187 -3187
  308. package/packages/language/ar-EG.ts +832 -832
  309. package/packages/language/de-DE.ts +832 -832
  310. package/packages/language/en-US.ts +832 -832
  311. package/packages/language/es-ES.ts +832 -832
  312. package/packages/language/fr-FR.ts +832 -832
  313. package/packages/language/hu-HU.ts +832 -832
  314. package/packages/language/hy-AM.ts +832 -832
  315. package/packages/language/id-ID.ts +832 -832
  316. package/packages/language/it-IT.ts +832 -832
  317. package/packages/language/ja-JP.ts +832 -832
  318. package/packages/language/ko-KR.ts +832 -832
  319. package/packages/language/ms-MY.ts +832 -832
  320. package/packages/language/nb-NO.ts +832 -832
  321. package/packages/language/pt-BR.ts +832 -832
  322. package/packages/language/ru-RU.ts +832 -832
  323. package/packages/language/th-TH.ts +832 -832
  324. package/packages/language/ug-CN.ts +832 -832
  325. package/packages/language/uk-UA.ts +832 -832
  326. package/packages/language/uz-UZ.ts +832 -832
  327. package/packages/language/vi-VN.ts +832 -832
  328. package/packages/language/zh-CHT.ts +832 -832
  329. package/packages/language/zh-CN.ts +832 -832
  330. package/packages/language/zh-HK.ts +3 -3
  331. package/packages/language/zh-MO.ts +3 -3
  332. package/packages/language/zh-TC.ts +3 -3
  333. package/packages/language/zh-TW.ts +3 -3
  334. package/packages/layout-aside/index.ts +16 -16
  335. package/packages/layout-aside/src/layout-aside.ts +115 -115
  336. package/packages/layout-body/index.ts +16 -16
  337. package/packages/layout-body/src/layout-body.ts +137 -137
  338. package/packages/layout-container/index.ts +16 -16
  339. package/packages/layout-container/src/layout-container.ts +65 -65
  340. package/packages/layout-footer/index.ts +16 -16
  341. package/packages/layout-footer/src/layout-footer.ts +53 -53
  342. package/packages/layout-header/index.ts +16 -16
  343. package/packages/layout-header/src/layout-header.ts +49 -49
  344. package/packages/link/index.ts +16 -16
  345. package/packages/link/src/link.ts +153 -153
  346. package/packages/list/index.ts +16 -16
  347. package/packages/list/src/list.ts +492 -492
  348. package/packages/loading/index.ts +34 -34
  349. package/packages/loading/src/loading.ts +162 -162
  350. package/packages/mention/index.ts +16 -16
  351. package/packages/mention/src/mention.ts +54 -54
  352. package/packages/menu/index.ts +16 -16
  353. package/packages/menu/src/menu.ts +632 -632
  354. package/packages/modal/index.ts +150 -150
  355. package/packages/modal/src/modal.ts +1657 -1657
  356. package/packages/notice-bar/index.ts +16 -16
  357. package/packages/notice-bar/src/notice-bar.ts +182 -182
  358. package/packages/number-input/index.ts +16 -16
  359. package/packages/number-input/src/number-input.ts +1255 -1255
  360. package/packages/number-input/src/util.ts +12 -12
  361. package/packages/optgroup/index.ts +16 -16
  362. package/packages/option/index.ts +16 -16
  363. package/packages/pager/index.ts +16 -16
  364. package/packages/pager/src/pager.ts +913 -913
  365. package/packages/password-input/index.ts +16 -16
  366. package/packages/password-input/src/password-input.ts +466 -466
  367. package/packages/print/index.ts +18 -18
  368. package/packages/print/src/page-break.ts +78 -78
  369. package/packages/print/src/print.ts +266 -266
  370. package/packages/print/src/util.ts +284 -284
  371. package/packages/print-page-break/index.ts +14 -14
  372. package/packages/pulldown/index.ts +16 -16
  373. package/packages/pulldown/src/pulldown.ts +532 -532
  374. package/packages/radio/index.ts +16 -16
  375. package/packages/radio/src/button.ts +221 -221
  376. package/packages/radio/src/group.ts +252 -252
  377. package/packages/radio/src/radio.ts +228 -228
  378. package/packages/radio-button/index.ts +16 -16
  379. package/packages/radio-group/index.ts +16 -16
  380. package/packages/rate/index.ts +16 -16
  381. package/packages/rate/src/rate.ts +199 -199
  382. package/packages/result/index.ts +16 -16
  383. package/packages/result/src/result.ts +93 -93
  384. package/packages/row/index.ts +16 -16
  385. package/packages/row/src/col.ts +130 -130
  386. package/packages/row/src/row.ts +106 -106
  387. package/packages/segmented/index.ts +16 -16
  388. package/packages/segmented/src/segmented.ts +281 -281
  389. package/packages/select/index.ts +16 -16
  390. package/packages/select/src/optgroup.ts +107 -107
  391. package/packages/select/src/option-info.ts +20 -20
  392. package/packages/select/src/option.ts +103 -103
  393. package/packages/select/src/select.ts +2000 -2000
  394. package/packages/select/src/util.ts +47 -47
  395. package/packages/slider/index.ts +16 -16
  396. package/packages/slider/src/slider.ts +332 -332
  397. package/packages/split/index.ts +16 -16
  398. package/packages/split-pane/index.ts +17 -17
  399. package/packages/splitter/index.ts +16 -16
  400. package/packages/splitter/src/splitter-panel.ts +171 -171
  401. package/packages/splitter/src/splitter.ts +1032 -1032
  402. package/packages/splitter/src/util.ts +21 -21
  403. package/packages/splitter-panel/index.ts +16 -16
  404. package/packages/steps/index.ts +16 -16
  405. package/packages/steps/src/steps.ts +57 -57
  406. package/packages/switch/index.ts +16 -16
  407. package/packages/switch/src/switch.ts +279 -279
  408. package/packages/tab-pane/index.ts +16 -16
  409. package/packages/table-select/index.ts +16 -16
  410. package/packages/table-select/src/table-select.ts +903 -903
  411. package/packages/tabs/index.ts +16 -16
  412. package/packages/tabs/src/tab-pane.ts +137 -137
  413. package/packages/tabs/src/tabs.ts +1014 -1014
  414. package/packages/tabs/src/util.ts +21 -21
  415. package/packages/tag/index.ts +16 -16
  416. package/packages/tag/src/tag.ts +195 -195
  417. package/packages/text/index.ts +16 -16
  418. package/packages/text/src/text.ts +267 -267
  419. package/packages/text-ellipsis/index.ts +16 -16
  420. package/packages/text-ellipsis/src/text-ellipsis.ts +291 -291
  421. package/packages/textarea/index.ts +16 -16
  422. package/packages/textarea/src/textarea.ts +436 -436
  423. package/packages/timeline/index.ts +16 -16
  424. package/packages/timeline/src/timeline-item.ts +41 -41
  425. package/packages/timeline/src/timeline.ts +54 -54
  426. package/packages/timeline-item/index.ts +16 -16
  427. package/packages/tip/index.ts +19 -19
  428. package/packages/tip/src/tip.ts +112 -112
  429. package/packages/tooltip/index.ts +16 -16
  430. package/packages/tooltip/src/tooltip.ts +641 -641
  431. package/packages/tour/index.ts +16 -16
  432. package/packages/tour/src/tour.ts +54 -54
  433. package/packages/tree/index.ts +16 -16
  434. package/packages/tree/src/store.ts +15 -15
  435. package/packages/tree/src/tree.ts +3080 -3080
  436. package/packages/tree/src/util.ts +44 -44
  437. package/packages/tree-select/index.ts +16 -16
  438. package/packages/tree-select/src/tree-select.ts +1115 -1115
  439. package/packages/ui/index.ts +695 -695
  440. package/packages/ui/src/anime.ts +52 -52
  441. package/packages/ui/src/comp.ts +3 -3
  442. package/packages/ui/src/dom.ts +263 -263
  443. package/packages/ui/src/log.ts +6 -6
  444. package/packages/ui/src/utils.ts +49 -49
  445. package/packages/ui/src/vn.ts +60 -60
  446. package/packages/upload/index.ts +20 -20
  447. package/packages/upload/src/upload.ts +2127 -2127
  448. package/packages/upload/src/util.ts +109 -109
  449. package/packages/vxe-u-i/index.ts +4 -4
  450. package/packages/watermark/index.ts +31 -31
  451. package/packages/watermark/src/util.ts +176 -176
  452. package/packages/watermark/src/watermark.ts +166 -166
  453. package/styles/all.scss +90 -90
  454. package/styles/base.scss +16 -16
  455. package/styles/components/alert.scss +101 -101
  456. package/styles/components/anchor.scss +44 -44
  457. package/styles/components/avatar.scss +115 -115
  458. package/styles/components/backtop.scss +82 -82
  459. package/styles/components/badge.scss +45 -45
  460. package/styles/components/breadcrumb.scss +29 -29
  461. package/styles/components/button-group.scss +30 -30
  462. package/styles/components/button.scss +415 -415
  463. package/styles/components/calendar.scss +471 -471
  464. package/styles/components/card.scss +121 -121
  465. package/styles/components/carousel.scss +184 -184
  466. package/styles/components/cascader.scss +140 -140
  467. package/styles/components/checkbox-button.scss +57 -57
  468. package/styles/components/checkbox.scss +81 -81
  469. package/styles/components/collapse.scss +56 -56
  470. package/styles/components/color-picker.scss +409 -409
  471. package/styles/components/context-menu.scss +102 -102
  472. package/styles/components/countdown.scss +35 -35
  473. package/styles/components/date-panel.scss +505 -505
  474. package/styles/components/date-picker.scss +247 -247
  475. package/styles/components/date-range-picker.scss +252 -252
  476. package/styles/components/drawer.scss +298 -298
  477. package/styles/components/empty.scss +79 -79
  478. package/styles/components/form.scss +668 -668
  479. package/styles/components/icon-picker.scss +211 -211
  480. package/styles/components/icon.scss +1044 -1044
  481. package/styles/components/image-group.scss +2 -2
  482. package/styles/components/image-preview.scss +215 -215
  483. package/styles/components/image.scss +16 -16
  484. package/styles/components/input.scss +846 -846
  485. package/styles/components/layout-aside.scss +22 -22
  486. package/styles/components/layout-body.scss +14 -14
  487. package/styles/components/layout-container.scss +13 -13
  488. package/styles/components/layout-footer.scss +14 -14
  489. package/styles/components/layout-header.scss +11 -11
  490. package/styles/components/link.scss +115 -115
  491. package/styles/components/list.scss +40 -40
  492. package/styles/components/loading.scss +137 -137
  493. package/styles/components/menu.scss +150 -150
  494. package/styles/components/modal.scss +480 -480
  495. package/styles/components/notice-bar.scss +91 -91
  496. package/styles/components/number-input.scss +283 -283
  497. package/styles/components/old-icon.scss +4 -4
  498. package/styles/components/pager.scss +282 -282
  499. package/styles/components/password-input.scss +374 -374
  500. package/styles/components/print.scss +3 -3
  501. package/styles/components/pulldown.scss +75 -75
  502. package/styles/components/radio-button.scss +57 -57
  503. package/styles/components/radio.scss +79 -79
  504. package/styles/components/rate.scss +76 -76
  505. package/styles/components/result.scss +91 -91
  506. package/styles/components/row.scss +69 -69
  507. package/styles/components/segmented.scss +215 -215
  508. package/styles/components/select.scss +244 -244
  509. package/styles/components/slider.scss +139 -139
  510. package/styles/components/split.scss +1 -1
  511. package/styles/components/splitter.scss +318 -318
  512. package/styles/components/switch.scss +128 -128
  513. package/styles/components/table-select.scss +105 -105
  514. package/styles/components/tabs.scss +745 -745
  515. package/styles/components/tag.scss +184 -184
  516. package/styles/components/text-ellipsis.scss +130 -130
  517. package/styles/components/text.scss +123 -123
  518. package/styles/components/textarea.scss +106 -106
  519. package/styles/components/tip.scss +97 -97
  520. package/styles/components/tooltip.scss +140 -140
  521. package/styles/components/tree-select.scss +166 -166
  522. package/styles/components/tree.scss +294 -294
  523. package/styles/components/upload.scss +497 -497
  524. package/styles/components/watermark.scss +26 -26
  525. package/styles/helpers/baseMixin.scss +95 -95
  526. package/styles/helpers/baseVar.scss +3 -3
  527. package/styles/helpers/placement.scss +38 -38
  528. package/styles/theme/base.scss +214 -214
  529. package/styles/theme/dark.scss +119 -119
  530. package/styles/theme/light.scss +118 -118
  531. package/styles/variable.scss +111 -111
  532. package/types/all.d.ts +328 -328
  533. package/types/components/alert.d.ts +80 -80
  534. package/types/components/anchor-link.d.ts +84 -84
  535. package/types/components/anchor.d.ts +84 -84
  536. package/types/components/avatar.d.ts +81 -81
  537. package/types/components/backtop.d.ts +115 -115
  538. package/types/components/badge.d.ts +69 -69
  539. package/types/components/breadcrumb-item.d.ts +73 -73
  540. package/types/components/breadcrumb.d.ts +80 -80
  541. package/types/components/button-group.d.ts +113 -113
  542. package/types/components/button.d.ts +314 -314
  543. package/types/components/calendar.d.ts +254 -254
  544. package/types/components/card.d.ts +86 -86
  545. package/types/components/carousel-item.d.ts +68 -68
  546. package/types/components/carousel.d.ts +126 -126
  547. package/types/components/cascader.d.ts +242 -242
  548. package/types/components/checkbox-button.d.ts +93 -93
  549. package/types/components/checkbox-group.d.ts +135 -135
  550. package/types/components/checkbox.d.ts +115 -115
  551. package/types/components/col.d.ts +73 -73
  552. package/types/components/colgroup.d.ts +131 -131
  553. package/types/components/collapse-pane.d.ts +82 -82
  554. package/types/components/collapse.d.ts +115 -115
  555. package/types/components/color-picker.d.ts +127 -127
  556. package/types/components/column.d.ts +852 -852
  557. package/types/components/context-menu.d.ts +300 -300
  558. package/types/components/countdown.d.ts +99 -99
  559. package/types/components/date-panel.d.ts +269 -269
  560. package/types/components/date-picker.d.ts +302 -302
  561. package/types/components/date-range-picker.d.ts +316 -316
  562. package/types/components/drawer.d.ts +295 -295
  563. package/types/components/empty.d.ts +71 -71
  564. package/types/components/flow-design.d.ts +78 -78
  565. package/types/components/flow-view.d.ts +78 -78
  566. package/types/components/form-design.d.ts +364 -364
  567. package/types/components/form-gather.d.ts +72 -72
  568. package/types/components/form-group.d.ts +63 -63
  569. package/types/components/form-item.d.ts +405 -405
  570. package/types/components/form-view.d.ts +175 -175
  571. package/types/components/form.d.ts +463 -463
  572. package/types/components/gantt-module/gantt-view.d.ts +170 -170
  573. package/types/components/gantt-module/index.d.ts +1 -1
  574. package/types/components/gantt-plugins/extend-gantt-chart.d.ts +114 -114
  575. package/types/components/gantt-plugins/index.d.ts +1 -1
  576. package/types/components/gantt.d.ts +1129 -1129
  577. package/types/components/grid.d.ts +1030 -1030
  578. package/types/components/icon-picker.d.ts +181 -181
  579. package/types/components/icon.d.ts +80 -80
  580. package/types/components/image-group.d.ts +120 -120
  581. package/types/components/image-preview.d.ts +159 -159
  582. package/types/components/image.d.ts +158 -158
  583. package/types/components/input.d.ts +425 -425
  584. package/types/components/layout-aside.d.ts +73 -73
  585. package/types/components/layout-body.d.ts +84 -84
  586. package/types/components/layout-container.d.ts +66 -66
  587. package/types/components/layout-footer.d.ts +66 -66
  588. package/types/components/layout-header.d.ts +64 -64
  589. package/types/components/link.d.ts +104 -104
  590. package/types/components/list-design.d.ts +177 -177
  591. package/types/components/list-view.d.ts +190 -190
  592. package/types/components/list.d.ts +196 -196
  593. package/types/components/loading.d.ts +96 -96
  594. package/types/components/mention.d.ts +70 -70
  595. package/types/components/menu.d.ts +203 -203
  596. package/types/components/modal.d.ts +540 -540
  597. package/types/components/notice-bar.d.ts +95 -95
  598. package/types/components/number-input.d.ts +300 -300
  599. package/types/components/optgroup.d.ts +81 -81
  600. package/types/components/option.d.ts +95 -95
  601. package/types/components/pager.d.ts +322 -322
  602. package/types/components/password-input.d.ts +129 -129
  603. package/types/components/print-page-break.d.ts +62 -62
  604. package/types/components/print.d.ts +199 -199
  605. package/types/components/pulldown.d.ts +222 -222
  606. package/types/components/radio-button.d.ts +104 -104
  607. package/types/components/radio-group.d.ts +136 -136
  608. package/types/components/radio.d.ts +121 -121
  609. package/types/components/rate.d.ts +75 -75
  610. package/types/components/result.d.ts +77 -77
  611. package/types/components/row.d.ts +72 -72
  612. package/types/components/segmented.d.ts +117 -117
  613. package/types/components/select.d.ts +515 -515
  614. package/types/components/slider.d.ts +117 -117
  615. package/types/components/split-pane.d.ts +135 -135
  616. package/types/components/split.d.ts +318 -318
  617. package/types/components/splitter-panel.d.ts +98 -98
  618. package/types/components/splitter.d.ts +283 -283
  619. package/types/components/steps.d.ts +61 -61
  620. package/types/components/switch.d.ts +124 -124
  621. package/types/components/tab-pane.d.ts +107 -107
  622. package/types/components/table-module/custom.d.ts +111 -111
  623. package/types/components/table-module/edit.d.ts +244 -244
  624. package/types/components/table-module/export.d.ts +96 -96
  625. package/types/components/table-module/filter.d.ts +140 -140
  626. package/types/components/table-module/index.d.ts +7 -7
  627. package/types/components/table-module/keyboard.d.ts +26 -26
  628. package/types/components/table-module/menu.d.ts +26 -26
  629. package/types/components/table-module/validator.d.ts +53 -53
  630. package/types/components/table-plugins/extend-cell-area.d.ts +734 -734
  631. package/types/components/table-plugins/extend-pivot-table.d.ts +62 -62
  632. package/types/components/table-plugins/filters-combination.d.ts +15 -15
  633. package/types/components/table-plugins/filters-complex-input.d.ts +9 -9
  634. package/types/components/table-plugins/index.d.ts +4 -4
  635. package/types/components/table-select.d.ts +212 -212
  636. package/types/components/table.d.ts +7222 -7206
  637. package/types/components/tabs.d.ts +324 -324
  638. package/types/components/tag.d.ts +107 -107
  639. package/types/components/text-ellipsis.d.ts +105 -105
  640. package/types/components/text.d.ts +115 -115
  641. package/types/components/textarea.d.ts +237 -237
  642. package/types/components/timeline-item.d.ts +68 -68
  643. package/types/components/timeline.d.ts +70 -70
  644. package/types/components/tip.d.ts +76 -76
  645. package/types/components/toolbar.d.ts +329 -329
  646. package/types/components/tooltip.d.ts +165 -165
  647. package/types/components/tour.d.ts +70 -70
  648. package/types/components/tree-select.d.ts +295 -295
  649. package/types/components/tree.d.ts +826 -826
  650. package/types/components/upload.d.ts +432 -432
  651. package/types/components/watermark.d.ts +113 -113
  652. package/types/index.d.ts +4 -4
  653. package/types/ui/commands.d.ts +57 -57
  654. package/types/ui/formats.d.ts +62 -62
  655. package/types/ui/global-config.d.ts +254 -254
  656. package/types/ui/global-icon.d.ts +292 -292
  657. package/types/ui/hooks.d.ts +11 -11
  658. package/types/ui/index.d.ts +95 -95
  659. package/types/ui/interceptor.d.ts +54 -54
  660. package/types/ui/menus.d.ts +77 -77
  661. package/types/ui/renderer.d.ts +1042 -1042
  662. package/types/ui/validators.d.ts +38 -38
  663. /package/es/icon/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  664. /package/es/icon/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  665. /package/es/icon/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  666. /package/es/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  667. /package/es/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  668. /package/es/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  669. /package/lib/icon/style/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  670. /package/lib/icon/style/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  671. /package/lib/icon/style/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
  672. /package/lib/{iconfont.1773972997530.ttf → iconfont.1774240783948.ttf} +0 -0
  673. /package/lib/{iconfont.1773972997530.woff → iconfont.1774240783948.woff} +0 -0
  674. /package/lib/{iconfont.1773972997530.woff2 → iconfont.1774240783948.woff2} +0 -0
@@ -1,1032 +1,1032 @@
1
- import { PropType, CreateElement, VNode } from 'vue'
2
- import { defineVxeComponent } from '../../ui/src/comp'
3
- import XEUtils from 'xe-utils'
4
- import { getConfig, validators, renderer, createEvent, globalMixins, globalEvents } from '../../ui'
5
- import { eqEmptyValue, getFuncText, isEnableConf } from '../../ui/src/utils'
6
- import { scrollToView } from '../../ui/src/dom'
7
- import { createItem, handleFieldOrItem, isHiddenItem, isActiveItem } from './util'
8
- import VxeTooltipComponent from '../../tooltip'
9
- import VxeFormConfigItem from './form-config-item'
10
- import VxeLoadingComponent from '../../loading'
11
- import { getSlotVNs } from '../../ui/src/vn'
12
- import { warnLog, errLog } from '../../ui/src/log'
13
-
14
- import '../render'
15
-
16
- import type { VxeFormPropTypes, VxeFormEmits, VxeComponentSizeType, ValueOf, FormReactData, VxeFormDefines, VxeFormItemPropTypes, FormInternalData, VxeTooltipConstructor } from '../../../types'
17
- import type { VxeGridConstructor, VxeGridPrivateMethods } from '../../../types/components/grid'
18
-
19
- class Rule {
20
- constructor (rule: any) {
21
- Object.assign(this, {
22
- $options: rule,
23
- required: rule.required,
24
- min: rule.min,
25
- max: rule.min,
26
- type: rule.type,
27
- pattern: rule.pattern,
28
- validator: rule.validator,
29
- trigger: rule.trigger,
30
- maxWidth: rule.maxWidth
31
- })
32
- }
33
-
34
- get content () {
35
- return getFuncText(this.$options.content || this.$options.message)
36
- }
37
-
38
- get message () {
39
- return this.content
40
- }
41
-
42
- [key: string]: any
43
- }
44
-
45
- // 如果存在 pattern,判断正则
46
- function validREValue (pattern: string | RegExp | undefined, val: string) {
47
- if (pattern && !(XEUtils.isRegExp(pattern) ? pattern : new RegExp(pattern)).test(val)) {
48
- return false
49
- }
50
- return true
51
- }
52
-
53
- // 如果存在 max,判断最大值
54
- function validMaxValue (max: string | number | undefined, num: number) {
55
- if (!XEUtils.eqNull(max) && num > XEUtils.toNumber(max)) {
56
- return false
57
- }
58
- return true
59
- }
60
-
61
- // 如果存在 min,判断最小值
62
- function validMinValue (min: string | number | undefined, num: number) {
63
- if (!XEUtils.eqNull(min) && num < XEUtils.toNumber(min)) {
64
- return false
65
- }
66
- return true
67
- }
68
-
69
- function validRuleValue (rule: VxeFormDefines.FormRule, val: any, required: boolean | undefined) {
70
- const { type, min, max, pattern } = rule
71
- const isArrType = type === 'array'
72
- const isNumType = type === 'number'
73
- const isStrType = type === 'string'
74
- const strVal = `${val}`
75
- if (!validREValue(pattern, strVal)) {
76
- return false
77
- }
78
- if (isArrType) {
79
- if (!XEUtils.isArray(val)) {
80
- return false
81
- }
82
- if (required) {
83
- if (!val.length) {
84
- return false
85
- }
86
- }
87
- if (!validMinValue(min, val.length)) {
88
- return false
89
- }
90
- if (!validMaxValue(max, val.length)) {
91
- return false
92
- }
93
- } else if (isNumType) {
94
- const numVal = Number(val)
95
- if (isNaN(numVal)) {
96
- return false
97
- }
98
- if (!validMinValue(min, numVal)) {
99
- return false
100
- }
101
- if (!validMaxValue(max, numVal)) {
102
- return false
103
- }
104
- } else {
105
- if (isStrType) {
106
- if (!XEUtils.isString(val)) {
107
- return false
108
- }
109
- }
110
- if (required) {
111
- if (!strVal) {
112
- return false
113
- }
114
- }
115
- if (!validMinValue(min, strVal.length)) {
116
- return false
117
- }
118
- if (!validMaxValue(max, strVal.length)) {
119
- return false
120
- }
121
- }
122
- return true
123
- }
124
-
125
- function checkRuleStatus (rule: VxeFormDefines.FormRule, data: any, val: any) {
126
- const { required, field } = rule
127
- const currVal = field ? XEUtils.get(data, field) : val
128
- const isEmptyVal = XEUtils.isArray(currVal) ? !currVal.length : eqEmptyValue(currVal)
129
- if (required) {
130
- if (isEmptyVal) {
131
- return false
132
- }
133
- if (!validRuleValue(rule, currVal, required)) {
134
- return false
135
- }
136
- } else {
137
- if (!isEmptyVal) {
138
- if (!validRuleValue(rule, currVal, required)) {
139
- return false
140
- }
141
- }
142
- }
143
- return true
144
- }
145
-
146
- function createInternalData (): FormInternalData {
147
- return {
148
- meTimeout: undefined,
149
- stTimeout: undefined,
150
- tooltipStore: {
151
- item: null,
152
- visible: false
153
- },
154
- itemFormatCache: {}
155
- }
156
- }
157
-
158
- export default /* define-vxe-component start */ defineVxeComponent({
159
- name: 'VxeForm',
160
- mixins: [
161
- globalMixins.sizeMixin
162
- ],
163
- props: {
164
- collapseStatus: {
165
- type: Boolean as PropType<VxeFormPropTypes.CollapseStatus>,
166
- default: true
167
- },
168
- loading: Boolean as PropType<VxeFormPropTypes.Loading>,
169
- data: Object as PropType<VxeFormPropTypes.Data>,
170
- size: {
171
- type: String as PropType<VxeFormPropTypes.Size>,
172
- default: () => getConfig().form.size || getConfig().size
173
- },
174
- span: {
175
- type: [String, Number] as PropType<VxeFormPropTypes.Span>,
176
- default: () => getConfig().form.span
177
- },
178
- align: {
179
- type: String as PropType<VxeFormPropTypes.Align>,
180
- default: () => getConfig().form.align
181
- },
182
- verticalAlign: {
183
- type: String as PropType<VxeFormPropTypes.VerticalAlign>,
184
- default: () => getConfig().form.verticalAlign
185
- },
186
- border: {
187
- type: Boolean as PropType<VxeFormPropTypes.Border>,
188
- default: () => getConfig().form.border
189
- },
190
- titleBackground: {
191
- type: Boolean as PropType<VxeFormPropTypes.TitleBackground>,
192
- default: () => getConfig().form.titleBackground
193
- },
194
- titleBold: {
195
- type: Boolean as PropType<VxeFormPropTypes.TitleBold>,
196
- default: () => getConfig().form.titleBold
197
- },
198
- titleAlign: {
199
- type: String as PropType<VxeFormPropTypes.TitleAlign>,
200
- default: () => getConfig().form.titleAlign
201
- },
202
- titleWidth: {
203
- type: [String, Number] as PropType<VxeFormPropTypes.TitleWidth>,
204
- default: () => getConfig().form.titleWidth
205
- },
206
- titleColon: {
207
- type: Boolean as PropType<VxeFormPropTypes.TitleColon>,
208
- default: () => getConfig().form.titleColon
209
- },
210
- titleAsterisk: {
211
- type: Boolean as PropType<VxeFormPropTypes.TitleAsterisk>,
212
- default: () => getConfig().form.titleAsterisk
213
- },
214
- titleOverflow: {
215
- type: [Boolean, String] as PropType<VxeFormPropTypes.TitleOverflow>,
216
- default: () => getConfig().form.titleOverflow
217
- },
218
- vertical: {
219
- type: Boolean as PropType<VxeFormPropTypes.Vertical>,
220
- default: () => getConfig().form.vertical
221
- },
222
- padding: {
223
- type: Boolean as PropType<VxeFormPropTypes.Padding>,
224
- default: () => getConfig().form.padding
225
- },
226
- className: [String, Function] as PropType<VxeFormPropTypes.ClassName>,
227
- readonly: Boolean as PropType<VxeFormPropTypes.Readonly>,
228
- disabled: Boolean as PropType<VxeFormPropTypes.Disabled>,
229
- items: Array as PropType<VxeFormPropTypes.Items>,
230
- rules: Object as PropType<VxeFormPropTypes.Rules>,
231
- preventSubmit: {
232
- type: Boolean as PropType<VxeFormPropTypes.PreventSubmit>,
233
- default: () => getConfig().form.preventSubmit
234
- },
235
- validConfig: Object as PropType<VxeFormPropTypes.ValidConfig>,
236
- tooltipConfig: Object as PropType<VxeFormPropTypes.TooltipConfig>,
237
- collapseConfig: Object as PropType<VxeFormPropTypes.CollapseConfig>,
238
- customLayout: {
239
- type: Boolean as PropType<VxeFormPropTypes.CustomLayout>,
240
- default: () => getConfig().form.customLayout
241
- },
242
- params: Object as PropType<VxeFormPropTypes.Params>
243
- },
244
- inject: {
245
- $xeGrid: {
246
- default: null
247
- }
248
- },
249
- provide () {
250
- const $xeForm = this
251
- return {
252
- $xeForm,
253
- xeFormItemInfo: null,
254
- $xeFormGroup: null,
255
- $xeFormItem: null
256
- }
257
- },
258
- data () {
259
- const xID = XEUtils.uniqueId()
260
- const reactData: FormReactData = {
261
- collapseAll: false,
262
- staticItems: [],
263
- formItems: [],
264
- itemWidth: 0
265
- }
266
- const internalData = createInternalData()
267
- return {
268
- xID,
269
- reactData,
270
- internalData,
271
-
272
- recalcFlag: 0
273
- }
274
- },
275
- computed: {
276
- ...({} as {
277
- computeSize(): VxeComponentSizeType
278
- $xeGrid(): (VxeGridConstructor & VxeGridPrivateMethods) | null
279
- }),
280
- computeValidOpts () {
281
- const $xeForm = this
282
- const props = $xeForm
283
-
284
- return Object.assign({}, getConfig().form.validConfig, props.validConfig)
285
- },
286
- computeTooltipOpts () {
287
- const $xeForm = this
288
- const props = $xeForm
289
-
290
- return Object.assign({}, getConfig().tooltip, getConfig().form.tooltipConfig, props.tooltipConfig)
291
- },
292
- computeCollapseOpts () {
293
- const $xeForm = this
294
- const props = $xeForm
295
-
296
- return Object.assign({}, getConfig().form.collapseConfig, props.collapseConfig)
297
- },
298
- computeAutoItemWidthList () {
299
- const $xeForm = this
300
- const props = $xeForm
301
- const reactData = $xeForm.reactData
302
-
303
- const { titleWidth: allTitleWidth, vertical: allVertical } = props
304
- const { formItems } = reactData
305
- const itemList: VxeFormDefines.ItemInfo[] = []
306
- XEUtils.eachTree(formItems, (item) => {
307
- const { titleWidth, vertical } = item
308
- if (titleWidth === 'auto') {
309
- itemList.push(item)
310
- } else {
311
- const itemVertical = XEUtils.eqNull(vertical) ? allVertical : vertical
312
- const itemTitleWidth = itemVertical ? null : (XEUtils.eqNull(titleWidth) ? allTitleWidth : titleWidth)
313
- if (itemTitleWidth === 'auto' && (!item.children || !item.children.length)) {
314
- itemList.push(item)
315
- }
316
- }
317
- }, { children: 'children' })
318
- return itemList
319
- }
320
- },
321
- methods: {
322
- //
323
- // Method
324
- //
325
- dispatchEvent (type: ValueOf<VxeFormEmits>, params: Record<string, any>, evnt: Event | null) {
326
- const $xeForm = this
327
- $xeForm.$emit(type, createEvent(evnt, { $form: $xeForm }, params))
328
- },
329
- callSlot (slotFunc: ((params: any, h: CreateElement) => any) | string | null, params: any, h: CreateElement) {
330
- const $xeForm = this
331
- const slots = $xeForm.$scopedSlots
332
-
333
- if (slotFunc) {
334
- if (XEUtils.isString(slotFunc)) {
335
- slotFunc = slots[slotFunc] || null
336
- }
337
- if (XEUtils.isFunction(slotFunc)) {
338
- return getSlotVNs(slotFunc.call($xeForm, params, h))
339
- }
340
- }
341
- return []
342
- },
343
- loadItem (list: VxeFormPropTypes.Items) {
344
- const $xeForm = this
345
- const slots = $xeForm.$scopedSlots
346
- const reactData = $xeForm.reactData
347
- const internalData = $xeForm.internalData
348
-
349
- if (list.length) {
350
- list.forEach((item) => {
351
- if (item.slots) {
352
- XEUtils.each(item.slots, (func) => {
353
- if (!XEUtils.isFunction(func)) {
354
- if (!slots[func]) {
355
- errLog('vxe.error.notSlot', [`[form] ${func}`])
356
- }
357
- }
358
- })
359
- }
360
- })
361
- }
362
- reactData.staticItems = XEUtils.mapTree(list, item => createItem($xeForm, item), { children: 'children' })
363
- internalData.itemFormatCache = {}
364
- return $xeForm.$nextTick().then(() => {
365
- return $xeForm.recalculate()
366
- })
367
- },
368
- getItems () {
369
- const $xeForm = this
370
- const reactData = $xeForm.reactData
371
-
372
- const itemList: VxeFormDefines.ItemInfo[] = []
373
- XEUtils.eachTree(reactData.formItems, item => {
374
- itemList.push(item)
375
- }, { children: 'children' })
376
- return itemList
377
- },
378
- getItemByField (field: string) {
379
- const $xeForm = this
380
- const reactData = $xeForm.reactData
381
-
382
- const rest = XEUtils.findTree(reactData.formItems, item => item.field === field, { children: 'children' })
383
- return rest ? rest.item : null
384
- },
385
- getCollapseStatus () {
386
- const $xeForm = this
387
- const reactData = $xeForm.reactData
388
-
389
- return reactData.collapseAll
390
- },
391
- toggleCollapse () {
392
- const $xeForm = this
393
- const reactData = $xeForm.reactData
394
-
395
- const status = !$xeForm.getCollapseStatus()
396
- reactData.collapseAll = status
397
- $xeForm.$emit('update:collapseStatus', status)
398
- return $xeForm.$nextTick()
399
- },
400
- toggleCollapseEvent (evnt: Event) {
401
- const $xeForm = this
402
- const props = $xeForm
403
- const $xeGrid = $xeForm.$xeGrid
404
-
405
- const actionRest = $xeForm.toggleCollapse()
406
- const status = $xeForm.getCollapseStatus()
407
- $xeForm.dispatchEvent('toggle-collapse', { status, collapse: status, data: props.data }, evnt)
408
- $xeForm.dispatchEvent('collapse', { status, collapse: status, data: props.data }, evnt)
409
- actionRest.then(() => {
410
- $xeForm.recalculate().then(() => {
411
- if ($xeGrid) {
412
- $xeGrid.recalculate(true)
413
- }
414
- })
415
- if ($xeGrid) {
416
- $xeGrid.recalculate()
417
- }
418
- })
419
- },
420
- clearValidate (fieldOrItem?: VxeFormItemPropTypes.Field | VxeFormItemPropTypes.Field[] | VxeFormDefines.ItemInfo | VxeFormDefines.ItemInfo[]) {
421
- const $xeForm = this
422
-
423
- if (fieldOrItem) {
424
- let fields: any = fieldOrItem
425
- if (!XEUtils.isArray(fieldOrItem)) {
426
- fields = [fieldOrItem]
427
- }
428
- fields.forEach((field: any) => {
429
- if (field) {
430
- const item = handleFieldOrItem($xeForm, field)
431
- if (item) {
432
- item.showError = false
433
- item.showIconMsg = false
434
- }
435
- }
436
- })
437
- } else {
438
- $xeForm.getItems().forEach((item) => {
439
- item.showError = false
440
- item.showIconMsg = false
441
- })
442
- }
443
- return $xeForm.$nextTick()
444
- },
445
- getResetValue (item: VxeFormDefines.ItemInfo, data: any, itemValue: any) {
446
- const $xeForm = this
447
- const $xeGrid = $xeForm.$xeGrid
448
-
449
- const { field, resetValue } = item
450
- if (XEUtils.isFunction(resetValue)) {
451
- return resetValue({ field, item, data, $form: $xeForm, $grid: $xeGrid })
452
- } else if (resetValue === null) {
453
- // 默认
454
- if (XEUtils.isArray(itemValue)) {
455
- return []
456
- }
457
- }
458
- return resetValue
459
- },
460
- reset () {
461
- const $xeForm = this
462
- const props = $xeForm
463
- const $xeGrid = $xeForm.$xeGrid
464
- const internalData = $xeForm.internalData
465
-
466
- const { data } = props
467
- const itemList = $xeForm.getItems()
468
- if (data) {
469
- itemList.forEach((item) => {
470
- const { field, itemRender } = item
471
- if (isEnableConf(itemRender)) {
472
- const { name, startField, endField } = itemRender
473
- const compConf = renderer.get(name)
474
- const fiResetMethod = compConf ? (compConf.formItemResetMethod || compConf.itemResetMethod) : null
475
- if (compConf && fiResetMethod) {
476
- fiResetMethod({ data, field, property: field, item, $form: $xeForm, $grid: $xeGrid })
477
- } else if (field) {
478
- const itemValue = XEUtils.get(data, field)
479
- XEUtils.set(data, field, $xeForm.getResetValue(item, data, itemValue))
480
- }
481
- if (startField && endField) {
482
- XEUtils.set(data, startField, $xeForm.getResetValue(item, data, XEUtils.get(data, startField)))
483
- XEUtils.set(data, endField, $xeForm.getResetValue(item, data, XEUtils.get(data, endField)))
484
- }
485
- }
486
- })
487
- }
488
- internalData.itemFormatCache = {}
489
- $xeForm.clearValidate()
490
- return $xeForm.recalculate()
491
- },
492
- resetEvent (evnt: Event) {
493
- const $xeForm = this
494
- const props = $xeForm
495
-
496
- evnt.preventDefault()
497
- $xeForm.reset()
498
- $xeForm.dispatchEvent('reset', { data: props.data }, evnt)
499
- },
500
- handleFocus (fields: string[]) {
501
- const $xeForm = this
502
- const props = $xeForm
503
- const $xeGrid = $xeForm.$xeGrid
504
-
505
- const el = $xeForm.$refs.refElem as HTMLFormElement
506
- if (el) {
507
- for (let i = 0; i < fields.length; i++) {
508
- const field = fields[i]
509
- const item = $xeForm.getItemByField(field)
510
- if (item && isEnableConf(item.itemRender)) {
511
- const { itemRender } = item
512
- const compConf = renderer.get(itemRender.name)
513
- // 定位到第一个
514
- if (!i) {
515
- scrollToView(el.querySelector(`.${item.id}`))
516
- }
517
- let inputElem: HTMLElement | null = null
518
- const autoFocus = itemRender.autoFocus || itemRender.autofocus || (compConf ? compConf.formItemAutoFocus : null)
519
- // 如果指定了聚焦 class
520
- if (XEUtils.isFunction(autoFocus)) {
521
- inputElem = autoFocus({ $form: $xeForm, $grid: $xeGrid, item, data: props.data, field })
522
- } else {
523
- if (autoFocus === true) {
524
- // 自动匹配模式,会自动匹配第一个可输入元素
525
- inputElem = el.querySelector(`.${item.id} input,textarea`)
526
- } else if (autoFocus) {
527
- inputElem = el.querySelector(`.${item.id} ${autoFocus}`) as HTMLInputElement
528
- }
529
- }
530
- if (inputElem) {
531
- inputElem.focus()
532
- break
533
- }
534
- }
535
- }
536
- }
537
- },
538
- /**
539
- * 校验数据
540
- * 按表格行、列顺序依次校验(同步或异步)
541
- * 校验规则根据索引顺序依次校验,如果是异步则会等待校验完成才会继续校验下一列
542
- * 如果校验失败则,触发回调或者 Promise<(ErrMap 校验不通过列的信息)>
543
- * 如果是传回调方式这返回一个 (ErrMap 校验不通过列的信息)
544
- *
545
- * rule 配置:
546
- * required=Boolean 是否必填
547
- * min=Number 最小长度
548
- * max=Number 最大长度
549
- * validator=Function({ itemValue, rule, rules, data, property }) 自定义校验,接收一个 Promise
550
- * trigger=change 触发方式
551
- */
552
- validItemRules (validType: string, fields: string | string[], val?: any): Promise<VxeFormDefines.ValidateErrorMapParams | undefined> {
553
- const $xeForm = this
554
- const props = $xeForm
555
-
556
- const { data, rules: formRules } = props
557
- const errorMaps: VxeFormDefines.ValidateErrorMapParams = {}
558
- if (!XEUtils.isArray(fields)) {
559
- fields = [fields]
560
- }
561
- return Promise.all(
562
- fields.map((property) => {
563
- const errorRules: Rule[] = []
564
- const syncVailds: Promise<any>[] = []
565
- if (property && formRules) {
566
- const rules = XEUtils.get(formRules, property)
567
- if (rules) {
568
- const itemValue = XEUtils.isUndefined(val) ? XEUtils.get(data, property) : val
569
- rules.forEach((rule) => {
570
- const { trigger, validator } = rule
571
- if (validType === 'all' || !trigger || validType === trigger) {
572
- if (validator) {
573
- const validParams = {
574
- itemValue,
575
- rule,
576
- rules,
577
- data,
578
- field: property,
579
- property,
580
- $form: $xeForm
581
- }
582
- let customValid: any
583
- if (XEUtils.isString(validator)) {
584
- const gvItem = validators.get(validator)
585
- if (gvItem) {
586
- const validatorMethod = gvItem.formItemValidatorMethod || gvItem.itemValidatorMethod
587
- if (validatorMethod) {
588
- customValid = validatorMethod(validParams)
589
- } else {
590
- warnLog('vxe.error.notValidators', [`[form] ${validator}`])
591
- }
592
- } else {
593
- errLog('vxe.error.notValidators', [`[form] ${validator}`])
594
- }
595
- } else {
596
- customValid = validator(validParams)
597
- }
598
- if (customValid) {
599
- if (XEUtils.isError(customValid)) {
600
- errorRules.push(new Rule({ type: 'custom', trigger, content: customValid.message, rule: new Rule(rule) }))
601
- } else if (customValid.catch) {
602
- // 如果为异步校验(注:异步校验是并发无序的)
603
- syncVailds.push(
604
- customValid.catch((e: any) => {
605
- errorRules.push(new Rule({ type: 'custom', trigger, content: e ? e.message : (rule.content || rule.message), rule: new Rule(rule) }))
606
- })
607
- )
608
- }
609
- }
610
- } else {
611
- if (!checkRuleStatus(rule, data, itemValue)) {
612
- errorRules.push(new Rule(rule))
613
- }
614
- }
615
- }
616
- })
617
- }
618
- }
619
- return Promise.all(syncVailds).then(() => {
620
- if (errorRules.length) {
621
- errorMaps[property] = errorRules.map(rule => {
622
- return {
623
- $form: $xeForm,
624
- rule,
625
- data,
626
- field: property,
627
- property
628
- }
629
- })
630
- }
631
- })
632
- })
633
- ).then(() => {
634
- if (!XEUtils.isEmpty(errorMaps)) {
635
- return Promise.reject(errorMaps)
636
- }
637
- })
638
- },
639
- beginValidate (itemList: VxeFormDefines.ItemInfo[], type?: string, callback?: any): Promise<VxeFormDefines.ValidateErrorMapParams | void> {
640
- const $xeForm = this
641
- const props = $xeForm
642
- const internalData = $xeForm.internalData
643
-
644
- const { data, rules: formRules } = props
645
- const validOpts = $xeForm.computeValidOpts
646
- const validRest: any = {}
647
- const validFields: string[] = []
648
- const itemValids: any[] = []
649
- clearTimeout(internalData.meTimeout)
650
- if (data && formRules) {
651
- itemList.forEach((item) => {
652
- const { field } = item
653
- if (field && !isHiddenItem($xeForm, item) && isActiveItem($xeForm, item)) {
654
- itemValids.push(
655
- $xeForm.validItemRules(type || 'all', field).then(() => {
656
- item.errRule = null
657
- }).catch((errorMaps: VxeFormDefines.ValidateErrorMapParams) => {
658
- const rest = errorMaps[field]
659
- if (!validRest[field]) {
660
- validRest[field] = []
661
- }
662
- validRest[field].push(rest)
663
- validFields.push(field)
664
- item.errRule = rest[0].rule
665
- return Promise.reject(rest)
666
- })
667
- )
668
- }
669
- })
670
- return Promise.all(itemValids).then(() => {
671
- if (callback) {
672
- callback()
673
- }
674
- }).catch(() => {
675
- return new Promise<void>((resolve) => {
676
- internalData.meTimeout = setTimeout(() => {
677
- itemList.forEach((item) => {
678
- if (item.errRule) {
679
- item.showError = true
680
- }
681
- })
682
- }, 20)
683
- if (validOpts.autoPos !== false) {
684
- $xeForm.$nextTick(() => {
685
- $xeForm.handleFocus(validFields)
686
- })
687
- }
688
- if (callback) {
689
- callback(validRest)
690
- resolve()
691
- } else {
692
- resolve(validRest)
693
- }
694
- })
695
- })
696
- }
697
- if (callback) {
698
- callback()
699
- }
700
- return Promise.resolve()
701
- },
702
- validate (callback: any) {
703
- const $xeForm = this
704
- const props = $xeForm
705
-
706
- const { readonly } = props
707
- $xeForm.clearValidate()
708
- if (readonly) {
709
- return $xeForm.$nextTick()
710
- }
711
- return $xeForm.beginValidate($xeForm.getItems(), '', callback).then((params) => {
712
- $xeForm.recalculate()
713
- return params
714
- })
715
- },
716
- validateField (fieldOrItem: VxeFormItemPropTypes.Field | VxeFormItemPropTypes.Field[] | VxeFormDefines.ItemInfo | VxeFormDefines.ItemInfo[], callback: any) {
717
- const $xeForm = this
718
- const props = $xeForm
719
-
720
- const { readonly } = props
721
- if (readonly) {
722
- return $xeForm.$nextTick()
723
- }
724
- let fields: any[] = []
725
- if (fieldOrItem) {
726
- if (XEUtils.isArray(fieldOrItem)) {
727
- fields = fieldOrItem
728
- } else {
729
- fields = [fieldOrItem]
730
- }
731
- }
732
- const itemList = fields.map(field => handleFieldOrItem($xeForm, field)) as VxeFormDefines.ItemInfo[]
733
- return $xeForm.beginValidate(itemList, '', callback).then((params) => {
734
- $xeForm.recalculate()
735
- return params
736
- })
737
- },
738
- handleSubmitEvent (evnt: Event) {
739
- const $xeForm = this
740
- const props = $xeForm
741
-
742
- const { readonly } = props
743
- $xeForm.clearValidate()
744
- if (readonly) {
745
- $xeForm.dispatchEvent('submit', { data: props.data }, evnt)
746
- $xeForm.recalculate()
747
- return
748
- }
749
- $xeForm.beginValidate($xeForm.getItems()).then((errMap) => {
750
- if (errMap) {
751
- $xeForm.dispatchEvent('submit-invalid', { data: props.data, errMap }, evnt)
752
- } else {
753
- $xeForm.dispatchEvent('submit', { data: props.data }, evnt)
754
- }
755
- $xeForm.recalculate()
756
- })
757
- },
758
- submitEvent (evnt: Event) {
759
- const $xeForm = this
760
- const props = $xeForm
761
-
762
- evnt.preventDefault()
763
- if (!props.preventSubmit) {
764
- $xeForm.handleSubmitEvent(evnt)
765
- }
766
- },
767
- closeTooltip () {
768
- const $xeForm = this
769
- const internalData = $xeForm.internalData
770
-
771
- const { tooltipStore } = internalData
772
- const $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
773
- if (tooltipStore.visible) {
774
- Object.assign(tooltipStore, {
775
- item: null,
776
- visible: false
777
- })
778
- if ($tooltip) {
779
- $tooltip.close()
780
- }
781
- }
782
- return $xeForm.$nextTick()
783
- },
784
- triggerTitleTipEvent (evnt: MouseEvent, params: {
785
- item: VxeFormDefines.ItemInfo;
786
- }) {
787
- const $xeForm = this
788
- const internalData = $xeForm.internalData
789
-
790
- const { item } = params
791
- const { tooltipStore } = internalData
792
- const $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
793
- const overflowElem = (evnt.currentTarget as HTMLDivElement).children[0]
794
- const content = (overflowElem.textContent || '').trim()
795
- const isCellOverflow = overflowElem.scrollWidth > overflowElem.clientWidth
796
- clearTimeout(internalData.stTimeout)
797
- if (tooltipStore.item !== item) {
798
- $xeForm.closeTooltip()
799
- }
800
- if (content && isCellOverflow) {
801
- Object.assign(tooltipStore, {
802
- item,
803
- visible: true
804
- })
805
- if ($tooltip) {
806
- $tooltip.open(overflowElem, content)
807
- }
808
- }
809
- },
810
- handleTitleTipLeaveEvent () {
811
- const $xeForm = this
812
- const internalData = $xeForm.internalData
813
-
814
- const tooltipOpts = $xeForm.computeTooltipOpts
815
- let $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
816
- if ($tooltip) {
817
- $tooltip.setActived(false)
818
- }
819
- if (tooltipOpts.enterable) {
820
- internalData.stTimeout = setTimeout(() => {
821
- $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
822
- if ($tooltip && !$tooltip.isActived()) {
823
- $xeForm.closeTooltip()
824
- }
825
- }, tooltipOpts.leaveDelay)
826
- } else {
827
- $xeForm.closeTooltip()
828
- }
829
- },
830
- handleValidIconEvent (evnt: Event, params: {
831
- item: VxeFormDefines.ItemInfo;
832
- }) {
833
- const { item } = params
834
- item.showIconMsg = !item.showIconMsg
835
- },
836
- triggerItemEvent (evnt: Event, field: string, itemValue?: any) {
837
- const $xeForm = this
838
-
839
- if (field) {
840
- return $xeForm.validItemRules(evnt ? (['blur'].includes(evnt.type) ? 'blur' : 'change') : 'all', field, itemValue)
841
- .then(() => {
842
- $xeForm.clearValidate(field)
843
- })
844
- .catch((errorMaps: VxeFormDefines.ValidateErrorMapParams) => {
845
- const rest = errorMaps[field]
846
- const item = $xeForm.getItemByField(field)
847
- if (rest && item) {
848
- item.showError = true
849
- item.errRule = rest[0].rule
850
- }
851
- })
852
- }
853
- return $xeForm.$nextTick()
854
- },
855
- /**
856
- * 更新项状态
857
- * 如果组件值 v-model 发生 change 时,调用改函数用于更新某一项编辑状态
858
- * 如果单元格配置了校验规则,则会进行校验
859
- */
860
- updateStatus (scope: any, itemValue?: any) {
861
- const $xeForm = this
862
-
863
- const { field } = scope
864
- return $xeForm.triggerItemEvent(new Event('change'), field, itemValue)
865
- },
866
- recalculate () {
867
- const $xeForm = this
868
-
869
- const autoItemWidthList = $xeForm.computeAutoItemWidthList
870
- const el = $xeForm.$refs.refElem as HTMLFormElement
871
- if (el && autoItemWidthList.length) {
872
- const itemElList = el.querySelectorAll<HTMLElement>(autoItemWidthList.map(item => `.vxe-form--item-title[itemid="${item.id}"]`).join(','))
873
- let maxItemWidth = 0
874
- XEUtils.arrayEach(itemElList, itemEl => {
875
- itemEl.style.width = ''
876
- maxItemWidth = Math.max(maxItemWidth, Math.ceil(itemEl.clientWidth + 2))
877
- })
878
- XEUtils.arrayEach(itemElList, itemEl => {
879
- itemEl.style.width = `${maxItemWidth}px`
880
- })
881
- }
882
- return $xeForm.$nextTick()
883
- },
884
- handleGlobalResizeEvent () {
885
- const $xeForm = this
886
-
887
- $xeForm.recalculate()
888
- },
889
-
890
- //
891
- // Render
892
- //
893
- renderVN (h: CreateElement): VNode {
894
- const $xeForm = this
895
- const props = $xeForm
896
- const slots = $xeForm.$scopedSlots
897
- const reactData = $xeForm.reactData
898
-
899
- const { loading, border, className, data, customLayout } = props
900
- const { formItems } = reactData
901
- // const formItems: any[] = []
902
- const vSize = $xeForm.computeSize
903
- const tooltipOpts = $xeForm.computeTooltipOpts
904
- const defaultSlot = slots.default
905
- return h('form', {
906
- ref: 'refElem',
907
- class: ['vxe-form', className ? (XEUtils.isFunction(className) ? className({ items: formItems, data, $form: $xeForm }) : className) : '', {
908
- [`size--${vSize}`]: vSize,
909
- 'is--border': border,
910
- 'custom--layout': customLayout,
911
- 'is--loading': loading
912
- }],
913
- on: {
914
- submit: $xeForm.submitEvent,
915
- reset: $xeForm.resetEvent
916
- }
917
- }, [
918
- h('div', {
919
- class: 'vxe-form--wrapper vxe-form--item-row'
920
- }, customLayout
921
- ? (defaultSlot ? defaultSlot({}) : [])
922
- : formItems.map((item, index) => {
923
- return h(VxeFormConfigItem, {
924
- key: index,
925
- props: {
926
- itemConfig: item
927
- }
928
- })
929
- })),
930
- h('div', {
931
- class: 'vxe-form-slots',
932
- ref: 'hideItem'
933
- }, customLayout ? [] : (defaultSlot ? defaultSlot({}) : [])),
934
- /**
935
- * 加载中
936
- */
937
- h(VxeLoadingComponent, {
938
- class: 'vxe-form--loading',
939
- props: {
940
- value: loading
941
- }
942
- }),
943
- /**
944
- * 工具提示
945
- */
946
- h(VxeTooltipComponent, {
947
- ref: 'refTooltip',
948
- ...tooltipOpts
949
- })
950
- ])
951
- }
952
- },
953
- watch: {
954
- vertical () {
955
- const $xeForm = this
956
-
957
- $xeForm.recalcFlag++
958
- },
959
- titleWidth () {
960
- const $xeForm = this
961
-
962
- $xeForm.recalcFlag++
963
- },
964
- recalcFlag () {
965
- const $xeForm = this
966
-
967
- $xeForm.$nextTick().then(() => {
968
- $xeForm.recalculate()
969
- })
970
- },
971
- 'reactData.staticItems' () {
972
- const $xeForm = this
973
- const reactData = $xeForm.reactData
974
-
975
- reactData.formItems = reactData.staticItems
976
- $xeForm.recalcFlag++
977
- },
978
- items () {
979
- const $xeForm = this
980
- const props = $xeForm
981
-
982
- $xeForm.loadItem(props.items || [])
983
- },
984
- collapseStatus (val) {
985
- const $xeForm = this
986
- const reactData = $xeForm.reactData
987
-
988
- reactData.collapseAll = !!val
989
- },
990
- readonly () {
991
- const $xeForm = this
992
-
993
- $xeForm.clearValidate()
994
- },
995
- disabled () {
996
- const $xeForm = this
997
-
998
- $xeForm.clearValidate()
999
- }
1000
- },
1001
- created () {
1002
- const $xeForm = this
1003
- const props = $xeForm
1004
- const reactData = $xeForm.reactData
1005
-
1006
- reactData.collapseAll = !!props.collapseStatus
1007
- },
1008
- mounted () {
1009
- const $xeForm = this
1010
- const props = $xeForm
1011
-
1012
- if (props.items) {
1013
- $xeForm.loadItem(props.items)
1014
- }
1015
- $xeForm.$nextTick(() => {
1016
- if (props.customLayout && props.items) {
1017
- errLog('vxe.error.errConflicts', ['[form] custom-layout', 'items'])
1018
- }
1019
- })
1020
- globalEvents.on($xeForm, 'resize', $xeForm.handleGlobalResizeEvent)
1021
- },
1022
- destroyed () {
1023
- const $xeForm = this
1024
- const internalData = $xeForm.internalData
1025
-
1026
- globalEvents.off($xeForm, 'resize')
1027
- XEUtils.assign(internalData, createInternalData())
1028
- },
1029
- render (this: any, h) {
1030
- return this.renderVN(h)
1031
- }
1032
- }) /* define-vxe-component end */
1
+ import { PropType, CreateElement, VNode } from 'vue'
2
+ import { defineVxeComponent } from '../../ui/src/comp'
3
+ import XEUtils from 'xe-utils'
4
+ import { getConfig, validators, renderer, createEvent, globalMixins, globalEvents } from '../../ui'
5
+ import { eqEmptyValue, getFuncText, isEnableConf } from '../../ui/src/utils'
6
+ import { scrollToView } from '../../ui/src/dom'
7
+ import { createItem, handleFieldOrItem, isHiddenItem, isActiveItem } from './util'
8
+ import VxeTooltipComponent from '../../tooltip'
9
+ import VxeFormConfigItem from './form-config-item'
10
+ import VxeLoadingComponent from '../../loading'
11
+ import { getSlotVNs } from '../../ui/src/vn'
12
+ import { warnLog, errLog } from '../../ui/src/log'
13
+
14
+ import '../render'
15
+
16
+ import type { VxeFormPropTypes, VxeFormEmits, VxeComponentSizeType, ValueOf, FormReactData, VxeFormDefines, VxeFormItemPropTypes, FormInternalData, VxeTooltipConstructor } from '../../../types'
17
+ import type { VxeGridConstructor, VxeGridPrivateMethods } from '../../../types/components/grid'
18
+
19
+ class Rule {
20
+ constructor (rule: any) {
21
+ Object.assign(this, {
22
+ $options: rule,
23
+ required: rule.required,
24
+ min: rule.min,
25
+ max: rule.min,
26
+ type: rule.type,
27
+ pattern: rule.pattern,
28
+ validator: rule.validator,
29
+ trigger: rule.trigger,
30
+ maxWidth: rule.maxWidth
31
+ })
32
+ }
33
+
34
+ get content () {
35
+ return getFuncText(this.$options.content || this.$options.message)
36
+ }
37
+
38
+ get message () {
39
+ return this.content
40
+ }
41
+
42
+ [key: string]: any
43
+ }
44
+
45
+ // 如果存在 pattern,判断正则
46
+ function validREValue (pattern: string | RegExp | undefined, val: string) {
47
+ if (pattern && !(XEUtils.isRegExp(pattern) ? pattern : new RegExp(pattern)).test(val)) {
48
+ return false
49
+ }
50
+ return true
51
+ }
52
+
53
+ // 如果存在 max,判断最大值
54
+ function validMaxValue (max: string | number | undefined, num: number) {
55
+ if (!XEUtils.eqNull(max) && num > XEUtils.toNumber(max)) {
56
+ return false
57
+ }
58
+ return true
59
+ }
60
+
61
+ // 如果存在 min,判断最小值
62
+ function validMinValue (min: string | number | undefined, num: number) {
63
+ if (!XEUtils.eqNull(min) && num < XEUtils.toNumber(min)) {
64
+ return false
65
+ }
66
+ return true
67
+ }
68
+
69
+ function validRuleValue (rule: VxeFormDefines.FormRule, val: any, required: boolean | undefined) {
70
+ const { type, min, max, pattern } = rule
71
+ const isArrType = type === 'array'
72
+ const isNumType = type === 'number'
73
+ const isStrType = type === 'string'
74
+ const strVal = `${val}`
75
+ if (!validREValue(pattern, strVal)) {
76
+ return false
77
+ }
78
+ if (isArrType) {
79
+ if (!XEUtils.isArray(val)) {
80
+ return false
81
+ }
82
+ if (required) {
83
+ if (!val.length) {
84
+ return false
85
+ }
86
+ }
87
+ if (!validMinValue(min, val.length)) {
88
+ return false
89
+ }
90
+ if (!validMaxValue(max, val.length)) {
91
+ return false
92
+ }
93
+ } else if (isNumType) {
94
+ const numVal = Number(val)
95
+ if (isNaN(numVal)) {
96
+ return false
97
+ }
98
+ if (!validMinValue(min, numVal)) {
99
+ return false
100
+ }
101
+ if (!validMaxValue(max, numVal)) {
102
+ return false
103
+ }
104
+ } else {
105
+ if (isStrType) {
106
+ if (!XEUtils.isString(val)) {
107
+ return false
108
+ }
109
+ }
110
+ if (required) {
111
+ if (!strVal) {
112
+ return false
113
+ }
114
+ }
115
+ if (!validMinValue(min, strVal.length)) {
116
+ return false
117
+ }
118
+ if (!validMaxValue(max, strVal.length)) {
119
+ return false
120
+ }
121
+ }
122
+ return true
123
+ }
124
+
125
+ function checkRuleStatus (rule: VxeFormDefines.FormRule, data: any, val: any) {
126
+ const { required, field } = rule
127
+ const currVal = field ? XEUtils.get(data, field) : val
128
+ const isEmptyVal = XEUtils.isArray(currVal) ? !currVal.length : eqEmptyValue(currVal)
129
+ if (required) {
130
+ if (isEmptyVal) {
131
+ return false
132
+ }
133
+ if (!validRuleValue(rule, currVal, required)) {
134
+ return false
135
+ }
136
+ } else {
137
+ if (!isEmptyVal) {
138
+ if (!validRuleValue(rule, currVal, required)) {
139
+ return false
140
+ }
141
+ }
142
+ }
143
+ return true
144
+ }
145
+
146
+ function createInternalData (): FormInternalData {
147
+ return {
148
+ meTimeout: undefined,
149
+ stTimeout: undefined,
150
+ tooltipStore: {
151
+ item: null,
152
+ visible: false
153
+ },
154
+ itemFormatCache: {}
155
+ }
156
+ }
157
+
158
+ export default /* define-vxe-component start */ defineVxeComponent({
159
+ name: 'VxeForm',
160
+ mixins: [
161
+ globalMixins.sizeMixin
162
+ ],
163
+ props: {
164
+ collapseStatus: {
165
+ type: Boolean as PropType<VxeFormPropTypes.CollapseStatus>,
166
+ default: true
167
+ },
168
+ loading: Boolean as PropType<VxeFormPropTypes.Loading>,
169
+ data: Object as PropType<VxeFormPropTypes.Data>,
170
+ size: {
171
+ type: String as PropType<VxeFormPropTypes.Size>,
172
+ default: () => getConfig().form.size || getConfig().size
173
+ },
174
+ span: {
175
+ type: [String, Number] as PropType<VxeFormPropTypes.Span>,
176
+ default: () => getConfig().form.span
177
+ },
178
+ align: {
179
+ type: String as PropType<VxeFormPropTypes.Align>,
180
+ default: () => getConfig().form.align
181
+ },
182
+ verticalAlign: {
183
+ type: String as PropType<VxeFormPropTypes.VerticalAlign>,
184
+ default: () => getConfig().form.verticalAlign
185
+ },
186
+ border: {
187
+ type: Boolean as PropType<VxeFormPropTypes.Border>,
188
+ default: () => getConfig().form.border
189
+ },
190
+ titleBackground: {
191
+ type: Boolean as PropType<VxeFormPropTypes.TitleBackground>,
192
+ default: () => getConfig().form.titleBackground
193
+ },
194
+ titleBold: {
195
+ type: Boolean as PropType<VxeFormPropTypes.TitleBold>,
196
+ default: () => getConfig().form.titleBold
197
+ },
198
+ titleAlign: {
199
+ type: String as PropType<VxeFormPropTypes.TitleAlign>,
200
+ default: () => getConfig().form.titleAlign
201
+ },
202
+ titleWidth: {
203
+ type: [String, Number] as PropType<VxeFormPropTypes.TitleWidth>,
204
+ default: () => getConfig().form.titleWidth
205
+ },
206
+ titleColon: {
207
+ type: Boolean as PropType<VxeFormPropTypes.TitleColon>,
208
+ default: () => getConfig().form.titleColon
209
+ },
210
+ titleAsterisk: {
211
+ type: Boolean as PropType<VxeFormPropTypes.TitleAsterisk>,
212
+ default: () => getConfig().form.titleAsterisk
213
+ },
214
+ titleOverflow: {
215
+ type: [Boolean, String] as PropType<VxeFormPropTypes.TitleOverflow>,
216
+ default: () => getConfig().form.titleOverflow
217
+ },
218
+ vertical: {
219
+ type: Boolean as PropType<VxeFormPropTypes.Vertical>,
220
+ default: () => getConfig().form.vertical
221
+ },
222
+ padding: {
223
+ type: Boolean as PropType<VxeFormPropTypes.Padding>,
224
+ default: () => getConfig().form.padding
225
+ },
226
+ className: [String, Function] as PropType<VxeFormPropTypes.ClassName>,
227
+ readonly: Boolean as PropType<VxeFormPropTypes.Readonly>,
228
+ disabled: Boolean as PropType<VxeFormPropTypes.Disabled>,
229
+ items: Array as PropType<VxeFormPropTypes.Items>,
230
+ rules: Object as PropType<VxeFormPropTypes.Rules>,
231
+ preventSubmit: {
232
+ type: Boolean as PropType<VxeFormPropTypes.PreventSubmit>,
233
+ default: () => getConfig().form.preventSubmit
234
+ },
235
+ validConfig: Object as PropType<VxeFormPropTypes.ValidConfig>,
236
+ tooltipConfig: Object as PropType<VxeFormPropTypes.TooltipConfig>,
237
+ collapseConfig: Object as PropType<VxeFormPropTypes.CollapseConfig>,
238
+ customLayout: {
239
+ type: Boolean as PropType<VxeFormPropTypes.CustomLayout>,
240
+ default: () => getConfig().form.customLayout
241
+ },
242
+ params: Object as PropType<VxeFormPropTypes.Params>
243
+ },
244
+ inject: {
245
+ $xeGrid: {
246
+ default: null
247
+ }
248
+ },
249
+ provide () {
250
+ const $xeForm = this
251
+ return {
252
+ $xeForm,
253
+ xeFormItemInfo: null,
254
+ $xeFormGroup: null,
255
+ $xeFormItem: null
256
+ }
257
+ },
258
+ data () {
259
+ const xID = XEUtils.uniqueId()
260
+ const reactData: FormReactData = {
261
+ collapseAll: false,
262
+ staticItems: [],
263
+ formItems: [],
264
+ itemWidth: 0
265
+ }
266
+ const internalData = createInternalData()
267
+ return {
268
+ xID,
269
+ reactData,
270
+ internalData,
271
+
272
+ recalcFlag: 0
273
+ }
274
+ },
275
+ computed: {
276
+ ...({} as {
277
+ computeSize(): VxeComponentSizeType
278
+ $xeGrid(): (VxeGridConstructor & VxeGridPrivateMethods) | null
279
+ }),
280
+ computeValidOpts () {
281
+ const $xeForm = this
282
+ const props = $xeForm
283
+
284
+ return Object.assign({}, getConfig().form.validConfig, props.validConfig)
285
+ },
286
+ computeTooltipOpts () {
287
+ const $xeForm = this
288
+ const props = $xeForm
289
+
290
+ return Object.assign({}, getConfig().tooltip, getConfig().form.tooltipConfig, props.tooltipConfig)
291
+ },
292
+ computeCollapseOpts () {
293
+ const $xeForm = this
294
+ const props = $xeForm
295
+
296
+ return Object.assign({}, getConfig().form.collapseConfig, props.collapseConfig)
297
+ },
298
+ computeAutoItemWidthList () {
299
+ const $xeForm = this
300
+ const props = $xeForm
301
+ const reactData = $xeForm.reactData
302
+
303
+ const { titleWidth: allTitleWidth, vertical: allVertical } = props
304
+ const { formItems } = reactData
305
+ const itemList: VxeFormDefines.ItemInfo[] = []
306
+ XEUtils.eachTree(formItems, (item) => {
307
+ const { titleWidth, vertical } = item
308
+ if (titleWidth === 'auto') {
309
+ itemList.push(item)
310
+ } else {
311
+ const itemVertical = XEUtils.eqNull(vertical) ? allVertical : vertical
312
+ const itemTitleWidth = itemVertical ? null : (XEUtils.eqNull(titleWidth) ? allTitleWidth : titleWidth)
313
+ if (itemTitleWidth === 'auto' && (!item.children || !item.children.length)) {
314
+ itemList.push(item)
315
+ }
316
+ }
317
+ }, { children: 'children' })
318
+ return itemList
319
+ }
320
+ },
321
+ methods: {
322
+ //
323
+ // Method
324
+ //
325
+ dispatchEvent (type: ValueOf<VxeFormEmits>, params: Record<string, any>, evnt: Event | null) {
326
+ const $xeForm = this
327
+ $xeForm.$emit(type, createEvent(evnt, { $form: $xeForm }, params))
328
+ },
329
+ callSlot (slotFunc: ((params: any, h: CreateElement) => any) | string | null, params: any, h: CreateElement) {
330
+ const $xeForm = this
331
+ const slots = $xeForm.$scopedSlots
332
+
333
+ if (slotFunc) {
334
+ if (XEUtils.isString(slotFunc)) {
335
+ slotFunc = slots[slotFunc] || null
336
+ }
337
+ if (XEUtils.isFunction(slotFunc)) {
338
+ return getSlotVNs(slotFunc.call($xeForm, params, h))
339
+ }
340
+ }
341
+ return []
342
+ },
343
+ loadItem (list: VxeFormPropTypes.Items) {
344
+ const $xeForm = this
345
+ const slots = $xeForm.$scopedSlots
346
+ const reactData = $xeForm.reactData
347
+ const internalData = $xeForm.internalData
348
+
349
+ if (list.length) {
350
+ list.forEach((item) => {
351
+ if (item.slots) {
352
+ XEUtils.each(item.slots, (func) => {
353
+ if (!XEUtils.isFunction(func)) {
354
+ if (!slots[func]) {
355
+ errLog('vxe.error.notSlot', [`[form] ${func}`])
356
+ }
357
+ }
358
+ })
359
+ }
360
+ })
361
+ }
362
+ reactData.staticItems = XEUtils.mapTree(list, item => createItem($xeForm, item), { children: 'children' })
363
+ internalData.itemFormatCache = {}
364
+ return $xeForm.$nextTick().then(() => {
365
+ return $xeForm.recalculate()
366
+ })
367
+ },
368
+ getItems () {
369
+ const $xeForm = this
370
+ const reactData = $xeForm.reactData
371
+
372
+ const itemList: VxeFormDefines.ItemInfo[] = []
373
+ XEUtils.eachTree(reactData.formItems, item => {
374
+ itemList.push(item)
375
+ }, { children: 'children' })
376
+ return itemList
377
+ },
378
+ getItemByField (field: string) {
379
+ const $xeForm = this
380
+ const reactData = $xeForm.reactData
381
+
382
+ const rest = XEUtils.findTree(reactData.formItems, item => item.field === field, { children: 'children' })
383
+ return rest ? rest.item : null
384
+ },
385
+ getCollapseStatus () {
386
+ const $xeForm = this
387
+ const reactData = $xeForm.reactData
388
+
389
+ return reactData.collapseAll
390
+ },
391
+ toggleCollapse () {
392
+ const $xeForm = this
393
+ const reactData = $xeForm.reactData
394
+
395
+ const status = !$xeForm.getCollapseStatus()
396
+ reactData.collapseAll = status
397
+ $xeForm.$emit('update:collapseStatus', status)
398
+ return $xeForm.$nextTick()
399
+ },
400
+ toggleCollapseEvent (evnt: Event) {
401
+ const $xeForm = this
402
+ const props = $xeForm
403
+ const $xeGrid = $xeForm.$xeGrid
404
+
405
+ const actionRest = $xeForm.toggleCollapse()
406
+ const status = $xeForm.getCollapseStatus()
407
+ $xeForm.dispatchEvent('toggle-collapse', { status, collapse: status, data: props.data }, evnt)
408
+ $xeForm.dispatchEvent('collapse', { status, collapse: status, data: props.data }, evnt)
409
+ actionRest.then(() => {
410
+ $xeForm.recalculate().then(() => {
411
+ if ($xeGrid) {
412
+ $xeGrid.recalculate(true)
413
+ }
414
+ })
415
+ if ($xeGrid) {
416
+ $xeGrid.recalculate()
417
+ }
418
+ })
419
+ },
420
+ clearValidate (fieldOrItem?: VxeFormItemPropTypes.Field | VxeFormItemPropTypes.Field[] | VxeFormDefines.ItemInfo | VxeFormDefines.ItemInfo[]) {
421
+ const $xeForm = this
422
+
423
+ if (fieldOrItem) {
424
+ let fields: any = fieldOrItem
425
+ if (!XEUtils.isArray(fieldOrItem)) {
426
+ fields = [fieldOrItem]
427
+ }
428
+ fields.forEach((field: any) => {
429
+ if (field) {
430
+ const item = handleFieldOrItem($xeForm, field)
431
+ if (item) {
432
+ item.showError = false
433
+ item.showIconMsg = false
434
+ }
435
+ }
436
+ })
437
+ } else {
438
+ $xeForm.getItems().forEach((item) => {
439
+ item.showError = false
440
+ item.showIconMsg = false
441
+ })
442
+ }
443
+ return $xeForm.$nextTick()
444
+ },
445
+ getResetValue (item: VxeFormDefines.ItemInfo, data: any, itemValue: any) {
446
+ const $xeForm = this
447
+ const $xeGrid = $xeForm.$xeGrid
448
+
449
+ const { field, resetValue } = item
450
+ if (XEUtils.isFunction(resetValue)) {
451
+ return resetValue({ field, item, data, $form: $xeForm, $grid: $xeGrid })
452
+ } else if (resetValue === null) {
453
+ // 默认
454
+ if (XEUtils.isArray(itemValue)) {
455
+ return []
456
+ }
457
+ }
458
+ return resetValue
459
+ },
460
+ reset () {
461
+ const $xeForm = this
462
+ const props = $xeForm
463
+ const $xeGrid = $xeForm.$xeGrid
464
+ const internalData = $xeForm.internalData
465
+
466
+ const { data } = props
467
+ const itemList = $xeForm.getItems()
468
+ if (data) {
469
+ itemList.forEach((item) => {
470
+ const { field, itemRender } = item
471
+ if (isEnableConf(itemRender)) {
472
+ const { name, startField, endField } = itemRender
473
+ const compConf = renderer.get(name)
474
+ const fiResetMethod = compConf ? (compConf.formItemResetMethod || compConf.itemResetMethod) : null
475
+ if (compConf && fiResetMethod) {
476
+ fiResetMethod({ data, field, property: field, item, $form: $xeForm, $grid: $xeGrid })
477
+ } else if (field) {
478
+ const itemValue = XEUtils.get(data, field)
479
+ XEUtils.set(data, field, $xeForm.getResetValue(item, data, itemValue))
480
+ }
481
+ if (startField && endField) {
482
+ XEUtils.set(data, startField, $xeForm.getResetValue(item, data, XEUtils.get(data, startField)))
483
+ XEUtils.set(data, endField, $xeForm.getResetValue(item, data, XEUtils.get(data, endField)))
484
+ }
485
+ }
486
+ })
487
+ }
488
+ internalData.itemFormatCache = {}
489
+ $xeForm.clearValidate()
490
+ return $xeForm.recalculate()
491
+ },
492
+ resetEvent (evnt: Event) {
493
+ const $xeForm = this
494
+ const props = $xeForm
495
+
496
+ evnt.preventDefault()
497
+ $xeForm.reset()
498
+ $xeForm.dispatchEvent('reset', { data: props.data }, evnt)
499
+ },
500
+ handleFocus (fields: string[]) {
501
+ const $xeForm = this
502
+ const props = $xeForm
503
+ const $xeGrid = $xeForm.$xeGrid
504
+
505
+ const el = $xeForm.$refs.refElem as HTMLFormElement
506
+ if (el) {
507
+ for (let i = 0; i < fields.length; i++) {
508
+ const field = fields[i]
509
+ const item = $xeForm.getItemByField(field)
510
+ if (item && isEnableConf(item.itemRender)) {
511
+ const { itemRender } = item
512
+ const compConf = renderer.get(itemRender.name)
513
+ // 定位到第一个
514
+ if (!i) {
515
+ scrollToView(el.querySelector(`.${item.id}`))
516
+ }
517
+ let inputElem: HTMLElement | null = null
518
+ const autoFocus = itemRender.autoFocus || itemRender.autofocus || (compConf ? compConf.formItemAutoFocus : null)
519
+ // 如果指定了聚焦 class
520
+ if (XEUtils.isFunction(autoFocus)) {
521
+ inputElem = autoFocus({ $form: $xeForm, $grid: $xeGrid, item, data: props.data, field })
522
+ } else {
523
+ if (autoFocus === true) {
524
+ // 自动匹配模式,会自动匹配第一个可输入元素
525
+ inputElem = el.querySelector(`.${item.id} input,textarea`)
526
+ } else if (autoFocus) {
527
+ inputElem = el.querySelector(`.${item.id} ${autoFocus}`) as HTMLInputElement
528
+ }
529
+ }
530
+ if (inputElem) {
531
+ inputElem.focus()
532
+ break
533
+ }
534
+ }
535
+ }
536
+ }
537
+ },
538
+ /**
539
+ * 校验数据
540
+ * 按表格行、列顺序依次校验(同步或异步)
541
+ * 校验规则根据索引顺序依次校验,如果是异步则会等待校验完成才会继续校验下一列
542
+ * 如果校验失败则,触发回调或者 Promise<(ErrMap 校验不通过列的信息)>
543
+ * 如果是传回调方式这返回一个 (ErrMap 校验不通过列的信息)
544
+ *
545
+ * rule 配置:
546
+ * required=Boolean 是否必填
547
+ * min=Number 最小长度
548
+ * max=Number 最大长度
549
+ * validator=Function({ itemValue, rule, rules, data, property }) 自定义校验,接收一个 Promise
550
+ * trigger=change 触发方式
551
+ */
552
+ validItemRules (validType: string, fields: string | string[], val?: any): Promise<VxeFormDefines.ValidateErrorMapParams | undefined> {
553
+ const $xeForm = this
554
+ const props = $xeForm
555
+
556
+ const { data, rules: formRules } = props
557
+ const errorMaps: VxeFormDefines.ValidateErrorMapParams = {}
558
+ if (!XEUtils.isArray(fields)) {
559
+ fields = [fields]
560
+ }
561
+ return Promise.all(
562
+ fields.map((property) => {
563
+ const errorRules: Rule[] = []
564
+ const syncVailds: Promise<any>[] = []
565
+ if (property && formRules) {
566
+ const rules = XEUtils.get(formRules, property)
567
+ if (rules) {
568
+ const itemValue = XEUtils.isUndefined(val) ? XEUtils.get(data, property) : val
569
+ rules.forEach((rule) => {
570
+ const { trigger, validator } = rule
571
+ if (validType === 'all' || !trigger || validType === trigger) {
572
+ if (validator) {
573
+ const validParams = {
574
+ itemValue,
575
+ rule,
576
+ rules,
577
+ data,
578
+ field: property,
579
+ property,
580
+ $form: $xeForm
581
+ }
582
+ let customValid: any
583
+ if (XEUtils.isString(validator)) {
584
+ const gvItem = validators.get(validator)
585
+ if (gvItem) {
586
+ const validatorMethod = gvItem.formItemValidatorMethod || gvItem.itemValidatorMethod
587
+ if (validatorMethod) {
588
+ customValid = validatorMethod(validParams)
589
+ } else {
590
+ warnLog('vxe.error.notValidators', [`[form] ${validator}`])
591
+ }
592
+ } else {
593
+ errLog('vxe.error.notValidators', [`[form] ${validator}`])
594
+ }
595
+ } else {
596
+ customValid = validator(validParams)
597
+ }
598
+ if (customValid) {
599
+ if (XEUtils.isError(customValid)) {
600
+ errorRules.push(new Rule({ type: 'custom', trigger, content: customValid.message, rule: new Rule(rule) }))
601
+ } else if (customValid.catch) {
602
+ // 如果为异步校验(注:异步校验是并发无序的)
603
+ syncVailds.push(
604
+ customValid.catch((e: any) => {
605
+ errorRules.push(new Rule({ type: 'custom', trigger, content: e ? e.message : (rule.content || rule.message), rule: new Rule(rule) }))
606
+ })
607
+ )
608
+ }
609
+ }
610
+ } else {
611
+ if (!checkRuleStatus(rule, data, itemValue)) {
612
+ errorRules.push(new Rule(rule))
613
+ }
614
+ }
615
+ }
616
+ })
617
+ }
618
+ }
619
+ return Promise.all(syncVailds).then(() => {
620
+ if (errorRules.length) {
621
+ errorMaps[property] = errorRules.map(rule => {
622
+ return {
623
+ $form: $xeForm,
624
+ rule,
625
+ data,
626
+ field: property,
627
+ property
628
+ }
629
+ })
630
+ }
631
+ })
632
+ })
633
+ ).then(() => {
634
+ if (!XEUtils.isEmpty(errorMaps)) {
635
+ return Promise.reject(errorMaps)
636
+ }
637
+ })
638
+ },
639
+ beginValidate (itemList: VxeFormDefines.ItemInfo[], type?: string, callback?: any): Promise<VxeFormDefines.ValidateErrorMapParams | void> {
640
+ const $xeForm = this
641
+ const props = $xeForm
642
+ const internalData = $xeForm.internalData
643
+
644
+ const { data, rules: formRules } = props
645
+ const validOpts = $xeForm.computeValidOpts
646
+ const validRest: any = {}
647
+ const validFields: string[] = []
648
+ const itemValids: any[] = []
649
+ clearTimeout(internalData.meTimeout)
650
+ if (data && formRules) {
651
+ itemList.forEach((item) => {
652
+ const { field } = item
653
+ if (field && !isHiddenItem($xeForm, item) && isActiveItem($xeForm, item)) {
654
+ itemValids.push(
655
+ $xeForm.validItemRules(type || 'all', field).then(() => {
656
+ item.errRule = null
657
+ }).catch((errorMaps: VxeFormDefines.ValidateErrorMapParams) => {
658
+ const rest = errorMaps[field]
659
+ if (!validRest[field]) {
660
+ validRest[field] = []
661
+ }
662
+ validRest[field].push(rest)
663
+ validFields.push(field)
664
+ item.errRule = rest[0].rule
665
+ return Promise.reject(rest)
666
+ })
667
+ )
668
+ }
669
+ })
670
+ return Promise.all(itemValids).then(() => {
671
+ if (callback) {
672
+ callback()
673
+ }
674
+ }).catch(() => {
675
+ return new Promise<void>((resolve) => {
676
+ internalData.meTimeout = setTimeout(() => {
677
+ itemList.forEach((item) => {
678
+ if (item.errRule) {
679
+ item.showError = true
680
+ }
681
+ })
682
+ }, 20)
683
+ if (validOpts.autoPos !== false) {
684
+ $xeForm.$nextTick(() => {
685
+ $xeForm.handleFocus(validFields)
686
+ })
687
+ }
688
+ if (callback) {
689
+ callback(validRest)
690
+ resolve()
691
+ } else {
692
+ resolve(validRest)
693
+ }
694
+ })
695
+ })
696
+ }
697
+ if (callback) {
698
+ callback()
699
+ }
700
+ return Promise.resolve()
701
+ },
702
+ validate (callback: any) {
703
+ const $xeForm = this
704
+ const props = $xeForm
705
+
706
+ const { readonly } = props
707
+ $xeForm.clearValidate()
708
+ if (readonly) {
709
+ return $xeForm.$nextTick()
710
+ }
711
+ return $xeForm.beginValidate($xeForm.getItems(), '', callback).then((params) => {
712
+ $xeForm.recalculate()
713
+ return params
714
+ })
715
+ },
716
+ validateField (fieldOrItem: VxeFormItemPropTypes.Field | VxeFormItemPropTypes.Field[] | VxeFormDefines.ItemInfo | VxeFormDefines.ItemInfo[], callback: any) {
717
+ const $xeForm = this
718
+ const props = $xeForm
719
+
720
+ const { readonly } = props
721
+ if (readonly) {
722
+ return $xeForm.$nextTick()
723
+ }
724
+ let fields: any[] = []
725
+ if (fieldOrItem) {
726
+ if (XEUtils.isArray(fieldOrItem)) {
727
+ fields = fieldOrItem
728
+ } else {
729
+ fields = [fieldOrItem]
730
+ }
731
+ }
732
+ const itemList = fields.map(field => handleFieldOrItem($xeForm, field)) as VxeFormDefines.ItemInfo[]
733
+ return $xeForm.beginValidate(itemList, '', callback).then((params) => {
734
+ $xeForm.recalculate()
735
+ return params
736
+ })
737
+ },
738
+ handleSubmitEvent (evnt: Event) {
739
+ const $xeForm = this
740
+ const props = $xeForm
741
+
742
+ const { readonly } = props
743
+ $xeForm.clearValidate()
744
+ if (readonly) {
745
+ $xeForm.dispatchEvent('submit', { data: props.data }, evnt)
746
+ $xeForm.recalculate()
747
+ return
748
+ }
749
+ $xeForm.beginValidate($xeForm.getItems()).then((errMap) => {
750
+ if (errMap) {
751
+ $xeForm.dispatchEvent('submit-invalid', { data: props.data, errMap }, evnt)
752
+ } else {
753
+ $xeForm.dispatchEvent('submit', { data: props.data }, evnt)
754
+ }
755
+ $xeForm.recalculate()
756
+ })
757
+ },
758
+ submitEvent (evnt: Event) {
759
+ const $xeForm = this
760
+ const props = $xeForm
761
+
762
+ evnt.preventDefault()
763
+ if (!props.preventSubmit) {
764
+ $xeForm.handleSubmitEvent(evnt)
765
+ }
766
+ },
767
+ closeTooltip () {
768
+ const $xeForm = this
769
+ const internalData = $xeForm.internalData
770
+
771
+ const { tooltipStore } = internalData
772
+ const $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
773
+ if (tooltipStore.visible) {
774
+ Object.assign(tooltipStore, {
775
+ item: null,
776
+ visible: false
777
+ })
778
+ if ($tooltip) {
779
+ $tooltip.close()
780
+ }
781
+ }
782
+ return $xeForm.$nextTick()
783
+ },
784
+ triggerTitleTipEvent (evnt: MouseEvent, params: {
785
+ item: VxeFormDefines.ItemInfo;
786
+ }) {
787
+ const $xeForm = this
788
+ const internalData = $xeForm.internalData
789
+
790
+ const { item } = params
791
+ const { tooltipStore } = internalData
792
+ const $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
793
+ const overflowElem = (evnt.currentTarget as HTMLDivElement).children[0]
794
+ const content = (overflowElem.textContent || '').trim()
795
+ const isCellOverflow = overflowElem.scrollWidth > overflowElem.clientWidth
796
+ clearTimeout(internalData.stTimeout)
797
+ if (tooltipStore.item !== item) {
798
+ $xeForm.closeTooltip()
799
+ }
800
+ if (content && isCellOverflow) {
801
+ Object.assign(tooltipStore, {
802
+ item,
803
+ visible: true
804
+ })
805
+ if ($tooltip) {
806
+ $tooltip.open(overflowElem, content)
807
+ }
808
+ }
809
+ },
810
+ handleTitleTipLeaveEvent () {
811
+ const $xeForm = this
812
+ const internalData = $xeForm.internalData
813
+
814
+ const tooltipOpts = $xeForm.computeTooltipOpts
815
+ let $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
816
+ if ($tooltip) {
817
+ $tooltip.setActived(false)
818
+ }
819
+ if (tooltipOpts.enterable) {
820
+ internalData.stTimeout = setTimeout(() => {
821
+ $tooltip = $xeForm.$refs.refTooltip as VxeTooltipConstructor
822
+ if ($tooltip && !$tooltip.isActived()) {
823
+ $xeForm.closeTooltip()
824
+ }
825
+ }, tooltipOpts.leaveDelay)
826
+ } else {
827
+ $xeForm.closeTooltip()
828
+ }
829
+ },
830
+ handleValidIconEvent (evnt: Event, params: {
831
+ item: VxeFormDefines.ItemInfo;
832
+ }) {
833
+ const { item } = params
834
+ item.showIconMsg = !item.showIconMsg
835
+ },
836
+ triggerItemEvent (evnt: Event, field: string, itemValue?: any) {
837
+ const $xeForm = this
838
+
839
+ if (field) {
840
+ return $xeForm.validItemRules(evnt ? (['blur'].includes(evnt.type) ? 'blur' : 'change') : 'all', field, itemValue)
841
+ .then(() => {
842
+ $xeForm.clearValidate(field)
843
+ })
844
+ .catch((errorMaps: VxeFormDefines.ValidateErrorMapParams) => {
845
+ const rest = errorMaps[field]
846
+ const item = $xeForm.getItemByField(field)
847
+ if (rest && item) {
848
+ item.showError = true
849
+ item.errRule = rest[0].rule
850
+ }
851
+ })
852
+ }
853
+ return $xeForm.$nextTick()
854
+ },
855
+ /**
856
+ * 更新项状态
857
+ * 如果组件值 v-model 发生 change 时,调用改函数用于更新某一项编辑状态
858
+ * 如果单元格配置了校验规则,则会进行校验
859
+ */
860
+ updateStatus (scope: any, itemValue?: any) {
861
+ const $xeForm = this
862
+
863
+ const { field } = scope
864
+ return $xeForm.triggerItemEvent(new Event('change'), field, itemValue)
865
+ },
866
+ recalculate () {
867
+ const $xeForm = this
868
+
869
+ const autoItemWidthList = $xeForm.computeAutoItemWidthList
870
+ const el = $xeForm.$refs.refElem as HTMLFormElement
871
+ if (el && autoItemWidthList.length) {
872
+ const itemElList = el.querySelectorAll<HTMLElement>(autoItemWidthList.map(item => `.vxe-form--item-title[itemid="${item.id}"]`).join(','))
873
+ let maxItemWidth = 0
874
+ XEUtils.arrayEach(itemElList, itemEl => {
875
+ itemEl.style.width = ''
876
+ maxItemWidth = Math.max(maxItemWidth, Math.ceil(itemEl.clientWidth + 2))
877
+ })
878
+ XEUtils.arrayEach(itemElList, itemEl => {
879
+ itemEl.style.width = `${maxItemWidth}px`
880
+ })
881
+ }
882
+ return $xeForm.$nextTick()
883
+ },
884
+ handleGlobalResizeEvent () {
885
+ const $xeForm = this
886
+
887
+ $xeForm.recalculate()
888
+ },
889
+
890
+ //
891
+ // Render
892
+ //
893
+ renderVN (h: CreateElement): VNode {
894
+ const $xeForm = this
895
+ const props = $xeForm
896
+ const slots = $xeForm.$scopedSlots
897
+ const reactData = $xeForm.reactData
898
+
899
+ const { loading, border, className, data, customLayout } = props
900
+ const { formItems } = reactData
901
+ // const formItems: any[] = []
902
+ const vSize = $xeForm.computeSize
903
+ const tooltipOpts = $xeForm.computeTooltipOpts
904
+ const defaultSlot = slots.default
905
+ return h('form', {
906
+ ref: 'refElem',
907
+ class: ['vxe-form', className ? (XEUtils.isFunction(className) ? className({ items: formItems, data, $form: $xeForm }) : className) : '', {
908
+ [`size--${vSize}`]: vSize,
909
+ 'is--border': border,
910
+ 'custom--layout': customLayout,
911
+ 'is--loading': loading
912
+ }],
913
+ on: {
914
+ submit: $xeForm.submitEvent,
915
+ reset: $xeForm.resetEvent
916
+ }
917
+ }, [
918
+ h('div', {
919
+ class: 'vxe-form--wrapper vxe-form--item-row'
920
+ }, customLayout
921
+ ? (defaultSlot ? defaultSlot({}) : [])
922
+ : formItems.map((item, index) => {
923
+ return h(VxeFormConfigItem, {
924
+ key: index,
925
+ props: {
926
+ itemConfig: item
927
+ }
928
+ })
929
+ })),
930
+ h('div', {
931
+ class: 'vxe-form-slots',
932
+ ref: 'hideItem'
933
+ }, customLayout ? [] : (defaultSlot ? defaultSlot({}) : [])),
934
+ /**
935
+ * 加载中
936
+ */
937
+ h(VxeLoadingComponent, {
938
+ class: 'vxe-form--loading',
939
+ props: {
940
+ value: loading
941
+ }
942
+ }),
943
+ /**
944
+ * 工具提示
945
+ */
946
+ h(VxeTooltipComponent, {
947
+ ref: 'refTooltip',
948
+ ...tooltipOpts
949
+ })
950
+ ])
951
+ }
952
+ },
953
+ watch: {
954
+ vertical () {
955
+ const $xeForm = this
956
+
957
+ $xeForm.recalcFlag++
958
+ },
959
+ titleWidth () {
960
+ const $xeForm = this
961
+
962
+ $xeForm.recalcFlag++
963
+ },
964
+ recalcFlag () {
965
+ const $xeForm = this
966
+
967
+ $xeForm.$nextTick().then(() => {
968
+ $xeForm.recalculate()
969
+ })
970
+ },
971
+ 'reactData.staticItems' () {
972
+ const $xeForm = this
973
+ const reactData = $xeForm.reactData
974
+
975
+ reactData.formItems = reactData.staticItems
976
+ $xeForm.recalcFlag++
977
+ },
978
+ items () {
979
+ const $xeForm = this
980
+ const props = $xeForm
981
+
982
+ $xeForm.loadItem(props.items || [])
983
+ },
984
+ collapseStatus (val) {
985
+ const $xeForm = this
986
+ const reactData = $xeForm.reactData
987
+
988
+ reactData.collapseAll = !!val
989
+ },
990
+ readonly () {
991
+ const $xeForm = this
992
+
993
+ $xeForm.clearValidate()
994
+ },
995
+ disabled () {
996
+ const $xeForm = this
997
+
998
+ $xeForm.clearValidate()
999
+ }
1000
+ },
1001
+ created () {
1002
+ const $xeForm = this
1003
+ const props = $xeForm
1004
+ const reactData = $xeForm.reactData
1005
+
1006
+ reactData.collapseAll = !!props.collapseStatus
1007
+ },
1008
+ mounted () {
1009
+ const $xeForm = this
1010
+ const props = $xeForm
1011
+
1012
+ if (props.items) {
1013
+ $xeForm.loadItem(props.items)
1014
+ }
1015
+ $xeForm.$nextTick(() => {
1016
+ if (props.customLayout && props.items) {
1017
+ errLog('vxe.error.errConflicts', ['[form] custom-layout', 'items'])
1018
+ }
1019
+ })
1020
+ globalEvents.on($xeForm, 'resize', $xeForm.handleGlobalResizeEvent)
1021
+ },
1022
+ destroyed () {
1023
+ const $xeForm = this
1024
+ const internalData = $xeForm.internalData
1025
+
1026
+ globalEvents.off($xeForm, 'resize')
1027
+ XEUtils.assign(internalData, createInternalData())
1028
+ },
1029
+ render (this: any, h) {
1030
+ return this.renderVN(h)
1031
+ }
1032
+ }) /* define-vxe-component end */