element-pe 2.3.3 → 2.3.4

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 (562) hide show
  1. package/dist/index.full.js +5 -1
  2. package/dist/index.full.min.js +20 -20
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +21 -21
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +5 -1
  7. package/es/components/affix/index.mjs +2 -2
  8. package/es/components/affix/src/affix.mjs +119 -26
  9. package/es/components/affix/src/affix.mjs.map +1 -1
  10. package/es/components/affix/src/affix2.mjs +26 -119
  11. package/es/components/affix/src/affix2.mjs.map +1 -1
  12. package/es/components/alert/index.mjs +2 -2
  13. package/es/components/alert/src/alert.mjs +38 -103
  14. package/es/components/alert/src/alert.mjs.map +1 -1
  15. package/es/components/alert/src/alert2.mjs +103 -38
  16. package/es/components/alert/src/alert2.mjs.map +1 -1
  17. package/es/components/autocomplete/index.d.ts +15 -15
  18. package/es/components/autocomplete/index.mjs +2 -2
  19. package/es/components/autocomplete/src/autocomplete.mjs +381 -99
  20. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  21. package/es/components/autocomplete/src/autocomplete.vue.d.ts +15 -15
  22. package/es/components/autocomplete/src/autocomplete2.mjs +99 -381
  23. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  24. package/es/components/backtop/index.mjs +2 -2
  25. package/es/components/backtop/src/backtop.mjs +61 -23
  26. package/es/components/backtop/src/backtop.mjs.map +1 -1
  27. package/es/components/backtop/src/backtop2.mjs +23 -61
  28. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  29. package/es/components/breadcrumb/index.d.ts +2 -2
  30. package/es/components/breadcrumb/index.mjs +2 -2
  31. package/es/components/breadcrumb/src/breadcrumb-item.vue.d.ts +1 -1
  32. package/es/components/breadcrumb/src/breadcrumb.mjs +39 -11
  33. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  34. package/es/components/breadcrumb/src/breadcrumb2.mjs +11 -39
  35. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  36. package/es/components/button/index.d.ts +1 -1
  37. package/es/components/button/index.mjs +1 -1
  38. package/es/components/button/src/button-group.mjs +6 -30
  39. package/es/components/button/src/button-group.mjs.map +1 -1
  40. package/es/components/button/src/button-group2.mjs +30 -6
  41. package/es/components/button/src/button-group2.mjs.map +1 -1
  42. package/es/components/button/src/button.vue.d.ts +1 -1
  43. package/es/components/calendar/index.d.ts +1 -1
  44. package/es/components/calendar/src/calendar.vue.d.ts +1 -1
  45. package/es/components/calendar/src/calendar2.mjs +1 -1
  46. package/es/components/calendar/src/date-table.mjs +33 -87
  47. package/es/components/calendar/src/date-table.mjs.map +1 -1
  48. package/es/components/calendar/src/date-table2.mjs +87 -33
  49. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  50. package/es/components/calendar/src/use-date-table.mjs +1 -1
  51. package/es/components/carousel/index.mjs +2 -2
  52. package/es/components/carousel/src/carousel-item.mjs +70 -8
  53. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  54. package/es/components/carousel/src/carousel-item2.mjs +8 -70
  55. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  56. package/es/components/cascader/index.d.ts +22 -22
  57. package/es/components/cascader/index.mjs +2 -2
  58. package/es/components/cascader/src/cascader.mjs +89 -655
  59. package/es/components/cascader/src/cascader.mjs.map +1 -1
  60. package/es/components/cascader/src/cascader.vue.d.ts +11 -11
  61. package/es/components/cascader/src/cascader2.mjs +655 -89
  62. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  63. package/es/components/checkbox/index.d.ts +3 -3
  64. package/es/components/checkbox/index.mjs +4 -4
  65. package/es/components/checkbox/src/checkbox-button.mjs +1 -1
  66. package/es/components/checkbox/src/checkbox-button.vue.d.ts +1 -1
  67. package/es/components/checkbox/src/checkbox-group.mjs +72 -33
  68. package/es/components/checkbox/src/checkbox-group.mjs.map +1 -1
  69. package/es/components/checkbox/src/checkbox-group2.mjs +33 -72
  70. package/es/components/checkbox/src/checkbox-group2.mjs.map +1 -1
  71. package/es/components/checkbox/src/checkbox.mjs +125 -67
  72. package/es/components/checkbox/src/checkbox.mjs.map +1 -1
  73. package/es/components/checkbox/src/checkbox.vue.d.ts +1 -1
  74. package/es/components/checkbox/src/checkbox2.mjs +67 -125
  75. package/es/components/checkbox/src/checkbox2.mjs.map +1 -1
  76. package/es/components/collapse/index.mjs +2 -2
  77. package/es/components/collapse/src/collapse.mjs +28 -18
  78. package/es/components/collapse/src/collapse.mjs.map +1 -1
  79. package/es/components/collapse/src/collapse2.mjs +18 -28
  80. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  81. package/es/components/color-picker/index.d.ts +4 -4
  82. package/es/components/color-picker/src/color-picker.vue.d.ts +4 -4
  83. package/es/components/date-picker/src/date-picker-com/panel-date-pick.vue.d.ts +4 -4
  84. package/es/components/date-picker/src/date-picker-com/panel-date-range.vue.d.ts +4 -4
  85. package/es/components/date-picker/src/panel-utils.d.ts +8 -8
  86. package/es/components/dialog/src/dialog-content.mjs +27 -96
  87. package/es/components/dialog/src/dialog-content.mjs.map +1 -1
  88. package/es/components/dialog/src/dialog-content2.mjs +96 -27
  89. package/es/components/dialog/src/dialog-content2.mjs.map +1 -1
  90. package/es/components/dialog/src/dialog.mjs +1 -1
  91. package/es/components/dialog/src/dialog2.mjs +1 -1
  92. package/es/components/drawer/index.mjs +2 -2
  93. package/es/components/drawer/src/drawer.mjs +191 -30
  94. package/es/components/drawer/src/drawer.mjs.map +1 -1
  95. package/es/components/drawer/src/drawer2.mjs +30 -191
  96. package/es/components/drawer/src/drawer2.mjs.map +1 -1
  97. package/es/components/dropdown/index.mjs +2 -2
  98. package/es/components/dropdown/src/dropdown-item-impl.mjs +2 -2
  99. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  100. package/es/components/dropdown/src/dropdown-menu.mjs +2 -2
  101. package/es/components/dropdown/src/dropdown.mjs +109 -310
  102. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  103. package/es/components/dropdown/src/dropdown2.mjs +310 -109
  104. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  105. package/es/components/empty/index.mjs +2 -2
  106. package/es/components/empty/src/empty.mjs +55 -11
  107. package/es/components/empty/src/empty.mjs.map +1 -1
  108. package/es/components/empty/src/empty2.mjs +11 -55
  109. package/es/components/empty/src/empty2.mjs.map +1 -1
  110. package/es/components/form/index.mjs +4 -4
  111. package/es/components/form/src/form-item.mjs +331 -46
  112. package/es/components/form/src/form-item.mjs.map +1 -1
  113. package/es/components/form/src/form-item2.mjs +46 -331
  114. package/es/components/form/src/form-item2.mjs.map +1 -1
  115. package/es/components/form/src/form.mjs +154 -58
  116. package/es/components/form/src/form.mjs.map +1 -1
  117. package/es/components/form/src/form2.mjs +58 -154
  118. package/es/components/form/src/form2.mjs.map +1 -1
  119. package/es/components/image/index.mjs +2 -2
  120. package/es/components/image/src/image.mjs +234 -67
  121. package/es/components/image/src/image.mjs.map +1 -1
  122. package/es/components/image/src/image2.mjs +67 -230
  123. package/es/components/image/src/image2.mjs.map +1 -1
  124. package/es/components/image-viewer/index.mjs +2 -2
  125. package/es/components/image-viewer/src/image-viewer.mjs +406 -45
  126. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  127. package/es/components/image-viewer/src/image-viewer2.mjs +45 -406
  128. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  129. package/es/components/index.mjs +31 -31
  130. package/es/components/input/index.d.ts +3 -3
  131. package/es/components/input/index.mjs +2 -2
  132. package/es/components/input/src/input.mjs +470 -124
  133. package/es/components/input/src/input.mjs.map +1 -1
  134. package/es/components/input/src/input.vue.d.ts +3 -3
  135. package/es/components/input/src/input2.mjs +124 -470
  136. package/es/components/input/src/input2.mjs.map +1 -1
  137. package/es/components/input-number/index.d.ts +12 -12
  138. package/es/components/input-number/src/input-number.vue.d.ts +12 -12
  139. package/es/components/link/index.mjs +2 -2
  140. package/es/components/link/src/link.mjs +51 -25
  141. package/es/components/link/src/link.mjs.map +1 -1
  142. package/es/components/link/src/link2.mjs +25 -51
  143. package/es/components/link/src/link2.mjs.map +1 -1
  144. package/es/components/menu/index.mjs +2 -2
  145. package/es/components/menu/src/menu-item.mjs +97 -14
  146. package/es/components/menu/src/menu-item.mjs.map +1 -1
  147. package/es/components/menu/src/menu-item2.mjs +14 -97
  148. package/es/components/menu/src/menu-item2.mjs.map +1 -1
  149. package/es/components/message/src/message.vue.d.ts +1 -1
  150. package/es/components/notification/index.mjs +1 -1
  151. package/es/components/notification/src/notification.mjs +151 -67
  152. package/es/components/notification/src/notification.mjs.map +1 -1
  153. package/es/components/notification/src/notification.vue.d.ts +1 -1
  154. package/es/components/notification/src/notification2.mjs +67 -151
  155. package/es/components/notification/src/notification2.mjs.map +1 -1
  156. package/es/components/notification/src/notify.mjs +2 -2
  157. package/es/components/pagination/src/components/jumper.mjs +9 -60
  158. package/es/components/pagination/src/components/jumper.mjs.map +1 -1
  159. package/es/components/pagination/src/components/jumper.vue.d.ts +3 -3
  160. package/es/components/pagination/src/components/jumper2.mjs +60 -9
  161. package/es/components/pagination/src/components/jumper2.mjs.map +1 -1
  162. package/es/components/pagination/src/components/sizes.vue.d.ts +1 -1
  163. package/es/components/pagination/src/pagination.mjs +1 -1
  164. package/es/components/popconfirm/index.d.ts +1 -1
  165. package/es/components/popconfirm/index.mjs +2 -2
  166. package/es/components/popconfirm/src/popconfirm.mjs +47 -110
  167. package/es/components/popconfirm/src/popconfirm.mjs.map +1 -1
  168. package/es/components/popconfirm/src/popconfirm.vue.d.ts +1 -1
  169. package/es/components/popconfirm/src/popconfirm2.mjs +110 -47
  170. package/es/components/popconfirm/src/popconfirm2.mjs.map +1 -1
  171. package/es/components/popover/src/popover.mjs +2 -2
  172. package/es/components/radio/index.d.ts +2 -2
  173. package/es/components/radio/index.mjs +4 -4
  174. package/es/components/radio/src/radio-button.mjs +68 -6
  175. package/es/components/radio/src/radio-button.mjs.map +1 -1
  176. package/es/components/radio/src/radio-button2.mjs +6 -68
  177. package/es/components/radio/src/radio-button2.mjs.map +1 -1
  178. package/es/components/radio/src/radio-group.mjs +42 -70
  179. package/es/components/radio/src/radio-group.mjs.map +1 -1
  180. package/es/components/radio/src/radio-group.vue.d.ts +1 -1
  181. package/es/components/radio/src/radio-group2.mjs +70 -42
  182. package/es/components/radio/src/radio-group2.mjs.map +1 -1
  183. package/es/components/rate/index.d.ts +1 -1
  184. package/es/components/rate/src/rate.vue.d.ts +1 -1
  185. package/es/components/resizable-columns/index.mjs +2 -2
  186. package/es/components/resizable-columns/src/resizable-columns.mjs +264 -21
  187. package/es/components/resizable-columns/src/resizable-columns.mjs.map +1 -1
  188. package/es/components/resizable-columns/src/resizable-columns2.mjs +21 -264
  189. package/es/components/resizable-columns/src/resizable-columns2.mjs.map +1 -1
  190. package/es/components/result/index.mjs +2 -2
  191. package/es/components/result/src/result.mjs +63 -29
  192. package/es/components/result/src/result.mjs.map +1 -1
  193. package/es/components/result/src/result2.mjs +29 -63
  194. package/es/components/result/src/result2.mjs.map +1 -1
  195. package/es/components/roving-focus-group/index.mjs +3 -3
  196. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  197. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -29
  198. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  199. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +29 -27
  200. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  201. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  202. package/es/components/segmented/index.mjs +2 -2
  203. package/es/components/segmented/src/segmented.mjs +29 -163
  204. package/es/components/segmented/src/segmented.mjs.map +1 -1
  205. package/es/components/segmented/src/segmented2.mjs +163 -29
  206. package/es/components/segmented/src/segmented2.mjs.map +1 -1
  207. package/es/components/select/index.d.ts +1 -1
  208. package/es/components/select/index.mjs +1 -1
  209. package/es/components/select/src/select.mjs +119 -377
  210. package/es/components/select/src/select.mjs.map +1 -1
  211. package/es/components/select/src/select.vue.d.ts +1 -1
  212. package/es/components/select/src/select2.mjs +377 -119
  213. package/es/components/select/src/select2.mjs.map +1 -1
  214. package/es/components/select-v2/index.d.ts +2 -2
  215. package/es/components/select-v2/src/select.vue.d.ts +1 -1
  216. package/es/components/skeleton/index.mjs +2 -2
  217. package/es/components/skeleton/src/skeleton-item.mjs +18 -23
  218. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  219. package/es/components/skeleton/src/skeleton-item2.mjs +23 -18
  220. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  221. package/es/components/skeleton/src/skeleton2.mjs +1 -1
  222. package/es/components/slider/index.d.ts +13 -13
  223. package/es/components/slider/src/slider.vue.d.ts +13 -13
  224. package/es/components/steps/index.mjs +2 -2
  225. package/es/components/steps/src/item.mjs +19 -193
  226. package/es/components/steps/src/item.mjs.map +1 -1
  227. package/es/components/steps/src/item2.mjs +193 -19
  228. package/es/components/steps/src/item2.mjs.map +1 -1
  229. package/es/components/teleport/index.mjs +2 -2
  230. package/es/components/teleport/src/teleport.mjs +18 -44
  231. package/es/components/teleport/src/teleport.mjs.map +1 -1
  232. package/es/components/teleport/src/teleport2.mjs +44 -18
  233. package/es/components/teleport/src/teleport2.mjs.map +1 -1
  234. package/es/components/time-picker/src/common/picker.vue.d.ts +3 -3
  235. package/es/components/time-select/index.d.ts +4 -4
  236. package/es/components/time-select/src/time-select.vue.d.ts +2 -2
  237. package/es/components/tooltip/index.mjs +1 -1
  238. package/es/components/tooltip/src/tooltip.mjs +1 -1
  239. package/es/components/tooltip/src/tooltip2.mjs +1 -1
  240. package/es/components/tooltip/src/trigger.mjs +73 -16
  241. package/es/components/tooltip/src/trigger.mjs.map +1 -1
  242. package/es/components/tooltip/src/trigger2.mjs +16 -73
  243. package/es/components/tooltip/src/trigger2.mjs.map +1 -1
  244. package/es/components/tooltip-v2/index.d.ts +5 -5
  245. package/es/components/tooltip-v2/index.mjs +2 -2
  246. package/es/components/tooltip-v2/src/content2.mjs +1 -1
  247. package/es/components/tooltip-v2/src/tooltip.mjs +20 -77
  248. package/es/components/tooltip-v2/src/tooltip.mjs.map +1 -1
  249. package/es/components/tooltip-v2/src/tooltip.vue.d.ts +5 -5
  250. package/es/components/tooltip-v2/src/tooltip2.mjs +77 -20
  251. package/es/components/tooltip-v2/src/tooltip2.mjs.map +1 -1
  252. package/es/components/tour/index.mjs +3 -3
  253. package/es/components/tour/src/content.mjs +69 -44
  254. package/es/components/tour/src/content.mjs.map +1 -1
  255. package/es/components/tour/src/content2.mjs +44 -69
  256. package/es/components/tour/src/content2.mjs.map +1 -1
  257. package/es/components/tour/src/step.mjs +171 -46
  258. package/es/components/tour/src/step.mjs.map +1 -1
  259. package/es/components/tour/src/step.vue.d.ts +1 -1
  260. package/es/components/tour/src/step2.mjs +46 -171
  261. package/es/components/tour/src/step2.mjs.map +1 -1
  262. package/es/components/tour/src/tour.mjs +69 -152
  263. package/es/components/tour/src/tour.mjs.map +1 -1
  264. package/es/components/tour/src/tour2.mjs +152 -69
  265. package/es/components/tour/src/tour2.mjs.map +1 -1
  266. package/es/components/transfer/index.d.ts +26 -26
  267. package/es/components/transfer/src/composables/use-check.mjs +1 -1
  268. package/es/components/transfer/src/transfer-panel.mjs +19 -128
  269. package/es/components/transfer/src/transfer-panel.mjs.map +1 -1
  270. package/es/components/transfer/src/transfer-panel.vue.d.ts +5 -5
  271. package/es/components/transfer/src/transfer-panel2.mjs +128 -19
  272. package/es/components/transfer/src/transfer-panel2.mjs.map +1 -1
  273. package/es/components/transfer/src/transfer.mjs +1 -1
  274. package/es/components/transfer/src/transfer.vue.d.ts +26 -26
  275. package/es/components/tree-v2/index.d.ts +2 -2
  276. package/es/components/tree-v2/src/tree-node.vue.d.ts +2 -2
  277. package/es/components/tree-v2/src/tree.vue.d.ts +2 -2
  278. package/es/components/visual-hidden/index.mjs +3 -3
  279. package/es/components/visual-hidden/src/visual-hidden.mjs +7 -35
  280. package/es/components/visual-hidden/src/visual-hidden.mjs.map +1 -1
  281. package/es/components/visual-hidden/src/visual-hidden2.mjs +35 -7
  282. package/es/components/visual-hidden/src/visual-hidden2.mjs.map +1 -1
  283. package/es/index.mjs +31 -31
  284. package/lib/components/affix/index.js +2 -2
  285. package/lib/components/affix/src/affix.js +119 -27
  286. package/lib/components/affix/src/affix.js.map +1 -1
  287. package/lib/components/affix/src/affix2.js +27 -119
  288. package/lib/components/affix/src/affix2.js.map +1 -1
  289. package/lib/components/alert/index.js +2 -2
  290. package/lib/components/alert/src/alert.js +39 -102
  291. package/lib/components/alert/src/alert.js.map +1 -1
  292. package/lib/components/alert/src/alert2.js +102 -39
  293. package/lib/components/alert/src/alert2.js.map +1 -1
  294. package/lib/components/autocomplete/index.d.ts +15 -15
  295. package/lib/components/autocomplete/index.js +2 -2
  296. package/lib/components/autocomplete/src/autocomplete.js +380 -99
  297. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  298. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +15 -15
  299. package/lib/components/autocomplete/src/autocomplete2.js +99 -380
  300. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  301. package/lib/components/backtop/index.js +2 -2
  302. package/lib/components/backtop/src/backtop.js +61 -24
  303. package/lib/components/backtop/src/backtop.js.map +1 -1
  304. package/lib/components/backtop/src/backtop2.js +24 -61
  305. package/lib/components/backtop/src/backtop2.js.map +1 -1
  306. package/lib/components/breadcrumb/index.d.ts +2 -2
  307. package/lib/components/breadcrumb/index.js +2 -2
  308. package/lib/components/breadcrumb/src/breadcrumb-item.vue.d.ts +1 -1
  309. package/lib/components/breadcrumb/src/breadcrumb.js +39 -11
  310. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  311. package/lib/components/breadcrumb/src/breadcrumb2.js +11 -39
  312. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  313. package/lib/components/button/index.d.ts +1 -1
  314. package/lib/components/button/index.js +1 -1
  315. package/lib/components/button/src/button-group.js +6 -30
  316. package/lib/components/button/src/button-group.js.map +1 -1
  317. package/lib/components/button/src/button-group2.js +30 -6
  318. package/lib/components/button/src/button-group2.js.map +1 -1
  319. package/lib/components/button/src/button.vue.d.ts +1 -1
  320. package/lib/components/calendar/index.d.ts +1 -1
  321. package/lib/components/calendar/src/calendar.vue.d.ts +1 -1
  322. package/lib/components/calendar/src/calendar2.js +1 -1
  323. package/lib/components/calendar/src/date-table.js +37 -87
  324. package/lib/components/calendar/src/date-table.js.map +1 -1
  325. package/lib/components/calendar/src/date-table2.js +87 -37
  326. package/lib/components/calendar/src/date-table2.js.map +1 -1
  327. package/lib/components/calendar/src/use-date-table.js +1 -1
  328. package/lib/components/carousel/index.js +2 -2
  329. package/lib/components/carousel/src/carousel-item.js +70 -8
  330. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  331. package/lib/components/carousel/src/carousel-item2.js +8 -70
  332. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  333. package/lib/components/cascader/index.d.ts +22 -22
  334. package/lib/components/cascader/index.js +2 -2
  335. package/lib/components/cascader/src/cascader.js +90 -655
  336. package/lib/components/cascader/src/cascader.js.map +1 -1
  337. package/lib/components/cascader/src/cascader.vue.d.ts +11 -11
  338. package/lib/components/cascader/src/cascader2.js +655 -90
  339. package/lib/components/cascader/src/cascader2.js.map +1 -1
  340. package/lib/components/checkbox/index.d.ts +3 -3
  341. package/lib/components/checkbox/index.js +4 -4
  342. package/lib/components/checkbox/src/checkbox-button.js +1 -1
  343. package/lib/components/checkbox/src/checkbox-button.vue.d.ts +1 -1
  344. package/lib/components/checkbox/src/checkbox-group.js +72 -34
  345. package/lib/components/checkbox/src/checkbox-group.js.map +1 -1
  346. package/lib/components/checkbox/src/checkbox-group2.js +34 -72
  347. package/lib/components/checkbox/src/checkbox-group2.js.map +1 -1
  348. package/lib/components/checkbox/src/checkbox.js +125 -68
  349. package/lib/components/checkbox/src/checkbox.js.map +1 -1
  350. package/lib/components/checkbox/src/checkbox.vue.d.ts +1 -1
  351. package/lib/components/checkbox/src/checkbox2.js +68 -125
  352. package/lib/components/checkbox/src/checkbox2.js.map +1 -1
  353. package/lib/components/collapse/index.js +2 -2
  354. package/lib/components/collapse/src/collapse.js +28 -20
  355. package/lib/components/collapse/src/collapse.js.map +1 -1
  356. package/lib/components/collapse/src/collapse2.js +20 -28
  357. package/lib/components/collapse/src/collapse2.js.map +1 -1
  358. package/lib/components/color-picker/index.d.ts +4 -4
  359. package/lib/components/color-picker/src/color-picker.vue.d.ts +4 -4
  360. package/lib/components/date-picker/src/date-picker-com/panel-date-pick.vue.d.ts +4 -4
  361. package/lib/components/date-picker/src/date-picker-com/panel-date-range.vue.d.ts +4 -4
  362. package/lib/components/date-picker/src/panel-utils.d.ts +8 -8
  363. package/lib/components/dialog/src/dialog-content.js +27 -95
  364. package/lib/components/dialog/src/dialog-content.js.map +1 -1
  365. package/lib/components/dialog/src/dialog-content2.js +95 -27
  366. package/lib/components/dialog/src/dialog-content2.js.map +1 -1
  367. package/lib/components/dialog/src/dialog.js +1 -1
  368. package/lib/components/dialog/src/dialog2.js +1 -1
  369. package/lib/components/drawer/index.js +2 -2
  370. package/lib/components/drawer/src/drawer.js +191 -31
  371. package/lib/components/drawer/src/drawer.js.map +1 -1
  372. package/lib/components/drawer/src/drawer2.js +31 -191
  373. package/lib/components/drawer/src/drawer2.js.map +1 -1
  374. package/lib/components/dropdown/index.js +2 -2
  375. package/lib/components/dropdown/src/dropdown-item-impl.js +2 -2
  376. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  377. package/lib/components/dropdown/src/dropdown-menu.js +2 -2
  378. package/lib/components/dropdown/src/dropdown.js +118 -310
  379. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  380. package/lib/components/dropdown/src/dropdown2.js +310 -118
  381. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  382. package/lib/components/empty/index.js +2 -2
  383. package/lib/components/empty/src/empty.js +55 -11
  384. package/lib/components/empty/src/empty.js.map +1 -1
  385. package/lib/components/empty/src/empty2.js +11 -55
  386. package/lib/components/empty/src/empty2.js.map +1 -1
  387. package/lib/components/form/index.js +4 -4
  388. package/lib/components/form/src/form-item.js +335 -47
  389. package/lib/components/form/src/form-item.js.map +1 -1
  390. package/lib/components/form/src/form-item2.js +47 -335
  391. package/lib/components/form/src/form-item2.js.map +1 -1
  392. package/lib/components/form/src/form.js +153 -58
  393. package/lib/components/form/src/form.js.map +1 -1
  394. package/lib/components/form/src/form2.js +58 -153
  395. package/lib/components/form/src/form2.js.map +1 -1
  396. package/lib/components/image/index.js +2 -2
  397. package/lib/components/image/src/image.js +233 -67
  398. package/lib/components/image/src/image.js.map +1 -1
  399. package/lib/components/image/src/image2.js +67 -229
  400. package/lib/components/image/src/image2.js.map +1 -1
  401. package/lib/components/image-viewer/index.js +2 -2
  402. package/lib/components/image-viewer/src/image-viewer.js +406 -46
  403. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  404. package/lib/components/image-viewer/src/image-viewer2.js +46 -406
  405. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  406. package/lib/components/index.js +31 -31
  407. package/lib/components/input/index.d.ts +3 -3
  408. package/lib/components/input/index.js +2 -2
  409. package/lib/components/input/src/input.js +469 -124
  410. package/lib/components/input/src/input.js.map +1 -1
  411. package/lib/components/input/src/input.vue.d.ts +3 -3
  412. package/lib/components/input/src/input2.js +124 -469
  413. package/lib/components/input/src/input2.js.map +1 -1
  414. package/lib/components/input-number/index.d.ts +12 -12
  415. package/lib/components/input-number/src/input-number.vue.d.ts +12 -12
  416. package/lib/components/link/index.js +2 -2
  417. package/lib/components/link/src/link.js +51 -26
  418. package/lib/components/link/src/link.js.map +1 -1
  419. package/lib/components/link/src/link2.js +26 -51
  420. package/lib/components/link/src/link2.js.map +1 -1
  421. package/lib/components/menu/index.js +2 -2
  422. package/lib/components/menu/src/menu-item.js +97 -15
  423. package/lib/components/menu/src/menu-item.js.map +1 -1
  424. package/lib/components/menu/src/menu-item2.js +15 -97
  425. package/lib/components/menu/src/menu-item2.js.map +1 -1
  426. package/lib/components/message/src/message.vue.d.ts +1 -1
  427. package/lib/components/notification/index.js +1 -1
  428. package/lib/components/notification/src/notification.js +150 -68
  429. package/lib/components/notification/src/notification.js.map +1 -1
  430. package/lib/components/notification/src/notification.vue.d.ts +1 -1
  431. package/lib/components/notification/src/notification2.js +68 -150
  432. package/lib/components/notification/src/notification2.js.map +1 -1
  433. package/lib/components/notification/src/notify.js +2 -2
  434. package/lib/components/pagination/src/components/jumper.js +9 -60
  435. package/lib/components/pagination/src/components/jumper.js.map +1 -1
  436. package/lib/components/pagination/src/components/jumper.vue.d.ts +3 -3
  437. package/lib/components/pagination/src/components/jumper2.js +60 -9
  438. package/lib/components/pagination/src/components/jumper2.js.map +1 -1
  439. package/lib/components/pagination/src/components/sizes.vue.d.ts +1 -1
  440. package/lib/components/pagination/src/pagination.js +1 -1
  441. package/lib/components/popconfirm/index.d.ts +1 -1
  442. package/lib/components/popconfirm/index.js +2 -2
  443. package/lib/components/popconfirm/src/popconfirm.js +48 -110
  444. package/lib/components/popconfirm/src/popconfirm.js.map +1 -1
  445. package/lib/components/popconfirm/src/popconfirm.vue.d.ts +1 -1
  446. package/lib/components/popconfirm/src/popconfirm2.js +110 -48
  447. package/lib/components/popconfirm/src/popconfirm2.js.map +1 -1
  448. package/lib/components/popover/src/popover.js +2 -2
  449. package/lib/components/radio/index.d.ts +2 -2
  450. package/lib/components/radio/index.js +4 -4
  451. package/lib/components/radio/src/radio-button.js +68 -6
  452. package/lib/components/radio/src/radio-button.js.map +1 -1
  453. package/lib/components/radio/src/radio-button2.js +6 -68
  454. package/lib/components/radio/src/radio-button2.js.map +1 -1
  455. package/lib/components/radio/src/radio-group.js +43 -70
  456. package/lib/components/radio/src/radio-group.js.map +1 -1
  457. package/lib/components/radio/src/radio-group.vue.d.ts +1 -1
  458. package/lib/components/radio/src/radio-group2.js +70 -43
  459. package/lib/components/radio/src/radio-group2.js.map +1 -1
  460. package/lib/components/rate/index.d.ts +1 -1
  461. package/lib/components/rate/src/rate.vue.d.ts +1 -1
  462. package/lib/components/resizable-columns/index.js +2 -2
  463. package/lib/components/resizable-columns/src/resizable-columns.js +264 -21
  464. package/lib/components/resizable-columns/src/resizable-columns.js.map +1 -1
  465. package/lib/components/resizable-columns/src/resizable-columns2.js +21 -264
  466. package/lib/components/resizable-columns/src/resizable-columns2.js.map +1 -1
  467. package/lib/components/result/index.js +2 -2
  468. package/lib/components/result/src/result.js +63 -31
  469. package/lib/components/result/src/result.js.map +1 -1
  470. package/lib/components/result/src/result2.js +31 -63
  471. package/lib/components/result/src/result2.js.map +1 -1
  472. package/lib/components/roving-focus-group/index.js +2 -2
  473. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  474. package/lib/components/roving-focus-group/src/roving-focus-group.js +27 -33
  475. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  476. package/lib/components/roving-focus-group/src/roving-focus-group2.js +33 -27
  477. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  478. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  479. package/lib/components/segmented/index.js +2 -2
  480. package/lib/components/segmented/src/segmented.js +29 -162
  481. package/lib/components/segmented/src/segmented.js.map +1 -1
  482. package/lib/components/segmented/src/segmented2.js +162 -29
  483. package/lib/components/segmented/src/segmented2.js.map +1 -1
  484. package/lib/components/select/index.d.ts +1 -1
  485. package/lib/components/select/index.js +1 -1
  486. package/lib/components/select/src/select.js +119 -377
  487. package/lib/components/select/src/select.js.map +1 -1
  488. package/lib/components/select/src/select.vue.d.ts +1 -1
  489. package/lib/components/select/src/select2.js +377 -119
  490. package/lib/components/select/src/select2.js.map +1 -1
  491. package/lib/components/select-v2/index.d.ts +2 -2
  492. package/lib/components/select-v2/src/select.vue.d.ts +1 -1
  493. package/lib/components/skeleton/index.js +2 -2
  494. package/lib/components/skeleton/src/skeleton-item.js +18 -23
  495. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  496. package/lib/components/skeleton/src/skeleton-item2.js +23 -18
  497. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  498. package/lib/components/skeleton/src/skeleton2.js +1 -1
  499. package/lib/components/slider/index.d.ts +13 -13
  500. package/lib/components/slider/src/slider.vue.d.ts +13 -13
  501. package/lib/components/steps/index.js +2 -2
  502. package/lib/components/steps/src/item.js +19 -193
  503. package/lib/components/steps/src/item.js.map +1 -1
  504. package/lib/components/steps/src/item2.js +193 -19
  505. package/lib/components/steps/src/item2.js.map +1 -1
  506. package/lib/components/teleport/index.js +2 -2
  507. package/lib/components/teleport/src/teleport.js +18 -44
  508. package/lib/components/teleport/src/teleport.js.map +1 -1
  509. package/lib/components/teleport/src/teleport2.js +44 -18
  510. package/lib/components/teleport/src/teleport2.js.map +1 -1
  511. package/lib/components/time-picker/src/common/picker.vue.d.ts +3 -3
  512. package/lib/components/time-select/index.d.ts +4 -4
  513. package/lib/components/time-select/src/time-select.vue.d.ts +2 -2
  514. package/lib/components/tooltip/index.js +1 -1
  515. package/lib/components/tooltip/src/tooltip.js +1 -1
  516. package/lib/components/tooltip/src/tooltip2.js +1 -1
  517. package/lib/components/tooltip/src/trigger.js +73 -16
  518. package/lib/components/tooltip/src/trigger.js.map +1 -1
  519. package/lib/components/tooltip/src/trigger2.js +16 -73
  520. package/lib/components/tooltip/src/trigger2.js.map +1 -1
  521. package/lib/components/tooltip-v2/index.d.ts +5 -5
  522. package/lib/components/tooltip-v2/index.js +2 -2
  523. package/lib/components/tooltip-v2/src/content2.js +1 -1
  524. package/lib/components/tooltip-v2/src/tooltip.js +20 -77
  525. package/lib/components/tooltip-v2/src/tooltip.js.map +1 -1
  526. package/lib/components/tooltip-v2/src/tooltip.vue.d.ts +5 -5
  527. package/lib/components/tooltip-v2/src/tooltip2.js +77 -20
  528. package/lib/components/tooltip-v2/src/tooltip2.js.map +1 -1
  529. package/lib/components/tour/index.js +3 -3
  530. package/lib/components/tour/src/content.js +69 -45
  531. package/lib/components/tour/src/content.js.map +1 -1
  532. package/lib/components/tour/src/content2.js +45 -69
  533. package/lib/components/tour/src/content2.js.map +1 -1
  534. package/lib/components/tour/src/step.js +170 -46
  535. package/lib/components/tour/src/step.js.map +1 -1
  536. package/lib/components/tour/src/step.vue.d.ts +1 -1
  537. package/lib/components/tour/src/step2.js +46 -170
  538. package/lib/components/tour/src/step2.js.map +1 -1
  539. package/lib/components/tour/src/tour.js +68 -150
  540. package/lib/components/tour/src/tour.js.map +1 -1
  541. package/lib/components/tour/src/tour2.js +150 -68
  542. package/lib/components/tour/src/tour2.js.map +1 -1
  543. package/lib/components/transfer/index.d.ts +26 -26
  544. package/lib/components/transfer/src/composables/use-check.js +1 -1
  545. package/lib/components/transfer/src/transfer-panel.js +21 -128
  546. package/lib/components/transfer/src/transfer-panel.js.map +1 -1
  547. package/lib/components/transfer/src/transfer-panel.vue.d.ts +5 -5
  548. package/lib/components/transfer/src/transfer-panel2.js +128 -21
  549. package/lib/components/transfer/src/transfer-panel2.js.map +1 -1
  550. package/lib/components/transfer/src/transfer.js +1 -1
  551. package/lib/components/transfer/src/transfer.vue.d.ts +26 -26
  552. package/lib/components/tree-v2/index.d.ts +2 -2
  553. package/lib/components/tree-v2/src/tree-node.vue.d.ts +2 -2
  554. package/lib/components/tree-v2/src/tree.vue.d.ts +2 -2
  555. package/lib/components/visual-hidden/index.js +2 -2
  556. package/lib/components/visual-hidden/src/visual-hidden.js +7 -35
  557. package/lib/components/visual-hidden/src/visual-hidden.js.map +1 -1
  558. package/lib/components/visual-hidden/src/visual-hidden2.js +35 -7
  559. package/lib/components/visual-hidden/src/visual-hidden2.js.map +1 -1
  560. package/lib/index.js +31 -31
  561. package/package.json +1 -1
  562. package/web-types.json +1 -1
