@element-plus/nightly 0.0.20250608 → 0.0.20250610

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 (572) hide show
  1. package/dist/index.full.js +92 -112
  2. package/dist/index.full.min.js +16 -16
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +16 -16
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +92 -112
  7. package/dist/locale/af.js +1 -1
  8. package/dist/locale/af.min.js +1 -1
  9. package/dist/locale/af.min.mjs +1 -1
  10. package/dist/locale/af.mjs +1 -1
  11. package/dist/locale/ar-eg.js +1 -1
  12. package/dist/locale/ar-eg.min.js +1 -1
  13. package/dist/locale/ar-eg.min.mjs +1 -1
  14. package/dist/locale/ar-eg.mjs +1 -1
  15. package/dist/locale/ar.js +1 -1
  16. package/dist/locale/ar.min.js +1 -1
  17. package/dist/locale/ar.min.mjs +1 -1
  18. package/dist/locale/ar.mjs +1 -1
  19. package/dist/locale/az.js +1 -1
  20. package/dist/locale/az.min.js +1 -1
  21. package/dist/locale/az.min.mjs +1 -1
  22. package/dist/locale/az.mjs +1 -1
  23. package/dist/locale/bg.js +1 -1
  24. package/dist/locale/bg.min.js +1 -1
  25. package/dist/locale/bg.min.mjs +1 -1
  26. package/dist/locale/bg.mjs +1 -1
  27. package/dist/locale/bn.js +1 -1
  28. package/dist/locale/bn.min.js +1 -1
  29. package/dist/locale/bn.min.mjs +1 -1
  30. package/dist/locale/bn.mjs +1 -1
  31. package/dist/locale/ca.js +1 -1
  32. package/dist/locale/ca.min.js +1 -1
  33. package/dist/locale/ca.min.mjs +1 -1
  34. package/dist/locale/ca.mjs +1 -1
  35. package/dist/locale/ckb.js +1 -1
  36. package/dist/locale/ckb.min.js +1 -1
  37. package/dist/locale/ckb.min.mjs +1 -1
  38. package/dist/locale/ckb.mjs +1 -1
  39. package/dist/locale/cs.js +1 -1
  40. package/dist/locale/cs.min.js +1 -1
  41. package/dist/locale/cs.min.mjs +1 -1
  42. package/dist/locale/cs.mjs +1 -1
  43. package/dist/locale/da.js +1 -1
  44. package/dist/locale/da.min.js +1 -1
  45. package/dist/locale/da.min.mjs +1 -1
  46. package/dist/locale/da.mjs +1 -1
  47. package/dist/locale/de.js +1 -1
  48. package/dist/locale/de.min.js +1 -1
  49. package/dist/locale/de.min.mjs +1 -1
  50. package/dist/locale/de.mjs +1 -1
  51. package/dist/locale/el.js +1 -1
  52. package/dist/locale/el.min.js +1 -1
  53. package/dist/locale/el.min.mjs +1 -1
  54. package/dist/locale/el.mjs +1 -1
  55. package/dist/locale/en.js +1 -1
  56. package/dist/locale/en.min.js +1 -1
  57. package/dist/locale/en.min.mjs +1 -1
  58. package/dist/locale/en.mjs +1 -1
  59. package/dist/locale/eo.js +1 -1
  60. package/dist/locale/eo.min.js +1 -1
  61. package/dist/locale/eo.min.mjs +1 -1
  62. package/dist/locale/eo.mjs +1 -1
  63. package/dist/locale/es.js +1 -1
  64. package/dist/locale/es.min.js +1 -1
  65. package/dist/locale/es.min.mjs +1 -1
  66. package/dist/locale/es.mjs +1 -1
  67. package/dist/locale/et.js +1 -1
  68. package/dist/locale/et.min.js +1 -1
  69. package/dist/locale/et.min.mjs +1 -1
  70. package/dist/locale/et.mjs +1 -1
  71. package/dist/locale/eu.js +1 -1
  72. package/dist/locale/eu.min.js +1 -1
  73. package/dist/locale/eu.min.mjs +1 -1
  74. package/dist/locale/eu.mjs +1 -1
  75. package/dist/locale/fa.js +1 -1
  76. package/dist/locale/fa.min.js +1 -1
  77. package/dist/locale/fa.min.mjs +1 -1
  78. package/dist/locale/fa.mjs +1 -1
  79. package/dist/locale/fi.js +1 -1
  80. package/dist/locale/fi.min.js +1 -1
  81. package/dist/locale/fi.min.mjs +1 -1
  82. package/dist/locale/fi.mjs +1 -1
  83. package/dist/locale/fr.js +1 -1
  84. package/dist/locale/fr.min.js +1 -1
  85. package/dist/locale/fr.min.mjs +1 -1
  86. package/dist/locale/fr.mjs +1 -1
  87. package/dist/locale/he.js +1 -1
  88. package/dist/locale/he.min.js +1 -1
  89. package/dist/locale/he.min.mjs +1 -1
  90. package/dist/locale/he.mjs +1 -1
  91. package/dist/locale/hi.js +1 -1
  92. package/dist/locale/hi.min.js +1 -1
  93. package/dist/locale/hi.min.mjs +1 -1
  94. package/dist/locale/hi.mjs +1 -1
  95. package/dist/locale/hr.js +1 -1
  96. package/dist/locale/hr.min.js +1 -1
  97. package/dist/locale/hr.min.mjs +1 -1
  98. package/dist/locale/hr.mjs +1 -1
  99. package/dist/locale/hu.js +1 -1
  100. package/dist/locale/hu.min.js +1 -1
  101. package/dist/locale/hu.min.mjs +1 -1
  102. package/dist/locale/hu.mjs +1 -1
  103. package/dist/locale/hy-am.js +1 -1
  104. package/dist/locale/hy-am.min.js +1 -1
  105. package/dist/locale/hy-am.min.mjs +1 -1
  106. package/dist/locale/hy-am.mjs +1 -1
  107. package/dist/locale/id.js +1 -1
  108. package/dist/locale/id.min.js +1 -1
  109. package/dist/locale/id.min.mjs +1 -1
  110. package/dist/locale/id.mjs +1 -1
  111. package/dist/locale/it.js +1 -1
  112. package/dist/locale/it.min.js +1 -1
  113. package/dist/locale/it.min.mjs +1 -1
  114. package/dist/locale/it.mjs +1 -1
  115. package/dist/locale/ja.js +1 -1
  116. package/dist/locale/ja.min.js +1 -1
  117. package/dist/locale/ja.min.mjs +1 -1
  118. package/dist/locale/ja.mjs +1 -1
  119. package/dist/locale/kk.js +1 -1
  120. package/dist/locale/kk.min.js +1 -1
  121. package/dist/locale/kk.min.mjs +1 -1
  122. package/dist/locale/kk.mjs +1 -1
  123. package/dist/locale/km.js +1 -1
  124. package/dist/locale/km.min.js +1 -1
  125. package/dist/locale/km.min.mjs +1 -1
  126. package/dist/locale/km.mjs +1 -1
  127. package/dist/locale/ko.js +1 -1
  128. package/dist/locale/ko.min.js +1 -1
  129. package/dist/locale/ko.min.mjs +1 -1
  130. package/dist/locale/ko.mjs +1 -1
  131. package/dist/locale/ku.js +1 -1
  132. package/dist/locale/ku.min.js +1 -1
  133. package/dist/locale/ku.min.mjs +1 -1
  134. package/dist/locale/ku.mjs +1 -1
  135. package/dist/locale/ky.js +1 -1
  136. package/dist/locale/ky.min.js +1 -1
  137. package/dist/locale/ky.min.mjs +1 -1
  138. package/dist/locale/ky.mjs +1 -1
  139. package/dist/locale/lo.js +1 -1
  140. package/dist/locale/lo.min.js +1 -1
  141. package/dist/locale/lo.min.mjs +1 -1
  142. package/dist/locale/lo.mjs +1 -1
  143. package/dist/locale/lt.js +1 -1
  144. package/dist/locale/lt.min.js +1 -1
  145. package/dist/locale/lt.min.mjs +1 -1
  146. package/dist/locale/lt.mjs +1 -1
  147. package/dist/locale/lv.js +1 -1
  148. package/dist/locale/lv.min.js +1 -1
  149. package/dist/locale/lv.min.mjs +1 -1
  150. package/dist/locale/lv.mjs +1 -1
  151. package/dist/locale/mg.js +1 -1
  152. package/dist/locale/mg.min.js +1 -1
  153. package/dist/locale/mg.min.mjs +1 -1
  154. package/dist/locale/mg.mjs +1 -1
  155. package/dist/locale/mn.js +1 -1
  156. package/dist/locale/mn.min.js +1 -1
  157. package/dist/locale/mn.min.mjs +1 -1
  158. package/dist/locale/mn.mjs +1 -1
  159. package/dist/locale/ms.js +1 -1
  160. package/dist/locale/ms.min.js +1 -1
  161. package/dist/locale/ms.min.mjs +1 -1
  162. package/dist/locale/ms.mjs +1 -1
  163. package/dist/locale/my.js +1 -1
  164. package/dist/locale/my.min.js +1 -1
  165. package/dist/locale/my.min.mjs +1 -1
  166. package/dist/locale/my.mjs +1 -1
  167. package/dist/locale/nb-no.js +1 -1
  168. package/dist/locale/nb-no.min.js +1 -1
  169. package/dist/locale/nb-no.min.mjs +1 -1
  170. package/dist/locale/nb-no.mjs +1 -1
  171. package/dist/locale/nl.js +1 -1
  172. package/dist/locale/nl.min.js +1 -1
  173. package/dist/locale/nl.min.mjs +1 -1
  174. package/dist/locale/nl.mjs +1 -1
  175. package/dist/locale/no.js +1 -1
  176. package/dist/locale/no.min.js +1 -1
  177. package/dist/locale/no.min.mjs +1 -1
  178. package/dist/locale/no.mjs +1 -1
  179. package/dist/locale/pa.js +1 -1
  180. package/dist/locale/pa.min.js +1 -1
  181. package/dist/locale/pa.min.mjs +1 -1
  182. package/dist/locale/pa.mjs +1 -1
  183. package/dist/locale/pl.js +1 -1
  184. package/dist/locale/pl.min.js +1 -1
  185. package/dist/locale/pl.min.mjs +1 -1
  186. package/dist/locale/pl.mjs +1 -1
  187. package/dist/locale/pt-br.js +1 -1
  188. package/dist/locale/pt-br.min.js +1 -1
  189. package/dist/locale/pt-br.min.mjs +1 -1
  190. package/dist/locale/pt-br.mjs +1 -1
  191. package/dist/locale/pt.js +1 -1
  192. package/dist/locale/pt.min.js +1 -1
  193. package/dist/locale/pt.min.mjs +1 -1
  194. package/dist/locale/pt.mjs +1 -1
  195. package/dist/locale/ro.js +1 -1
  196. package/dist/locale/ro.min.js +1 -1
  197. package/dist/locale/ro.min.mjs +1 -1
  198. package/dist/locale/ro.mjs +1 -1
  199. package/dist/locale/ru.js +1 -1
  200. package/dist/locale/ru.min.js +1 -1
  201. package/dist/locale/ru.min.mjs +1 -1
  202. package/dist/locale/ru.mjs +1 -1
  203. package/dist/locale/sk.js +1 -1
  204. package/dist/locale/sk.min.js +1 -1
  205. package/dist/locale/sk.min.mjs +1 -1
  206. package/dist/locale/sk.mjs +1 -1
  207. package/dist/locale/sl.js +1 -1
  208. package/dist/locale/sl.min.js +1 -1
  209. package/dist/locale/sl.min.mjs +1 -1
  210. package/dist/locale/sl.mjs +1 -1
  211. package/dist/locale/sr.js +1 -1
  212. package/dist/locale/sr.min.js +1 -1
  213. package/dist/locale/sr.min.mjs +1 -1
  214. package/dist/locale/sr.mjs +1 -1
  215. package/dist/locale/sv.js +1 -1
  216. package/dist/locale/sv.min.js +1 -1
  217. package/dist/locale/sv.min.mjs +1 -1
  218. package/dist/locale/sv.mjs +1 -1
  219. package/dist/locale/sw.js +1 -1
  220. package/dist/locale/sw.min.js +1 -1
  221. package/dist/locale/sw.min.mjs +1 -1
  222. package/dist/locale/sw.mjs +1 -1
  223. package/dist/locale/ta.js +1 -1
  224. package/dist/locale/ta.min.js +1 -1
  225. package/dist/locale/ta.min.mjs +1 -1
  226. package/dist/locale/ta.mjs +1 -1
  227. package/dist/locale/te.js +1 -1
  228. package/dist/locale/te.min.js +1 -1
  229. package/dist/locale/te.min.mjs +1 -1
  230. package/dist/locale/te.mjs +1 -1
  231. package/dist/locale/th.js +1 -1
  232. package/dist/locale/th.min.js +1 -1
  233. package/dist/locale/th.min.mjs +1 -1
  234. package/dist/locale/th.mjs +1 -1
  235. package/dist/locale/tk.js +1 -1
  236. package/dist/locale/tk.min.js +1 -1
  237. package/dist/locale/tk.min.mjs +1 -1
  238. package/dist/locale/tk.mjs +1 -1
  239. package/dist/locale/tr.js +1 -1
  240. package/dist/locale/tr.min.js +1 -1
  241. package/dist/locale/tr.min.mjs +1 -1
  242. package/dist/locale/tr.mjs +1 -1
  243. package/dist/locale/ug-cn.js +1 -1
  244. package/dist/locale/ug-cn.min.js +1 -1
  245. package/dist/locale/ug-cn.min.mjs +1 -1
  246. package/dist/locale/ug-cn.mjs +1 -1
  247. package/dist/locale/uk.js +1 -1
  248. package/dist/locale/uk.min.js +1 -1
  249. package/dist/locale/uk.min.mjs +1 -1
  250. package/dist/locale/uk.mjs +1 -1
  251. package/dist/locale/uz-uz.js +1 -1
  252. package/dist/locale/uz-uz.min.js +1 -1
  253. package/dist/locale/uz-uz.min.mjs +1 -1
  254. package/dist/locale/uz-uz.mjs +1 -1
  255. package/dist/locale/vi.js +1 -1
  256. package/dist/locale/vi.min.js +1 -1
  257. package/dist/locale/vi.min.mjs +1 -1
  258. package/dist/locale/vi.mjs +1 -1
  259. package/dist/locale/zh-cn.js +1 -1
  260. package/dist/locale/zh-cn.min.js +1 -1
  261. package/dist/locale/zh-cn.min.mjs +1 -1
  262. package/dist/locale/zh-cn.mjs +1 -1
  263. package/dist/locale/zh-hk.js +1 -1
  264. package/dist/locale/zh-hk.min.js +1 -1
  265. package/dist/locale/zh-hk.min.mjs +1 -1
  266. package/dist/locale/zh-hk.mjs +1 -1
  267. package/dist/locale/zh-mo.js +1 -1
  268. package/dist/locale/zh-mo.min.js +1 -1
  269. package/dist/locale/zh-mo.min.mjs +1 -1
  270. package/dist/locale/zh-mo.mjs +1 -1
  271. package/dist/locale/zh-tw.js +1 -1
  272. package/dist/locale/zh-tw.min.js +1 -1
  273. package/dist/locale/zh-tw.min.mjs +1 -1
  274. package/dist/locale/zh-tw.mjs +1 -1
  275. package/es/components/alert/index.mjs +2 -2
  276. package/es/components/alert/src/alert.mjs +41 -108
  277. package/es/components/alert/src/alert.mjs.map +1 -1
  278. package/es/components/alert/src/alert2.mjs +108 -41
  279. package/es/components/alert/src/alert2.mjs.map +1 -1
  280. package/es/components/button/index.mjs +2 -2
  281. package/es/components/button/src/button-group.mjs +1 -1
  282. package/es/components/button/src/button.mjs +87 -62
  283. package/es/components/button/src/button.mjs.map +1 -1
  284. package/es/components/button/src/button2.mjs +62 -87
  285. package/es/components/button/src/button2.mjs.map +1 -1
  286. package/es/components/cascader-panel/src/index.mjs +1 -1
  287. package/es/components/cascader-panel/src/menu.mjs +1 -1
  288. package/es/components/cascader-panel/src/node.mjs +206 -115
  289. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  290. package/es/components/cascader-panel/src/node2.mjs +115 -206
  291. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  292. package/es/components/cascader-panel/src/store.mjs +1 -1
  293. package/es/components/checkbox/index.mjs +2 -2
  294. package/es/components/checkbox/src/checkbox-button.mjs +1 -1
  295. package/es/components/checkbox/src/checkbox.mjs +59 -119
  296. package/es/components/checkbox/src/checkbox.mjs.map +1 -1
  297. package/es/components/checkbox/src/checkbox2.mjs +119 -59
  298. package/es/components/checkbox/src/checkbox2.mjs.map +1 -1
  299. package/es/components/collapse/index.mjs +2 -2
  300. package/es/components/collapse/src/collapse.mjs +28 -23
  301. package/es/components/collapse/src/collapse.mjs.map +1 -1
  302. package/es/components/collapse/src/collapse2.mjs +23 -28
  303. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  304. package/es/components/color-picker/index.mjs +2 -2
  305. package/es/components/color-picker/src/color-picker.mjs +39 -399
  306. package/es/components/color-picker/src/color-picker.mjs.map +1 -1
  307. package/es/components/color-picker/src/color-picker2.mjs +399 -39
  308. package/es/components/color-picker/src/color-picker2.mjs.map +1 -1
  309. package/es/components/color-picker/src/components/predefine.mjs +1 -1
  310. package/es/components/date-picker/src/composables/use-range-picker.d.ts +2 -1
  311. package/es/components/date-picker/src/composables/use-range-picker.mjs +2 -0
  312. package/es/components/date-picker/src/composables/use-range-picker.mjs.map +1 -1
  313. package/es/components/date-picker/src/date-picker-com/panel-date-range.vue.d.ts +2 -2
  314. package/es/components/date-picker/src/date-picker-com/panel-month-range.mjs +9 -2
  315. package/es/components/date-picker/src/date-picker-com/panel-month-range.mjs.map +1 -1
  316. package/es/components/date-picker/src/date-picker-com/panel-month-range.vue.d.ts +3 -0
  317. package/es/components/date-picker/src/date-picker-com/panel-year-range.mjs +77 -107
  318. package/es/components/date-picker/src/date-picker-com/panel-year-range.mjs.map +1 -1
  319. package/es/components/date-picker/src/date-picker-com/panel-year-range.vue.d.ts +3 -0
  320. package/es/components/date-picker/src/panel-utils.d.ts +12 -5
  321. package/es/components/date-picker/src/props/panel-date-range.d.ts +1 -1
  322. package/es/components/date-picker/src/props/panel-date-range.mjs +1 -2
  323. package/es/components/date-picker/src/props/panel-date-range.mjs.map +1 -1
  324. package/es/components/date-picker/src/props/panel-month-range.d.ts +1 -0
  325. package/es/components/date-picker/src/props/panel-year-range.d.ts +1 -0
  326. package/es/components/date-picker/src/props/shared.d.ts +1 -0
  327. package/es/components/date-picker/src/props/shared.mjs +1 -0
  328. package/es/components/date-picker/src/props/shared.mjs.map +1 -1
  329. package/es/components/date-picker/src/utils.d.ts +2 -1
  330. package/es/components/date-picker/src/utils.mjs +5 -5
  331. package/es/components/date-picker/src/utils.mjs.map +1 -1
  332. package/es/components/form/index.mjs +4 -4
  333. package/es/components/form/src/form-item.mjs +47 -320
  334. package/es/components/form/src/form-item.mjs.map +1 -1
  335. package/es/components/form/src/form-item2.mjs +320 -47
  336. package/es/components/form/src/form-item2.mjs.map +1 -1
  337. package/es/components/form/src/form.mjs +54 -160
  338. package/es/components/form/src/form.mjs.map +1 -1
  339. package/es/components/form/src/form2.mjs +160 -54
  340. package/es/components/form/src/form2.mjs.map +1 -1
  341. package/es/components/icon/index.mjs +2 -2
  342. package/es/components/icon/src/icon.mjs +35 -8
  343. package/es/components/icon/src/icon.mjs.map +1 -1
  344. package/es/components/icon/src/icon2.mjs +8 -35
  345. package/es/components/icon/src/icon2.mjs.map +1 -1
  346. package/es/components/index.mjs +22 -22
  347. package/es/components/notification/index.mjs +1 -1
  348. package/es/components/notification/src/notification.mjs +73 -140
  349. package/es/components/notification/src/notification.mjs.map +1 -1
  350. package/es/components/notification/src/notification2.mjs +140 -73
  351. package/es/components/notification/src/notification2.mjs.map +1 -1
  352. package/es/components/notification/src/notify.mjs +2 -2
  353. package/es/components/pagination/src/components/pager.mjs +210 -16
  354. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  355. package/es/components/pagination/src/components/pager2.mjs +16 -210
  356. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  357. package/es/components/pagination/src/pagination.mjs +1 -1
  358. package/es/components/popconfirm/src/popconfirm.mjs +1 -1
  359. package/es/components/popper/index.mjs +4 -4
  360. package/es/components/popper/src/arrow.mjs +30 -7
  361. package/es/components/popper/src/arrow.mjs.map +1 -1
  362. package/es/components/popper/src/arrow2.mjs +7 -30
  363. package/es/components/popper/src/arrow2.mjs.map +1 -1
  364. package/es/components/popper/src/content.mjs +94 -130
  365. package/es/components/popper/src/content.mjs.map +1 -1
  366. package/es/components/popper/src/content2.mjs +130 -94
  367. package/es/components/popper/src/content2.mjs.map +1 -1
  368. package/es/components/segmented/index.mjs +2 -2
  369. package/es/components/segmented/src/segmented.mjs +42 -168
  370. package/es/components/segmented/src/segmented.mjs.map +1 -1
  371. package/es/components/segmented/src/segmented2.mjs +168 -42
  372. package/es/components/segmented/src/segmented2.mjs.map +1 -1
  373. package/es/components/select/index.mjs +2 -2
  374. package/es/components/select/src/select.mjs +448 -130
  375. package/es/components/select/src/select.mjs.map +1 -1
  376. package/es/components/select/src/select2.mjs +130 -448
  377. package/es/components/select/src/select2.mjs.map +1 -1
  378. package/es/components/slider/index.mjs +2 -2
  379. package/es/components/slider/src/button.mjs +91 -19
  380. package/es/components/slider/src/button.mjs.map +1 -1
  381. package/es/components/slider/src/button2.mjs +19 -91
  382. package/es/components/slider/src/button2.mjs.map +1 -1
  383. package/es/components/slider/src/slider.mjs +92 -238
  384. package/es/components/slider/src/slider.mjs.map +1 -1
  385. package/es/components/slider/src/slider2.mjs +238 -92
  386. package/es/components/slider/src/slider2.mjs.map +1 -1
  387. package/es/components/splitter/index.mjs +2 -2
  388. package/es/components/splitter/src/splitter.mjs +7 -77
  389. package/es/components/splitter/src/splitter.mjs.map +1 -1
  390. package/es/components/splitter/src/splitter2.mjs +77 -7
  391. package/es/components/splitter/src/splitter2.mjs.map +1 -1
  392. package/es/components/tabs/index.mjs +2 -2
  393. package/es/components/tabs/src/tab-pane.mjs +13 -71
  394. package/es/components/tabs/src/tab-pane.mjs.map +1 -1
  395. package/es/components/tabs/src/tab-pane2.mjs +71 -13
  396. package/es/components/tabs/src/tab-pane2.mjs.map +1 -1
  397. package/es/components/tooltip/index.mjs +2 -2
  398. package/es/components/tooltip/src/content.mjs +1 -1
  399. package/es/components/tooltip/src/content2.mjs +1 -1
  400. package/es/components/tooltip/src/tooltip.mjs +30 -169
  401. package/es/components/tooltip/src/tooltip.mjs.map +1 -1
  402. package/es/components/tooltip/src/tooltip2.mjs +169 -30
  403. package/es/components/tooltip/src/tooltip2.mjs.map +1 -1
  404. package/es/components/tour/index.mjs +2 -2
  405. package/es/components/tour/src/step.mjs +168 -44
  406. package/es/components/tour/src/step.mjs.map +1 -1
  407. package/es/components/tour/src/step2.mjs +44 -168
  408. package/es/components/tour/src/step2.mjs.map +1 -1
  409. package/es/components/upload/index.mjs +2 -2
  410. package/es/components/upload/src/upload-content.mjs +33 -196
  411. package/es/components/upload/src/upload-content.mjs.map +1 -1
  412. package/es/components/upload/src/upload-content2.mjs +196 -33
  413. package/es/components/upload/src/upload-content2.mjs.map +1 -1
  414. package/es/components/upload/src/upload-dragger.mjs +10 -56
  415. package/es/components/upload/src/upload-dragger.mjs.map +1 -1
  416. package/es/components/upload/src/upload-dragger2.mjs +56 -10
  417. package/es/components/upload/src/upload-dragger2.mjs.map +1 -1
  418. package/es/components/upload/src/upload2.mjs +1 -1
  419. package/es/index.mjs +22 -22
  420. package/es/version.d.ts +1 -1
  421. package/es/version.mjs +1 -1
  422. package/es/version.mjs.map +1 -1
  423. package/lib/components/alert/index.js +2 -2
  424. package/lib/components/alert/src/alert.js +42 -107
  425. package/lib/components/alert/src/alert.js.map +1 -1
  426. package/lib/components/alert/src/alert2.js +107 -42
  427. package/lib/components/alert/src/alert2.js.map +1 -1
  428. package/lib/components/button/index.js +2 -2
  429. package/lib/components/button/src/button-group.js +1 -1
  430. package/lib/components/button/src/button.js +87 -65
  431. package/lib/components/button/src/button.js.map +1 -1
  432. package/lib/components/button/src/button2.js +65 -87
  433. package/lib/components/button/src/button2.js.map +1 -1
  434. package/lib/components/cascader-panel/src/index.js +1 -1
  435. package/lib/components/cascader-panel/src/menu.js +1 -1
  436. package/lib/components/cascader-panel/src/node.js +206 -115
  437. package/lib/components/cascader-panel/src/node.js.map +1 -1
  438. package/lib/components/cascader-panel/src/node2.js +115 -206
  439. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  440. package/lib/components/cascader-panel/src/store.js +1 -1
  441. package/lib/components/checkbox/index.js +2 -2
  442. package/lib/components/checkbox/src/checkbox-button.js +1 -1
  443. package/lib/components/checkbox/src/checkbox.js +60 -119
  444. package/lib/components/checkbox/src/checkbox.js.map +1 -1
  445. package/lib/components/checkbox/src/checkbox2.js +119 -60
  446. package/lib/components/checkbox/src/checkbox2.js.map +1 -1
  447. package/lib/components/collapse/index.js +2 -2
  448. package/lib/components/collapse/src/collapse.js +28 -25
  449. package/lib/components/collapse/src/collapse.js.map +1 -1
  450. package/lib/components/collapse/src/collapse2.js +25 -28
  451. package/lib/components/collapse/src/collapse2.js.map +1 -1
  452. package/lib/components/color-picker/index.js +2 -2
  453. package/lib/components/color-picker/src/color-picker.js +40 -398
  454. package/lib/components/color-picker/src/color-picker.js.map +1 -1
  455. package/lib/components/color-picker/src/color-picker2.js +398 -40
  456. package/lib/components/color-picker/src/color-picker2.js.map +1 -1
  457. package/lib/components/color-picker/src/components/predefine.js +1 -1
  458. package/lib/components/date-picker/src/composables/use-range-picker.d.ts +2 -1
  459. package/lib/components/date-picker/src/composables/use-range-picker.js +2 -0
  460. package/lib/components/date-picker/src/composables/use-range-picker.js.map +1 -1
  461. package/lib/components/date-picker/src/date-picker-com/panel-date-range.vue.d.ts +2 -2
  462. package/lib/components/date-picker/src/date-picker-com/panel-month-range.js +8 -1
  463. package/lib/components/date-picker/src/date-picker-com/panel-month-range.js.map +1 -1
  464. package/lib/components/date-picker/src/date-picker-com/panel-month-range.vue.d.ts +3 -0
  465. package/lib/components/date-picker/src/date-picker-com/panel-year-range.js +79 -109
  466. package/lib/components/date-picker/src/date-picker-com/panel-year-range.js.map +1 -1
  467. package/lib/components/date-picker/src/date-picker-com/panel-year-range.vue.d.ts +3 -0
  468. package/lib/components/date-picker/src/panel-utils.d.ts +12 -5
  469. package/lib/components/date-picker/src/props/panel-date-range.d.ts +1 -1
  470. package/lib/components/date-picker/src/props/panel-date-range.js +1 -2
  471. package/lib/components/date-picker/src/props/panel-date-range.js.map +1 -1
  472. package/lib/components/date-picker/src/props/panel-month-range.d.ts +1 -0
  473. package/lib/components/date-picker/src/props/panel-year-range.d.ts +1 -0
  474. package/lib/components/date-picker/src/props/shared.d.ts +1 -0
  475. package/lib/components/date-picker/src/props/shared.js +1 -0
  476. package/lib/components/date-picker/src/props/shared.js.map +1 -1
  477. package/lib/components/date-picker/src/utils.d.ts +2 -1
  478. package/lib/components/date-picker/src/utils.js +5 -5
  479. package/lib/components/date-picker/src/utils.js.map +1 -1
  480. package/lib/components/form/index.js +4 -4
  481. package/lib/components/form/src/form-item.js +48 -324
  482. package/lib/components/form/src/form-item.js.map +1 -1
  483. package/lib/components/form/src/form-item2.js +324 -48
  484. package/lib/components/form/src/form-item2.js.map +1 -1
  485. package/lib/components/form/src/form.js +55 -159
  486. package/lib/components/form/src/form.js.map +1 -1
  487. package/lib/components/form/src/form2.js +159 -55
  488. package/lib/components/form/src/form2.js.map +1 -1
  489. package/lib/components/icon/index.js +2 -2
  490. package/lib/components/icon/src/icon.js +35 -8
  491. package/lib/components/icon/src/icon.js.map +1 -1
  492. package/lib/components/icon/src/icon2.js +8 -35
  493. package/lib/components/icon/src/icon2.js.map +1 -1
  494. package/lib/components/index.js +22 -22
  495. package/lib/components/notification/index.js +1 -1
  496. package/lib/components/notification/src/notification.js +74 -139
  497. package/lib/components/notification/src/notification.js.map +1 -1
  498. package/lib/components/notification/src/notification2.js +139 -74
  499. package/lib/components/notification/src/notification2.js.map +1 -1
  500. package/lib/components/notification/src/notify.js +2 -2
  501. package/lib/components/pagination/src/components/pager.js +210 -16
  502. package/lib/components/pagination/src/components/pager.js.map +1 -1
  503. package/lib/components/pagination/src/components/pager2.js +16 -210
  504. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  505. package/lib/components/pagination/src/pagination.js +1 -1
  506. package/lib/components/popconfirm/src/popconfirm.js +1 -1
  507. package/lib/components/popper/index.js +4 -4
  508. package/lib/components/popper/src/arrow.js +30 -8
  509. package/lib/components/popper/src/arrow.js.map +1 -1
  510. package/lib/components/popper/src/arrow2.js +8 -30
  511. package/lib/components/popper/src/arrow2.js.map +1 -1
  512. package/lib/components/popper/src/content.js +99 -130
  513. package/lib/components/popper/src/content.js.map +1 -1
  514. package/lib/components/popper/src/content2.js +130 -99
  515. package/lib/components/popper/src/content2.js.map +1 -1
  516. package/lib/components/segmented/index.js +2 -2
  517. package/lib/components/segmented/src/segmented.js +44 -168
  518. package/lib/components/segmented/src/segmented.js.map +1 -1
  519. package/lib/components/segmented/src/segmented2.js +168 -44
  520. package/lib/components/segmented/src/segmented2.js.map +1 -1
  521. package/lib/components/select/index.js +2 -2
  522. package/lib/components/select/src/select.js +448 -131
  523. package/lib/components/select/src/select.js.map +1 -1
  524. package/lib/components/select/src/select2.js +131 -448
  525. package/lib/components/select/src/select2.js.map +1 -1
  526. package/lib/components/slider/index.js +2 -2
  527. package/lib/components/slider/src/button.js +91 -20
  528. package/lib/components/slider/src/button.js.map +1 -1
  529. package/lib/components/slider/src/button2.js +20 -91
  530. package/lib/components/slider/src/button2.js.map +1 -1
  531. package/lib/components/slider/src/slider.js +93 -238
  532. package/lib/components/slider/src/slider.js.map +1 -1
  533. package/lib/components/slider/src/slider2.js +238 -93
  534. package/lib/components/slider/src/slider2.js.map +1 -1
  535. package/lib/components/splitter/index.js +2 -2
  536. package/lib/components/splitter/src/splitter.js +7 -77
  537. package/lib/components/splitter/src/splitter.js.map +1 -1
  538. package/lib/components/splitter/src/splitter2.js +77 -7
  539. package/lib/components/splitter/src/splitter2.js.map +1 -1
  540. package/lib/components/tabs/index.js +2 -2
  541. package/lib/components/tabs/src/tab-pane.js +13 -71
  542. package/lib/components/tabs/src/tab-pane.js.map +1 -1
  543. package/lib/components/tabs/src/tab-pane2.js +71 -13
  544. package/lib/components/tabs/src/tab-pane2.js.map +1 -1
  545. package/lib/components/tooltip/index.js +2 -2
  546. package/lib/components/tooltip/src/content.js +1 -1
  547. package/lib/components/tooltip/src/content2.js +1 -1
  548. package/lib/components/tooltip/src/tooltip.js +33 -168
  549. package/lib/components/tooltip/src/tooltip.js.map +1 -1
  550. package/lib/components/tooltip/src/tooltip2.js +168 -33
  551. package/lib/components/tooltip/src/tooltip2.js.map +1 -1
  552. package/lib/components/tour/index.js +2 -2
  553. package/lib/components/tour/src/step.js +167 -44
  554. package/lib/components/tour/src/step.js.map +1 -1
  555. package/lib/components/tour/src/step2.js +44 -167
  556. package/lib/components/tour/src/step2.js.map +1 -1
  557. package/lib/components/upload/index.js +2 -2
  558. package/lib/components/upload/src/upload-content.js +31 -194
  559. package/lib/components/upload/src/upload-content.js.map +1 -1
  560. package/lib/components/upload/src/upload-content2.js +194 -31
  561. package/lib/components/upload/src/upload-content2.js.map +1 -1
  562. package/lib/components/upload/src/upload-dragger.js +11 -56
  563. package/lib/components/upload/src/upload-dragger.js.map +1 -1
  564. package/lib/components/upload/src/upload-dragger2.js +56 -11
  565. package/lib/components/upload/src/upload-dragger2.js.map +1 -1
  566. package/lib/components/upload/src/upload2.js +1 -1
  567. package/lib/index.js +22 -22
  568. package/lib/version.d.ts +1 -1
  569. package/lib/version.js +1 -1
  570. package/lib/version.js.map +1 -1
  571. package/package.json +2 -2
  572. package/web-types.json +1 -1
