@element-plus/nightly 0.0.20260315 → 0.0.20260317

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 (599) hide show
  1. package/attributes.json +1 -1
  2. package/dist/index.full.js +603 -526
  3. package/dist/index.full.min.js +9 -9
  4. package/dist/index.full.min.js.map +1 -1
  5. package/dist/index.full.min.mjs +8 -8
  6. package/dist/index.full.min.mjs.map +1 -1
  7. package/dist/index.full.mjs +603 -526
  8. package/dist/locale/af.js +1 -1
  9. package/dist/locale/af.min.js +1 -1
  10. package/dist/locale/af.min.mjs +1 -1
  11. package/dist/locale/af.mjs +1 -1
  12. package/dist/locale/ar-eg.js +1 -1
  13. package/dist/locale/ar-eg.min.js +1 -1
  14. package/dist/locale/ar-eg.min.mjs +1 -1
  15. package/dist/locale/ar-eg.mjs +1 -1
  16. package/dist/locale/ar.js +1 -1
  17. package/dist/locale/ar.min.js +1 -1
  18. package/dist/locale/ar.min.mjs +1 -1
  19. package/dist/locale/ar.mjs +1 -1
  20. package/dist/locale/az.js +1 -1
  21. package/dist/locale/az.min.js +1 -1
  22. package/dist/locale/az.min.mjs +1 -1
  23. package/dist/locale/az.mjs +1 -1
  24. package/dist/locale/bg.js +1 -1
  25. package/dist/locale/bg.min.js +1 -1
  26. package/dist/locale/bg.min.mjs +1 -1
  27. package/dist/locale/bg.mjs +1 -1
  28. package/dist/locale/bn.js +1 -1
  29. package/dist/locale/bn.min.js +1 -1
  30. package/dist/locale/bn.min.mjs +1 -1
  31. package/dist/locale/bn.mjs +1 -1
  32. package/dist/locale/ca.js +1 -1
  33. package/dist/locale/ca.min.js +1 -1
  34. package/dist/locale/ca.min.mjs +1 -1
  35. package/dist/locale/ca.mjs +1 -1
  36. package/dist/locale/ckb.js +1 -1
  37. package/dist/locale/ckb.min.js +1 -1
  38. package/dist/locale/ckb.min.mjs +1 -1
  39. package/dist/locale/ckb.mjs +1 -1
  40. package/dist/locale/cs.js +1 -1
  41. package/dist/locale/cs.min.js +1 -1
  42. package/dist/locale/cs.min.mjs +1 -1
  43. package/dist/locale/cs.mjs +1 -1
  44. package/dist/locale/da.js +1 -1
  45. package/dist/locale/da.min.js +1 -1
  46. package/dist/locale/da.min.mjs +1 -1
  47. package/dist/locale/da.mjs +1 -1
  48. package/dist/locale/de.js +1 -1
  49. package/dist/locale/de.min.js +1 -1
  50. package/dist/locale/de.min.mjs +1 -1
  51. package/dist/locale/de.mjs +1 -1
  52. package/dist/locale/el.js +1 -1
  53. package/dist/locale/el.min.js +1 -1
  54. package/dist/locale/el.min.mjs +1 -1
  55. package/dist/locale/el.mjs +1 -1
  56. package/dist/locale/en.js +1 -1
  57. package/dist/locale/en.min.js +1 -1
  58. package/dist/locale/en.min.mjs +1 -1
  59. package/dist/locale/en.mjs +1 -1
  60. package/dist/locale/eo.js +1 -1
  61. package/dist/locale/eo.min.js +1 -1
  62. package/dist/locale/eo.min.mjs +1 -1
  63. package/dist/locale/eo.mjs +1 -1
  64. package/dist/locale/es.js +1 -1
  65. package/dist/locale/es.min.js +1 -1
  66. package/dist/locale/es.min.mjs +1 -1
  67. package/dist/locale/es.mjs +1 -1
  68. package/dist/locale/et.js +1 -1
  69. package/dist/locale/et.min.js +1 -1
  70. package/dist/locale/et.min.mjs +1 -1
  71. package/dist/locale/et.mjs +1 -1
  72. package/dist/locale/eu.js +1 -1
  73. package/dist/locale/eu.min.js +1 -1
  74. package/dist/locale/eu.min.mjs +1 -1
  75. package/dist/locale/eu.mjs +1 -1
  76. package/dist/locale/fa.js +1 -1
  77. package/dist/locale/fa.min.js +1 -1
  78. package/dist/locale/fa.min.mjs +1 -1
  79. package/dist/locale/fa.mjs +1 -1
  80. package/dist/locale/fi.js +1 -1
  81. package/dist/locale/fi.min.js +1 -1
  82. package/dist/locale/fi.min.mjs +1 -1
  83. package/dist/locale/fi.mjs +1 -1
  84. package/dist/locale/fr.js +1 -1
  85. package/dist/locale/fr.min.js +1 -1
  86. package/dist/locale/fr.min.mjs +1 -1
  87. package/dist/locale/fr.mjs +1 -1
  88. package/dist/locale/he.js +1 -1
  89. package/dist/locale/he.min.js +1 -1
  90. package/dist/locale/he.min.mjs +1 -1
  91. package/dist/locale/he.mjs +1 -1
  92. package/dist/locale/hi.js +1 -1
  93. package/dist/locale/hi.min.js +1 -1
  94. package/dist/locale/hi.min.mjs +1 -1
  95. package/dist/locale/hi.mjs +1 -1
  96. package/dist/locale/hr.js +1 -1
  97. package/dist/locale/hr.min.js +1 -1
  98. package/dist/locale/hr.min.mjs +1 -1
  99. package/dist/locale/hr.mjs +1 -1
  100. package/dist/locale/hu.js +1 -1
  101. package/dist/locale/hu.min.js +1 -1
  102. package/dist/locale/hu.min.mjs +1 -1
  103. package/dist/locale/hu.mjs +1 -1
  104. package/dist/locale/hy-am.js +1 -1
  105. package/dist/locale/hy-am.min.js +1 -1
  106. package/dist/locale/hy-am.min.mjs +1 -1
  107. package/dist/locale/hy-am.mjs +1 -1
  108. package/dist/locale/id.js +1 -1
  109. package/dist/locale/id.min.js +1 -1
  110. package/dist/locale/id.min.mjs +1 -1
  111. package/dist/locale/id.mjs +1 -1
  112. package/dist/locale/it.js +1 -1
  113. package/dist/locale/it.min.js +1 -1
  114. package/dist/locale/it.min.mjs +1 -1
  115. package/dist/locale/it.mjs +1 -1
  116. package/dist/locale/ja.js +1 -1
  117. package/dist/locale/ja.min.js +1 -1
  118. package/dist/locale/ja.min.mjs +1 -1
  119. package/dist/locale/ja.mjs +1 -1
  120. package/dist/locale/kk.js +1 -1
  121. package/dist/locale/kk.min.js +1 -1
  122. package/dist/locale/kk.min.mjs +1 -1
  123. package/dist/locale/kk.mjs +1 -1
  124. package/dist/locale/km.js +1 -1
  125. package/dist/locale/km.min.js +1 -1
  126. package/dist/locale/km.min.mjs +1 -1
  127. package/dist/locale/km.mjs +1 -1
  128. package/dist/locale/ko.js +1 -1
  129. package/dist/locale/ko.min.js +1 -1
  130. package/dist/locale/ko.min.mjs +1 -1
  131. package/dist/locale/ko.mjs +1 -1
  132. package/dist/locale/ku.js +1 -1
  133. package/dist/locale/ku.min.js +1 -1
  134. package/dist/locale/ku.min.mjs +1 -1
  135. package/dist/locale/ku.mjs +1 -1
  136. package/dist/locale/ky.js +1 -1
  137. package/dist/locale/ky.min.js +1 -1
  138. package/dist/locale/ky.min.mjs +1 -1
  139. package/dist/locale/ky.mjs +1 -1
  140. package/dist/locale/lo.js +1 -1
  141. package/dist/locale/lo.min.js +1 -1
  142. package/dist/locale/lo.min.mjs +1 -1
  143. package/dist/locale/lo.mjs +1 -1
  144. package/dist/locale/lt.js +1 -1
  145. package/dist/locale/lt.min.js +1 -1
  146. package/dist/locale/lt.min.mjs +1 -1
  147. package/dist/locale/lt.mjs +1 -1
  148. package/dist/locale/lv.js +1 -1
  149. package/dist/locale/lv.min.js +1 -1
  150. package/dist/locale/lv.min.mjs +1 -1
  151. package/dist/locale/lv.mjs +1 -1
  152. package/dist/locale/mg.js +1 -1
  153. package/dist/locale/mg.min.js +1 -1
  154. package/dist/locale/mg.min.mjs +1 -1
  155. package/dist/locale/mg.mjs +1 -1
  156. package/dist/locale/mn.js +1 -1
  157. package/dist/locale/mn.min.js +1 -1
  158. package/dist/locale/mn.min.mjs +1 -1
  159. package/dist/locale/mn.mjs +1 -1
  160. package/dist/locale/ms.js +1 -1
  161. package/dist/locale/ms.min.js +1 -1
  162. package/dist/locale/ms.min.mjs +1 -1
  163. package/dist/locale/ms.mjs +1 -1
  164. package/dist/locale/my.js +1 -1
  165. package/dist/locale/my.min.js +1 -1
  166. package/dist/locale/my.min.mjs +1 -1
  167. package/dist/locale/my.mjs +1 -1
  168. package/dist/locale/nb-no.js +1 -1
  169. package/dist/locale/nb-no.min.js +1 -1
  170. package/dist/locale/nb-no.min.mjs +1 -1
  171. package/dist/locale/nb-no.mjs +1 -1
  172. package/dist/locale/nl.js +1 -1
  173. package/dist/locale/nl.min.js +1 -1
  174. package/dist/locale/nl.min.mjs +1 -1
  175. package/dist/locale/nl.mjs +1 -1
  176. package/dist/locale/no.js +1 -1
  177. package/dist/locale/no.min.js +1 -1
  178. package/dist/locale/no.min.mjs +1 -1
  179. package/dist/locale/no.mjs +1 -1
  180. package/dist/locale/pa.js +1 -1
  181. package/dist/locale/pa.min.js +1 -1
  182. package/dist/locale/pa.min.mjs +1 -1
  183. package/dist/locale/pa.mjs +1 -1
  184. package/dist/locale/pl.js +1 -1
  185. package/dist/locale/pl.min.js +1 -1
  186. package/dist/locale/pl.min.mjs +1 -1
  187. package/dist/locale/pl.mjs +1 -1
  188. package/dist/locale/pt-br.js +1 -1
  189. package/dist/locale/pt-br.min.js +1 -1
  190. package/dist/locale/pt-br.min.mjs +1 -1
  191. package/dist/locale/pt-br.mjs +1 -1
  192. package/dist/locale/pt.js +1 -1
  193. package/dist/locale/pt.min.js +1 -1
  194. package/dist/locale/pt.min.mjs +1 -1
  195. package/dist/locale/pt.mjs +1 -1
  196. package/dist/locale/ro.js +1 -1
  197. package/dist/locale/ro.min.js +1 -1
  198. package/dist/locale/ro.min.mjs +1 -1
  199. package/dist/locale/ro.mjs +1 -1
  200. package/dist/locale/ru.js +1 -1
  201. package/dist/locale/ru.min.js +1 -1
  202. package/dist/locale/ru.min.mjs +1 -1
  203. package/dist/locale/ru.mjs +1 -1
  204. package/dist/locale/sk.js +1 -1
  205. package/dist/locale/sk.min.js +1 -1
  206. package/dist/locale/sk.min.mjs +1 -1
  207. package/dist/locale/sk.mjs +1 -1
  208. package/dist/locale/sl.js +1 -1
  209. package/dist/locale/sl.min.js +1 -1
  210. package/dist/locale/sl.min.mjs +1 -1
  211. package/dist/locale/sl.mjs +1 -1
  212. package/dist/locale/sr.js +1 -1
  213. package/dist/locale/sr.min.js +1 -1
  214. package/dist/locale/sr.min.mjs +1 -1
  215. package/dist/locale/sr.mjs +1 -1
  216. package/dist/locale/sv.js +1 -1
  217. package/dist/locale/sv.min.js +1 -1
  218. package/dist/locale/sv.min.mjs +1 -1
  219. package/dist/locale/sv.mjs +1 -1
  220. package/dist/locale/sw.js +1 -1
  221. package/dist/locale/sw.min.js +1 -1
  222. package/dist/locale/sw.min.mjs +1 -1
  223. package/dist/locale/sw.mjs +1 -1
  224. package/dist/locale/ta.js +1 -1
  225. package/dist/locale/ta.min.js +1 -1
  226. package/dist/locale/ta.min.mjs +1 -1
  227. package/dist/locale/ta.mjs +1 -1
  228. package/dist/locale/te.js +1 -1
  229. package/dist/locale/te.min.js +1 -1
  230. package/dist/locale/te.min.mjs +1 -1
  231. package/dist/locale/te.mjs +1 -1
  232. package/dist/locale/th.js +1 -1
  233. package/dist/locale/th.min.js +1 -1
  234. package/dist/locale/th.min.mjs +1 -1
  235. package/dist/locale/th.mjs +1 -1
  236. package/dist/locale/tk.js +1 -1
  237. package/dist/locale/tk.min.js +1 -1
  238. package/dist/locale/tk.min.mjs +1 -1
  239. package/dist/locale/tk.mjs +1 -1
  240. package/dist/locale/tr.js +1 -1
  241. package/dist/locale/tr.min.js +1 -1
  242. package/dist/locale/tr.min.mjs +1 -1
  243. package/dist/locale/tr.mjs +1 -1
  244. package/dist/locale/ug-cn.js +1 -1
  245. package/dist/locale/ug-cn.min.js +1 -1
  246. package/dist/locale/ug-cn.min.mjs +1 -1
  247. package/dist/locale/ug-cn.mjs +1 -1
  248. package/dist/locale/uk.js +1 -1
  249. package/dist/locale/uk.min.js +1 -1
  250. package/dist/locale/uk.min.mjs +1 -1
  251. package/dist/locale/uk.mjs +1 -1
  252. package/dist/locale/uz-uz.js +1 -1
  253. package/dist/locale/uz-uz.min.js +1 -1
  254. package/dist/locale/uz-uz.min.mjs +1 -1
  255. package/dist/locale/uz-uz.mjs +1 -1
  256. package/dist/locale/vi.js +1 -1
  257. package/dist/locale/vi.min.js +1 -1
  258. package/dist/locale/vi.min.mjs +1 -1
  259. package/dist/locale/vi.mjs +1 -1
  260. package/dist/locale/zh-cn.js +1 -1
  261. package/dist/locale/zh-cn.min.js +1 -1
  262. package/dist/locale/zh-cn.min.mjs +1 -1
  263. package/dist/locale/zh-cn.mjs +1 -1
  264. package/dist/locale/zh-hk.js +1 -1
  265. package/dist/locale/zh-hk.min.js +1 -1
  266. package/dist/locale/zh-hk.min.mjs +1 -1
  267. package/dist/locale/zh-hk.mjs +1 -1
  268. package/dist/locale/zh-mo.js +1 -1
  269. package/dist/locale/zh-mo.min.js +1 -1
  270. package/dist/locale/zh-mo.min.mjs +1 -1
  271. package/dist/locale/zh-mo.mjs +1 -1
  272. package/dist/locale/zh-tw.js +1 -1
  273. package/dist/locale/zh-tw.min.js +1 -1
  274. package/dist/locale/zh-tw.min.mjs +1 -1
  275. package/dist/locale/zh-tw.mjs +1 -1
  276. package/es/components/affix/src/affix.d.ts +1 -1
  277. package/es/components/affix/src/affix.vue.d.ts +2 -2
  278. package/es/components/alert/src/alert.d.ts +1 -1
  279. package/es/components/alert/src/alert.vue.d.ts +2 -2
  280. package/es/components/autocomplete/src/autocomplete.d.ts +4 -4
  281. package/es/components/autocomplete/src/autocomplete.vue.d.ts +13 -13
  282. package/es/components/avatar/src/avatar.d.ts +1 -1
  283. package/es/components/backtop/src/backtop.vue.d.ts +1 -1
  284. package/es/components/badge/src/badge.d.ts +1 -1
  285. package/es/components/button/src/button-group.vue.d.ts +1 -1
  286. package/es/components/button/src/button.d.ts +1 -1
  287. package/es/components/button/src/button.vue.d.ts +4 -4
  288. package/es/components/card/src/card.d.ts +1 -1
  289. package/es/components/card/src/card.vue.d.ts +1 -1
  290. package/es/components/carousel/src/carousel.d.ts +1 -1
  291. package/es/components/carousel/src/carousel.vue.d.ts +1 -1
  292. package/es/components/cascader/src/cascader.d.ts +3 -3
  293. package/es/components/cascader/src/cascader.vue.d.ts +14 -14
  294. package/es/components/cascader-panel/src/index.vue.d.ts +2 -2
  295. package/es/components/check-tag/src/check-tag.d.ts +1 -1
  296. package/es/components/checkbox/src/checkbox-button.vue.d.ts +4 -4
  297. package/es/components/checkbox/src/checkbox.d.ts +8 -8
  298. package/es/components/checkbox/src/checkbox.vue.d.ts +4 -4
  299. package/es/components/collapse/src/collapse.d.ts +1 -1
  300. package/es/components/collapse/src/collapse.vue.d.ts +1 -1
  301. package/es/components/color-picker/src/color-picker.vue.d.ts +7 -7
  302. package/es/components/config-provider/src/config-provider.d.ts +2 -2
  303. package/es/components/date-picker/src/date-picker.d.ts +13 -13
  304. package/es/components/date-picker/src/props.d.ts +2 -2
  305. package/es/components/date-picker-panel/src/date-picker-panel.d.ts +6 -6
  306. package/es/components/date-picker-panel/src/props/date-picker-panel.d.ts +1 -1
  307. package/es/components/descriptions/src/description-item.d.ts +19 -19
  308. package/es/components/descriptions/src/description.vue.d.ts +1 -1
  309. package/es/components/dialog/src/dialog.vue.d.ts +3 -3
  310. package/es/components/divider/src/divider.d.ts +1 -1
  311. package/es/components/drawer/src/drawer.vue.d.ts +4 -4
  312. package/es/components/dropdown/src/dropdown-item.vue.d.ts +1 -1
  313. package/es/components/dropdown/src/dropdown-menu.vue.d.ts +1 -1
  314. package/es/components/dropdown/src/dropdown.d.ts +3 -3
  315. package/es/components/dropdown/src/dropdown.vue.d.ts +96 -96
  316. package/es/components/empty/src/empty.vue.d.ts +1 -1
  317. package/es/components/focus-trap/src/focus-trap.vue.d.ts +1 -1
  318. package/es/components/form/src/form-item.d.ts +1 -1
  319. package/es/components/form/src/form.d.ts +2 -2
  320. package/es/components/image/src/image.d.ts +1 -1
  321. package/es/components/image/src/image.vue.d.ts +3 -3
  322. package/es/components/image-viewer/src/image-viewer.vue.d.ts +2 -2
  323. package/es/components/input/src/input.d.ts +3 -3
  324. package/es/components/input/src/input.vue.d.ts +5 -5
  325. package/es/components/input/src/input.vue_vue_type_script_setup_true_lang.mjs +3 -1
  326. package/es/components/input/src/input.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  327. package/es/components/input/src/input2.mjs.map +1 -1
  328. package/es/components/input-number/src/input-number.d.ts +3 -3
  329. package/es/components/input-number/src/input-number.vue.d.ts +4 -4
  330. package/es/components/input-tag/src/input-tag.d.ts +2 -2
  331. package/es/components/input-tag/src/input-tag.vue.d.ts +10 -10
  332. package/es/components/link/src/link.d.ts +2 -2
  333. package/es/components/link/src/link.vue.d.ts +1 -1
  334. package/es/components/mention/src/mention.d.ts +3 -3
  335. package/es/components/mention/src/mention.vue.d.ts +9 -9
  336. package/es/components/menu/src/menu.d.ts +1 -1
  337. package/es/components/menu/src/sub-menu.d.ts +1 -1
  338. package/es/components/message/src/message.d.ts +2 -2
  339. package/es/components/message/src/message.vue.d.ts +4 -4
  340. package/es/components/notification/src/notification.d.ts +2 -2
  341. package/es/components/notification/src/notification.vue.d.ts +3 -3
  342. package/es/components/overlay/index.d.ts +2 -2
  343. package/es/components/overlay/src/overlay.d.ts +1 -1
  344. package/es/components/pagination/src/pagination.d.ts +2 -2
  345. package/es/components/popconfirm/src/popconfirm.d.ts +2 -2
  346. package/es/components/popconfirm/src/popconfirm.vue.d.ts +3 -3
  347. package/es/components/popover/src/popover.d.ts +1 -1
  348. package/es/components/popover/src/popover.vue.d.ts +9 -9
  349. package/es/components/popper/src/composables/use-content.d.ts +5 -5
  350. package/es/components/popper/src/composables/use-focus-trap.d.ts +1 -1
  351. package/es/components/popper/src/content.vue.d.ts +9 -9
  352. package/es/components/popper/src/popper.d.ts +2 -2
  353. package/es/components/progress/src/progress.d.ts +1 -1
  354. package/es/components/progress/src/progress.vue.d.ts +1 -1
  355. package/es/components/radio/src/radio-button.d.ts +3 -3
  356. package/es/components/radio/src/radio-button.vue.d.ts +3 -3
  357. package/es/components/radio/src/radio-group.vue.d.ts +4 -4
  358. package/es/components/radio/src/radio.d.ts +6 -6
  359. package/es/components/radio/src/radio.vue.d.ts +4 -4
  360. package/es/components/rate/src/rate.vue.d.ts +2 -2
  361. package/es/components/result/src/result.d.ts +1 -1
  362. package/es/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  363. package/es/components/row/src/row.d.ts +1 -1
  364. package/es/components/row/src/row.vue.d.ts +1 -1
  365. package/es/components/scrollbar/src/scrollbar.vue.d.ts +3 -3
  366. package/es/components/segmented/index.d.ts +34 -66
  367. package/es/components/segmented/src/segmented.d.ts +6 -5
  368. package/es/components/segmented/src/segmented.mjs.map +1 -1
  369. package/es/components/segmented/src/segmented.vue.d.ts +21 -26
  370. package/es/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.mjs +58 -4
  371. package/es/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  372. package/es/components/segmented/src/segmented2.mjs.map +1 -1
  373. package/es/components/select/src/option.d.ts +2 -2
  374. package/es/components/select/src/option.vue.d.ts +6 -6
  375. package/es/components/select/src/select.d.ts +4 -4
  376. package/es/components/select/src/select.vue.d.ts +112 -112
  377. package/es/components/select-v2/src/defaults.d.ts +2 -2
  378. package/es/components/select-v2/src/select.vue.d.ts +87 -87
  379. package/es/components/skeleton/src/skeleton-item.d.ts +1 -1
  380. package/es/components/skeleton/src/skeleton.vue.d.ts +1 -1
  381. package/es/components/slider/src/slider.vue.d.ts +6 -6
  382. package/es/components/space/src/space.d.ts +5 -5
  383. package/es/components/statistic/src/statistic.vue.d.ts +2 -2
  384. package/es/components/steps/src/item.vue.d.ts +1 -1
  385. package/es/components/steps/src/steps.vue.d.ts +1 -1
  386. package/es/components/switch/src/switch.vue.d.ts +3 -3
  387. package/es/components/table/src/table-body/events-helper.mjs +1 -3
  388. package/es/components/table/src/table-body/events-helper.mjs.map +1 -1
  389. package/es/components/table/src/table-body/index.d.ts +1 -1
  390. package/es/components/table/src/table-column/index.d.ts +18 -18
  391. package/es/components/table/src/table-header/index.d.ts +12 -12
  392. package/es/components/table/src/table.vue.d.ts +41 -41
  393. package/es/components/tabs/src/tab-nav.mjs +13 -10
  394. package/es/components/tabs/src/tab-nav.mjs.map +1 -1
  395. package/es/components/tabs/src/tab-pane.vue.d.ts +1 -1
  396. package/es/components/tabs/src/tabs.d.ts +4 -4
  397. package/es/components/tag/src/tag.d.ts +1 -1
  398. package/es/components/text/src/text.d.ts +1 -1
  399. package/es/components/time-picker/src/common/picker.vue.d.ts +17 -17
  400. package/es/components/time-picker/src/common/props.d.ts +2 -2
  401. package/es/components/time-picker/src/time-picker.d.ts +13 -13
  402. package/es/components/time-select/src/time-select.vue.d.ts +7 -7
  403. package/es/components/timeline/src/timeline-item.d.ts +1 -1
  404. package/es/components/timeline/src/timeline-item.vue.d.ts +1 -1
  405. package/es/components/tooltip/src/content.vue.d.ts +14 -14
  406. package/es/components/tooltip/src/tooltip.d.ts +1 -1
  407. package/es/components/tooltip/src/tooltip.vue.d.ts +20 -20
  408. package/es/components/tour/src/content.d.ts +1 -1
  409. package/es/components/tour/src/step.d.ts +1 -1
  410. package/es/components/tour/src/tour.d.ts +1 -1
  411. package/es/components/tour/src/tour.vue.d.ts +2 -2
  412. package/es/components/transfer/src/transfer.vue.d.ts +1 -1
  413. package/es/components/tree/src/tree.vue.d.ts +15 -15
  414. package/es/components/tree-select/src/tree-select.vue.d.ts +38 -38
  415. package/es/components/tree-v2/src/tree.vue.d.ts +2 -2
  416. package/es/components/upload/src/upload-content.d.ts +1 -1
  417. package/es/components/upload/src/upload-content.vue.d.ts +2 -2
  418. package/es/components/upload/src/upload-list.d.ts +1 -1
  419. package/es/components/upload/src/upload.d.ts +2 -2
  420. package/es/components/upload/src/upload.vue.d.ts +3 -3
  421. package/es/components/virtual-list/src/builders/build-grid.d.ts +1 -1
  422. package/es/components/virtual-list/src/components/dynamic-size-grid.d.ts +1 -1
  423. package/es/components/virtual-list/src/components/dynamic-size-list.d.ts +2 -2
  424. package/es/components/virtual-list/src/components/fixed-size-grid.d.ts +1 -1
  425. package/es/components/virtual-list/src/components/fixed-size-list.d.ts +2 -2
  426. package/es/components/watermark/src/watermark.vue.d.ts +1 -1
  427. package/es/hooks/use-floating/index.d.ts +4 -4
  428. package/es/hooks/use-popper/index.d.ts +5 -5
  429. package/es/utils/index.d.ts +2 -1
  430. package/es/utils/index.mjs +2 -1
  431. package/es/utils/numbers.d.ts +9 -0
  432. package/es/utils/numbers.mjs +13 -0
  433. package/es/utils/numbers.mjs.map +1 -0
  434. package/es/utils/vue/size.d.ts +1 -1
  435. package/es/version.mjs +1 -1
  436. package/es/version.mjs.map +1 -1
  437. package/lib/components/affix/src/affix.d.ts +1 -1
  438. package/lib/components/affix/src/affix.vue.d.ts +2 -2
  439. package/lib/components/alert/src/alert.d.ts +1 -1
  440. package/lib/components/alert/src/alert.vue.d.ts +2 -2
  441. package/lib/components/autocomplete/src/autocomplete.d.ts +4 -4
  442. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +13 -13
  443. package/lib/components/avatar/src/avatar.d.ts +1 -1
  444. package/lib/components/backtop/src/backtop.vue.d.ts +1 -1
  445. package/lib/components/badge/src/badge.d.ts +1 -1
  446. package/lib/components/button/src/button-group.vue.d.ts +1 -1
  447. package/lib/components/button/src/button.d.ts +1 -1
  448. package/lib/components/button/src/button.vue.d.ts +4 -4
  449. package/lib/components/card/src/card.d.ts +1 -1
  450. package/lib/components/card/src/card.vue.d.ts +1 -1
  451. package/lib/components/carousel/src/carousel.d.ts +1 -1
  452. package/lib/components/carousel/src/carousel.vue.d.ts +1 -1
  453. package/lib/components/cascader/src/cascader.d.ts +3 -3
  454. package/lib/components/cascader/src/cascader.vue.d.ts +14 -14
  455. package/lib/components/cascader-panel/src/index.vue.d.ts +2 -2
  456. package/lib/components/check-tag/src/check-tag.d.ts +1 -1
  457. package/lib/components/checkbox/src/checkbox-button.vue.d.ts +4 -4
  458. package/lib/components/checkbox/src/checkbox.d.ts +8 -8
  459. package/lib/components/checkbox/src/checkbox.vue.d.ts +4 -4
  460. package/lib/components/collapse/src/collapse.d.ts +1 -1
  461. package/lib/components/collapse/src/collapse.vue.d.ts +1 -1
  462. package/lib/components/color-picker/src/color-picker.vue.d.ts +7 -7
  463. package/lib/components/config-provider/src/config-provider.d.ts +2 -2
  464. package/lib/components/date-picker/src/date-picker.d.ts +13 -13
  465. package/lib/components/date-picker/src/props.d.ts +2 -2
  466. package/lib/components/date-picker-panel/src/date-picker-panel.d.ts +6 -6
  467. package/lib/components/date-picker-panel/src/props/date-picker-panel.d.ts +1 -1
  468. package/lib/components/descriptions/src/description-item.d.ts +19 -19
  469. package/lib/components/descriptions/src/description.vue.d.ts +1 -1
  470. package/lib/components/dialog/src/dialog.vue.d.ts +3 -3
  471. package/lib/components/divider/src/divider.d.ts +1 -1
  472. package/lib/components/drawer/src/drawer.vue.d.ts +4 -4
  473. package/lib/components/dropdown/src/dropdown-item.vue.d.ts +1 -1
  474. package/lib/components/dropdown/src/dropdown-menu.vue.d.ts +1 -1
  475. package/lib/components/dropdown/src/dropdown.d.ts +3 -3
  476. package/lib/components/dropdown/src/dropdown.vue.d.ts +96 -96
  477. package/lib/components/empty/src/empty.vue.d.ts +1 -1
  478. package/lib/components/focus-trap/src/focus-trap.vue.d.ts +1 -1
  479. package/lib/components/form/src/form-item.d.ts +1 -1
  480. package/lib/components/form/src/form.d.ts +2 -2
  481. package/lib/components/image/src/image.d.ts +1 -1
  482. package/lib/components/image/src/image.vue.d.ts +3 -3
  483. package/lib/components/image-viewer/src/image-viewer.vue.d.ts +2 -2
  484. package/lib/components/input/src/input.d.ts +3 -3
  485. package/lib/components/input/src/input.vue.d.ts +5 -5
  486. package/lib/components/input/src/input.vue_vue_type_script_setup_true_lang.js +3 -1
  487. package/lib/components/input/src/input.vue_vue_type_script_setup_true_lang.js.map +1 -1
  488. package/lib/components/input/src/input2.js.map +1 -1
  489. package/lib/components/input-number/src/input-number.d.ts +3 -3
  490. package/lib/components/input-number/src/input-number.vue.d.ts +4 -4
  491. package/lib/components/input-tag/src/input-tag.d.ts +2 -2
  492. package/lib/components/input-tag/src/input-tag.vue.d.ts +10 -10
  493. package/lib/components/link/src/link.d.ts +2 -2
  494. package/lib/components/link/src/link.vue.d.ts +1 -1
  495. package/lib/components/mention/src/mention.d.ts +3 -3
  496. package/lib/components/mention/src/mention.vue.d.ts +9 -9
  497. package/lib/components/menu/src/menu.d.ts +1 -1
  498. package/lib/components/menu/src/sub-menu.d.ts +1 -1
  499. package/lib/components/message/src/message.d.ts +2 -2
  500. package/lib/components/message/src/message.vue.d.ts +4 -4
  501. package/lib/components/notification/src/notification.d.ts +2 -2
  502. package/lib/components/notification/src/notification.vue.d.ts +3 -3
  503. package/lib/components/overlay/index.d.ts +2 -2
  504. package/lib/components/overlay/src/overlay.d.ts +1 -1
  505. package/lib/components/pagination/src/pagination.d.ts +2 -2
  506. package/lib/components/popconfirm/src/popconfirm.d.ts +2 -2
  507. package/lib/components/popconfirm/src/popconfirm.vue.d.ts +3 -3
  508. package/lib/components/popover/src/popover.d.ts +1 -1
  509. package/lib/components/popover/src/popover.vue.d.ts +9 -9
  510. package/lib/components/popper/src/composables/use-content.d.ts +5 -5
  511. package/lib/components/popper/src/composables/use-focus-trap.d.ts +1 -1
  512. package/lib/components/popper/src/content.vue.d.ts +9 -9
  513. package/lib/components/popper/src/popper.d.ts +2 -2
  514. package/lib/components/progress/src/progress.d.ts +1 -1
  515. package/lib/components/progress/src/progress.vue.d.ts +1 -1
  516. package/lib/components/radio/src/radio-button.d.ts +3 -3
  517. package/lib/components/radio/src/radio-button.vue.d.ts +3 -3
  518. package/lib/components/radio/src/radio-group.vue.d.ts +4 -4
  519. package/lib/components/radio/src/radio.d.ts +6 -6
  520. package/lib/components/radio/src/radio.vue.d.ts +4 -4
  521. package/lib/components/rate/src/rate.vue.d.ts +2 -2
  522. package/lib/components/result/src/result.d.ts +1 -1
  523. package/lib/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  524. package/lib/components/row/src/row.d.ts +1 -1
  525. package/lib/components/row/src/row.vue.d.ts +1 -1
  526. package/lib/components/scrollbar/src/scrollbar.vue.d.ts +3 -3
  527. package/lib/components/segmented/index.d.ts +34 -66
  528. package/lib/components/segmented/src/segmented.d.ts +6 -5
  529. package/lib/components/segmented/src/segmented.js.map +1 -1
  530. package/lib/components/segmented/src/segmented.vue.d.ts +21 -26
  531. package/lib/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.js +57 -3
  532. package/lib/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.js.map +1 -1
  533. package/lib/components/segmented/src/segmented2.js.map +1 -1
  534. package/lib/components/select/src/option.d.ts +2 -2
  535. package/lib/components/select/src/option.vue.d.ts +6 -6
  536. package/lib/components/select/src/select.d.ts +4 -4
  537. package/lib/components/select/src/select.vue.d.ts +112 -112
  538. package/lib/components/select-v2/src/defaults.d.ts +2 -2
  539. package/lib/components/select-v2/src/select.vue.d.ts +87 -87
  540. package/lib/components/skeleton/src/skeleton-item.d.ts +1 -1
  541. package/lib/components/skeleton/src/skeleton.vue.d.ts +1 -1
  542. package/lib/components/slider/src/slider.vue.d.ts +6 -6
  543. package/lib/components/space/src/space.d.ts +5 -5
  544. package/lib/components/statistic/src/statistic.vue.d.ts +2 -2
  545. package/lib/components/steps/src/item.vue.d.ts +1 -1
  546. package/lib/components/steps/src/steps.vue.d.ts +1 -1
  547. package/lib/components/switch/src/switch.vue.d.ts +3 -3
  548. package/lib/components/table/src/table-body/events-helper.js +2 -4
  549. package/lib/components/table/src/table-body/events-helper.js.map +1 -1
  550. package/lib/components/table/src/table-body/index.d.ts +1 -1
  551. package/lib/components/table/src/table-column/index.d.ts +18 -18
  552. package/lib/components/table/src/table-header/index.d.ts +12 -12
  553. package/lib/components/table/src/table.vue.d.ts +41 -41
  554. package/lib/components/tabs/src/tab-nav.js +13 -10
  555. package/lib/components/tabs/src/tab-nav.js.map +1 -1
  556. package/lib/components/tabs/src/tab-pane.vue.d.ts +1 -1
  557. package/lib/components/tabs/src/tabs.d.ts +4 -4
  558. package/lib/components/tag/src/tag.d.ts +1 -1
  559. package/lib/components/text/src/text.d.ts +1 -1
  560. package/lib/components/time-picker/src/common/picker.vue.d.ts +17 -17
  561. package/lib/components/time-picker/src/common/props.d.ts +2 -2
  562. package/lib/components/time-picker/src/time-picker.d.ts +13 -13
  563. package/lib/components/time-select/src/time-select.vue.d.ts +7 -7
  564. package/lib/components/timeline/src/timeline-item.d.ts +1 -1
  565. package/lib/components/timeline/src/timeline-item.vue.d.ts +1 -1
  566. package/lib/components/tooltip/src/content.vue.d.ts +14 -14
  567. package/lib/components/tooltip/src/tooltip.d.ts +1 -1
  568. package/lib/components/tooltip/src/tooltip.vue.d.ts +20 -20
  569. package/lib/components/tour/src/content.d.ts +1 -1
  570. package/lib/components/tour/src/step.d.ts +1 -1
  571. package/lib/components/tour/src/tour.d.ts +1 -1
  572. package/lib/components/tour/src/tour.vue.d.ts +2 -2
  573. package/lib/components/transfer/src/transfer.vue.d.ts +1 -1
  574. package/lib/components/tree/src/tree.vue.d.ts +15 -15
  575. package/lib/components/tree-select/src/tree-select.vue.d.ts +38 -38
  576. package/lib/components/tree-v2/src/tree.vue.d.ts +2 -2
  577. package/lib/components/upload/src/upload-content.d.ts +1 -1
  578. package/lib/components/upload/src/upload-content.vue.d.ts +2 -2
  579. package/lib/components/upload/src/upload-list.d.ts +1 -1
  580. package/lib/components/upload/src/upload.d.ts +2 -2
  581. package/lib/components/upload/src/upload.vue.d.ts +3 -3
  582. package/lib/components/virtual-list/src/builders/build-grid.d.ts +1 -1
  583. package/lib/components/virtual-list/src/components/dynamic-size-grid.d.ts +1 -1
  584. package/lib/components/virtual-list/src/components/dynamic-size-list.d.ts +2 -2
  585. package/lib/components/virtual-list/src/components/fixed-size-grid.d.ts +1 -1
  586. package/lib/components/virtual-list/src/components/fixed-size-list.d.ts +2 -2
  587. package/lib/components/watermark/src/watermark.vue.d.ts +1 -1
  588. package/lib/hooks/use-floating/index.d.ts +4 -4
  589. package/lib/hooks/use-popper/index.d.ts +5 -5
  590. package/lib/utils/index.d.ts +2 -1
  591. package/lib/utils/index.js +2 -0
  592. package/lib/utils/numbers.d.ts +9 -0
  593. package/lib/utils/numbers.js +15 -0
  594. package/lib/utils/numbers.js.map +1 -0
  595. package/lib/utils/vue/size.d.ts +1 -1
  596. package/lib/version.js +1 -1
  597. package/lib/version.js.map +1 -1
  598. package/package.json +4 -3
  599. package/web-types.json +1 -1