@@ -1,337 +1,52 @@
1
- import { defineComponent, useSlots, inject, ref, computed, nextTick, reactive, toRefs, provide, onMounted, onBeforeUnmount, openBlock, createElementBlock, normalizeClass, unref, createVNode, withCtx, createBlock, resolveDynamicComponent, normalizeStyle, renderSlot, createTextVNode, toDisplayString, createCommentVNode, createElementVNode, TransitionGroup } from 'vue';
2
- import '../../config-provider/index.mjs';
3
- import AsyncValidator from 'async-validator';
4
- import { castArray, clone } from 'lodash-unified';
5
- import { refDebounced } from '@vueuse/core';
1
+ import '../../../constants/index.mjs';
6
2
  import '../../../utils/index.mjs';
7
- import '../../../hooks/index.mjs';
8
- import './hooks/index.mjs';
9
- import { formItemProps } from './form-item.mjs';
10
- import FormLabelWrap from './form-label-wrap.mjs';
11
- import { formContextKey, formItemContextKey } from './constants.mjs';
12
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
13
- import { useGlobalConfig } from '../../config-provider/src/hooks/use-global-config.mjs';
14
- import { useFormSize, useFormViewMode, useFormSelf } from './hooks/use-form-common-props.mjs';
15
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
16
- import { useId } from '../../../hooks/use-id/index.mjs';
17
- import { addUnit } from '../../../utils/dom/style.mjs';
18
- import { isBoolean } from '../../../utils/types.mjs';
19
- import { isString, isFunction } from '@vue/shared';
20
- import { getProp } from '../../../utils/objects.mjs';
21
- import { watch } from '../../config-provider/src/for-editor.mjs';
3
+ import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
4
+ import { componentSizes } from '../../../constants/size.mjs';
22
5
 