@@ -2,169 +2,65 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var vue = require('vue');
6
- var constants = require('./constants.js');
7
- var form = require('./form2.js');
8
- var utils = require('./utils.js');
9
- var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
10
- var useFormCommonProps = require('./hooks/use-form-common-props.js');
11
- var index = require('../../../hooks/use-namespace/index.js');
12
- var error = require('../../../utils/error.js');
5
+ var runtime = require('../../../utils/vue/props/runtime.js');
6
+ var size = require('../../../constants/size.js');
13
7
  var shared = require('@vue/shared');
8
+ var types = require('../../../utils/types.js');
14
9
 
15
- const COMPONENT_NAME = "ElForm";
16
- const __default__ = vue.defineComponent({
17
- name: COMPONENT_NAME
10
+ const formMetaProps = runtime.buildProps({
11
+ size: {
12
+ type: String,
13
+ values: size.componentSizes
14
+ },
15
+ disabled: Boolean
18
16
  });
19
- const _sfc_main = /* @__PURE__ */ vue.defineComponent({
20
- ...__default__,
21
- props: form.formProps,
22
- emits: form.formEmits,
23
- setup(__props, { expose, emit }) {
24
- const props = __props;
25
- const formRef = vue.ref();
26
- const fields = vue.reactive([]);
27
- const formSize = useFormCommonProps.useFormSize();
28
- const ns = index.useNamespace("form");
29
- const formClasses = vue.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
- error.debugWarn(COMPONENT_NAME, "model is required for resetFields to work.");
54
- return;
55
- }
56
- utils.filterFields(fields, properties).forEach((field) => field.resetField());
57
- };
58
- const clearValidate = (props2 = []) => {
59
- utils.filterFields(fields, props2).forEach((field) => field.clearValidate());
60
- };
61
- const isValidatable = vue.computed(() => {
62
- const hasModel = !!props.model;
63
- if (!hasModel) {
64
- error.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 = utils.filterFields(fields, props2);
72
- if (!filteredFields.length) {
73
- error.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
- if (field.validateState === "error")
90
- field.resetField();
91
- } catch (fields3) {
92
- validationErrors = {
93
- ...validationErrors,
94
- ...fields3
95
- };
96
- }
97
- }
98
- if (Object.keys(validationErrors).length === 0)
99
- return true;
100
- return Promise.reject(validationErrors);
101
- };
102
- const validateField = async (modelProps = [], callback) => {
103
- let result = false;
104
- const shouldThrow = !shared.isFunction(callback);
105
- try {
106
- result = await doValidateField(modelProps);
107
- if (result === true) {
108
- await (callback == null ? void 0 : callback(result));
109
- }
110
- return result;
111
- } catch (e) {
112
- if (e instanceof Error)
113
- throw e;
114
- const invalidFields = e;
115
- if (props.scrollToError) {
116
- if (formRef.value) {
117
- const formItem = formRef.value.querySelector(`.${ns.b()}-item.is-error`);
118
- formItem == null ? void 0 : formItem.scrollIntoView(props.scrollIntoViewOptions);
119
- }
120
- }
121
- !result && await (callback == null ? void 0 : callback(false, invalidFields));
122
- return shouldThrow && Promise.reject(invalidFields);
123
- }
124
- };
125
- const scrollToField = (prop) => {
126
- var _a;
127
- const field = utils.filterFields(fields, prop)[0];
128
- if (field) {
129
- (_a = field.$el) == null ? void 0 : _a.scrollIntoView(props.scrollIntoViewOptions);
130
- }
131
- };
132
- vue.watch(() => props.rules, () => {
133
- if (props.validateOnRuleChange) {
134
- validate().catch((err) => error.debugWarn(err));
135
- }
136
- }, { deep: true, flush: "post" });
137
- vue.provide(constants.formContextKey, vue.reactive({
138
- ...vue.toRefs(props),
139
- emit,
140
- resetFields,
141
- clearValidate,
142
- validateField,
143
- getField,
144
- addField,
145
- removeField,
146
- ...utils.useFormLabelWidth()
147
- }));
148
- expose({
149
- validate,
150
- validateField,
151
- resetFields,
152
- clearValidate,
153
- scrollToField,
154
- fields
155
- });
156
- return (_ctx, _cache) => {
157
- return vue.openBlock(), vue.createElementBlock("form", {
158
- ref_key: "formRef",
159
- ref: formRef,
160
- class: vue.normalizeClass(vue.unref(formClasses))
161
- }, [
162
- vue.renderSlot(_ctx.$slots, "default")
163
- ], 2);
164
- };
17
+ const formProps = runtime.buildProps({
18
+ ...formMetaProps,
19
+ model: Object,
20
+ rules: {
21
+ type: runtime.definePropType(Object)
22
+ },
23
+ labelPosition: {
24
+ type: String,
25
+ values: ["left", "right", "top"],
26
+ default: "right"
27
+ },
28
+ requireAsteriskPosition: {
29
+ type: String,
30
+ values: ["left", "right"],
31
+ default: "left"
32
+ },
33
+ labelWidth: {
34
+ type: [String, Number],
35
+ default: ""
36
+ },
37
+ labelSuffix: {
38
+ type: String,
39
+ default: ""
40
+ },
41
+ inline: Boolean,
42
+ inlineMessage: Boolean,
43
+ statusIcon: Boolean,
44
+ showMessage: {
45
+ type: Boolean,
46
+ default: true
47
+ },
48
+ validateOnRuleChange: {
49
+ type: Boolean,
50
+ default: true
51
+ },
52
+ hideRequiredAsterisk: Boolean,
53
+ scrollToError: Boolean,
54
+ scrollIntoViewOptions: {
55
+ type: [Object, Boolean],
56
+ default: true
165
57
  }
166
58
  });
167
- var Form = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "form.vue"]]);
59
+ const formEmits = {
60
+ validate: (prop, isValid, message) => (shared.isArray(prop) || shared.isString(prop)) && types.isBoolean(isValid) && shared.isString(message)
61
+ };
168
62
 
169
- exports["default"] = Form;
63
+ exports.formEmits = formEmits;
64
+ exports.formMetaProps = formMetaProps;
65
+ exports.formProps = formProps;
170
66
  //# sourceMappingURL=form.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"form.js","sources":["../../../../../../packages/components/form/src/form.vue"],"sourcesContent":["<template>\n <form ref=\"formRef\" :class=\"formClasses\">\n <slot />\n </form>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, reactive, ref, toRefs, watch } from 'vue'\nimport { debugWarn, isFunction } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from './hooks'\nimport { formContextKey } from './constants'\nimport { formEmits, formProps } from './form'\nimport { filterFields, useFormLabelWidth } from './utils'\n\nimport type { ValidateFieldsError } from 'async-validator'\nimport type { Arrayable } from '@element-plus/utils'\nimport type {\n FormContext,\n FormItemContext,\n FormValidateCallback,\n FormValidationResult,\n} from './types'\nimport type { FormItemProp } from './form-item'\n\nconst COMPONENT_NAME = 'ElForm'\ndefineOptions({\n name: COMPONENT_NAME,\n})\nconst props = defineProps(formProps)\nconst emit = defineEmits(formEmits)\n\nconst formRef = ref<HTMLElement>()\nconst fields = reactive<FormItemContext[]>([])\n\nconst formSize = useFormSize()\nconst ns = useNamespace('form')\nconst formClasses = computed(() => {\n const { labelPosition, inline } = props\n return [\n ns.b(),\n ns.m(formSize.value || 'default'),\n {\n [ns.m(`label-${labelPosition}`)]: labelPosition,\n [ns.m('inline')]: inline,\n },\n ]\n})\n\nconst getField: FormContext['getField'] = (prop) => {\n return fields.find((field) => field.prop === prop)\n}\n\nconst addField: FormContext['addField'] = (field) => {\n fields.push(field)\n}\n\nconst removeField: FormContext['removeField'] = (field) => {\n if (field.prop) {\n fields.splice(fields.indexOf(field), 1)\n }\n}\n\nconst resetFields: FormContext['resetFields'] = (properties = []) => {\n if (!props.model) {\n debugWarn(COMPONENT_NAME, 'model is required for resetFields to work.')\n return\n }\n filterFields(fields, properties).forEach((field) => field.resetField())\n}\n\nconst clearValidate: FormContext['clearValidate'] = (props = []) => {\n filterFields(fields, props).forEach((field) => field.clearValidate())\n}\n\nconst isValidatable = computed(() => {\n const hasModel = !!props.model\n if (!hasModel) {\n debugWarn(COMPONENT_NAME, 'model is required for validate to work.')\n }\n return hasModel\n})\n\nconst obtainValidateFields = (props: Arrayable<FormItemProp>) => {\n if (fields.length === 0) return []\n\n const filteredFields = filterFields(fields, props)\n if (!filteredFields.length) {\n debugWarn(COMPONENT_NAME, 'please pass correct props!')\n return []\n }\n return filteredFields\n}\n\nconst validate = async (\n callback?: FormValidateCallback\n): FormValidationResult => validateField(undefined, callback)\n\nconst doValidateField = async (\n props: Arrayable<FormItemProp> = []\n): Promise<boolean> => {\n if (!isValidatable.value) return false\n\n const fields = obtainValidateFields(props)\n if (fields.length === 0) return true\n\n let validationErrors: ValidateFieldsError = {}\n for (const field of fields) {\n try {\n await field.validate('')\n if (field.validateState === 'error') field.resetField()\n } catch (fields) {\n validationErrors = {\n ...validationErrors,\n ...(fields as ValidateFieldsError),\n }\n }\n }\n\n if (Object.keys(validationErrors).length === 0) return true\n return Promise.reject(validationErrors)\n}\n\nconst validateField: FormContext['validateField'] = async (\n modelProps = [],\n callback\n) => {\n let result = false\n const shouldThrow = !isFunction(callback)\n try {\n result = await doValidateField(modelProps)\n // When result is false meaning that the fields are not validatable\n if (result === true) {\n await callback?.(result)\n }\n return result\n } catch (e) {\n if (e instanceof Error) throw e\n\n const invalidFields = e as ValidateFieldsError\n\n if (props.scrollToError) {\n // form-item may be dynamically rendered based on the judgment conditions, and the order in invalidFields is uncertain.\n // Therefore, the first form field with an error is determined by directly looking for the rendered element.\n if (formRef.value) {\n const formItem = formRef.value!.querySelector(\n `.${ns.b()}-item.is-error`\n )\n formItem?.scrollIntoView(props.scrollIntoViewOptions)\n }\n }\n !result && (await callback?.(false, invalidFields))\n return shouldThrow && Promise.reject(invalidFields)\n }\n}\n\nconst scrollToField = (prop: FormItemProp) => {\n const field = filterFields(fields, prop)[0]\n if (field) {\n field.$el?.scrollIntoView(props.scrollIntoViewOptions)\n }\n}\n\nwatch(\n () => props.rules,\n () => {\n if (props.validateOnRuleChange) {\n validate().catch((err) => debugWarn(err))\n }\n },\n { deep: true, flush: 'post' }\n)\n\nprovide(\n formContextKey,\n reactive({\n ...toRefs(props),\n emit,\n\n resetFields,\n clearValidate,\n validateField,\n getField,\n addField,\n removeField,\n\n ...useFormLabelWidth(),\n })\n)\n\ndefineExpose({\n /**\n * @description Validate the whole form. Receives a callback or returns `Promise`.\n */\n validate,\n /**\n * @description Validate specified fields.\n */\n validateField,\n /**\n * @description Reset specified fields and remove validation result.\n */\n resetFields,\n /**\n * @description Clear validation message for specified fields.\n */\n clearValidate,\n /**\n * @description Scroll to the specified fields.\n */\n scrollToField,\n /**\n * @description All fields context.\n */\n fields,\n})\n</script>\n"],"names":["ref","reactive","useFormSize","useNamespace","computed","debugWarn","filterFields","props","fields","isFunction","watch","provide","formContextKey","toRefs","useFormLabelWidth","_openBlock","_createElementBlock","_normalizeClass","_unref","_renderSlot","_export_sfc"],"mappings":";;;;;;;;;;;;;;;uCA0Bc,CAAA;AAAA,EACZ,IAAM,EAAA,cAAA;AACR;;;;;;;AAIA,IAAA,MAAM,UAAUA,OAAiB,EAAA,CAAA;AACjC,IAAM,MAAA,MAAA,GAASC,YAA4B,CAAA,EAAE,CAAA,CAAA;AAE7C,IAAA,MAAM,WAAWC,8BAAY,EAAA,CAAA;AAC7B,IAAM,MAAA,EAAA,GAAKC,mBAAa,MAAM,CAAA,CAAA;AAC9B,IAAM,MAAA,WAAA,GAAcC,aAAS,MAAM;AACjC,MAAM,MAAA,EAAE,aAAe,EAAA,MAAA,EAAW,GAAA,KAAA,CAAA;AAClC,MAAO,OAAA;AAAA,QACL,GAAG,CAAE,EAAA;AAAA,QACL,EAAG,CAAA,CAAA,CAAE,QAAS,CAAA,KAAA,IAAS,SAAS,CAAA;AAAA,QAChC;AAAA,UACE,CAAC,EAAG,CAAA,CAAA,CAAE,SAAS,aAAa,CAAA,CAAE,CAAC,GAAG,aAAA;AAAA,UAClC,CAAC,EAAA,CAAG,CAAE,CAAA,QAAQ,CAAC,GAAG,MAAA;AAAA,SACpB;AAAA,OACF,CAAA;AAAA,KACD,CAAA,CAAA;AAED,IAAM,MAAA,QAAA,GAAoC,CAAC,IAAS,KAAA;AAClD,MAAA,OAAO,OAAO,IAAK,CAAA,CAAC,KAAU,KAAA,KAAA,CAAM,SAAS,IAAI,CAAA,CAAA;AAAA,KACnD,CAAA;AAEA,IAAM,MAAA,QAAA,GAAoC,CAAC,KAAU,KAAA;AACnD,MAAA,MAAA,CAAO,KAAK,KAAK,CAAA,CAAA;AAAA,KACnB,CAAA;AAEA,IAAM,MAAA,WAAA,GAA0C,CAAC,KAAU,KAAA;AACzD,MAAA,IAAI,MAAM,IAAM,EAAA;AACd,QAAA,MAAA,CAAO,MAAO,CAAA,MAAA,CAAO,OAAQ,CAAA,KAAK,GAAG,CAAC,CAAA,CAAA;AAAA,OACxC;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,WAA0C,GAAA,CAAC,UAAa,GAAA,EAAO,KAAA;AACnE,MAAI,IAAA,CAAC,MAAM,KAAO,EAAA;AAChB,QAAAC,eAAA,CAAU,gBAAgB,4CAA4C,CAAA,CAAA;AACtE,QAAA,OAAA;AAAA,OACF;AACA,MAAaC,kBAAA,CAAA,MAAA,EAAQ,UAAU,CAAE,CAAA,OAAA,CAAQ,CAAC,KAAU,KAAA,KAAA,CAAM,YAAY,CAAA,CAAA;AAAA,KACxE,CAAA;AAEA,IAAA,MAAM,aAA8C,GAAA,CAACC,MAAQ,GAAA,EAAO,KAAA;AAClE,MAAaD,kBAAA,CAAA,MAAA,EAAQC,MAAK,CAAE,CAAA,OAAA,CAAQ,CAAC,KAAU,KAAA,KAAA,CAAM,eAAe,CAAA,CAAA;AAAA,KACtE,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgBH,aAAS,MAAM;AACnC,MAAM,MAAA,QAAA,GAAW,CAAC,CAAC,KAAM,CAAA,KAAA,CAAA;AACzB,MAAA,IAAI,CAAC,QAAU,EAAA;AACb,QAAAC,eAAA,CAAU,gBAAgB,yCAAyC,CAAA,CAAA;AAAA,OACrE;AACA,MAAO,OAAA,QAAA,CAAA;AAAA,KACR,CAAA,CAAA;AAED,IAAM,MAAA,oBAAA,GAAuB,CAACE,MAAmC,KAAA;AAC/D,MAAA,IAAI,MAAO,CAAA,MAAA,KAAW,CAAG;AAEzB,QAAM,OAAA,EAAA,CAAA;AACN,MAAI,oBAAgB,GAAQD,kBAAA,CAAA,MAAA,EAAA,MAAA,CAAA,CAAA;AAC1B,MAAA,IAAA,CAAA,uBAA0B;AAC1B,QAAAD,eAAQ,CAAA,cAAA,EAAA,4BAAA,CAAA,CAAA;AAAA,QACV,OAAA,EAAA,CAAA;AACA,OAAO;AAAA,MACT,OAAA,cAAA,CAAA;AAEA,KAAA,CAAA;AAIA,IAAA,MAAM,QAAkB,GAAA,OAAA,QACW,KAAA,aACZ,CAAA,KAAA,CAAA,EAAA,QAAA,CAAA,CAAA;AACrB,IAAI,MAAA,eAAe,GAAA,OAAc,MAAA,GAAA,EAAA,KAAA;AAEjC,MAAMG,IAAAA,CAAAA;AACN,QAAIA,OAAAA,KAAkB,CAAA;AAEtB,MAAA,oCAA6C,CAAA,MAAA,CAAA,CAAA;AAC7C,MAAA,IAAA,OAAW,YAAiB,CAAA;AAC1B,QAAI,OAAA,IAAA,CAAA;AACF,MAAM,IAAA,qBAAe,CAAE;AACvB,MAAA,KAAA,MAAU,KAAA,IAAA,OAAA,EAAA;AAA4C,QACxD;AACE,UAAmB,MAAA,KAAA,CAAA,QAAA,CAAA,EAAA,CAAA,CAAA;AAAA,UAAA,IACd,KAAA,CAAA,aAAA,KAAA,OAAA;AAAA,YACH,KAAIA,CAAAA,UAAAA,EAAAA,CAAAA;AAAA,SACN,CAAA,OAAA,OAAA,EAAA;AAAA,UACF,gBAAA,GAAA;AAAA,YACF,GAAA,gBAAA;AAEA,sBAAgB;AAChB,WAAO,CAAA;AAA+B,SACxC;AAEA,OAAA;AAIE,MAAA,IAAI,MAAS,CAAA,IAAA,CAAA,gBAAA,CAAA,CAAA,MAAA,KAAA,CAAA;AACb,QAAM,OAAA,IAAA,CAAA;AACN,MAAI,OAAA,OAAA,CAAA,MAAA,CAAA,gBAAA,CAAA,CAAA;AACF,KAAS,CAAA;AAET,IAAA,MAAA,aAAe,GAAM,OAAA,UAAA,GAAA,EAAA,EAAA,QAAA,KAAA;AACnB,MAAA,IAAA,MAAM;AAAiB,MACzB,MAAA,WAAA,GAAA,CAAAC,iBAAA,CAAA,QAAA,CAAA,CAAA;AACA,MAAO,IAAA;AAAA,iBACG,MAAA,eAAA,CAAA,UAAA,CAAA,CAAA;AACV,QAAI,IAAA,MAAA,KAAA;AAEJ,UAAA,OAAsB,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,MAAA,CAAA,CAAA,CAAA;AAEtB,SAAA;AAGE,QAAA,cAAY;AACV,OAAM,CAAA,OAAA,CAAA,EAAA;AAA0B,QAC9B,IAAA,CAAA,YAAU,KAAA;AAAA,UACZ,MAAA,CAAA,CAAA;AACA,QAAU,MAAA,aAAA,GAAA,CAAA,CAAA;AAA0C,QACtD,IAAA,KAAA,CAAA,aAAA,EAAA;AAAA,UACF,IAAA,OAAA,CAAA,KAAA,EAAA;AACA,YAAY,MAAA,QAAiB,GAAA,OAAA,CAAA,KAAA,CAAO,aAAa,CAAA,CAAA,CAAA,EAAA,EAAA,CAAA,CAAA,EAAA,CAAA,cAAA,CAAA,CAAA,CAAA;AACjD,YAAO,QAAA,IAAA,IAAA,GAAuB,KAAA,CAAA,GAAA,QAAoB,CAAA,cAAA,CAAA,KAAA,CAAA,qBAAA,CAAA,CAAA;AAAA,WACpD;AAAA,SACF;AAEA,QAAM,CAAA,MAAA,IAAA,OAAgB,QAAwB,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,EAAA,aAAA,CAAA,CAAA,CAAA;AAC5C,QAAA,OAAc,WAAA,IAAA,OAAqB,CAAA,MAAA,CAAI,aAAG,CAAA,CAAA;AAC1C,OAAA;AACE,KAAM,CAAA;AAA+C,IACvD,MAAA,aAAA,GAAA,CAAA,IAAA,KAAA;AAAA,MACF,IAAA,EAAA,CAAA;AAEA,MAAA,MAAA,KAAA,GAAAH,kBAAA,CAAA,MAAA,EAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,MACE,SAAY,EAAA;AAAA,QACN,CAAA,EAAA,GAAA,KAAA,CAAA,GAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,cAAA,CAAA,KAAA,CAAA,qBAAA,CAAA,CAAA;AACJ,OAAA;AACE,KAAA,CAAA;AAAwC,IAC1CI,SAAA,CAAA,MAAA,KAAA,CAAA,KAAA,EAAA,MAAA;AAAA,MACF,IAAA,KAAA,CAAA,oBAAA,EAAA;AAAA,QACE,QAAY,EAAA,CAAA,KAAA,CAAA,CAAA,GAAc,KAAAL,eAAA,CAAA,GAAA,CAAA,CAAA,CAAA;AAAA,OAC9B;AAEA,KAAA,EAAA,EAAA,IAAA,EAAA,IAAA,EAAA,KAAA,EAAA,MAAA,EAAA,CAAA,CAAA;AAAA,IACEM,WAAA,CAAAC,wBAAA,EAAAX,YAAA,CAAA;AAAA,MACA,GAASY,UAAA,CAAA,KAAA,CAAA;AAAA,MACP,IAAA;AAAe,MACf,WAAA;AAAA,MAEA,aAAA;AAAA,MACA,aAAA;AAAA,MACA,QAAA;AAAA,MACA,QAAA;AAAA,MACA,WAAA;AAAA,MACA,GAAAC,uBAAA,EAAA;AAAA,KAAA,CAAA,CAAA,CAEA;AAAqB,IAAA,MACtB,CAAA;AAAA,MACH,QAAA;AAEA,MAAa,aAAA;AAAA,MAAA,WAAA;AAAA,MAAA,aAAA;AAAA,MAAA,aAAA;AAAA,MAIX,MAAA;AAAA,KAAA,CAAA,CAAA;AAAA,IAAA,OAAA,CAAA,IAAA,EAAA,MAAA,KAAA;AAAA,MAAA,OAAAC,aAAA,EAAA,EAAAC,sBAAA,CAAA,MAAA,EAAA;AAAA,QAIA,OAAA,EAAA,SAAA;AAAA,QAAA,GAAA,EAAA,OAAA;AAAA,QAAA,KAAA,EAAAC,kBAAA,CAAAC,SAAA,CAAA,WAAA,CAAA,CAAA;AAAA,OAAA,EAAA;AAAA,QAIAC,cAAA,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,CAAA;AAAA,OAAA,EAAA,CAAA,CAAA,CAAA;AAAA,KAAA,CAAA;AAAA,GAAA;AAAA,CAIA,CAAA,CAAA;AAAA,WAAA,gBAAAC,iCAAA,CAAA,SAAA,EAAA,CAAA,CAAA,QAAA,EAAA,UAAA,CAAA,CAAA,CAAA;;;;"}
1
+ {"version":3,"file":"form.js","sources":["../../../../../../packages/components/form/src/form.ts"],"sourcesContent":["import { componentSizes } from '@element-plus/constants'\nimport {\n buildProps,\n definePropType,\n isArray,\n isBoolean,\n isString,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { FormItemProp } from './form-item'\nimport type { FormRules } from './types'\n\nexport const formMetaProps = buildProps({\n /**\n * @description Control the size of components in this form.\n */\n size: {\n type: String,\n values: componentSizes,\n },\n /**\n * @description Whether to disable all components in this form. If set to `true`, it will override the `disabled` prop of the inner component.\n */\n disabled: Boolean,\n} as const)\n\nexport const formProps = buildProps({\n ...formMetaProps,\n /**\n * @description Data of form component.\n */\n model: Object,\n /**\n * @description Validation rules of form.\n */\n rules: {\n type: definePropType<FormRules>(Object),\n },\n /**\n * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required.\n */\n labelPosition: {\n type: String,\n values: ['left', 'right', 'top'],\n default: 'right',\n },\n /**\n * @description Position of asterisk.\n */\n requireAsteriskPosition: {\n type: String,\n values: ['left', 'right'],\n default: 'left',\n },\n /**\n * @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported.\n */\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description Suffix of the label.\n */\n labelSuffix: {\n type: String,\n default: '',\n },\n /**\n * @description Whether the form is inline.\n */\n inline: Boolean,\n /**\n * @description Whether to display the error message inline with the form item.\n */\n inlineMessage: Boolean,\n /**\n * @description Whether to display an icon indicating the validation result.\n */\n statusIcon: Boolean,\n /**\n * @description Whether to show the error message.\n */\n showMessage: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to trigger validation when the `rules` prop is changed.\n */\n validateOnRuleChange: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to hide required fields should have a red asterisk (star) beside their labels.\n */\n hideRequiredAsterisk: Boolean,\n /**\n * @description When validation fails, scroll to the first error form entry.\n */\n scrollToError: Boolean,\n /**\n * @description When validation fails, it scrolls to the first error item based on the scrollIntoView option.\n */\n scrollIntoViewOptions: {\n type: [Object, Boolean],\n default: true,\n },\n} as const)\nexport type FormProps = ExtractPropTypes<typeof formProps>\nexport type FormMetaProps = ExtractPropTypes<typeof formMetaProps>\n\nexport const formEmits = {\n validate: (prop: FormItemProp, isValid: boolean, message: string) =>\n (isArray(prop) || isString(prop)) &&\n isBoolean(isValid) &&\n isString(message),\n}\nexport type FormEmits = typeof formEmits\n"],"names":["buildProps","componentSizes","definePropType","isArray","isString","isBoolean"],"mappings":";;;;;;;;;AAQY,MAAC,aAAa,GAAGA,kBAAU,CAAC;AACxC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAEC,mBAAc;AAC1B,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,CAAC,EAAE;AACS,MAAC,SAAS,GAAGD,kBAAU,CAAC;AACpC,EAAE,GAAG,aAAa;AAClB,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAEE,sBAAc,CAAC,MAAM,CAAC;AAChC,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC;AACpC,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,uBAAuB,EAAE;AAC3B,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC7B,IAAI,OAAO,EAAE,MAAM;AACnB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,MAAM,EAAE,OAAO;AACjB,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,UAAU,EAAE,OAAO;AACrB,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE,OAAO;AAC/B,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,qBAAqB,EAAE;AACzB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC3B,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,SAAS,GAAG;AACzB,EAAE,QAAQ,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,KAAK,CAACC,cAAO,CAAC,IAAI,CAAC,IAAIC,eAAQ,CAAC,IAAI,CAAC,KAAKC,eAAS,CAAC,OAAO,CAAC,IAAID,eAAQ,CAAC,OAAO,CAAC;AACpH;;;;;;"}
@@ -2,65 +2,169 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var runtime = require('../../../utils/vue/props/runtime.js');
6
- var size = require('../../../constants/size.js');
5
+ var vue = require('vue');
6
+ var constants = require('./constants.js');
7
+ var form = require('./form.js');
8
+ var utils = require('./utils.js');
9
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
10
+ var useFormCommonProps = require('./hooks/use-form-common-props.js');
11
+ var index = require('../../../hooks/use-namespace/index.js');
12
+ var error = require('../../../utils/error.js');
7
13
  var shared = require('@vue/shared');
8
- var types = require('../../../utils/types.js');
9
14
 
10
- const formMetaProps = runtime.buildProps({
11
- size: {
12
- type: String,
13
- values: size.componentSizes
14
- },
15
- disabled: Boolean
15
+ const COMPONENT_NAME = "ElForm";
16
+ const __default__ = vue.defineComponent({
17
+ name: COMPONENT_NAME
16
18
  });
17
- const formProps = runtime.buildProps({
18
- ...formMetaProps,
19
- model: Object,
20
- rules: {
21
- type: runtime.definePropType(Object)
22
- },
23
- labelPosition: {
24
- type: String,
25
- values: ["left", "right", "top"],
26
- default: "right"
27
- },
28
- requireAsteriskPosition: {
29
- type: String,
30
- values: ["left", "right"],
31
- default: "left"
32
- },
33
- labelWidth: {
34
- type: [String, Number],
35
- default: ""
36
- },
37
- labelSuffix: {
38
- type: String,
39
- default: ""
40
- },
41
- inline: Boolean,
42
- inlineMessage: Boolean,
43
- statusIcon: Boolean,
44
- showMessage: {
45
- type: Boolean,
46
- default: true
47
- },
48
- validateOnRuleChange: {
49
- type: Boolean,
50
- default: true
51
- },
52
- hideRequiredAsterisk: Boolean,
53
- scrollToError: Boolean,
54
- scrollIntoViewOptions: {
55
- type: [Object, Boolean],
56
- default: true
19
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
20
+ ...__default__,
21
+ props: form.formProps,
22
+ emits: form.formEmits,
23
+ setup(__props, { expose, emit }) {
24
+ const props = __props;
25
+ const formRef = vue.ref();
26
+ const fields = vue.reactive([]);
27
+ const formSize = useFormCommonProps.useFormSize();
28
+ const ns = index.useNamespace("form");
29
+ const formClasses = vue.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
+ error.debugWarn(COMPONENT_NAME, "model is required for resetFields to work.");
54
+ return;
55
+ }
56
+ utils.filterFields(fields, properties).forEach((field) => field.resetField());
57
+ };
58
+ const clearValidate = (props2 = []) => {
59
+ utils.filterFields(fields, props2).forEach((field) => field.clearValidate());
60
+ };
61
+ const isValidatable = vue.computed(() => {
62
+ const hasModel = !!props.model;
63
+ if (!hasModel) {
64
+ error.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 = utils.filterFields(fields, props2);
72
+ if (!filteredFields.length) {
73
+ error.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
+ if (field.validateState === "error")
90
+ field.resetField();
91
+ } catch (fields3) {
92
+ validationErrors = {
93
+ ...validationErrors,
94
+ ...fields3
95
+ };
96
+ }
97
+ }
98
+ if (Object.keys(validationErrors).length === 0)
99
+ return true;
100
+ return Promise.reject(validationErrors);
101
+ };
102
+ const validateField = async (modelProps = [], callback) => {
103
+ let result = false;
104
+ const shouldThrow = !shared.isFunction(callback);
105
+ try {
106
+ result = await doValidateField(modelProps);
107
+ if (result === true) {
108
+ await (callback == null ? void 0 : callback(result));
109
+ }
110
+ return result;
111
+ } catch (e) {
112
+ if (e instanceof Error)
113
+ throw e;
114
+ const invalidFields = e;
115
+ if (props.scrollToError) {
116
+ if (formRef.value) {
117
+ const formItem = formRef.value.querySelector(`.${ns.b()}-item.is-error`);
118
+ formItem == null ? void 0 : formItem.scrollIntoView(props.scrollIntoViewOptions);
119
+ }
120
+ }
121
+ !result && await (callback == null ? void 0 : callback(false, invalidFields));
122
+ return shouldThrow && Promise.reject(invalidFields);
123
+ }
124
+ };
125
+ const scrollToField = (prop) => {
126
+ var _a;
127
+ const field = utils.filterFields(fields, prop)[0];
128
+ if (field) {
129
+ (_a = field.$el) == null ? void 0 : _a.scrollIntoView(props.scrollIntoViewOptions);
130
+ }
131
+ };
132
+ vue.watch(() => props.rules, () => {
133
+ if (props.validateOnRuleChange) {
134
+ validate().catch((err) => error.debugWarn(err));
135
+ }
136
+ }, { deep: true, flush: "post" });
137
+ vue.provide(constants.formContextKey, vue.reactive({
138
+ ...vue.toRefs(props),
139
+ emit,
140
+ resetFields,
141
+ clearValidate,
142
+ validateField,
143
+ getField,
144
+ addField,
145
+ removeField,
146
+ ...utils.useFormLabelWidth()
147
+ }));
148
+ expose({
149
+ validate,
150
+ validateField,
151
+ resetFields,
152
+ clearValidate,
153
+ scrollToField,
154
+ fields
155
+ });
156
+ return (_ctx, _cache) => {
157
+ return vue.openBlock(), vue.createElementBlock("form", {
158
+ ref_key: "formRef",
159
+ ref: formRef,
160
+ class: vue.normalizeClass(vue.unref(formClasses))
161
+ }, [
162
+ vue.renderSlot(_ctx.$slots, "default")
163
+ ], 2);
164
+ };
57
165
  }
58
166
  });
59
- const formEmits = {
60
- validate: (prop, isValid, message) => (shared.isArray(prop) || shared.isString(prop)) && types.isBoolean(isValid) && shared.isString(message)
61
- };
167
+ var Form = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "form.vue"]]);
62
168
 