@@ -5,7 +5,7 @@ import { useNamespace } from "../../../hooks/use-namespace/index.mjs";
5
5
  import { useId } from "../../../hooks/use-id/index.mjs";
6
6
  import { useFormDisabled, useFormSize } from "../../form/src/hooks/use-form-common-props.mjs";
7
7
  import { useFormItem, useFormItemInputId } from "../../form/src/hooks/use-form-item.mjs";
8
- import { defaultProps, segmentedEmits, segmentedProps } from "./segmented.mjs";
8
+ import { defaultProps, segmentedEmits } from "./segmented.mjs";
9
9
  import { useActiveElement, useResizeObserver } from "@vueuse/core";
10
10
  import { Fragment, computed, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, defineComponent, normalizeClass, normalizeStyle, openBlock, reactive, ref, renderList, renderSlot, toDisplayString, unref, watch } from "vue";
11
11
 
@@ -24,7 +24,62 @@ const _hoisted_2 = [
24
24
  var segmented_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
25
25
  name: "ElSegmented",
26
26
  __name: "segmented",
27
- props: segmentedProps,
27
+ props: {
28
+ direction: {
29
+ type: String,
30
+ required: false,
31
+ default: "horizontal"
32
+ },
33
+ options: {
34
+ type: Array,
35
+ required: false,
36
+ default: () => []
37
+ },
38
+ modelValue: {
39
+ type: [
40
+ String,
41
+ Number,
42
+ Boolean
43
+ ],
44
+ required: false,
45
+ default: void 0
46
+ },
47
+ props: {
48
+ type: Object,
49
+ required: false,
50
+ default: () => defaultProps
51
+ },
52
+ block: {
53
+ type: Boolean,
54
+ required: false
55
+ },
56
+ size: {
57
+ type: null,
58
+ required: false
59
+ },
60
+ disabled: {
61
+ type: Boolean,
62
+ required: false,
63
+ default: void 0
64
+ },
65
+ validateEvent: {
66
+ type: Boolean,
67
+ required: false,
68
+ default: true
69
+ },
70
+ id: {
71
+ type: String,
72
+ required: false
73
+ },
74
+ name: {
75
+ type: String,
76
+ required: false
77
+ },
78
+ ariaLabel: {
79
+ type: String,
80
+ required: false
81
+ }
82
+ },
28
83
  emits: segmentedEmits,
29
84
  setup(__props, { emit: __emit }) {
30
85
  const props = __props;
@@ -55,7 +110,6 @@ var segmented_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defi
55
110
  ...defaultProps,
56
111
  ...props.props
57
112
  }));