23
- const _hoisted_1 = ["role", "aria-labelledby", "widget"];
24
- const _hoisted_2 = ["widget"];
25
- const __default__ = defineComponent({
26
- name: "ElFormItem"
27
- });
28
- const _sfc_main = /* @__PURE__ */ defineComponent({
29
- ...__default__,
30
- props: formItemProps,
31
- setup(__props, { expose }) {
32
- const props = __props;
33
- const forEditor = useGlobalConfig("forEditor");
34
- const slots = useSlots();
35
- const formContext = inject(formContextKey, void 0);
36
- const parentFormItemContext = inject(formItemContextKey, void 0);
37
- const _size = useFormSize(void 0, { formItem: false });
38
- const inputViewMode = useFormViewMode(void 0);
39
- const ns = useNamespace("form-item");
40
- const _form = useFormSelf();
41
- const labelId = useId().value;
42
- const inputIds = ref([]);
43
- const validateState = ref("");
44
- const validateStateDebounced = refDebounced(validateState, 100);
45
- const validateMessage = ref("");
46
- const formItemRef = ref();
47
- let initialValue = void 0;
48
- let isResettingField = false;
49
- const labelStyle = computed(() => {
50
- if ((formContext == null ? void 0 : formContext.labelPosition) === "top") {
51
- return {};
52
- }
53
- const labelWidth = addUnit(props.labelWidth || (formContext == null ? void 0 : formContext.labelWidth) || "");
54
- if (labelWidth)
55
- return { width: labelWidth };
56
- return {};
57
- });
58
- const contentStyle = computed(() => {
59
- if ((formContext == null ? void 0 : formContext.labelPosition) === "top" || (formContext == null ? void 0 : formContext.inline)) {
60
- return {};
61
- }
62
- if (!props.label && !props.labelWidth && isNested) {
63
- return {};
64
- }
65
- const labelWidth = addUnit(props.labelWidth || (formContext == null ? void 0 : formContext.labelWidth) || "");
66
- if (!props.label && !slots.label) {
67
- return { marginLeft: labelWidth };
68
- }
69
- return {};
70
- });
71
- const formItemClasses = computed(() => [
72
- ns.b(),
73
- ns.m(_size.value),
74
- ns.is("error", validateState.value === "error"),
75
- ns.is("validating", validateState.value === "validating"),
76
- ns.is("success", validateState.value === "success"),
77
- ns.is("required", isRequired.value || props.required),
78
- ns.is("no-asterisk", formContext == null ? void 0 : formContext.hideRequiredAsterisk),
79
- (formContext == null ? void 0 : formContext.requireAsteriskPosition) === "right" ? "asterisk-right" : "asterisk-left",
80
- { [ns.m("feedback")]: formContext == null ? void 0 : formContext.statusIcon },
81
- inputViewMode.value ? "view-mode-" + inputViewMode.value : ""
82
- ]);
83
- const _inlineMessage = computed(() => isBoolean(props.inlineMessage) ? props.inlineMessage : (formContext == null ? void 0 : formContext.inlineMessage) || false);
84
- const validateClasses = computed(() => [
85
- ns.e("error"),
86
- { [ns.em("error", "inline")]: _inlineMessage.value }
87
- ]);
88
- const propString = computed(() => {
89
- if (!props.prop)
90
- return "";
91
- return isString(props.prop) ? props.prop : props.prop.join(".");
92
- });
93
- const hasLabel = computed(() => {
94
- return !!(props.label || slots.label);
95
- });
96
- const labelFor = computed(() => {
97
- return props.for || (inputIds.value.length === 1 ? inputIds.value[0] : void 0);
98
- });
99
- const isGroup = computed(() => {
100
- return !labelFor.value && hasLabel.value;
101
- });
102
- const isNested = !!parentFormItemContext;
103
- const fieldValue = computed(() => {
104
- const model = formContext == null ? void 0 : formContext.model;
105
- if (!model || !props.prop) {
106
- return;
107
- }
108
- return getProp(model, props.prop).value;
109
- });
110
- const normalizedRules = computed(() => {
111
- const { required } = props;
112
- const rules = [];
113
- if (props.rules) {
114
- rules.push(...castArray(props.rules));
115
- }
116
- const formRules = formContext == null ? void 0 : formContext.rules;
117
- if (formRules && props.prop) {
118
- const _rules = getProp(formRules, props.prop).value;
119
- if (_rules) {
120
- rules.push(...castArray(_rules));
121
- }
122
- }
123
- if (required !== void 0) {
124
- const requiredRules = rules.map((rule, i) => [rule, i]).filter(([rule]) => Object.keys(rule).includes("required"));
125
- if (requiredRules.length > 0) {
126
- for (const [rule, i] of requiredRules) {
127
- if (rule.required === required)
128
- continue;
129
- rules[i] = { ...rule, required };
130
- }
131
- } else {
132
- rules.push({ required });
133
- }
134
- }
135
- return rules;
136
- });
137
- const validateEnabled = computed(() => normalizedRules.value.length > 0);
138
- const getFilteredRule = (trigger) => {
139
- const rules = normalizedRules.value;
140
- return rules.filter((rule) => {
141
- if (!rule.trigger || !trigger)
142
- return true;
143
- if (Array.isArray(rule.trigger)) {
144
- return rule.trigger.includes(trigger);
145
- } else {
146
- return rule.trigger === trigger;
147
- }
148
- }).map(({ trigger: trigger2, ...rule }) => rule);
149
- };
150
- const isRequired = computed(() => normalizedRules.value.some((rule) => rule.required));
151
- const shouldShowError = computed(() => {
152
- var _a;
153
- return validateStateDebounced.value === "error" && props.showMessage && ((_a = formContext == null ? void 0 : formContext.showMessage) != null ? _a : true);
154
- });
155
- const currentLabel = computed(() => `${props.label || ""}${(formContext == null ? void 0 : formContext.labelSuffix) || ""}`);
156
- const setValidationState = (state) => {
157
- validateState.value = state;
158
- };
159
- const onValidationFailed = (error) => {
160
- var _a, _b;
161
- const { errors, fields } = error;
162
- if (!errors || !fields) {
163
- console.error(error);
164
- }
165
- setValidationState("error");
166
- validateMessage.value = errors ? (_b = (_a = errors == null ? void 0 : errors[0]) == null ? void 0 : _a.message) != null ? _b : `${props.prop} is required` : "";
167
- formContext == null ? void 0 : formContext.emit("validate", props.prop, false, validateMessage.value);
168
- };
169
- const onValidationSucceeded = () => {
170
- setValidationState("success");
171
- formContext == null ? void 0 : formContext.emit("validate", props.prop, true, "");
172
- };
173
- const doValidate = async (rules) => {
174
- const modelName = propString.value;
175
- const validator = new AsyncValidator({
176
- [modelName]: rules
177
- });
178
- return validator.validate({ [modelName]: fieldValue.value }, { firstFields: true }).then(() => {
179
- onValidationSucceeded();
180
- return true;
181
- }).catch((err) => {
182
- onValidationFailed(err);
183
- return Promise.reject(err);
184
- });
185
- };
186
- const validate = async (trigger, callback) => {
187
- if (isResettingField || !props.prop) {
188
- return false;
189
- }
190
- const hasCallback = isFunction(callback);
191
- if (!validateEnabled.value) {
192
- callback == null ? void 0 : callback(false);
193
- return false;
194
- }
195
- const rules = getFilteredRule(trigger);
196
- if (rules.length === 0) {
197
- callback == null ? void 0 : callback(true);
198
- return true;
199
- }
200
- setValidationState("validating");
201
- return doValidate(rules).then(() => {
202
- callback == null ? void 0 : callback(true);
203
- return true;
204
- }).catch((err) => {
205
- const { fields } = err;
206
- callback == null ? void 0 : callback(false, fields);
207
- return hasCallback ? false : Promise.reject(fields);
208
- });
209
- };
210
- const clearValidate = () => {
211
- setValidationState("");
212
- validateMessage.value = "";
213
- isResettingField = false;
214
- };
215
- const resetField = async () => {
216
- const model = formContext == null ? void 0 : formContext.model;
217
- if (!model || !props.prop)
218
- return;
219
- const computedValue = getProp(model, props.prop);
220
- isResettingField = true;
221
- computedValue.value = clone(initialValue);
222
- await nextTick();
223
- clearValidate();
224
- isResettingField = false;
225
- };
226
- const addInputId = (id) => {
227
- if (!inputIds.value.includes(id)) {
228
- inputIds.value.push(id);
229
- }
230
- };
231
- const removeInputId = (id) => {
232
- inputIds.value = inputIds.value.filter((listId) => listId !== id);
233
- };
234
- watch(() => props.error, (val) => {
235
- validateMessage.value = val || "";
236
- setValidationState(val ? "error" : "");
237
- }, { immediate: true });
238
- watch(() => props.validateStatus, (val) => setValidationState(val || ""));
239
- const context = reactive({
240
- ...toRefs(props),
241
- $el: formItemRef,
242
- size: _size,
243
- validateState,
244
- labelId,
245
- inputIds,
246
- isGroup,
247
- hasLabel,
248
- fieldValue,
249
- addInputId,
250
- removeInputId,
251
- resetField,
252
- clearValidate,
253
- validate
254
- });
255
- provide(formItemContextKey, context);
256
- onMounted(() => {
257
- if (props.prop) {
258
- formContext == null ? void 0 : formContext.addField(context);
259
- initialValue = clone(fieldValue.value);
260
- }
261
- });
262
- onBeforeUnmount(() => {
263
- formContext == null ? void 0 : formContext.removeField(context);
264
- });
265
- expose({
266
- form: _form,
267
- size: _size,
268
- validateMessage,
269
- validateState,
270
- validate,
271
- clearValidate,
272
- resetField
273
- });
274
- return (_ctx, _cache) => {
275
- var _a;
276
- return openBlock(), createElementBlock("div", {
277
- ref_key: "formItemRef",
278
- ref: formItemRef,
279
- class: normalizeClass(unref(formItemClasses)),
280
- role: unref(isGroup) ? "group" : void 0,
281
- "aria-labelledby": unref(isGroup) ? unref(labelId) : void 0,
282
- widget: _ctx.widget
283
- }, [
284
- createVNode(unref(FormLabelWrap), {
285
- "is-auto-width": unref(labelStyle).width === "auto",
286
- "update-all": ((_a = unref(formContext)) == null ? void 0 : _a.labelWidth) === "auto"
287
- }, {
288
- default: withCtx(() => [
289
- unref(hasLabel) ? (openBlock(), createBlock(resolveDynamicComponent(unref(labelFor) ? "label" : "div"), {
290
- key: 0,
291
- id: unref(labelId),
292
- for: unref(labelFor),
293
- class: normalizeClass(unref(ns).e("label")),
294
- style: normalizeStyle(unref(labelStyle)),
295
- widget: _ctx.widget ? "form-item:label:" + _ctx.widget.split(":")[1] : void 0
296
- }, {
297
- default: withCtx(() => [
298
- renderSlot(_ctx.$slots, "label", { label: unref(currentLabel) }, () => [
299
- createTextVNode(toDisplayString(unref(currentLabel)), 1)
300
- ])
301
- ]),
302
- _: 3
303
- }, 8, ["id", "for", "class", "style", "widget"])) : createCommentVNode("v-if", true)
304
- ]),
305
- _: 3
306
- }, 8, ["is-auto-width", "update-all"]),
307
- createElementVNode("div", {
308
- class: normalizeClass(unref(ns).e("content")),
309
- style: normalizeStyle(unref(contentStyle)),
310
- widget: _ctx.widget ? "form-item:default:" + _ctx.widget.split(":")[1] : void 0
311
- }, [
312
- renderSlot(_ctx.$slots, "default"),
313
- createVNode(TransitionGroup, {
314
- duration: unref(forEditor) ? -1 : 0,
315
- name: `${unref(ns).namespace.value}-zoom-in-top`
316
- }, {
317
- default: withCtx(() => [
318
- unref(shouldShowError) ? renderSlot(_ctx.$slots, "error", {
319
- key: 0,
320
- error: validateMessage.value
321
- }, () => [
322
- createElementVNode("div", {
323
- class: normalizeClass(unref(validateClasses))
324
- }, toDisplayString(validateMessage.value), 3)
325
- ]) : createCommentVNode("v-if", true)
326
- ]),
327
- _: 3
328
- }, 8, ["duration", "name"])
329
- ], 14, _hoisted_2)
330
- ], 10, _hoisted_1);
331
- };
6
+ const formItemValidateStates = [
7
+ "",
8
+ "error",
9
+ "validating",
10
+ "success"
11
+ ];
12
+ const formItemProps = buildProps({
13
+ label: String,
14
+ labelWidth: {
15
+ type: [String, Number],
16
+ default: ""
17
+ },
18
+ prop: {
19
+ type: definePropType([String, Array])
20
+ },
21
+ required: {
22
+ type: Boolean,
23
+ default: void 0
24
+ },
25
+ rules: {
26
+ type: definePropType([Object, Array])
27
+ },
28
+ error: String,
29
+ validateStatus: {
30
+ type: String,
31
+ values: formItemValidateStates
32
+ },
33
+ for: String,
34
+ inlineMessage: {
35
+ type: [String, Boolean],
36
+ default: ""
37
+ },
38
+ showMessage: {
39
+ type: Boolean,
40
+ default: true
41
+ },
42
+ size: {
43
+ type: String,
44
+ values: componentSizes
45
+ },
46
+ widget: {
47
+ type: String
332
48
  }
333
49
  });
334
- var FormItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "form-item.vue"]]);
335
50
 