63
- exports.formEmits = formEmits;
64
- exports.formMetaProps = formMetaProps;
65
- exports.formProps = formProps;
169
+ exports["default"] = Form;
66
170
  //# sourceMappingURL=form2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"form2.js","sources":["../../../../../../packages/components/form/src/form.ts"],"sourcesContent":["import { componentSizes } from '@element-plus/constants'\nimport {\n buildProps,\n definePropType,\n isArray,\n isBoolean,\n isString,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { FormItemProp } from './form-item'\nimport type { FormRules } from './types'\n\nexport const formMetaProps = buildProps({\n /**\n * @description Control the size of components in this form.\n */\n size: {\n type: String,\n values: componentSizes,\n },\n /**\n * @description Whether to disable all components in this form. If set to `true`, it will override the `disabled` prop of the inner component.\n */\n disabled: Boolean,\n} as const)\n\nexport const formProps = buildProps({\n ...formMetaProps,\n /**\n * @description Data of form component.\n */\n model: Object,\n /**\n * @description Validation rules of form.\n */\n rules: {\n type: definePropType<FormRules>(Object),\n },\n /**\n * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required.\n */\n labelPosition: {\n type: String,\n values: ['left', 'right', 'top'],\n default: 'right',\n },\n /**\n * @description Position of asterisk.\n */\n requireAsteriskPosition: {\n type: String,\n values: ['left', 'right'],\n default: 'left',\n },\n /**\n * @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported.\n */\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description Suffix of the label.\n */\n labelSuffix: {\n type: String,\n default: '',\n },\n /**\n * @description Whether the form is inline.\n */\n inline: Boolean,\n /**\n * @description Whether to display the error message inline with the form item.\n */\n inlineMessage: Boolean,\n /**\n * @description Whether to display an icon indicating the validation result.\n */\n statusIcon: Boolean,\n /**\n * @description Whether to show the error message.\n */\n showMessage: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to trigger validation when the `rules` prop is changed.\n */\n validateOnRuleChange: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to hide required fields should have a red asterisk (star) beside their labels.\n */\n hideRequiredAsterisk: Boolean,\n /**\n * @description When validation fails, scroll to the first error form entry.\n */\n scrollToError: Boolean,\n /**\n * @description When validation fails, it scrolls to the first error item based on the scrollIntoView option.\n */\n scrollIntoViewOptions: {\n type: [Object, Boolean],\n default: true,\n },\n} as const)\nexport type FormProps = ExtractPropTypes<typeof formProps>\nexport type FormMetaProps = ExtractPropTypes<typeof formMetaProps>\n\nexport const formEmits = {\n validate: (prop: FormItemProp, isValid: boolean, message: string) =>\n (isArray(prop) || isString(prop)) &&\n isBoolean(isValid) &&\n isString(message),\n}\nexport type FormEmits = typeof formEmits\n"],"names":["buildProps","componentSizes","definePropType","isArray","isString","isBoolean"],"mappings":";;;;;;;;;AAQY,MAAC,aAAa,GAAGA,kBAAU,CAAC;AACxC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAEC,mBAAc;AAC1B,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,CAAC,EAAE;AACS,MAAC,SAAS,GAAGD,kBAAU,CAAC;AACpC,EAAE,GAAG,aAAa;AAClB,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAEE,sBAAc,CAAC,MAAM,CAAC;AAChC,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC;AACpC,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,uBAAuB,EAAE;AAC3B,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC7B,IAAI,OAAO,EAAE,MAAM;AACnB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,MAAM,EAAE,OAAO;AACjB,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,UAAU,EAAE,OAAO;AACrB,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE,OAAO;AAC/B,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,qBAAqB,EAAE;AACzB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC3B,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,SAAS,GAAG;AACzB,EAAE,QAAQ,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,KAAK,CAACC,cAAO,CAAC,IAAI,CAAC,IAAIC,eAAQ,CAAC,IAAI,CAAC,KAAKC,eAAS,CAAC,OAAO,CAAC,IAAID,eAAQ,CAAC,OAAO,CAAC;AACpH;;;;;;"}