58
- const intoAny = (item) => item;
59
113
  const getValue = (item) => {
60
114
  return isObject(item) ? item[aliasProps.value.value] : item;
61
115
  };
@@ -151,7 +205,7 @@ var segmented_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defi
151
205
  disabled: getDisabled(item),
152
206
  checked: getSelected(item),
153
207
  onChange: ($event) => handleChange($event, item)
154
- }, null, 42, _hoisted_2), createElementVNode("div", { class: normalizeClass(unref(ns).e("item-label")) }, [renderSlot(_ctx.$slots, "default", { item: intoAny(item) }, () => [createTextVNode(toDisplayString(getLabel(item)), 1)])], 2)], 2);
208
+ }, null, 42, _hoisted_2), createElementVNode("div", { class: normalizeClass(unref(ns).e("item-label")) }, [renderSlot(_ctx.$slots, "default", { item }, () => [createTextVNode(toDisplayString(getLabel(item)), 1)])], 2)], 2);
155
209
  }), 128))], 2)], 10, _hoisted_1)) : createCommentVNode("v-if", true);
156
210
  };
157
211
  }
@@ -1 +1 @@
1
- {"version":3,"file":"segmented.vue_vue_type_script_setup_true_lang.mjs","names":[],"sources":["../../../../../../packages/components/segmented/src/segmented.vue"],"sourcesContent":["<template>\n <div\n v-if=\"options.length\"\n :id=\"inputId\"\n ref=\"segmentedRef\"\n :class=\"segmentedCls\"\n role=\"radiogroup\"\n :aria-label=\"!isLabeledByFormItem ? ariaLabel || 'segmented' : undefined\"\n :aria-labelledby=\"isLabeledByFormItem ? formItem!.labelId : undefined\"\n >\n <div :class=\"[ns.e('group'), ns.m(direction)]\">\n <div :style=\"selectedStyle\" :class=\"selectedCls\" />\n <label\n v-for=\"(item, index) in options\"\n :key=\"index\"\n :class=\"getItemCls(item)\"\n >\n <input\n :class=\"ns.e('item-input')\"\n type=\"radio\"\n :name=\"name\"\n :disabled=\"getDisabled(item)\"\n :checked=\"getSelected(item)\"\n @change=\"handleChange($event, item)\"\n />\n <div :class=\"ns.e('item-label')\">\n <slot :item=\"intoAny(item)\">{{ getLabel(item) }}</slot>\n </div>\n </label>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, reactive, ref, watch } from 'vue'\nimport { useActiveElement, useResizeObserver } from '@vueuse/core'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport {\n useFormDisabled,\n useFormItem,\n useFormItemInputId,\n useFormSize,\n} from '@element-plus/components/form'\nimport { debugWarn, isObject } from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { defaultProps, segmentedEmits } from './segmented'\n\nimport type { Option } from './types'\nimport type { SegmentedProps } from './segmented'\n\ndefineOptions({\n name: 'ElSegmented',\n})\n\nconst props = withDefaults(defineProps<SegmentedProps>(), {\n direction: 'horizontal',\n options: () => [],\n props: () => defaultProps,\n validateEvent: true,\n modelValue: undefined,\n disabled: undefined,\n})\nconst emit = defineEmits(segmentedEmits)\n\nconst ns = useNamespace('segmented')\nconst segmentedId = useId()\nconst segmentedSize = useFormSize()\nconst _disabled = useFormDisabled()\nconst { formItem } = useFormItem()\nconst { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n formItemContext: formItem,\n})\n\nconst segmentedRef = ref<HTMLElement | null>(null)\nconst activeElement = useActiveElement()\n\nconst state = reactive({\n isInit: false,\n width: 0,\n height: 0,\n translateX: 0,\n translateY: 0,\n focusVisible: false,\n})\n\nconst handleChange = (evt: Event, item: Option) => {\n const value = getValue(item)\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n ;(evt.target as HTMLInputElement).checked = value === props.modelValue\n}\n\nconst aliasProps = computed(() => ({ ...defaultProps, ...props.props }))\n\n//FIXME: remove this when vue >=3.3\nconst intoAny = (item: any) => item\n\nconst getValue = (item: Option) => {\n return isObject(item) ? item[aliasProps.value.value] : item\n}\n\nconst getLabel = (item: Option) => {\n return isObject(item) ? item[aliasProps.value.label] : item\n}\n\nconst getDisabled = (item: Option | undefined) => {\n return !!(\n _disabled.value ||\n (isObject(item) ? item[aliasProps.value.disabled] : false)\n )\n}\n\nconst getSelected = (item: Option) => {\n return props.modelValue === getValue(item)\n}\n\nconst getOption = (value: any) => {\n return props.options.find((item) => getValue(item) === value)\n}\n\nconst getItemCls = (item: Option) => {\n return [\n ns.e('item'),\n ns.is('selected', getSelected(item)),\n ns.is('disabled', getDisabled(item)),\n ]\n}\n\nconst updateSelect = () => {\n if (!segmentedRef.value) return\n const selectedItem = segmentedRef.value.querySelector(\n '.is-selected'\n ) as HTMLElement\n const selectedItemInput = segmentedRef.value.querySelector(\n '.is-selected input'\n ) as HTMLElement\n if (!selectedItem || !selectedItemInput) {\n state.width = 0\n state.height = 0\n state.translateX = 0\n state.translateY = 0\n state.focusVisible = false\n return\n }\n state.isInit = true\n if (props.direction === 'vertical') {\n state.height = selectedItem.offsetHeight\n state.translateY = selectedItem.offsetTop\n } else {\n state.width = selectedItem.offsetWidth\n state.translateX = selectedItem.offsetLeft\n }\n try {\n // This will failed in test\n state.focusVisible = selectedItemInput.matches(':focus-visible')\n } catch {}\n}\n\nconst segmentedCls = computed(() => [\n ns.b(),\n ns.m(segmentedSize.value),\n ns.is('block', props.block),\n])\n\nconst selectedStyle = computed(() => ({\n width: props.direction === 'vertical' ? '100%' : `${state.width}px`,\n height: props.direction === 'vertical' ? `${state.height}px` : '100%',\n transform:\n props.direction === 'vertical'\n ? `translateY(${state.translateY}px)`\n : `translateX(${state.translateX}px)`,\n display: state.isInit ? 'block' : 'none',\n}))\n\nconst selectedCls = computed(() => [\n ns.e('item-selected'),\n ns.is('disabled', getDisabled(getOption(props.modelValue))),\n ns.is('focus-visible', state.focusVisible),\n])\n\nconst name = computed(() => {\n return props.name || segmentedId.value\n})\n\nuseResizeObserver(segmentedRef, updateSelect)\n\nwatch(activeElement, updateSelect)\n\nwatch(\n () => props.modelValue,\n () => {\n updateSelect()\n if (props.validateEvent) {\n formItem?.validate?.('change').catch((err) => debugWarn(err))\n }\n },\n {\n flush: 'post',\n }\n)\n</script>\n"],"mappings":"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"}
1
+ {"version":3,"file":"segmented.vue_vue_type_script_setup_true_lang.mjs","names":[],"sources":["../../../../../../packages/components/segmented/src/segmented.vue"],"sourcesContent":["<template>\n <div\n v-if=\"options.length\"\n :id=\"inputId\"\n ref=\"segmentedRef\"\n :class=\"segmentedCls\"\n role=\"radiogroup\"\n :aria-label=\"!isLabeledByFormItem ? ariaLabel || 'segmented' : undefined\"\n :aria-labelledby=\"isLabeledByFormItem ? formItem!.labelId : undefined\"\n >\n <div :class=\"[ns.e('group'), ns.m(direction)]\">\n <div :style=\"selectedStyle\" :class=\"selectedCls\" />\n <label\n v-for=\"(item, index) in options\"\n :key=\"index\"\n :class=\"getItemCls(item)\"\n >\n <input\n :class=\"ns.e('item-input')\"\n type=\"radio\"\n :name=\"name\"\n :disabled=\"getDisabled(item)\"\n :checked=\"getSelected(item)\"\n @change=\"handleChange($event, item)\"\n />\n <div :class=\"ns.e('item-label')\">\n <slot :item=\"item\">{{ getLabel(item) }}</slot>\n </div>\n </label>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup generic=\"T extends Option = Option\">\nimport { computed, reactive, ref, watch } from 'vue'\nimport { useActiveElement, useResizeObserver } from '@vueuse/core'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport {\n useFormDisabled,\n useFormItem,\n useFormItemInputId,\n useFormSize,\n} from '@element-plus/components/form'\nimport { debugWarn, isObject } from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { defaultProps, segmentedEmits } from './segmented'\n\nimport type { Option } from './types'\nimport type { SegmentedProps } from './segmented'\n\ndefineOptions({\n name: 'ElSegmented',\n})\n\nconst props = withDefaults(defineProps<SegmentedProps<T>>(), {\n direction: 'horizontal',\n options: () => [],\n props: () => defaultProps,\n validateEvent: true,\n modelValue: undefined,\n disabled: undefined,\n})\nconst emit = defineEmits(segmentedEmits)\n\nconst ns = useNamespace('segmented')\nconst segmentedId = useId()\nconst segmentedSize = useFormSize()\nconst _disabled = useFormDisabled()\nconst { formItem } = useFormItem()\nconst { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n formItemContext: formItem,\n})\n\nconst segmentedRef = ref<HTMLElement | null>(null)\nconst activeElement = useActiveElement()\n\nconst state = reactive({\n isInit: false,\n width: 0,\n height: 0,\n translateX: 0,\n translateY: 0,\n focusVisible: false,\n})\n\nconst handleChange = (evt: Event, item: T) => {\n const value = getValue(item)\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n ;(evt.target as HTMLInputElement).checked = value === props.modelValue\n}\n\nconst aliasProps = computed(() => ({ ...defaultProps, ...props.props }))\n\nconst getValue = (item: T) => {\n return isObject(item) ? item[aliasProps.value.value] : item\n}\n\nconst getLabel = (item: T) => {\n return isObject(item) ? item[aliasProps.value.label] : item\n}\n\nconst getDisabled = (item: T | undefined) => {\n return !!(\n _disabled.value ||\n (isObject(item) ? item[aliasProps.value.disabled] : false)\n )\n}\n\nconst getSelected = (item: T) => {\n return props.modelValue === getValue(item)\n}\n\nconst getOption = (value: any) => {\n return props.options.find((item) => getValue(item) === value)\n}\n\nconst getItemCls = (item: T) => {\n return [\n ns.e('item'),\n ns.is('selected', getSelected(item)),\n ns.is('disabled', getDisabled(item)),\n ]\n}\n\nconst updateSelect = () => {\n if (!segmentedRef.value) return\n const selectedItem = segmentedRef.value.querySelector(\n '.is-selected'\n ) as HTMLElement\n const selectedItemInput = segmentedRef.value.querySelector(\n '.is-selected input'\n ) as HTMLElement\n if (!selectedItem || !selectedItemInput) {\n state.width = 0\n state.height = 0\n state.translateX = 0\n state.translateY = 0\n state.focusVisible = false\n return\n }\n state.isInit = true\n if (props.direction === 'vertical') {\n state.height = selectedItem.offsetHeight\n state.translateY = selectedItem.offsetTop\n } else {\n state.width = selectedItem.offsetWidth\n state.translateX = selectedItem.offsetLeft\n }\n try {\n // This will failed in test\n state.focusVisible = selectedItemInput.matches(':focus-visible')\n } catch {}\n}\n\nconst segmentedCls = computed(() => [\n ns.b(),\n ns.m(segmentedSize.value),\n ns.is('block', props.block),\n])\n\nconst selectedStyle = computed(() => ({\n width: props.direction === 'vertical' ? '100%' : `${state.width}px`,\n height: props.direction === 'vertical' ? `${state.height}px` : '100%',\n transform:\n props.direction === 'vertical'\n ? `translateY(${state.translateY}px)`\n : `translateX(${state.translateX}px)`,\n display: state.isInit ? 'block' : 'none',\n}))\n\nconst selectedCls = computed(() => [\n ns.e('item-selected'),\n ns.is('disabled', getDisabled(getOption(props.modelValue))),\n ns.is('focus-visible', state.focusVisible),\n])\n\nconst name = computed(() => {\n return props.name || segmentedId.value\n})\n\nuseResizeObserver(segmentedRef, updateSelect)\n\nwatch(activeElement, updateSelect)\n\nwatch(\n () => props.modelValue,\n () => {\n updateSelect()\n if (props.validateEvent) {\n formItem?.validate?.('change').catch((err) => debugWarn(err))\n }\n },\n {\n flush: 'post',\n }\n)\n</script>\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"segmented2.mjs","names":[],"sources":["../../../../../../packages/components/segmented/src/segmented.vue"],"sourcesContent":["<template>\n <div\n v-if=\"options.length\"\n :id=\"inputId\"\n ref=\"segmentedRef\"\n :class=\"segmentedCls\"\n role=\"radiogroup\"\n :aria-label=\"!isLabeledByFormItem ? ariaLabel || 'segmented' : undefined\"\n :aria-labelledby=\"isLabeledByFormItem ? formItem!.labelId : undefined\"\n >\n <div :class=\"[ns.e('group'), ns.m(direction)]\">\n <div :style=\"selectedStyle\" :class=\"selectedCls\" />\n <label\n v-for=\"(item, index) in options\"\n :key=\"index\"\n :class=\"getItemCls(item)\"\n >\n <input\n :class=\"ns.e('item-input')\"\n type=\"radio\"\n :name=\"name\"\n :disabled=\"getDisabled(item)\"\n :checked=\"getSelected(item)\"\n @change=\"handleChange($event, item)\"\n />\n <div :class=\"ns.e('item-label')\">\n <slot :item=\"intoAny(item)\">{{ getLabel(item) }}</slot>\n </div>\n </label>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, reactive, ref, watch } from 'vue'\nimport { useActiveElement, useResizeObserver } from '@vueuse/core'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport {\n useFormDisabled,\n useFormItem,\n useFormItemInputId,\n useFormSize,\n} from '@element-plus/components/form'\nimport { debugWarn, isObject } from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { defaultProps, segmentedEmits } from './segmented'\n\nimport type { Option } from './types'\nimport type { SegmentedProps } from './segmented'\n\ndefineOptions({\n name: 'ElSegmented',\n})\n\nconst props = withDefaults(defineProps<SegmentedProps>(), {\n direction: 'horizontal',\n options: () => [],\n props: () => defaultProps,\n validateEvent: true,\n modelValue: undefined,\n disabled: undefined,\n})\nconst emit = defineEmits(segmentedEmits)\n\nconst ns = useNamespace('segmented')\nconst segmentedId = useId()\nconst segmentedSize = useFormSize()\nconst _disabled = useFormDisabled()\nconst { formItem } = useFormItem()\nconst { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n formItemContext: formItem,\n})\n\nconst segmentedRef = ref<HTMLElement | null>(null)\nconst activeElement = useActiveElement()\n\nconst state = reactive({\n isInit: false,\n width: 0,\n height: 0,\n translateX: 0,\n translateY: 0,\n focusVisible: false,\n})\n\nconst handleChange = (evt: Event, item: Option) => {\n const value = getValue(item)\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n ;(evt.target as HTMLInputElement).checked = value === props.modelValue\n}\n\nconst aliasProps = computed(() => ({ ...defaultProps, ...props.props }))\n\n//FIXME: remove this when vue >=3.3\nconst intoAny = (item: any) => item\n\nconst getValue = (item: Option) => {\n return isObject(item) ? item[aliasProps.value.value] : item\n}\n\nconst getLabel = (item: Option) => {\n return isObject(item) ? item[aliasProps.value.label] : item\n}\n\nconst getDisabled = (item: Option | undefined) => {\n return !!(\n _disabled.value ||\n (isObject(item) ? item[aliasProps.value.disabled] : false)\n )\n}\n\nconst getSelected = (item: Option) => {\n return props.modelValue === getValue(item)\n}\n\nconst getOption = (value: any) => {\n return props.options.find((item) => getValue(item) === value)\n}\n\nconst getItemCls = (item: Option) => {\n return [\n ns.e('item'),\n ns.is('selected', getSelected(item)),\n ns.is('disabled', getDisabled(item)),\n ]\n}\n\nconst updateSelect = () => {\n if (!segmentedRef.value) return\n const selectedItem = segmentedRef.value.querySelector(\n '.is-selected'\n ) as HTMLElement\n const selectedItemInput = segmentedRef.value.querySelector(\n '.is-selected input'\n ) as HTMLElement\n if (!selectedItem || !selectedItemInput) {\n state.width = 0\n state.height = 0\n state.translateX = 0\n state.translateY = 0\n state.focusVisible = false\n return\n }\n state.isInit = true\n if (props.direction === 'vertical') {\n state.height = selectedItem.offsetHeight\n state.translateY = selectedItem.offsetTop\n } else {\n state.width = selectedItem.offsetWidth\n state.translateX = selectedItem.offsetLeft\n }\n try {\n // This will failed in test\n state.focusVisible = selectedItemInput.matches(':focus-visible')\n } catch {}\n}\n\nconst segmentedCls = computed(() => [\n ns.b(),\n ns.m(segmentedSize.value),\n ns.is('block', props.block),\n])\n\nconst selectedStyle = computed(() => ({\n width: props.direction === 'vertical' ? '100%' : `${state.width}px`,\n height: props.direction === 'vertical' ? `${state.height}px` : '100%',\n transform:\n props.direction === 'vertical'\n ? `translateY(${state.translateY}px)`\n : `translateX(${state.translateX}px)`,\n display: state.isInit ? 'block' : 'none',\n}))\n\nconst selectedCls = computed(() => [\n ns.e('item-selected'),\n ns.is('disabled', getDisabled(getOption(props.modelValue))),\n ns.is('focus-visible', state.focusVisible),\n])\n\nconst name = computed(() => {\n return props.name || segmentedId.value\n})\n\nuseResizeObserver(segmentedRef, updateSelect)\n\nwatch(activeElement, updateSelect)\n\nwatch(\n () => props.modelValue,\n () => {\n updateSelect()\n if (props.validateEvent) {\n formItem?.validate?.('change').catch((err) => debugWarn(err))\n }\n },\n {\n flush: 'post',\n }\n)\n</script>\n"],"mappings":""}
1
+ {"version":3,"file":"segmented2.mjs","names":[],"sources":["../../../../../../packages/components/segmented/src/segmented.vue"],"sourcesContent":["<template>\n <div\n v-if=\"options.length\"\n :id=\"inputId\"\n ref=\"segmentedRef\"\n :class=\"segmentedCls\"\n role=\"radiogroup\"\n :aria-label=\"!isLabeledByFormItem ? ariaLabel || 'segmented' : undefined\"\n :aria-labelledby=\"isLabeledByFormItem ? formItem!.labelId : undefined\"\n >\n <div :class=\"[ns.e('group'), ns.m(direction)]\">\n <div :style=\"selectedStyle\" :class=\"selectedCls\" />\n <label\n v-for=\"(item, index) in options\"\n :key=\"index\"\n :class=\"getItemCls(item)\"\n >\n <input\n :class=\"ns.e('item-input')\"\n type=\"radio\"\n :name=\"name\"\n :disabled=\"getDisabled(item)\"\n :checked=\"getSelected(item)\"\n @change=\"handleChange($event, item)\"\n />\n <div :class=\"ns.e('item-label')\">\n <slot :item=\"item\">{{ getLabel(item) }}</slot>\n </div>\n </label>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup generic=\"T extends Option = Option\">\nimport { computed, reactive, ref, watch } from 'vue'\nimport { useActiveElement, useResizeObserver } from '@vueuse/core'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport {\n useFormDisabled,\n useFormItem,\n useFormItemInputId,\n useFormSize,\n} from '@element-plus/components/form'\nimport { debugWarn, isObject } from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { defaultProps, segmentedEmits } from './segmented'\n\nimport type { Option } from './types'\nimport type { SegmentedProps } from './segmented'\n\ndefineOptions({\n name: 'ElSegmented',\n})\n\nconst props = withDefaults(defineProps<SegmentedProps<T>>(), {\n direction: 'horizontal',\n options: () => [],\n props: () => defaultProps,\n validateEvent: true,\n modelValue: undefined,\n disabled: undefined,\n})\nconst emit = defineEmits(segmentedEmits)\n\nconst ns = useNamespace('segmented')\nconst segmentedId = useId()\nconst segmentedSize = useFormSize()\nconst _disabled = useFormDisabled()\nconst { formItem } = useFormItem()\nconst { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n formItemContext: formItem,\n})\n\nconst segmentedRef = ref<HTMLElement | null>(null)\nconst activeElement = useActiveElement()\n\nconst state = reactive({\n isInit: false,\n width: 0,\n height: 0,\n translateX: 0,\n translateY: 0,\n focusVisible: false,\n})\n\nconst handleChange = (evt: Event, item: T) => {\n const value = getValue(item)\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n ;(evt.target as HTMLInputElement).checked = value === props.modelValue\n}\n\nconst aliasProps = computed(() => ({ ...defaultProps, ...props.props }))\n\nconst getValue = (item: T) => {\n return isObject(item) ? item[aliasProps.value.value] : item\n}\n\nconst getLabel = (item: T) => {\n return isObject(item) ? item[aliasProps.value.label] : item\n}\n\nconst getDisabled = (item: T | undefined) => {\n return !!(\n _disabled.value ||\n (isObject(item) ? item[aliasProps.value.disabled] : false)\n )\n}\n\nconst getSelected = (item: T) => {\n return props.modelValue === getValue(item)\n}\n\nconst getOption = (value: any) => {\n return props.options.find((item) => getValue(item) === value)\n}\n\nconst getItemCls = (item: T) => {\n return [\n ns.e('item'),\n ns.is('selected', getSelected(item)),\n ns.is('disabled', getDisabled(item)),\n ]\n}\n\nconst updateSelect = () => {\n if (!segmentedRef.value) return\n const selectedItem = segmentedRef.value.querySelector(\n '.is-selected'\n ) as HTMLElement\n const selectedItemInput = segmentedRef.value.querySelector(\n '.is-selected input'\n ) as HTMLElement\n if (!selectedItem || !selectedItemInput) {\n state.width = 0\n state.height = 0\n state.translateX = 0\n state.translateY = 0\n state.focusVisible = false\n return\n }\n state.isInit = true\n if (props.direction === 'vertical') {\n state.height = selectedItem.offsetHeight\n state.translateY = selectedItem.offsetTop\n } else {\n state.width = selectedItem.offsetWidth\n state.translateX = selectedItem.offsetLeft\n }\n try {\n // This will failed in test\n state.focusVisible = selectedItemInput.matches(':focus-visible')\n } catch {}\n}\n\nconst segmentedCls = computed(() => [\n ns.b(),\n ns.m(segmentedSize.value),\n ns.is('block', props.block),\n])\n\nconst selectedStyle = computed(() => ({\n width: props.direction === 'vertical' ? '100%' : `${state.width}px`,\n height: props.direction === 'vertical' ? `${state.height}px` : '100%',\n transform:\n props.direction === 'vertical'\n ? `translateY(${state.translateY}px)`\n : `translateX(${state.translateX}px)`,\n display: state.isInit ? 'block' : 'none',\n}))\n\nconst selectedCls = computed(() => [\n ns.e('item-selected'),\n ns.is('disabled', getDisabled(getOption(props.modelValue))),\n ns.is('focus-visible', state.focusVisible),\n])\n\nconst name = computed(() => {\n return props.name || segmentedId.value\n})\n\nuseResizeObserver(segmentedRef, updateSelect)\n\nwatch(activeElement, updateSelect)\n\nwatch(\n () => props.modelValue,\n () => {\n updateSelect()\n if (props.validateEvent) {\n formItem?.validate?.('change').catch((err) => debugWarn(err))\n }\n },\n {\n flush: 'post',\n }\n)\n</script>\n"],"mappings":""}
@@ -5,13 +5,13 @@ import * as vue from "vue";
5
5
  //#region ../../packages/components/select/src/option.d.ts