336
- export { FormItem as default };
51
+ export { formItemProps, formItemValidateStates };
337
52
  //# sourceMappingURL=form-item2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form-item2.mjs","sources":["../../../../../../packages/components/form/src/form-item.vue"],"sourcesContent":["<template>\n <div\n ref=\"formItemRef\"\n :class=\"formItemClasses\"\n :role=\"isGroup ? 'group' : undefined\"\n :aria-labelledby=\"isGroup ? labelId : undefined\"\n :widget=\"widget\"\n >\n <form-label-wrap\n :is-auto-width=\"labelStyle.width === 'auto'\"\n :update-all=\"formContext?.labelWidth === 'auto'\"\n >\n <component\n :is=\"labelFor ? 'label' : 'div'\"\n v-if=\"hasLabel\"\n :id=\"labelId\"\n :for=\"labelFor\"\n :class=\"ns.e('label')\"\n :style=\"labelStyle\"\n :widget=\"widget ? 'form-item:label:' + widget.split(':')[1] : undefined\"\n >\n <slot name=\"label\" :label=\"currentLabel\">\n {{ currentLabel }}\n </slot>\n </component>\n </form-label-wrap>\n\n <div :class=\"ns.e('content')\" :style=\"contentStyle\"\n :widget=\"widget ? 'form-item:default:' + widget.split(':')[1] : undefined\"\n >\n <slot />\n <transition-group :duration=\"forEditor ? -1 : 0\" :name=\"`${ns.namespace.value}-zoom-in-top`\">\n <slot v-if=\"shouldShowError\" name=\"error\" :error=\"validateMessage\">\n <div :class=\"validateClasses\">\n {{ validateMessage }}\n </div>\n </slot>\n </transition-group>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n inject,\n nextTick,\n onBeforeUnmount,\n onMounted,\n provide,\n reactive,\n ref,\n toRefs,\n useSlots,\n} from 'vue'\nimport { useGlobalConfig, watch } from '../../config-provider'\nimport AsyncValidator from 'async-validator'\nimport { clone } from 'lodash-unified'\nimport { refDebounced } from '@vueuse/core'\nimport {\n addUnit,\n ensureArray,\n getProp,\n isBoolean,\n isFunction,\n isString,\n} from '@element-plus/utils'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { useFormSize, useFormViewMode, useFormSelf } from './hooks'\nimport { formItemProps } from './form-item'\nimport FormLabelWrap from './form-label-wrap'\nimport { formContextKey, formItemContextKey } from './constants'\n\nimport type { CSSProperties } from 'vue'\nimport type { RuleItem } from 'async-validator'\nimport type { Arrayable } from '@element-plus/utils'\nimport type {\n FormItemContext,\n FormItemRule,\n FormValidateFailure,\n} from './types'\nimport type { FormItemValidateState } from './form-item'\n\nconst forEditor = useGlobalConfig('forEditor')\n\ndefineOptions({\n name: 'ElFormItem',\n})\nconst props = defineProps(formItemProps)\nconst slots = useSlots()\n\nconst formContext = inject(formContextKey, undefined)\nconst parentFormItemContext = inject(formItemContextKey, undefined)\n\nconst _size = useFormSize(undefined, { formItem: false })\nconst inputViewMode = useFormViewMode(undefined)\nconst ns = useNamespace('form-item')\nconst _form = useFormSelf()\n\nconst labelId = useId().value\nconst inputIds = ref<string[]>([])\n\nconst validateState = ref<FormItemValidateState>('')\nconst validateStateDebounced = refDebounced(validateState, 100)\nconst validateMessage = ref('')\nconst formItemRef = ref<HTMLDivElement>()\n// special inline value.\nlet initialValue: any = undefined\nlet isResettingField = false\n\nconst labelStyle = computed<CSSProperties>(() => {\n if (formContext?.labelPosition === 'top') {\n return {}\n }\n\n const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n if (labelWidth) return { width: labelWidth }\n return {}\n})\n\nconst contentStyle = computed<CSSProperties>(() => {\n if (formContext?.labelPosition === 'top' || formContext?.inline) {\n return {}\n }\n if (!props.label && !props.labelWidth && isNested) {\n return {}\n }\n const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n if (!props.label && !slots.label) {\n return { marginLeft: labelWidth }\n }\n return {}\n})\n\nconst formItemClasses = computed(() => [\n ns.b(),\n ns.m(_size.value),\n ns.is('error', validateState.value === 'error'),\n ns.is('validating', validateState.value === 'validating'),\n ns.is('success', validateState.value === 'success'),\n ns.is('required', isRequired.value || props.required),\n ns.is('no-asterisk', formContext?.hideRequiredAsterisk),\n formContext?.requireAsteriskPosition === 'right'\n ? 'asterisk-right'\n : 'asterisk-left',\n { [ns.m('feedback')]: formContext?.statusIcon },\n inputViewMode.value ? 'view-mode-' + inputViewMode.value : ''\n])\n\nconst _inlineMessage = computed(() =>\n isBoolean(props.inlineMessage)\n ? props.inlineMessage\n : formContext?.inlineMessage || false\n)\n\nconst validateClasses = computed(() => [\n ns.e('error'),\n { [ns.em('error', 'inline')]: _inlineMessage.value },\n])\n\nconst propString = computed(() => {\n if (!props.prop) return ''\n return isString(props.prop) ? props.prop : props.prop.join('.')\n})\n\nconst hasLabel = computed<boolean>(() => {\n return !!(props.label || slots.label)\n})\n\nconst labelFor = computed<string | undefined>(() => {\n return (\n props.for || (inputIds.value.length === 1 ? inputIds.value[0] : undefined)\n )\n})\n\nconst isGroup = computed<boolean>(() => {\n return !labelFor.value && hasLabel.value\n})\n\nconst isNested = !!parentFormItemContext\n\nconst fieldValue = computed(() => {\n const model = formContext?.model\n if (!model || !props.prop) {\n return\n }\n return getProp(model, props.prop).value\n})\n\nconst normalizedRules = computed(() => {\n const { required } = props\n\n const rules: FormItemRule[] = []\n\n if (props.rules) {\n rules.push(...ensureArray(props.rules))\n }\n\n const formRules = formContext?.rules\n if (formRules && props.prop) {\n const _rules = getProp<Arrayable<FormItemRule> | undefined>(\n formRules,\n props.prop\n ).value\n if (_rules) {\n rules.push(...ensureArray(_rules))\n }\n }\n\n if (required !== undefined) {\n const requiredRules = rules\n .map((rule, i) => [rule, i] as const)\n .filter(([rule]) => Object.keys(rule).includes('required'))\n\n if (requiredRules.length > 0) {\n for (const [rule, i] of requiredRules) {\n if (rule.required === required) continue\n rules[i] = { ...rule, required }\n }\n } else {\n rules.push({ required })\n }\n }\n\n return rules\n})\n\nconst validateEnabled = computed(() => normalizedRules.value.length > 0)\n\nconst getFilteredRule = (trigger: string) => {\n const rules = normalizedRules.value\n return (\n rules\n .filter((rule) => {\n if (!rule.trigger || !trigger) return true\n if (Array.isArray(rule.trigger)) {\n return rule.trigger.includes(trigger)\n } else {\n return rule.trigger === trigger\n }\n })\n // exclude trigger\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n .map(({ trigger, ...rule }): RuleItem => rule)\n )\n}\n\nconst isRequired = computed(() =>\n normalizedRules.value.some((rule) => rule.required)\n)\n\nconst shouldShowError = computed(\n () =>\n validateStateDebounced.value === 'error' &&\n props.showMessage &&\n (formContext?.showMessage ?? true)\n)\n\nconst currentLabel = computed(\n () => `${props.label || ''}${formContext?.labelSuffix || ''}`\n)\n\nconst setValidationState = (state: FormItemValidateState) => {\n validateState.value = state\n}\n\nconst onValidationFailed = (error: FormValidateFailure) => {\n const { errors, fields } = error\n if (!errors || !fields) {\n console.error(error)\n }\n\n setValidationState('error')\n validateMessage.value = errors\n ? errors?.[0]?.message ?? `${props.prop} is required`\n : ''\n\n formContext?.emit('validate', props.prop!, false, validateMessage.value)\n}\n\nconst onValidationSucceeded = () => {\n setValidationState('success')\n formContext?.emit('validate', props.prop!, true, '')\n}\n\nconst doValidate = async (rules: RuleItem[]): Promise<true> => {\n const modelName = propString.value\n const validator = new AsyncValidator({\n [modelName]: rules,\n })\n return validator\n .validate({ [modelName]: fieldValue.value }, { firstFields: true })\n .then(() => {\n onValidationSucceeded()\n return true as const\n })\n .catch((err: FormValidateFailure) => {\n onValidationFailed(err as FormValidateFailure)\n return Promise.reject(err)\n })\n}\n\nconst validate: FormItemContext['validate'] = async (trigger, callback) => {\n // skip validation if its resetting\n if (isResettingField || !props.prop) {\n return false\n }\n\n const hasCallback = isFunction(callback)\n if (!validateEnabled.value) {\n callback?.(false)\n return false\n }\n\n const rules = getFilteredRule(trigger)\n if (rules.length === 0) {\n callback?.(true)\n return true\n }\n\n setValidationState('validating')\n\n return doValidate(rules)\n .then(() => {\n callback?.(true)\n return true as const\n })\n .catch((err: FormValidateFailure) => {\n const { fields } = err\n callback?.(false, fields)\n return hasCallback ? false : Promise.reject(fields)\n })\n}\n\nconst clearValidate: FormItemContext['clearValidate'] = () => {\n setValidationState('')\n validateMessage.value = ''\n isResettingField = false\n}\n\nconst resetField: FormItemContext['resetField'] = async () => {\n const model = formContext?.model\n if (!model || !props.prop) return\n\n const computedValue = getProp(model, props.prop)\n\n // prevent validation from being triggered\n isResettingField = true\n\n computedValue.value = clone(initialValue)\n\n await nextTick()\n clearValidate()\n\n isResettingField = false\n}\n\nconst addInputId: FormItemContext['addInputId'] = (id: string) => {\n if (!inputIds.value.includes(id)) {\n inputIds.value.push(id)\n }\n}\n\nconst removeInputId: FormItemContext['removeInputId'] = (id: string) => {\n inputIds.value = inputIds.value.filter((listId) => listId !== id)\n}\n\nwatch(\n () => props.error,\n (val) => {\n validateMessage.value = val || ''\n setValidationState(val ? 'error' : '')\n },\n { immediate: true }\n)\n\nwatch(\n () => props.validateStatus,\n (val) => setValidationState(val || '')\n)\n\nconst context: FormItemContext = reactive({\n ...toRefs(props),\n $el: formItemRef,\n size: _size,\n validateState,\n labelId,\n inputIds,\n isGroup,\n hasLabel,\n fieldValue,\n addInputId,\n removeInputId,\n resetField,\n clearValidate,\n validate,\n})\n\nprovide(formItemContextKey, context)\n\nonMounted(() => {\n if (props.prop) {\n formContext?.addField(context)\n initialValue = clone(fieldValue.value)\n }\n})\n\nonBeforeUnmount(() => {\n formContext?.removeField(context)\n})\n\ndefineExpose({\n /**\n * @description Form.\n */\n form: _form,\n /**\n * @description Form item size.\n */\n size: _size,\n /**\n * @description Validation message.\n */\n validateMessage,\n /**\n * @description Validation state.\n */\n validateState,\n /**\n * @description Validate form item.\n */\n validate,\n /**\n * @description Remove validation status of the field.\n */\n clearValidate,\n /**\n * @description Reset current field and remove validation result.\n */\n resetField,\n})\n</script>\n"],"names":["ensureArray"],"mappings":"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"}