1
+ {"version":3,"file":"form2.js","sources":["../../../../../../packages/components/form/src/form.vue"],"sourcesContent":["<template>\n <form ref=\"formRef\" :class=\"formClasses\">\n <slot />\n </form>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, reactive, ref, toRefs, watch } from 'vue'\nimport { debugWarn, isFunction } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from './hooks'\nimport { formContextKey } from './constants'\nimport { formEmits, formProps } from './form'\nimport { filterFields, useFormLabelWidth } from './utils'\n\nimport type { ValidateFieldsError } from 'async-validator'\nimport type { Arrayable } from '@element-plus/utils'\nimport type {\n FormContext,\n FormItemContext,\n FormValidateCallback,\n FormValidationResult,\n} from './types'\nimport type { FormItemProp } from './form-item'\n\nconst COMPONENT_NAME = 'ElForm'\ndefineOptions({\n name: COMPONENT_NAME,\n})\nconst props = defineProps(formProps)\nconst emit = defineEmits(formEmits)\n\nconst formRef = ref<HTMLElement>()\nconst fields = reactive<FormItemContext[]>([])\n\nconst formSize = useFormSize()\nconst ns = useNamespace('form')\nconst formClasses = computed(() => {\n const { labelPosition, inline } = props\n return [\n ns.b(),\n ns.m(formSize.value || 'default'),\n {\n [ns.m(`label-${labelPosition}`)]: labelPosition,\n [ns.m('inline')]: inline,\n },\n ]\n})\n\nconst getField: FormContext['getField'] = (prop) => {\n return fields.find((field) => field.prop === prop)\n}\n\nconst addField: FormContext['addField'] = (field) => {\n fields.push(field)\n}\n\nconst removeField: FormContext['removeField'] = (field) => {\n if (field.prop) {\n fields.splice(fields.indexOf(field), 1)\n }\n}\n\nconst resetFields: FormContext['resetFields'] = (properties = []) => {\n if (!props.model) {\n debugWarn(COMPONENT_NAME, 'model is required for resetFields to work.')\n return\n }\n filterFields(fields, properties).forEach((field) => field.resetField())\n}\n\nconst clearValidate: FormContext['clearValidate'] = (props = []) => {\n filterFields(fields, props).forEach((field) => field.clearValidate())\n}\n\nconst isValidatable = computed(() => {\n const hasModel = !!props.model\n if (!hasModel) {\n debugWarn(COMPONENT_NAME, 'model is required for validate to work.')\n }\n return hasModel\n})\n\nconst obtainValidateFields = (props: Arrayable<FormItemProp>) => {\n if (fields.length === 0) return []\n\n const filteredFields = filterFields(fields, props)\n if (!filteredFields.length) {\n debugWarn(COMPONENT_NAME, 'please pass correct props!')\n return []\n }\n return filteredFields\n}\n\nconst validate = async (\n callback?: FormValidateCallback\n): FormValidationResult => validateField(undefined, callback)\n\nconst doValidateField = async (\n props: Arrayable<FormItemProp> = []\n): Promise<boolean> => {\n if (!isValidatable.value) return false\n\n const fields = obtainValidateFields(props)\n if (fields.length === 0) return true\n\n let validationErrors: ValidateFieldsError = {}\n for (const field of fields) {\n try {\n await field.validate('')\n if (field.validateState === 'error') field.resetField()\n } catch (fields) {\n validationErrors = {\n ...validationErrors,\n ...(fields as ValidateFieldsError),\n }\n }\n }\n\n if (Object.keys(validationErrors).length === 0) return true\n return Promise.reject(validationErrors)\n}\n\nconst validateField: FormContext['validateField'] = async (\n modelProps = [],\n callback\n) => {\n let result = false\n const shouldThrow = !isFunction(callback)\n try {\n result = await doValidateField(modelProps)\n // When result is false meaning that the fields are not validatable\n if (result === true) {\n await callback?.(result)\n }\n return result\n } catch (e) {\n if (e instanceof Error) throw e\n\n const invalidFields = e as ValidateFieldsError\n\n if (props.scrollToError) {\n // form-item may be dynamically rendered based on the judgment conditions, and the order in invalidFields is uncertain.\n // Therefore, the first form field with an error is determined by directly looking for the rendered element.\n if (formRef.value) {\n const formItem = formRef.value!.querySelector(\n `.${ns.b()}-item.is-error`\n )\n formItem?.scrollIntoView(props.scrollIntoViewOptions)\n }\n }\n !result && (await callback?.(false, invalidFields))\n return shouldThrow && Promise.reject(invalidFields)\n }\n}\n\nconst scrollToField = (prop: FormItemProp) => {\n const field = filterFields(fields, prop)[0]\n if (field) {\n field.$el?.scrollIntoView(props.scrollIntoViewOptions)\n }\n}\n\nwatch(\n () => props.rules,\n () => {\n if (props.validateOnRuleChange) {\n validate().catch((err) => debugWarn(err))\n }\n },\n { deep: true, flush: 'post' }\n)\n\nprovide(\n formContextKey,\n reactive({\n ...toRefs(props),\n emit,\n\n resetFields,\n clearValidate,\n validateField,\n getField,\n addField,\n removeField,\n\n ...useFormLabelWidth(),\n })\n)\n\ndefineExpose({\n /**\n * @description Validate the whole form. Receives a callback or returns `Promise`.\n */\n validate,\n /**\n * @description Validate specified fields.\n */\n validateField,\n /**\n * @description Reset specified fields and remove validation result.\n */\n resetFields,\n /**\n * @description Clear validation message for specified fields.\n */\n clearValidate,\n /**\n * @description Scroll to the specified fields.\n */\n scrollToField,\n /**\n * @description All fields context.\n */\n fields,\n})\n</script>\n"],"names":["ref","reactive","useFormSize","useNamespace","computed","debugWarn","filterFields","props","fields","isFunction","watch","provide","formContextKey","toRefs","useFormLabelWidth","_openBlock","_createElementBlock","_normalizeClass","_unref","_renderSlot","_export_sfc"],"mappings":"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"}
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var icon$1 = require('./src/icon2.js');
6
- var icon = require('./src/icon.js');
5
+ var icon$1 = require('./src/icon.js');
6
+ var icon = require('./src/icon2.js');
7
7
  var install = require('../../utils/vue/install.js');