6
6
  declare const optionProps: {
7
7
  value: {
8
- readonly type: vue.PropType<EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown>>;
8
+ readonly type: vue.PropType<EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown>>;
9
9
  readonly required: true;
10
10
  readonly validator: ((val: unknown) => boolean) | undefined;
11
11
  __epPropKey: true;
12
12
  };
13
13
  label: {
14
- readonly type: vue.PropType<EpPropMergeType<(NumberConstructor | StringConstructor)[], unknown, unknown>>;
14
+ readonly type: vue.PropType<EpPropMergeType<(StringConstructor | NumberConstructor)[], unknown, unknown>>;
15
15
  readonly required: false;
16
16
  readonly validator: ((val: unknown) => boolean) | undefined;
17
17
  __epPropKey: true;
@@ -7,13 +7,13 @@ import * as vue from "vue";
7
7
  declare const _default: typeof __VLS_export;
8
8
  declare const __VLS_export: vue.DefineComponent<vue.ExtractPropTypes<{
9
9
  value: {
10
- readonly type: vue.PropType<EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown>>;
10
+ readonly type: vue.PropType<EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown>>;
11
11
  readonly required: true;
12
12
  readonly validator: ((val: unknown) => boolean) | undefined;
13
13
  __epPropKey: true;
14
14
  };
15
15
  label: {
16
- readonly type: vue.PropType<EpPropMergeType<(NumberConstructor | StringConstructor)[], unknown, unknown>>;
16
+ readonly type: vue.PropType<EpPropMergeType<(StringConstructor | NumberConstructor)[], unknown, unknown>>;
17
17
  readonly required: false;
18
18
  readonly validator: ((val: unknown) => boolean) | undefined;
19
19
  __epPropKey: true;
@@ -41,7 +41,7 @@ declare const __VLS_export: vue.DefineComponent<vue.ExtractPropTypes<{
41
41
  };
42
42
  id: vue.Ref<string, string>;
43
43
  containerKls: vue.ComputedRef<string[]>;
44
- currentLabel: vue.ComputedRef<boolean | EpPropMergeType<(NumberConstructor | StringConstructor)[], unknown, unknown>>;
44
+ currentLabel: vue.ComputedRef<boolean | EpPropMergeType<(StringConstructor | NumberConstructor)[], unknown, unknown>>;
45
45
  itemSelected: vue.ComputedRef<boolean>;
46
46
  isDisabled: vue.ComputedRef<boolean>;
47
47
  select: SelectContext;
@@ -58,13 +58,13 @@ declare const __VLS_export: vue.DefineComponent<vue.ExtractPropTypes<{
58
58
  selectOptionClick: () => void;
59
59
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
60
60
  value: {
61
- readonly type: vue.PropType<EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown>>;
61
+ readonly type: vue.PropType<EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown>>;
62
62
  readonly required: true;
63
63
  readonly validator: ((val: unknown) => boolean) | undefined;
64
64
  __epPropKey: true;
65
65
  };
66
66
  label: {
67
- readonly type: vue.PropType<EpPropMergeType<(NumberConstructor | StringConstructor)[], unknown, unknown>>;
67
+ readonly type: vue.PropType<EpPropMergeType<(StringConstructor | NumberConstructor)[], unknown, unknown>>;
68
68
  readonly required: false;
69
69
  readonly validator: ((val: unknown) => boolean) | undefined;
70
70
  __epPropKey: true;
@@ -72,8 +72,8 @@ declare const __VLS_export: vue.DefineComponent<vue.ExtractPropTypes<{
72
72
  created: BooleanConstructor;
73
73
  disabled: BooleanConstructor;
74
74
  }>> & Readonly<{}>, {
75
- disabled: boolean;
76
75
  created: boolean;
76
+ disabled: boolean;
77
77
  }, {}, {}, {}, string, vue.ComponentProvideOptions, true, {}, any>;
78
78
  //#endregion
79
79
  export { _default };
@@ -33,7 +33,7 @@ declare const selectProps: {
33
33
  valueOnClear: EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | (((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null)) | null)[], unknown, unknown, undefined, boolean>;
34
34
  name: StringConstructor;
35
35
  id: StringConstructor;
36
- modelValue: EpPropFinalized<(new (...args: any[]) => string | number | boolean | Record<string, any> | EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown>[]) | (() => EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown> | EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown>[] | null) | (((new (...args: any[]) => string | number | boolean | Record<string, any> | EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown>[]) | (() => EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown> | EpPropMergeType<(BooleanConstructor | ObjectConstructor | NumberConstructor | StringConstructor)[], unknown, unknown>[] | null)) | null)[], unknown, unknown, undefined, boolean>;
36
+ modelValue: EpPropFinalized<(new (...args: any[]) => string | number | boolean | Record<string, any> | EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown>[]) | (() => EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown> | EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown>[] | null) | (((new (...args: any[]) => string | number | boolean | Record<string, any> | EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown>[]) | (() => EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown> | EpPropMergeType<(BooleanConstructor | StringConstructor | NumberConstructor | ObjectConstructor)[], unknown, unknown>[] | null)) | null)[], unknown, unknown, undefined, boolean>;
37
37
  autocomplete: EpPropFinalized<StringConstructor, unknown, unknown, string, boolean>;
38
38
  automaticDropdown: BooleanConstructor;
39
39
  size: {
@@ -95,7 +95,7 @@ declare const selectProps: {
95
95
  suffixIcon: EpPropFinalized<(new (...args: any[]) => (string | vue.Component) & {}) | (() => string | vue.Component) | (((new (...args: any[]) => (string | vue.Component) & {}) | (() => string | vue.Component)) | null)[], unknown, unknown, vue.DefineComponent<{}, void, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<{}>, {}, {}, {}, {}, string, vue.ComponentProvideOptions, true, {}, any>, boolean>;
96
96
  tagType: {
97
97
  default: string;
98
- type: vue.PropType<EpPropMergeType<StringConstructor, "info" | "primary" | "success" | "warning" | "danger", unknown>>;
98
+ type: vue.PropType<EpPropMergeType<StringConstructor, "primary" | "success" | "info" | "warning" | "danger", unknown>>;
99
99
  required: false;
100
100
  validator: ((val: unknown) => boolean) | undefined;
101
101
  __epPropKey: true;
@@ -111,9 +111,9 @@ declare const selectProps: {
111
111
  remoteShowSuffix: BooleanConstructor;
112
112
  showArrow: EpPropFinalized<BooleanConstructor, unknown, unknown, boolean, boolean>;
113
113
  offset: EpPropFinalized<NumberConstructor, unknown, unknown, number, boolean>;
114
- placement: EpPropFinalized<(new (...args: any[]) => "top" | "auto" | "bottom" | "bottom-start" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement) | (((new (...args: any[]) => "top" | "auto" | "bottom" | "bottom-start" | "left" | "right" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement)) | null)[], Placement, unknown, string, boolean>;
114
+ placement: EpPropFinalized<(new (...args: any[]) => "auto" | "auto-start" | "auto-end" | "top" | "bottom" | "right" | "left" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement) | (((new (...args: any[]) => "auto" | "auto-start" | "auto-end" | "top" | "bottom" | "right" | "left" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end") | (() => Placement)) | null)[], Placement, unknown, string, boolean>;
115
115
  fallbackPlacements: EpPropFinalized<(new (...args: any[]) => Placement[]) | (() => Placement[]) | (((new (...args: any[]) => Placement[]) | (() => Placement[])) | null)[], unknown, unknown, string[], boolean>;
116
- tabindex: EpPropFinalized<(NumberConstructor | StringConstructor)[], unknown, unknown, number, boolean>;
116
+ tabindex: EpPropFinalized<(StringConstructor | NumberConstructor)[], unknown, unknown, number, boolean>;
117
117
  appendTo: {
118
118
  readonly type: vue.PropType<EpPropMergeType<(new (...args: any[]) => string | HTMLElement) | (() => EpPropMergeType<(new (...args: any[]) => string | HTMLElement) | (() => string | HTMLElement) | (((new (...args: any[]) => string | HTMLElement) | (() => string | HTMLElement)) | null)[], unknown, unknown>) | (((new (...args: any[]) => string | HTMLElement) | (() => EpPropMergeType<(new (...args: any[]) => string | HTMLElement) | (() => string | HTMLElement) | (((new (...args: any[]) => string | HTMLElement) | (() => string | HTMLElement)) | null)[], unknown, unknown>)) | null)[], unknown, unknown>>;
119
119
  readonly required: false;