1
+ {"version":3,"file":"form-item2.mjs","sources":["../../../../../../packages/components/form/src/form-item.ts"],"sourcesContent":["import { componentSizes } from '@element-plus/constants'\nimport { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { FormItemRule } from './types'\n\nexport const formItemValidateStates = [\n '',\n 'error',\n 'validating',\n 'success',\n] as const\nexport type FormItemValidateState = typeof formItemValidateStates[number]\n\nexport type FormItemProp = Arrayable<string>\n\nexport const formItemProps = buildProps({\n /**\n * @description Label text.\n */\n label: String,\n /**\n * @description Width of label, e.g. `'50px'`. `'auto'` is supported.\n */\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description A key of `model`. It could be an array of property paths (e.g `['a', 'b', '0']`). In the use of `validate` and `resetFields` method, the attribute is required.\n */\n prop: {\n type: definePropType<FormItemProp>([String, Array]),\n },\n /**\n * @description Whether the field is required or not, will be determined by validation rules if omitted.\n */\n required: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description Validation rules of form, see the [following table](#formitemrule), more advanced usage at [async-validator](https://github.com/yiminghe/async-validator).\n */\n rules: {\n type: definePropType<Arrayable<FormItemRule>>([Object, Array]),\n },\n /**\n * @description Field error message, set its value and the field will validate error and show this message immediately.\n */\n error: String,\n /**\n * @description Validation state of formItem.\n */\n validateStatus: {\n type: String,\n values: formItemValidateStates,\n },\n /**\n * @description Same as for in native label.\n */\n for: String,\n /**\n * @description Inline style validate message.\n */\n inlineMessage: {\n type: [String, Boolean],\n default: '',\n },\n /**\n * @description Whether to show the error message.\n */\n showMessage: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Control the size of components in this form-item.\n */\n size: {\n type: String,\n values: componentSizes,\n },\n widget: {\n type: String,\n },\n} as const)\nexport type FormItemProps = ExtractPropTypes<typeof formItemProps>\n"],"names":[],"mappings":";;;;;AAEY,MAAC,sBAAsB,GAAG;AACtC,EAAE,EAAE;AACJ,EAAE,OAAO;AACT,EAAE,YAAY;AACd,EAAE,SAAS;AACX,EAAE;AACU,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACzC,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK,CAAC;AACnB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACzC,GAAG;AACH,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,cAAc,EAAE;AAClB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,sBAAsB;AAClC,GAAG;AACH,EAAE,GAAG,EAAE,MAAM;AACb,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC3B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,cAAc;AAC1B,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,GAAG;AACH,CAAC;;;;"}
@@ -1,65 +1,161 @@
1
- import '../../../constants/index.mjs';
1
+ import { defineComponent, computed, provide, reactive, toRefs, openBlock, createElementBlock, normalizeClass, unref, renderSlot } from 'vue';
2
+ import '../../config-provider/index.mjs';
2
3
  import '../../../utils/index.mjs';