8
8
 
9
9
  const ElIcon = install.withInstall(icon$1["default"]);
@@ -2,16 +2,43 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var runtime = require('../../../utils/vue/props/runtime.js');
5
+ var vue = require('vue');
6
+ var icon = require('./icon2.js');
7
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
8
+ var index = require('../../../hooks/use-namespace/index.js');
9
+ var types = require('../../../utils/types.js');
10
+ var style = require('../../../utils/dom/style.js');
6
11
 
7
- const iconProps = runtime.buildProps({
8
- size: {
9
- type: runtime.definePropType([Number, String])
10
- },
11
- color: {
12
- type: String
12
+ const __default__ = vue.defineComponent({
13
+ name: "ElIcon",
14
+ inheritAttrs: false
15
+ });
16
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
17
+ ...__default__,
18
+ props: icon.iconProps,
19
+ setup(__props) {
20
+ const props = __props;
21
+ const ns = index.useNamespace("icon");
22
+ const style$1 = vue.computed(() => {
23
+ const { size, color } = props;
24
+ if (!size && !color)
25
+ return {};
26
+ return {
27
+ fontSize: types.isUndefined(size) ? void 0 : style.addUnit(size),
28
+ "--color": color
29
+ };
30
+ });
31
+ return (_ctx, _cache) => {
32
+ return vue.openBlock(), vue.createElementBlock("i", vue.mergeProps({
33
+ class: vue.unref(ns).b(),
34
+ style: vue.unref(style$1)
35
+ }, _ctx.$attrs), [
36
+ vue.renderSlot(_ctx.$slots, "default")
37
+ ], 16);
38
+ };
13
39
  }
14
40
  });
41
+ var Icon = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "icon.vue"]]);
15
42
 
16
- exports.iconProps = iconProps;
43
+ exports["default"] = Icon;
17
44
  //# sourceMappingURL=icon.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"icon.js","sources":["../../../../../../packages/components/icon/src/icon.ts"],"sourcesContent":["import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Icon from './icon.vue'\n\nexport const iconProps = buildProps({\n /**\n * @description SVG icon size, size x size\n */\n size: {\n type: definePropType<number | string>([Number, String]),\n },\n /**\n * @description SVG tag's fill attribute\n */\n color: {\n type: String,\n },\n} as const)\nexport type IconProps = ExtractPropTypes<typeof iconProps>\nexport type IconInstance = InstanceType<typeof Icon> & unknown\n"],"names":["buildProps","definePropType"],"mappings":";;;;;;AACY,MAAC,SAAS,GAAGA,kBAAU,CAAC;AACpC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAEC,sBAAc,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC1C,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"icon.js","sources":["../../../../../../packages/components/icon/src/icon.vue"],"sourcesContent":["<template>\n <i :class=\"ns.b()\" :style=\"style\" v-bind=\"$attrs\">\n <slot />\n </i>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { addUnit, isUndefined } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { iconProps } from './icon'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n name: 'ElIcon',\n inheritAttrs: false,\n})\nconst props = defineProps(iconProps)\nconst ns = useNamespace('icon')\n\nconst style = computed<CSSProperties>(() => {\n const { size, color } = props\n if (!size && !color) return {}\n\n return {\n fontSize: isUndefined(size) ? undefined : addUnit(size),\n '--color': color,\n }\n})\n</script>\n"],"names":["useNamespace","style","computed","isUndefined","addUnit"],"mappings":";;;;;;;;;;;uCAac,CAAA;AAAA,EACZ,IAAM,EAAA,QAAA;AAAA,EACN,YAAc,EAAA,KAAA;AAChB,CAAA,CAAA,CAAA;;;;;;AAEA,IAAM,MAAA,EAAA,GAAKA,mBAAa,MAAM,CAAA,CAAA;AAE9B,IAAM,MAAAC,OAAA,GAAQC,aAAwB,MAAM;AAC1C,MAAM,MAAA,EAAE,IAAM,EAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AACxB,MAAA,IAAI,CAAC,IAAA,IAAQ,CAAC,KAAA;AAEd,QAAO,OAAA,EAAA,CAAA;AAAA,MAAA;AACiD,QACtD,QAAW,EAAAC,iBAAA,CAAA,IAAA,CAAA,GAAA,KAAA,CAAA,GAAAC,aAAA,CAAA,IAAA,CAAA;AAAA,QACb,SAAA,EAAA,KAAA;AAAA,OACD,CAAA;;;;;;;;;;;;;;;;"}