3
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
4
- import { componentSizes, viewModes } from '../../../constants/size.mjs';
5
- import { isArray, isString } from '@vue/shared';
6
- import { isBoolean } from '../../../utils/types.mjs';
4
+ import '../../../hooks/index.mjs';
5
+ import './hooks/index.mjs';
6
+ import { formContextKey } from './constants.mjs';
7
+ import { formProps, formEmits } from './form2.mjs';
8
+ import { filterFields, useFormLabelWidth } from './utils.mjs';
9
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
10
+ import { useFormSize } from './hooks/use-form-common-props.mjs';
11
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
12
+ import { debugWarn } from '../../../utils/error.mjs';
13
+ import { isFunction } from '@vue/shared';
14
+ import { watch } from '../../config-provider/src/for-editor.mjs';
7
15
 
8
- const formMetaProps = buildProps({
9
- size: {
10
- type: String,
11
- values: componentSizes
12
- },
13
- disabled: Boolean,
14
- viewMode: {
15
- type: String,
16
- values: viewModes
17
- }
16
+ const COMPONENT_NAME = "ElForm";
17
+ const __default__ = defineComponent({
18
+ name: COMPONENT_NAME
18
19
  });
19
- const formProps = buildProps({
20
- ...formMetaProps,
21
- model: Object,
22
- rules: {
23
- type: definePropType(Object)
24
- },
25
- labelPosition: {
26
- type: String,
27
- values: ["left", "right", "top"],
28
- default: "right"
29
- },
30
- requireAsteriskPosition: {
31
- type: String,
32
- values: ["left", "right"],
33
- default: "left"
34
- },
35
- labelWidth: {
36
- type: [String, Number],
37
- default: ""
38
- },
39
- labelSuffix: {
40
- type: String,
41
- default: ""
42
- },
43
- inline: Boolean,
44
- inlineMessage: Boolean,
45
- statusIcon: Boolean,
46
- showMessage: {
47
- type: Boolean,
48
- default: true
49
- },
50
- validateOnRuleChange: {
51
- type: Boolean,
52
- default: true
53
- },
54
- hideRequiredAsterisk: Boolean,
55
- scrollToError: Boolean,
56
- scrollIntoViewOptions: {
57
- type: [Object, Boolean]
20
+ const _sfc_main = /* @__PURE__ */ defineComponent({
21
+ ...__default__,
22
+ props: formProps,
23
+ emits: formEmits,
24
+ setup(__props, { expose, emit }) {
25
+ const props = __props;
26
+ const fields = [];
27
+ const formSize = useFormSize();
28
+ const ns = useNamespace("form");
29
+ const formClasses = computed(() => {
30
+ const { labelPosition, inline } = props;
31
+ return [
32
+ ns.b(),
33
+ ns.m(formSize.value || "default"),
34
+ {
35
+ [ns.m(`label-${labelPosition}`)]: labelPosition,
36
+ [ns.m("inline")]: inline
37
+ }
38
+ ];
39
+ });
40
+ const getField = (prop) => {
41
+ return fields.find((field) => field.prop === prop);
42
+ };
43
+ const addField = (field) => {
44
+ fields.push(field);
45
+ };
46
+ const removeField = (field) => {
47
+ if (field.prop) {
48
+ fields.splice(fields.indexOf(field), 1);
49
+ }
50
+ };
51
+ const resetFields = (properties = []) => {
52
+ if (!props.model) {
53
+ debugWarn(COMPONENT_NAME, "model is required for resetFields to work.");
54
+ return;
55
+ }
56
+ filterFields(fields, properties).forEach((field) => field.resetField());
57
+ };
58
+ const clearValidate = (props2 = []) => {
59
+ filterFields(fields, props2).forEach((field) => field.clearValidate());
60
+ };
61
+ const isValidatable = computed(() => {
62
+ const hasModel = !!props.model;
63
+ if (!hasModel) {
64
+ debugWarn(COMPONENT_NAME, "model is required for validate to work.");
65
+ }
66
+ return hasModel;
67
+ });
68
+ const obtainValidateFields = (props2) => {
69
+ if (fields.length === 0)
70
+ return [];
71
+ const filteredFields = filterFields(fields, props2);
72
+ if (!filteredFields.length) {
73
+ debugWarn(COMPONENT_NAME, "please pass correct props!");
74
+ return [];
75
+ }
76
+ return filteredFields;
77
+ };
78
+ const validate = async (callback) => validateField(void 0, callback);
79
+ const doValidateField = async (props2 = []) => {
80
+ if (!isValidatable.value)
81
+ return false;
82
+ const fields2 = obtainValidateFields(props2);
83
+ if (fields2.length === 0)
84
+ return true;
85
+ let validationErrors = {};
86
+ for (const field of fields2) {
87
+ try {
88
+ await field.validate("");
89
+ } catch (fields3) {
90
+ validationErrors = {
91
+ ...validationErrors,
92
+ ...fields3
93
+ };
94
+ }
95
+ }
96
+ if (Object.keys(validationErrors).length === 0)
97
+ return true;
98
+ return Promise.reject(validationErrors);
99
+ };
100
+ const validateField = async (modelProps = [], callback) => {
101
+ const shouldThrow = !isFunction(callback);
102
+ try {
103
+ const result = await doValidateField(modelProps);
104
+ if (result === true) {
105
+ callback == null ? void 0 : callback(result);
106
+ }
107
+ return result;
108
+ } catch (e) {
109
+ if (e instanceof Error)
110
+ throw e;
111
+ const invalidFields = e;
112
+ if (props.scrollToError) {
113
+ scrollToField(Object.keys(invalidFields)[0]);
114
+ }
115
+ callback == null ? void 0 : callback(false, invalidFields);
116
+ return shouldThrow && Promise.reject(invalidFields);
117
+ }
118
+ };
119
+ const scrollToField = (prop) => {
120
+ var _a;
121
+ const field = filterFields(fields, prop)[0];
122
+ if (field) {
123
+ (_a = field.$el) == null ? void 0 : _a.scrollIntoView(props.scrollIntoViewOptions);
124
+ }
125
+ };
126
+ watch(() => props.rules, () => {
127
+ if (props.validateOnRuleChange) {
128
+ validate().catch((err) => debugWarn(err));
129
+ }
130
+ }, { deep: true });
131
+ provide(formContextKey, reactive({
132
+ ...toRefs(props),
133
+ emit,
134
+ resetFields,
135
+ clearValidate,
136
+ validateField,
137
+ getField,
138
+ addField,
139
+ removeField,
140
+ ...useFormLabelWidth()
141
+ }));
142
+ expose({
143
+ validate,
144
+ validateField,
145
+ resetFields,
146
+ clearValidate,
147
+ scrollToField
148
+ });
149
+ return (_ctx, _cache) => {
150
+ return openBlock(), createElementBlock("form", {
151
+ class: normalizeClass(unref(formClasses))
152
+ }, [
153
+ renderSlot(_ctx.$slots, "default")
154
+ ], 2);
155
+ };
58
156
  }
59
157
  });
60
- const formEmits = {
61
- validate: (prop, isValid, message) => (isArray(prop) || isString(prop)) && isBoolean(isValid) && isString(message)
62
- };
158
+ var Form = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "form.vue"]]);
63
159
 
64
- export { formEmits, formProps };
160
+ export { Form as default };
65
161
  //# sourceMappingURL=form.mjs.map