element-plus 2.13.6 → 2.13.7

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 (870) hide show
  1. package/attributes.json +1 -1
  2. package/dist/index.css +1 -1
  3. package/dist/index.full.js +199 -101
  4. package/dist/index.full.min.js +7 -7
  5. package/dist/index.full.min.js.map +1 -1
  6. package/dist/index.full.min.mjs +7 -7
  7. package/dist/index.full.min.mjs.map +1 -1
  8. package/dist/index.full.mjs +199 -101
  9. package/dist/locale/af.js +1 -1
  10. package/dist/locale/af.min.js +1 -1
  11. package/dist/locale/af.min.mjs +1 -1
  12. package/dist/locale/af.mjs +1 -1
  13. package/dist/locale/ar-eg.js +1 -1
  14. package/dist/locale/ar-eg.min.js +1 -1
  15. package/dist/locale/ar-eg.min.mjs +1 -1
  16. package/dist/locale/ar-eg.mjs +1 -1
  17. package/dist/locale/ar.js +1 -1
  18. package/dist/locale/ar.min.js +1 -1
  19. package/dist/locale/ar.min.mjs +1 -1
  20. package/dist/locale/ar.mjs +1 -1
  21. package/dist/locale/az.js +1 -1
  22. package/dist/locale/az.min.js +1 -1
  23. package/dist/locale/az.min.mjs +1 -1
  24. package/dist/locale/az.mjs +1 -1
  25. package/dist/locale/bg.js +1 -1
  26. package/dist/locale/bg.min.js +1 -1
  27. package/dist/locale/bg.min.mjs +1 -1
  28. package/dist/locale/bg.mjs +1 -1
  29. package/dist/locale/bn.js +1 -1
  30. package/dist/locale/bn.min.js +1 -1
  31. package/dist/locale/bn.min.mjs +1 -1
  32. package/dist/locale/bn.mjs +1 -1
  33. package/dist/locale/ca.js +1 -1
  34. package/dist/locale/ca.min.js +1 -1
  35. package/dist/locale/ca.min.mjs +1 -1
  36. package/dist/locale/ca.mjs +1 -1
  37. package/dist/locale/ckb.js +1 -1
  38. package/dist/locale/ckb.min.js +1 -1
  39. package/dist/locale/ckb.min.mjs +1 -1
  40. package/dist/locale/ckb.mjs +1 -1
  41. package/dist/locale/cs.js +1 -1
  42. package/dist/locale/cs.min.js +1 -1
  43. package/dist/locale/cs.min.mjs +1 -1
  44. package/dist/locale/cs.mjs +1 -1
  45. package/dist/locale/da.js +1 -1
  46. package/dist/locale/da.min.js +1 -1
  47. package/dist/locale/da.min.mjs +1 -1
  48. package/dist/locale/da.mjs +1 -1
  49. package/dist/locale/de.js +1 -1
  50. package/dist/locale/de.min.js +1 -1
  51. package/dist/locale/de.min.mjs +1 -1
  52. package/dist/locale/de.mjs +1 -1
  53. package/dist/locale/el.js +1 -1
  54. package/dist/locale/el.min.js +1 -1
  55. package/dist/locale/el.min.mjs +1 -1
  56. package/dist/locale/el.mjs +1 -1
  57. package/dist/locale/en.js +1 -1
  58. package/dist/locale/en.min.js +1 -1
  59. package/dist/locale/en.min.mjs +1 -1
  60. package/dist/locale/en.mjs +1 -1
  61. package/dist/locale/eo.js +1 -1
  62. package/dist/locale/eo.min.js +1 -1
  63. package/dist/locale/eo.min.mjs +1 -1
  64. package/dist/locale/eo.mjs +1 -1
  65. package/dist/locale/es.js +1 -1
  66. package/dist/locale/es.min.js +1 -1
  67. package/dist/locale/es.min.mjs +1 -1
  68. package/dist/locale/es.mjs +1 -1
  69. package/dist/locale/et.js +1 -1
  70. package/dist/locale/et.min.js +1 -1
  71. package/dist/locale/et.min.mjs +1 -1
  72. package/dist/locale/et.mjs +1 -1
  73. package/dist/locale/eu.js +1 -1
  74. package/dist/locale/eu.min.js +1 -1
  75. package/dist/locale/eu.min.mjs +1 -1
  76. package/dist/locale/eu.mjs +1 -1
  77. package/dist/locale/fa.js +1 -1
  78. package/dist/locale/fa.min.js +1 -1
  79. package/dist/locale/fa.min.mjs +1 -1
  80. package/dist/locale/fa.mjs +1 -1
  81. package/dist/locale/fi.js +1 -1
  82. package/dist/locale/fi.min.js +1 -1
  83. package/dist/locale/fi.min.mjs +1 -1
  84. package/dist/locale/fi.mjs +1 -1
  85. package/dist/locale/fr.js +1 -1
  86. package/dist/locale/fr.min.js +1 -1
  87. package/dist/locale/fr.min.mjs +1 -1
  88. package/dist/locale/fr.mjs +1 -1
  89. package/dist/locale/he.js +1 -1
  90. package/dist/locale/he.min.js +1 -1
  91. package/dist/locale/he.min.mjs +1 -1
  92. package/dist/locale/he.mjs +1 -1
  93. package/dist/locale/hi.js +1 -1
  94. package/dist/locale/hi.min.js +1 -1
  95. package/dist/locale/hi.min.mjs +1 -1
  96. package/dist/locale/hi.mjs +1 -1
  97. package/dist/locale/hr.js +1 -1
  98. package/dist/locale/hr.min.js +1 -1
  99. package/dist/locale/hr.min.mjs +1 -1
  100. package/dist/locale/hr.mjs +1 -1
  101. package/dist/locale/hu.js +1 -1
  102. package/dist/locale/hu.min.js +1 -1
  103. package/dist/locale/hu.min.mjs +1 -1
  104. package/dist/locale/hu.mjs +1 -1
  105. package/dist/locale/hy-am.js +1 -1
  106. package/dist/locale/hy-am.min.js +1 -1
  107. package/dist/locale/hy-am.min.mjs +1 -1
  108. package/dist/locale/hy-am.mjs +1 -1
  109. package/dist/locale/id.js +1 -1
  110. package/dist/locale/id.min.js +1 -1
  111. package/dist/locale/id.min.mjs +1 -1
  112. package/dist/locale/id.mjs +1 -1
  113. package/dist/locale/it.js +1 -1
  114. package/dist/locale/it.min.js +1 -1
  115. package/dist/locale/it.min.mjs +1 -1
  116. package/dist/locale/it.mjs +1 -1
  117. package/dist/locale/ja.js +1 -1
  118. package/dist/locale/ja.min.js +1 -1
  119. package/dist/locale/ja.min.mjs +1 -1
  120. package/dist/locale/ja.mjs +1 -1
  121. package/dist/locale/kk.js +1 -1
  122. package/dist/locale/kk.min.js +1 -1
  123. package/dist/locale/kk.min.mjs +1 -1
  124. package/dist/locale/kk.mjs +1 -1
  125. package/dist/locale/km.js +1 -1
  126. package/dist/locale/km.min.js +1 -1
  127. package/dist/locale/km.min.mjs +1 -1
  128. package/dist/locale/km.mjs +1 -1
  129. package/dist/locale/ko.js +1 -1
  130. package/dist/locale/ko.min.js +1 -1
  131. package/dist/locale/ko.min.mjs +1 -1
  132. package/dist/locale/ko.mjs +1 -1
  133. package/dist/locale/ku.js +1 -1
  134. package/dist/locale/ku.min.js +1 -1
  135. package/dist/locale/ku.min.mjs +1 -1
  136. package/dist/locale/ku.mjs +1 -1
  137. package/dist/locale/ky.js +1 -1
  138. package/dist/locale/ky.min.js +1 -1
  139. package/dist/locale/ky.min.mjs +1 -1
  140. package/dist/locale/ky.mjs +1 -1
  141. package/dist/locale/lo.js +1 -1
  142. package/dist/locale/lo.min.js +1 -1
  143. package/dist/locale/lo.min.mjs +1 -1
  144. package/dist/locale/lo.mjs +1 -1
  145. package/dist/locale/lt.js +1 -1
  146. package/dist/locale/lt.min.js +1 -1
  147. package/dist/locale/lt.min.mjs +1 -1
  148. package/dist/locale/lt.mjs +1 -1
  149. package/dist/locale/lv.js +1 -1
  150. package/dist/locale/lv.min.js +1 -1
  151. package/dist/locale/lv.min.mjs +1 -1
  152. package/dist/locale/lv.mjs +1 -1
  153. package/dist/locale/mg.js +1 -1
  154. package/dist/locale/mg.min.js +1 -1
  155. package/dist/locale/mg.min.mjs +1 -1
  156. package/dist/locale/mg.mjs +1 -1
  157. package/dist/locale/mn.js +1 -1
  158. package/dist/locale/mn.min.js +1 -1
  159. package/dist/locale/mn.min.mjs +1 -1
  160. package/dist/locale/mn.mjs +1 -1
  161. package/dist/locale/ms.js +1 -1
  162. package/dist/locale/ms.min.js +1 -1
  163. package/dist/locale/ms.min.mjs +1 -1
  164. package/dist/locale/ms.mjs +1 -1
  165. package/dist/locale/my.js +1 -1
  166. package/dist/locale/my.min.js +1 -1
  167. package/dist/locale/my.min.mjs +1 -1
  168. package/dist/locale/my.mjs +1 -1
  169. package/dist/locale/nb-no.js +1 -1
  170. package/dist/locale/nb-no.min.js +1 -1
  171. package/dist/locale/nb-no.min.mjs +1 -1
  172. package/dist/locale/nb-no.mjs +1 -1
  173. package/dist/locale/nl.js +1 -1
  174. package/dist/locale/nl.min.js +1 -1
  175. package/dist/locale/nl.min.mjs +1 -1
  176. package/dist/locale/nl.mjs +1 -1
  177. package/dist/locale/no.js +1 -1
  178. package/dist/locale/no.min.js +1 -1
  179. package/dist/locale/no.min.mjs +1 -1
  180. package/dist/locale/no.mjs +1 -1
  181. package/dist/locale/pa.js +1 -1
  182. package/dist/locale/pa.min.js +1 -1
  183. package/dist/locale/pa.min.mjs +1 -1
  184. package/dist/locale/pa.mjs +1 -1
  185. package/dist/locale/pl.js +1 -1
  186. package/dist/locale/pl.min.js +1 -1
  187. package/dist/locale/pl.min.mjs +1 -1
  188. package/dist/locale/pl.mjs +1 -1
  189. package/dist/locale/pt-br.js +1 -1
  190. package/dist/locale/pt-br.min.js +1 -1
  191. package/dist/locale/pt-br.min.mjs +1 -1
  192. package/dist/locale/pt-br.mjs +1 -1
  193. package/dist/locale/pt.js +1 -1
  194. package/dist/locale/pt.min.js +1 -1
  195. package/dist/locale/pt.min.mjs +1 -1
  196. package/dist/locale/pt.mjs +1 -1
  197. package/dist/locale/ro.js +1 -1
  198. package/dist/locale/ro.min.js +1 -1
  199. package/dist/locale/ro.min.mjs +1 -1
  200. package/dist/locale/ro.mjs +1 -1
  201. package/dist/locale/ru.js +1 -1
  202. package/dist/locale/ru.min.js +1 -1
  203. package/dist/locale/ru.min.mjs +1 -1
  204. package/dist/locale/ru.mjs +1 -1
  205. package/dist/locale/sk.js +1 -1
  206. package/dist/locale/sk.min.js +1 -1
  207. package/dist/locale/sk.min.mjs +1 -1
  208. package/dist/locale/sk.mjs +1 -1
  209. package/dist/locale/sl.js +1 -1
  210. package/dist/locale/sl.min.js +1 -1
  211. package/dist/locale/sl.min.mjs +1 -1
  212. package/dist/locale/sl.mjs +1 -1
  213. package/dist/locale/sr.js +1 -1
  214. package/dist/locale/sr.min.js +1 -1
  215. package/dist/locale/sr.min.mjs +1 -1
  216. package/dist/locale/sr.mjs +1 -1
  217. package/dist/locale/sv.js +1 -1
  218. package/dist/locale/sv.min.js +1 -1
  219. package/dist/locale/sv.min.mjs +1 -1
  220. package/dist/locale/sv.mjs +1 -1
  221. package/dist/locale/sw.js +1 -1
  222. package/dist/locale/sw.min.js +1 -1
  223. package/dist/locale/sw.min.mjs +1 -1
  224. package/dist/locale/sw.mjs +1 -1
  225. package/dist/locale/ta.js +1 -1
  226. package/dist/locale/ta.min.js +1 -1
  227. package/dist/locale/ta.min.mjs +1 -1
  228. package/dist/locale/ta.mjs +1 -1
  229. package/dist/locale/te.js +1 -1
  230. package/dist/locale/te.min.js +1 -1
  231. package/dist/locale/te.min.mjs +1 -1
  232. package/dist/locale/te.mjs +1 -1
  233. package/dist/locale/th.js +1 -1
  234. package/dist/locale/th.min.js +1 -1
  235. package/dist/locale/th.min.mjs +1 -1
  236. package/dist/locale/th.mjs +1 -1
  237. package/dist/locale/tk.js +1 -1
  238. package/dist/locale/tk.min.js +1 -1
  239. package/dist/locale/tk.min.mjs +1 -1
  240. package/dist/locale/tk.mjs +1 -1
  241. package/dist/locale/tr.js +1 -1
  242. package/dist/locale/tr.min.js +1 -1
  243. package/dist/locale/tr.min.mjs +1 -1
  244. package/dist/locale/tr.mjs +1 -1
  245. package/dist/locale/ug-cn.js +1 -1
  246. package/dist/locale/ug-cn.min.js +1 -1
  247. package/dist/locale/ug-cn.min.mjs +1 -1
  248. package/dist/locale/ug-cn.mjs +1 -1
  249. package/dist/locale/uk.js +1 -1
  250. package/dist/locale/uk.min.js +1 -1
  251. package/dist/locale/uk.min.mjs +1 -1
  252. package/dist/locale/uk.mjs +1 -1
  253. package/dist/locale/uz-uz.js +1 -1
  254. package/dist/locale/uz-uz.min.js +1 -1
  255. package/dist/locale/uz-uz.min.mjs +1 -1
  256. package/dist/locale/uz-uz.mjs +1 -1
  257. package/dist/locale/vi.js +1 -1
  258. package/dist/locale/vi.min.js +1 -1
  259. package/dist/locale/vi.min.mjs +1 -1
  260. package/dist/locale/vi.mjs +1 -1
  261. package/dist/locale/zh-cn.js +1 -1
  262. package/dist/locale/zh-cn.min.js +1 -1
  263. package/dist/locale/zh-cn.min.mjs +1 -1
  264. package/dist/locale/zh-cn.mjs +1 -1
  265. package/dist/locale/zh-hk.js +1 -1
  266. package/dist/locale/zh-hk.min.js +1 -1
  267. package/dist/locale/zh-hk.min.mjs +1 -1
  268. package/dist/locale/zh-hk.mjs +1 -1
  269. package/dist/locale/zh-mo.js +1 -1
  270. package/dist/locale/zh-mo.min.js +1 -1
  271. package/dist/locale/zh-mo.min.mjs +1 -1
  272. package/dist/locale/zh-mo.mjs +1 -1
  273. package/dist/locale/zh-tw.js +1 -1
  274. package/dist/locale/zh-tw.min.js +1 -1
  275. package/dist/locale/zh-tw.min.mjs +1 -1
  276. package/dist/locale/zh-tw.mjs +1 -1
  277. package/es/component.mjs +3 -3
  278. package/es/components/affix/src/affix.d.ts +3 -2
  279. package/es/components/affix/src/affix.vue.d.ts +4 -5
  280. package/es/components/alert/src/alert.vue.d.ts +1 -1
  281. package/es/components/anchor/src/anchor-link.vue.d.ts +1 -3
  282. package/es/components/anchor/src/anchor-link.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  283. package/es/components/anchor/src/anchor-link2.mjs.map +1 -1
  284. package/es/components/anchor/src/anchor.vue.d.ts +2 -2
  285. package/es/components/autocomplete/index.d.ts +2 -2
  286. package/es/components/autocomplete/src/autocomplete.d.ts +21 -13
  287. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  288. package/es/components/autocomplete/src/autocomplete.vue.d.ts +55 -80
  289. package/es/components/autocomplete/src/autocomplete.vue_vue_type_script_setup_true_lang.mjs +4 -2
  290. package/es/components/autocomplete/src/autocomplete.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  291. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  292. package/es/components/avatar/src/avatar-group-props.d.ts +1 -1
  293. package/es/components/avatar/src/avatar-group.d.ts +2 -2
  294. package/es/components/avatar/src/avatar.d.ts +3 -2
  295. package/es/components/avatar/src/avatar.vue.d.ts +2 -3
  296. package/es/components/backtop/src/backtop.vue.d.ts +1 -1
  297. package/es/components/badge/src/badge.vue.d.ts +1 -1
  298. package/es/components/button/src/button-custom.mjs +17 -0
  299. package/es/components/button/src/button-custom.mjs.map +1 -1
  300. package/es/components/button/src/button.d.ts +1 -1
  301. package/es/components/button/src/button.vue.d.ts +3 -3
  302. package/es/components/calendar/src/use-date-table.mjs +2 -1
  303. package/es/components/calendar/src/use-date-table.mjs.map +1 -1
  304. package/es/components/card/src/card.d.ts +1 -1
  305. package/es/components/carousel/src/carousel-item.vue.d.ts +1 -1
  306. package/es/components/carousel/src/carousel.d.ts +1 -1
  307. package/es/components/cascader/src/cascader.d.ts +2 -2
  308. package/es/components/cascader/src/cascader.vue.d.ts +15 -15
  309. package/es/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.mjs +9 -4
  310. package/es/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  311. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  312. package/es/components/cascader-panel/src/index.mjs.map +1 -1
  313. package/es/components/cascader-panel/src/index.vue.d.ts +2 -2
  314. package/es/components/cascader-panel/src/index.vue_vue_type_script_setup_true_lang.mjs +1 -1
  315. package/es/components/cascader-panel/src/index.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  316. package/es/components/checkbox/src/checkbox-button.vue.d.ts +4 -4
  317. package/es/components/checkbox/src/checkbox-group.d.ts +1 -1
  318. package/es/components/checkbox/src/checkbox-group.vue.d.ts +2 -2
  319. package/es/components/checkbox/src/checkbox.d.ts +3 -3
  320. package/es/components/checkbox/src/checkbox.vue.d.ts +4 -4
  321. package/es/components/checkbox/src/composables/use-checkbox-model.mjs +6 -2
  322. package/es/components/checkbox/src/composables/use-checkbox-model.mjs.map +1 -1
  323. package/es/components/checkbox/src/composables/use-checkbox-status.d.ts +2 -2
  324. package/es/components/checkbox/src/composables/use-checkbox.d.ts +2 -2
  325. package/es/components/col/src/col.vue.d.ts +1 -1
  326. package/es/components/collapse/src/collapse.d.ts +1 -1
  327. package/es/components/collapse/src/collapse.vue.d.ts +1 -1
  328. package/es/components/color-picker/src/color-picker.d.ts +1 -1
  329. package/es/components/color-picker/src/color-picker.vue.d.ts +7 -7
  330. package/es/components/color-picker/src/color-picker.vue_vue_type_script_setup_true_lang.mjs +1 -1
  331. package/es/components/color-picker-panel/src/color-picker-panel.vue.d.ts +1 -1
  332. package/es/components/color-picker-panel/src/composables/use-predefine.mjs.map +1 -1
  333. package/es/components/config-provider/src/config-provider-props.d.ts +1 -1
  334. package/es/components/config-provider/src/config-provider.d.ts +3 -3
  335. package/es/components/config-provider/src/hooks/use-global-config.d.ts +1 -1
  336. package/es/components/countdown/src/countdown.vue_vue_type_script_setup_true_lang.mjs +1 -1
  337. package/es/components/date-picker/src/date-picker.d.ts +12 -12
  338. package/es/components/date-picker/src/props.d.ts +2 -2
  339. package/es/components/date-picker-panel/src/date-picker-com/panel-date-pick.mjs.map +1 -1
  340. package/es/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue_vue_type_script_setup_true_lang.mjs +2 -2
  341. package/es/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  342. package/es/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.mjs +1 -1
  343. package/es/components/date-picker-panel/src/date-picker-panel.d.ts +3 -3
  344. package/es/components/descriptions/src/description-item.d.ts +8 -8
  345. package/es/components/descriptions/src/description.d.ts +1 -1
  346. package/es/components/descriptions/src/description.mjs.map +1 -1
  347. package/es/components/descriptions/src/description.vue.d.ts +1 -1
  348. package/es/components/dialog/src/dialog.vue.d.ts +11 -11
  349. package/es/components/dialog/src/dialog.vue_vue_type_script_setup_true_lang.mjs +6 -5
  350. package/es/components/dialog/src/dialog.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  351. package/es/components/dialog/src/dialog2.mjs.map +1 -1
  352. package/es/components/dialog/src/use-dialog.d.ts +4 -2
  353. package/es/components/dialog/src/use-dialog.mjs +8 -1
  354. package/es/components/dialog/src/use-dialog.mjs.map +1 -1
  355. package/es/components/divider/src/divider.d.ts +1 -1
  356. package/es/components/drawer/src/drawer.vue.d.ts +5 -5
  357. package/es/components/dropdown/src/dropdown-item.vue.d.ts +4 -10
  358. package/es/components/dropdown/src/dropdown-menu.vue.d.ts +1 -1
  359. package/es/components/dropdown/src/dropdown.d.ts +2 -2
  360. package/es/components/dropdown/src/dropdown.vue.d.ts +60 -66
  361. package/es/components/focus-trap/src/focus-trap.vue.d.ts +1 -1
  362. package/es/components/form/src/form-item.d.ts +2 -2
  363. package/es/components/form/src/form-item.vue.d.ts +1 -1
  364. package/es/components/form/src/form-item.vue_vue_type_script_setup_true_lang.mjs +11 -1
  365. package/es/components/form/src/form-item.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  366. package/es/components/form/src/form-item2.mjs.map +1 -1
  367. package/es/components/form/src/form.d.ts +4 -4
  368. package/es/components/form/src/form.vue.d.ts +1 -1
  369. package/es/components/form/src/form.vue_vue_type_script_setup_true_lang.mjs +11 -3
  370. package/es/components/form/src/form.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  371. package/es/components/form/src/form2.mjs.map +1 -1
  372. package/es/components/form/src/hooks/use-form-common-props.d.ts +2 -2
  373. package/es/components/form/src/types.d.ts +2 -1
  374. package/es/components/icon/src/icon.vue.d.ts +1 -3
  375. package/es/components/icon/src/icon.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  376. package/es/components/icon/src/icon2.mjs.map +1 -1
  377. package/es/components/image/src/image.d.ts +1 -1
  378. package/es/components/image/src/image.vue.d.ts +3 -3
  379. package/es/components/image-viewer/src/image-viewer.vue.d.ts +2 -2
  380. package/es/components/index.d.ts +2 -2
  381. package/es/components/index.mjs +6 -6
  382. package/es/components/input/src/input.d.ts +13 -3
  383. package/es/components/input/src/input.mjs +1 -0
  384. package/es/components/input/src/input.mjs.map +1 -1
  385. package/es/components/input/src/input.vue.d.ts +6 -5
  386. package/es/components/input/src/input.vue_vue_type_script_setup_true_lang.mjs +76 -11
  387. package/es/components/input/src/input.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  388. package/es/components/input/src/input2.mjs.map +1 -1
  389. package/es/components/input-number/src/input-number.d.ts +3 -3
  390. package/es/components/input-number/src/input-number.vue.d.ts +5 -5
  391. package/es/components/input-number/src/input-number.vue_vue_type_script_setup_true_lang.mjs +1 -1
  392. package/es/components/input-tag/src/composables/use-input-tag.d.ts +1 -1
  393. package/es/components/input-tag/src/input-tag.d.ts +2 -2
  394. package/es/components/input-tag/src/input-tag.vue.d.ts +9 -9
  395. package/es/components/link/src/link.d.ts +1 -1
  396. package/es/components/link/src/link.vue.d.ts +1 -1
  397. package/es/components/mention/src/helper.d.ts +1 -1
  398. package/es/components/mention/src/helper.mjs.map +1 -1
  399. package/es/components/mention/src/mention.d.ts +17 -10
  400. package/es/components/mention/src/mention.mjs.map +1 -1
  401. package/es/components/mention/src/mention.vue.d.ts +48 -55
  402. package/es/components/mention/src/mention.vue_vue_type_script_setup_true_lang.mjs +5 -3
  403. package/es/components/mention/src/mention.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  404. package/es/components/mention/src/mention2.mjs.map +1 -1
  405. package/es/components/menu/src/menu.d.ts +1 -1
  406. package/es/components/menu/src/menu.mjs +1 -1
  407. package/es/components/menu/src/sub-menu.d.ts +1 -1
  408. package/es/components/menu/src/utils/menu-item.mjs +1 -1
  409. package/es/components/menu/src/utils/submenu.mjs +1 -1
  410. package/es/components/message/src/message.d.ts +1 -1
  411. package/es/components/message/src/message.vue.d.ts +3 -3
  412. package/es/components/message/src/message.vue_vue_type_script_setup_true_lang.mjs +1 -1
  413. package/es/components/message/src/message.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  414. package/es/components/message/src/message2.mjs.map +1 -1
  415. package/es/components/message-box/src/index.vue_vue_type_script_lang.mjs +1 -1
  416. package/es/components/message-box/src/message-box.type.d.ts +5 -3
  417. package/es/components/notification/src/notification.vue.d.ts +4 -4
  418. package/es/components/overlay/index.d.ts +3 -3
  419. package/es/components/overlay/src/overlay.d.ts +2 -2
  420. package/es/components/pagination/src/pagination.d.ts +6 -6
  421. package/es/components/popconfirm/src/popconfirm.vue.d.ts +2 -2
  422. package/es/components/popover/src/popover.d.ts +1 -1
  423. package/es/components/popover/src/popover.vue.d.ts +7 -7
  424. package/es/components/popper/src/composables/use-content.d.ts +5 -5
  425. package/es/components/popper/src/composables/use-focus-trap.d.ts +1 -1
  426. package/es/components/popper/src/content.d.ts +4 -4
  427. package/es/components/popper/src/content.vue.d.ts +4 -4
  428. package/es/components/popper/src/popper.d.ts +2 -2
  429. package/es/components/popper/src/trigger.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  430. package/es/components/popper/src/trigger2.mjs.map +1 -1
  431. package/es/components/progress/src/progress.vue.d.ts +2 -2
  432. package/es/components/radio/src/radio-button.d.ts +1 -1
  433. package/es/components/radio/src/radio-button.vue.d.ts +2 -2
  434. package/es/components/radio/src/radio-group.d.ts +1 -1
  435. package/es/components/radio/src/radio-group.vue.d.ts +4 -4
  436. package/es/components/radio/src/radio.d.ts +2 -2
  437. package/es/components/radio/src/radio.vue.d.ts +4 -4
  438. package/es/components/rate/src/rate.d.ts +1 -1
  439. package/es/components/rate/src/rate.vue.d.ts +2 -2
  440. package/es/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  441. package/es/components/row/src/row.d.ts +1 -1
  442. package/es/components/scrollbar/src/scrollbar.vue.d.ts +1 -1
  443. package/es/components/scrollbar/src/scrollbar.vue_vue_type_script_setup_true_lang.mjs +4 -3
  444. package/es/components/scrollbar/src/scrollbar.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  445. package/es/components/scrollbar/src/scrollbar2.mjs.map +1 -1
  446. package/es/components/segmented/index.d.ts +2 -2
  447. package/es/components/segmented/src/segmented.d.ts +1 -1
  448. package/es/components/segmented/src/segmented.vue.d.ts +1 -1
  449. package/es/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.mjs +2 -57
  450. package/es/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  451. package/es/components/select/src/option.d.ts +1 -1
  452. package/es/components/select/src/option.vue.d.ts +3 -2
  453. package/es/components/select/src/option.vue_vue_type_script_lang.mjs +11 -0
  454. package/es/components/select/src/option.vue_vue_type_script_lang.mjs.map +1 -1
  455. package/es/components/select/src/option2.mjs +2 -1
  456. package/es/components/select/src/option2.mjs.map +1 -1
  457. package/es/components/select/src/select.d.ts +3 -3
  458. package/es/components/select/src/select.vue.d.ts +76 -81
  459. package/es/components/select/src/select.vue_vue_type_script_lang.mjs +1 -1
  460. package/es/components/select/src/type.d.ts +1 -0
  461. package/es/components/select-v2/src/defaults.d.ts +2 -2
  462. package/es/components/select-v2/src/defaults.mjs.map +1 -1
  463. package/es/components/select-v2/src/option-item.mjs +2 -1
  464. package/es/components/select-v2/src/option-item.mjs.map +1 -1
  465. package/es/components/select-v2/src/option-item.vue_vue_type_script_lang.mjs +13 -1
  466. package/es/components/select-v2/src/option-item.vue_vue_type_script_lang.mjs.map +1 -1
  467. package/es/components/select-v2/src/select.vue.d.ts +62 -68
  468. package/es/components/select-v2/src/select.vue_vue_type_script_lang.mjs +1 -1
  469. package/es/components/skeleton/src/skeleton-item.d.ts +1 -1
  470. package/es/components/skeleton/src/skeleton.vue.d.ts +1 -1
  471. package/es/components/slider/src/button.vue.d.ts +1 -1
  472. package/es/components/slider/src/slider.d.ts +2 -2
  473. package/es/components/slider/src/slider.vue.d.ts +9 -9
  474. package/es/components/space/src/space.d.ts +10 -9
  475. package/es/components/steps/src/steps.vue.d.ts +1 -1
  476. package/es/components/switch/src/switch.d.ts +1 -1
  477. package/es/components/switch/src/switch.vue.d.ts +3 -3
  478. package/es/components/table/src/table-body/index.d.ts +1 -1
  479. package/es/components/table/src/table-column/index.d.ts +15 -15
  480. package/es/components/table/src/table-footer/index.d.ts +1 -1
  481. package/es/components/table/src/table-header/index.d.ts +15 -15
  482. package/es/components/table/src/table.vue.d.ts +35 -35
  483. package/es/components/table/src/table.vue_vue_type_script_lang.mjs +1 -1
  484. package/es/components/table-v2/src/components/header.d.ts +1 -1
  485. package/es/components/table-v2/src/components/index.d.ts +2 -2
  486. package/es/components/table-v2/src/components/row.d.ts +12 -3
  487. package/es/components/table-v2/src/components/row.mjs.map +1 -1
  488. package/es/components/table-v2/src/table-grid.d.ts +2 -2
  489. package/es/components/table-v2/src/table-v2.d.ts +18 -6
  490. package/es/components/table-v2/src/table-v2.mjs +1 -0
  491. package/es/components/table-v2/src/table-v2.mjs.map +1 -1
  492. package/es/components/tabs/src/tab-bar.vue.d.ts +1 -1
  493. package/es/components/tabs/src/tab-bar.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  494. package/es/components/tabs/src/tab-bar2.mjs.map +1 -1
  495. package/es/components/tabs/src/tab-nav.d.ts +1 -1
  496. package/es/components/tabs/src/tabs.d.ts +5 -5
  497. package/es/components/tag/src/tag.d.ts +1 -1
  498. package/es/components/text/src/text.d.ts +1 -1
  499. package/es/components/time-picker/src/common/picker.mjs.map +1 -1
  500. package/es/components/time-picker/src/common/picker.vue.d.ts +16 -16
  501. package/es/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.mjs +4 -3
  502. package/es/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  503. package/es/components/time-picker/src/common/props.d.ts +2 -2
  504. package/es/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_setup_true_lang.mjs +1 -1
  505. package/es/components/time-picker/src/time-picker.d.ts +12 -12
  506. package/es/components/time-select/src/time-select.d.ts +1 -1
  507. package/es/components/time-select/src/time-select.vue.d.ts +5 -5
  508. package/es/components/timeline/src/timeline-item.d.ts +2 -2
  509. package/es/components/timeline/src/timeline-item.vue.d.ts +1 -1
  510. package/es/components/tooltip/src/content.d.ts +1 -1
  511. package/es/components/tooltip/src/content.vue.d.ts +6 -6
  512. package/es/components/tooltip/src/tooltip.d.ts +2 -2
  513. package/es/components/tooltip/src/tooltip.vue.d.ts +12 -12
  514. package/es/components/tour/src/content.d.ts +2 -2
  515. package/es/components/tour/src/step.d.ts +1 -1
  516. package/es/components/tour/src/tour.d.ts +1 -1
  517. package/es/components/tour/src/tour.vue.d.ts +3 -3
  518. package/es/components/transfer/src/composables/use-check.d.ts +4 -4
  519. package/es/components/transfer/src/composables/use-check.mjs.map +1 -1
  520. package/es/components/transfer/src/composables/use-computed-data.d.ts +3 -3
  521. package/es/components/transfer/src/composables/use-computed-data.mjs +1 -1
  522. package/es/components/transfer/src/composables/use-computed-data.mjs.map +1 -1
  523. package/es/components/transfer/src/composables/use-move.d.ts +2 -2
  524. package/es/components/transfer/src/composables/use-move.mjs.map +1 -1
  525. package/es/components/transfer/src/composables/use-props-alias.d.ts +4 -2
  526. package/es/components/transfer/src/composables/use-props-alias.mjs.map +1 -1
  527. package/es/components/transfer/src/transfer-panel.d.ts +11 -10
  528. package/es/components/transfer/src/transfer-panel.mjs.map +1 -1
  529. package/es/components/transfer/src/transfer-panel.vue.d.ts +23 -25
  530. package/es/components/transfer/src/transfer-panel.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  531. package/es/components/transfer/src/transfer-panel2.mjs.map +1 -1
  532. package/es/components/transfer/src/transfer.d.ts +9 -8
  533. package/es/components/transfer/src/transfer.mjs.map +1 -1
  534. package/es/components/transfer/src/transfer.vue.d.ts +32 -42
  535. package/es/components/transfer/src/transfer.vue_vue_type_script_setup_true_lang.mjs.map +1 -1
  536. package/es/components/transfer/src/transfer2.mjs.map +1 -1
  537. package/es/components/tree/src/tree.vue.d.ts +19 -25
  538. package/es/components/tree-select/src/tree-select.vue.d.ts +31 -31
  539. package/es/components/tree-v2/src/tree.vue.d.ts +3 -3
  540. package/es/components/upload/src/upload-content.mjs.map +1 -1
  541. package/es/components/upload/src/upload-content.vue.d.ts +1 -1
  542. package/es/components/upload/src/upload.vue.d.ts +2 -2
  543. package/es/components/virtual-list/src/builders/build-grid.d.ts +1 -1
  544. package/es/components/virtual-list/src/components/dynamic-size-grid.d.ts +1 -1
  545. package/es/components/virtual-list/src/components/dynamic-size-list.d.ts +2 -2
  546. package/es/components/virtual-list/src/components/fixed-size-grid.d.ts +1 -1
  547. package/es/components/virtual-list/src/components/fixed-size-list.d.ts +2 -2
  548. package/es/constants/index.mjs +2 -2
  549. package/es/directives/trap-focus/index.mjs +1 -1
  550. package/es/hooks/use-floating/index.d.ts +8 -8
  551. package/es/hooks/use-popper/index.d.ts +5 -5
  552. package/es/hooks/use-size/index.d.ts +3 -3
  553. package/es/hooks/use-timeout/index.mjs +6 -2
  554. package/es/hooks/use-timeout/index.mjs.map +1 -1
  555. package/es/index.d.ts +2 -2
  556. package/es/index.mjs +13 -13
  557. package/es/plugin.mjs +1 -1
  558. package/es/utils/index.d.ts +2 -2
  559. package/es/utils/typescript.d.ts +22 -5
  560. package/es/utils/typescript.mjs.map +1 -1
  561. package/es/utils/vue/typescript.d.ts +3 -2
  562. package/es/utils/vue/vnode.d.ts +4 -4
  563. package/es/version.mjs +1 -1
  564. package/es/version.mjs.map +1 -1
  565. package/lib/component.js +107 -107
  566. package/lib/components/affix/src/affix.d.ts +3 -2
  567. package/lib/components/affix/src/affix.vue.d.ts +4 -5
  568. package/lib/components/alert/src/alert.vue.d.ts +1 -1
  569. package/lib/components/anchor/src/anchor-link.vue.d.ts +1 -3
  570. package/lib/components/anchor/src/anchor-link.vue_vue_type_script_setup_true_lang.js.map +1 -1
  571. package/lib/components/anchor/src/anchor-link2.js.map +1 -1
  572. package/lib/components/anchor/src/anchor.vue.d.ts +2 -2
  573. package/lib/components/autocomplete/index.d.ts +2 -2
  574. package/lib/components/autocomplete/src/autocomplete.d.ts +21 -13
  575. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  576. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +55 -80
  577. package/lib/components/autocomplete/src/autocomplete.vue_vue_type_script_setup_true_lang.js +4 -2
  578. package/lib/components/autocomplete/src/autocomplete.vue_vue_type_script_setup_true_lang.js.map +1 -1
  579. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  580. package/lib/components/avatar/src/avatar-group-props.d.ts +1 -1
  581. package/lib/components/avatar/src/avatar-group.d.ts +2 -2
  582. package/lib/components/avatar/src/avatar.d.ts +3 -2
  583. package/lib/components/avatar/src/avatar.vue.d.ts +2 -3
  584. package/lib/components/backtop/src/backtop.vue.d.ts +1 -1
  585. package/lib/components/badge/src/badge.vue.d.ts +1 -1
  586. package/lib/components/button/src/button-custom.js +17 -0
  587. package/lib/components/button/src/button-custom.js.map +1 -1
  588. package/lib/components/button/src/button.d.ts +1 -1
  589. package/lib/components/button/src/button.vue.d.ts +3 -3
  590. package/lib/components/calendar/src/use-date-table.js +2 -1
  591. package/lib/components/calendar/src/use-date-table.js.map +1 -1
  592. package/lib/components/card/src/card.d.ts +1 -1
  593. package/lib/components/carousel/src/carousel-item.vue.d.ts +1 -1
  594. package/lib/components/carousel/src/carousel.d.ts +1 -1
  595. package/lib/components/cascader/src/cascader.d.ts +2 -2
  596. package/lib/components/cascader/src/cascader.vue.d.ts +15 -15
  597. package/lib/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.js +44 -39
  598. package/lib/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.js.map +1 -1
  599. package/lib/components/cascader/src/cascader2.js.map +1 -1
  600. package/lib/components/cascader-panel/src/index.js.map +1 -1
  601. package/lib/components/cascader-panel/src/index.vue.d.ts +2 -2
  602. package/lib/components/cascader-panel/src/index.vue_vue_type_script_setup_true_lang.js +11 -11
  603. package/lib/components/cascader-panel/src/index.vue_vue_type_script_setup_true_lang.js.map +1 -1
  604. package/lib/components/checkbox/src/checkbox-button.vue.d.ts +4 -4
  605. package/lib/components/checkbox/src/checkbox-group.d.ts +1 -1
  606. package/lib/components/checkbox/src/checkbox-group.vue.d.ts +2 -2
  607. package/lib/components/checkbox/src/checkbox.d.ts +3 -3
  608. package/lib/components/checkbox/src/checkbox.vue.d.ts +4 -4
  609. package/lib/components/checkbox/src/composables/use-checkbox-model.js +6 -2
  610. package/lib/components/checkbox/src/composables/use-checkbox-model.js.map +1 -1
  611. package/lib/components/checkbox/src/composables/use-checkbox-status.d.ts +2 -2
  612. package/lib/components/checkbox/src/composables/use-checkbox.d.ts +2 -2
  613. package/lib/components/col/src/col.vue.d.ts +1 -1
  614. package/lib/components/collapse/src/collapse.d.ts +1 -1
  615. package/lib/components/collapse/src/collapse.vue.d.ts +1 -1
  616. package/lib/components/color-picker/src/color-picker.d.ts +1 -1
  617. package/lib/components/color-picker/src/color-picker.vue.d.ts +7 -7
  618. package/lib/components/color-picker/src/color-picker.vue_vue_type_script_setup_true_lang.js +18 -18
  619. package/lib/components/color-picker/src/color-picker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  620. package/lib/components/color-picker-panel/src/color-picker-panel.vue.d.ts +1 -1
  621. package/lib/components/color-picker-panel/src/composables/use-predefine.js.map +1 -1
  622. package/lib/components/config-provider/src/config-provider-props.d.ts +1 -1
  623. package/lib/components/config-provider/src/config-provider.d.ts +3 -3
  624. package/lib/components/config-provider/src/hooks/use-global-config.d.ts +1 -1
  625. package/lib/components/countdown/src/countdown.vue_vue_type_script_setup_true_lang.js +1 -1
  626. package/lib/components/date-picker/src/date-picker.d.ts +12 -12
  627. package/lib/components/date-picker/src/props.d.ts +2 -2
  628. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-pick.js.map +1 -1
  629. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue_vue_type_script_setup_true_lang.js +19 -19
  630. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue_vue_type_script_setup_true_lang.js.map +1 -1
  631. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.js +23 -23
  632. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.js.map +1 -1
  633. package/lib/components/date-picker-panel/src/date-picker-panel.d.ts +3 -3
  634. package/lib/components/descriptions/src/description-item.d.ts +8 -8
  635. package/lib/components/descriptions/src/description.d.ts +1 -1
  636. package/lib/components/descriptions/src/description.js.map +1 -1
  637. package/lib/components/descriptions/src/description.vue.d.ts +1 -1
  638. package/lib/components/dialog/src/dialog.vue.d.ts +11 -11
  639. package/lib/components/dialog/src/dialog.vue_vue_type_script_setup_true_lang.js +6 -5
  640. package/lib/components/dialog/src/dialog.vue_vue_type_script_setup_true_lang.js.map +1 -1
  641. package/lib/components/dialog/src/dialog2.js.map +1 -1
  642. package/lib/components/dialog/src/use-dialog.d.ts +4 -2
  643. package/lib/components/dialog/src/use-dialog.js +8 -1
  644. package/lib/components/dialog/src/use-dialog.js.map +1 -1
  645. package/lib/components/divider/src/divider.d.ts +1 -1
  646. package/lib/components/drawer/src/drawer.vue.d.ts +5 -5
  647. package/lib/components/dropdown/src/dropdown-item.vue.d.ts +4 -10
  648. package/lib/components/dropdown/src/dropdown-menu.vue.d.ts +1 -1
  649. package/lib/components/dropdown/src/dropdown.d.ts +2 -2
  650. package/lib/components/dropdown/src/dropdown.vue.d.ts +60 -66
  651. package/lib/components/focus-trap/src/focus-trap.vue.d.ts +1 -1
  652. package/lib/components/form/src/form-item.d.ts +2 -2
  653. package/lib/components/form/src/form-item.vue.d.ts +1 -1
  654. package/lib/components/form/src/form-item.vue_vue_type_script_setup_true_lang.js +11 -1
  655. package/lib/components/form/src/form-item.vue_vue_type_script_setup_true_lang.js.map +1 -1
  656. package/lib/components/form/src/form-item2.js.map +1 -1
  657. package/lib/components/form/src/form.d.ts +4 -4
  658. package/lib/components/form/src/form.vue.d.ts +1 -1
  659. package/lib/components/form/src/form.vue_vue_type_script_setup_true_lang.js +11 -3
  660. package/lib/components/form/src/form.vue_vue_type_script_setup_true_lang.js.map +1 -1
  661. package/lib/components/form/src/form2.js.map +1 -1
  662. package/lib/components/form/src/hooks/use-form-common-props.d.ts +2 -2
  663. package/lib/components/form/src/types.d.ts +2 -1
  664. package/lib/components/icon/src/icon.vue.d.ts +1 -3
  665. package/lib/components/icon/src/icon.vue_vue_type_script_setup_true_lang.js.map +1 -1
  666. package/lib/components/icon/src/icon2.js.map +1 -1
  667. package/lib/components/image/src/image.d.ts +1 -1
  668. package/lib/components/image/src/image.vue.d.ts +3 -3
  669. package/lib/components/image-viewer/src/image-viewer.vue.d.ts +2 -2
  670. package/lib/components/index.d.ts +2 -2
  671. package/lib/components/index.js +123 -123
  672. package/lib/components/input/src/input.d.ts +13 -3
  673. package/lib/components/input/src/input.js +1 -0
  674. package/lib/components/input/src/input.js.map +1 -1
  675. package/lib/components/input/src/input.vue.d.ts +6 -5
  676. package/lib/components/input/src/input.vue_vue_type_script_setup_true_lang.js +76 -11
  677. package/lib/components/input/src/input.vue_vue_type_script_setup_true_lang.js.map +1 -1
  678. package/lib/components/input/src/input2.js.map +1 -1
  679. package/lib/components/input-number/src/input-number.d.ts +3 -3
  680. package/lib/components/input-number/src/input-number.vue.d.ts +5 -5
  681. package/lib/components/input-number/src/input-number.vue_vue_type_script_setup_true_lang.js +12 -12
  682. package/lib/components/input-number/src/input-number.vue_vue_type_script_setup_true_lang.js.map +1 -1
  683. package/lib/components/input-tag/src/composables/use-input-tag.d.ts +1 -1
  684. package/lib/components/input-tag/src/input-tag.d.ts +2 -2
  685. package/lib/components/input-tag/src/input-tag.vue.d.ts +9 -9
  686. package/lib/components/link/src/link.d.ts +1 -1
  687. package/lib/components/link/src/link.vue.d.ts +1 -1
  688. package/lib/components/mention/src/helper.d.ts +1 -1
  689. package/lib/components/mention/src/helper.js.map +1 -1
  690. package/lib/components/mention/src/mention.d.ts +17 -10
  691. package/lib/components/mention/src/mention.js.map +1 -1
  692. package/lib/components/mention/src/mention.vue.d.ts +48 -55
  693. package/lib/components/mention/src/mention.vue_vue_type_script_setup_true_lang.js +4 -2
  694. package/lib/components/mention/src/mention.vue_vue_type_script_setup_true_lang.js.map +1 -1
  695. package/lib/components/mention/src/mention2.js.map +1 -1
  696. package/lib/components/menu/src/menu.d.ts +1 -1
  697. package/lib/components/menu/src/menu.js +7 -7
  698. package/lib/components/menu/src/menu.js.map +1 -1
  699. package/lib/components/menu/src/sub-menu.d.ts +1 -1
  700. package/lib/components/menu/src/utils/menu-item.js +11 -11
  701. package/lib/components/menu/src/utils/menu-item.js.map +1 -1
  702. package/lib/components/menu/src/utils/submenu.js +9 -9
  703. package/lib/components/menu/src/utils/submenu.js.map +1 -1
  704. package/lib/components/message/src/message.d.ts +1 -1
  705. package/lib/components/message/src/message.vue.d.ts +3 -3
  706. package/lib/components/message/src/message.vue_vue_type_script_setup_true_lang.js +1 -1
  707. package/lib/components/message/src/message.vue_vue_type_script_setup_true_lang.js.map +1 -1
  708. package/lib/components/message/src/message2.js.map +1 -1
  709. package/lib/components/message-box/src/index.vue_vue_type_script_lang.js +19 -19
  710. package/lib/components/message-box/src/index.vue_vue_type_script_lang.js.map +1 -1
  711. package/lib/components/message-box/src/message-box.type.d.ts +5 -3
  712. package/lib/components/notification/src/notification.vue.d.ts +4 -4
  713. package/lib/components/overlay/index.d.ts +3 -3
  714. package/lib/components/overlay/src/overlay.d.ts +2 -2
  715. package/lib/components/pagination/src/pagination.d.ts +6 -6
  716. package/lib/components/popconfirm/src/popconfirm.vue.d.ts +2 -2
  717. package/lib/components/popover/src/popover.d.ts +1 -1
  718. package/lib/components/popover/src/popover.vue.d.ts +7 -7
  719. package/lib/components/popper/src/composables/use-content.d.ts +5 -5
  720. package/lib/components/popper/src/composables/use-focus-trap.d.ts +1 -1
  721. package/lib/components/popper/src/content.d.ts +4 -4
  722. package/lib/components/popper/src/content.vue.d.ts +4 -4
  723. package/lib/components/popper/src/popper.d.ts +2 -2
  724. package/lib/components/popper/src/trigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  725. package/lib/components/popper/src/trigger2.js.map +1 -1
  726. package/lib/components/progress/src/progress.vue.d.ts +2 -2
  727. package/lib/components/radio/src/radio-button.d.ts +1 -1
  728. package/lib/components/radio/src/radio-button.vue.d.ts +2 -2
  729. package/lib/components/radio/src/radio-group.d.ts +1 -1
  730. package/lib/components/radio/src/radio-group.vue.d.ts +4 -4
  731. package/lib/components/radio/src/radio.d.ts +2 -2
  732. package/lib/components/radio/src/radio.vue.d.ts +4 -4
  733. package/lib/components/rate/src/rate.d.ts +1 -1
  734. package/lib/components/rate/src/rate.vue.d.ts +2 -2
  735. package/lib/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  736. package/lib/components/row/src/row.d.ts +1 -1
  737. package/lib/components/scrollbar/src/scrollbar.vue.d.ts +1 -1
  738. package/lib/components/scrollbar/src/scrollbar.vue_vue_type_script_setup_true_lang.js +4 -3
  739. package/lib/components/scrollbar/src/scrollbar.vue_vue_type_script_setup_true_lang.js.map +1 -1
  740. package/lib/components/scrollbar/src/scrollbar2.js.map +1 -1
  741. package/lib/components/segmented/index.d.ts +2 -2
  742. package/lib/components/segmented/src/segmented.d.ts +1 -1
  743. package/lib/components/segmented/src/segmented.vue.d.ts +1 -1
  744. package/lib/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.js +1 -56
  745. package/lib/components/segmented/src/segmented.vue_vue_type_script_setup_true_lang.js.map +1 -1
  746. package/lib/components/select/src/option.d.ts +1 -1
  747. package/lib/components/select/src/option.vue.d.ts +3 -2
  748. package/lib/components/select/src/option.vue_vue_type_script_lang.js +11 -0
  749. package/lib/components/select/src/option.vue_vue_type_script_lang.js.map +1 -1
  750. package/lib/components/select/src/option2.js +2 -1
  751. package/lib/components/select/src/option2.js.map +1 -1
  752. package/lib/components/select/src/select.d.ts +3 -3
  753. package/lib/components/select/src/select.vue.d.ts +76 -81
  754. package/lib/components/select/src/select.vue_vue_type_script_lang.js +10 -10
  755. package/lib/components/select/src/select.vue_vue_type_script_lang.js.map +1 -1
  756. package/lib/components/select/src/type.d.ts +1 -0
  757. package/lib/components/select-v2/src/defaults.d.ts +2 -2
  758. package/lib/components/select-v2/src/defaults.js.map +1 -1
  759. package/lib/components/select-v2/src/option-item.js +2 -1
  760. package/lib/components/select-v2/src/option-item.js.map +1 -1
  761. package/lib/components/select-v2/src/option-item.vue_vue_type_script_lang.js +13 -1
  762. package/lib/components/select-v2/src/option-item.vue_vue_type_script_lang.js.map +1 -1
  763. package/lib/components/select-v2/src/select.vue.d.ts +62 -68
  764. package/lib/components/select-v2/src/select.vue_vue_type_script_lang.js +10 -10
  765. package/lib/components/select-v2/src/select.vue_vue_type_script_lang.js.map +1 -1
  766. package/lib/components/skeleton/src/skeleton-item.d.ts +1 -1
  767. package/lib/components/skeleton/src/skeleton.vue.d.ts +1 -1
  768. package/lib/components/slider/src/button.vue.d.ts +1 -1
  769. package/lib/components/slider/src/slider.d.ts +2 -2
  770. package/lib/components/slider/src/slider.vue.d.ts +9 -9
  771. package/lib/components/space/src/space.d.ts +10 -9
  772. package/lib/components/steps/src/steps.vue.d.ts +1 -1
  773. package/lib/components/switch/src/switch.d.ts +1 -1
  774. package/lib/components/switch/src/switch.vue.d.ts +3 -3
  775. package/lib/components/table/src/table-body/index.d.ts +1 -1
  776. package/lib/components/table/src/table-column/index.d.ts +15 -15
  777. package/lib/components/table/src/table-footer/index.d.ts +1 -1
  778. package/lib/components/table/src/table-header/index.d.ts +15 -15
  779. package/lib/components/table/src/table.vue.d.ts +35 -35
  780. package/lib/components/table/src/table.vue_vue_type_script_lang.js +8 -8
  781. package/lib/components/table/src/table.vue_vue_type_script_lang.js.map +1 -1
  782. package/lib/components/table-v2/src/components/header.d.ts +1 -1
  783. package/lib/components/table-v2/src/components/index.d.ts +2 -2
  784. package/lib/components/table-v2/src/components/row.d.ts +12 -3
  785. package/lib/components/table-v2/src/components/row.js.map +1 -1
  786. package/lib/components/table-v2/src/table-grid.d.ts +2 -2
  787. package/lib/components/table-v2/src/table-v2.d.ts +18 -6
  788. package/lib/components/table-v2/src/table-v2.js +1 -0
  789. package/lib/components/table-v2/src/table-v2.js.map +1 -1
  790. package/lib/components/tabs/src/tab-bar.vue.d.ts +1 -1
  791. package/lib/components/tabs/src/tab-bar.vue_vue_type_script_setup_true_lang.js.map +1 -1
  792. package/lib/components/tabs/src/tab-bar2.js.map +1 -1
  793. package/lib/components/tabs/src/tab-nav.d.ts +1 -1
  794. package/lib/components/tabs/src/tabs.d.ts +5 -5
  795. package/lib/components/tag/src/tag.d.ts +1 -1
  796. package/lib/components/text/src/text.d.ts +1 -1
  797. package/lib/components/time-picker/src/common/picker.js.map +1 -1
  798. package/lib/components/time-picker/src/common/picker.vue.d.ts +16 -16
  799. package/lib/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.js +4 -3
  800. package/lib/components/time-picker/src/common/picker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  801. package/lib/components/time-picker/src/common/props.d.ts +2 -2
  802. package/lib/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_setup_true_lang.js +10 -10
  803. package/lib/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_setup_true_lang.js.map +1 -1
  804. package/lib/components/time-picker/src/time-picker.d.ts +12 -12
  805. package/lib/components/time-select/src/time-select.d.ts +1 -1
  806. package/lib/components/time-select/src/time-select.vue.d.ts +5 -5
  807. package/lib/components/timeline/src/timeline-item.d.ts +2 -2
  808. package/lib/components/timeline/src/timeline-item.vue.d.ts +1 -1
  809. package/lib/components/tooltip/src/content.d.ts +1 -1
  810. package/lib/components/tooltip/src/content.vue.d.ts +6 -6
  811. package/lib/components/tooltip/src/tooltip.d.ts +2 -2
  812. package/lib/components/tooltip/src/tooltip.vue.d.ts +12 -12
  813. package/lib/components/tour/src/content.d.ts +2 -2
  814. package/lib/components/tour/src/step.d.ts +1 -1
  815. package/lib/components/tour/src/tour.d.ts +1 -1
  816. package/lib/components/tour/src/tour.vue.d.ts +3 -3
  817. package/lib/components/transfer/src/composables/use-check.d.ts +4 -4
  818. package/lib/components/transfer/src/composables/use-check.js.map +1 -1
  819. package/lib/components/transfer/src/composables/use-computed-data.d.ts +3 -3
  820. package/lib/components/transfer/src/composables/use-computed-data.js +1 -1
  821. package/lib/components/transfer/src/composables/use-computed-data.js.map +1 -1
  822. package/lib/components/transfer/src/composables/use-move.d.ts +2 -2
  823. package/lib/components/transfer/src/composables/use-move.js.map +1 -1
  824. package/lib/components/transfer/src/composables/use-props-alias.d.ts +4 -2
  825. package/lib/components/transfer/src/composables/use-props-alias.js.map +1 -1
  826. package/lib/components/transfer/src/transfer-panel.d.ts +11 -10
  827. package/lib/components/transfer/src/transfer-panel.js.map +1 -1
  828. package/lib/components/transfer/src/transfer-panel.vue.d.ts +23 -25
  829. package/lib/components/transfer/src/transfer-panel.vue_vue_type_script_setup_true_lang.js.map +1 -1
  830. package/lib/components/transfer/src/transfer-panel2.js.map +1 -1
  831. package/lib/components/transfer/src/transfer.d.ts +9 -8
  832. package/lib/components/transfer/src/transfer.js.map +1 -1
  833. package/lib/components/transfer/src/transfer.vue.d.ts +32 -42
  834. package/lib/components/transfer/src/transfer.vue_vue_type_script_setup_true_lang.js.map +1 -1
  835. package/lib/components/transfer/src/transfer2.js.map +1 -1
  836. package/lib/components/tree/src/tree.vue.d.ts +19 -25
  837. package/lib/components/tree-select/src/tree-select.vue.d.ts +31 -31
  838. package/lib/components/tree-v2/src/tree.vue.d.ts +3 -3
  839. package/lib/components/upload/src/upload-content.js.map +1 -1
  840. package/lib/components/upload/src/upload-content.vue.d.ts +1 -1
  841. package/lib/components/upload/src/upload.vue.d.ts +2 -2
  842. package/lib/components/virtual-list/src/builders/build-grid.d.ts +1 -1
  843. package/lib/components/virtual-list/src/components/dynamic-size-grid.d.ts +1 -1
  844. package/lib/components/virtual-list/src/components/dynamic-size-list.d.ts +2 -2
  845. package/lib/components/virtual-list/src/components/fixed-size-grid.d.ts +1 -1
  846. package/lib/components/virtual-list/src/components/fixed-size-list.d.ts +2 -2
  847. package/lib/constants/index.js +2 -2
  848. package/lib/directives/trap-focus/index.js +5 -5
  849. package/lib/directives/trap-focus/index.js.map +1 -1
  850. package/lib/hooks/use-floating/index.d.ts +8 -8
  851. package/lib/hooks/use-popper/index.d.ts +5 -5
  852. package/lib/hooks/use-size/index.d.ts +3 -3
  853. package/lib/hooks/use-timeout/index.js +6 -2
  854. package/lib/hooks/use-timeout/index.js.map +1 -1
  855. package/lib/index.d.ts +2 -2
  856. package/lib/index.js +267 -267
  857. package/lib/plugin.js +12 -12
  858. package/lib/utils/index.d.ts +2 -2
  859. package/lib/utils/typescript.d.ts +22 -5
  860. package/lib/utils/typescript.js.map +1 -1
  861. package/lib/utils/vue/typescript.d.ts +3 -2
  862. package/lib/utils/vue/vnode.d.ts +4 -4
  863. package/lib/version.js +1 -1
  864. package/lib/version.js.map +1 -1
  865. package/package.json +2 -2
  866. package/tags.json +1 -1
  867. package/theme-chalk/el-table.css +1 -1
  868. package/theme-chalk/index.css +1 -1
  869. package/theme-chalk/src/table.scss +1 -1
  870. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete.js","names":["buildProps","inputProps","definePropType","NOOP","useTooltipContentProps","UPDATE_MODEL_EVENT","isNumber","INPUT_EVENT","CHANGE_EVENT"],"sources":["../../../../../../packages/components/autocomplete/src/autocomplete.ts"],"sourcesContent":["import {\n NOOP,\n buildProps,\n definePropType,\n isNumber,\n isObject,\n isString,\n} from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { inputProps } from '@element-plus/components/input'\n\nimport type { ExtractPublicPropTypes } from 'vue'\nimport type Autocomplete from './autocomplete.vue'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Awaitable } from '@element-plus/utils'\nimport type { InputProps } from '@element-plus/components/input'\nimport type { ElTooltipContentProps } from '@element-plus/components/tooltip'\n\nexport type AutocompleteData = Record<string, any>[]\nexport type AutocompleteFetchSuggestionsCallback = (\n data: AutocompleteData\n) => void\nexport type AutocompleteFetchSuggestions =\n | ((\n queryString: string,\n cb: AutocompleteFetchSuggestionsCallback\n ) => Awaitable<AutocompleteData> | void)\n | AutocompleteData\n\nexport type AutocompletePlacement =\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n\nexport interface AutocompleteProps extends InputProps {\n /**\n * @description key name of the input suggestion object for display\n */\n valueKey?: string\n /**\n * @description binding value\n */\n modelValue?: string | number\n /**\n * @description debounce delay when typing, in milliseconds\n */\n debounce?: number\n /**\n * @description placement of the popup menu\n */\n placement?: AutocompletePlacement\n /**\n * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n */\n fetchSuggestions?: AutocompleteFetchSuggestions\n /**\n * @description custom class name for autocomplete's dropdown\n */\n popperClass?: ElTooltipContentProps['popperClass']\n /**\n * @description custom style for autocomplete's dropdown\n */\n popperStyle?: ElTooltipContentProps['popperStyle']\n /**\n * @description whether show suggestions when input focus\n */\n triggerOnFocus?: boolean\n /**\n * @description whether to emit a `select` event on enter when there is no autocomplete match\n */\n selectWhenUnmatched?: boolean\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading?: boolean\n /**\n * @description whether select dropdown is teleported to the body\n */\n teleported?: ElTooltipContentProps['teleported']\n /**\n * @description which select dropdown appends to\n */\n appendTo?: ElTooltipContentProps['appendTo']\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem?: boolean\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth?: boolean\n /**\n * @description whether keyboard navigation loops from end to start\n */\n loopNavigation?: boolean\n}\n\n/**\n * @deprecated Removed after 3.0.0, Use `AutocompleteProps` instead.\n */\nexport const autocompleteProps = buildProps({\n ...inputProps,\n /**\n * @description key name of the input suggestion object for display\n */\n valueKey: {\n type: String,\n default: 'value',\n },\n /**\n * @description binding value\n */\n modelValue: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description debounce delay when typing, in milliseconds\n */\n debounce: {\n type: Number,\n default: 300,\n },\n /**\n * @description placement of the popup menu\n */\n placement: {\n type: definePropType<Placement>(String),\n values: [\n 'top',\n 'top-start',\n 'top-end',\n 'bottom',\n 'bottom-start',\n 'bottom-end',\n ],\n default: 'bottom-start',\n },\n /**\n * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n */\n fetchSuggestions: {\n type: definePropType<AutocompleteFetchSuggestions>([Function, Array]),\n default: NOOP,\n },\n /**\n * @description custom class name for autocomplete's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for autocomplete's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description whether show suggestions when input focus\n */\n triggerOnFocus: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to emit a `select` event on enter when there is no autocomplete match\n */\n selectWhenUnmatched: Boolean,\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading: Boolean,\n /**\n * @description whether select dropdown is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description which select dropdown appends to\n */\n appendTo: useTooltipContentProps.appendTo,\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem: Boolean,\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth: Boolean,\n /**\n * @description whether keyboard navigation loops from end to start\n */\n loopNavigation: {\n type: Boolean,\n default: true,\n },\n} as const)\n\n/**\n * @deprecated Removed after 3.0.0, Use `AutocompleteProps` instead.\n */\nexport type AutocompletePropsPublic = ExtractPublicPropTypes<\n typeof autocompleteProps\n>\n\nexport const autocompleteEmits = {\n [UPDATE_MODEL_EVENT]: (value: string | number) =>\n isString(value) || isNumber(value),\n [INPUT_EVENT]: (value: string | number) => isString(value) || isNumber(value),\n [CHANGE_EVENT]: (value: string | number) =>\n isString(value) || isNumber(value),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n select: (item: Record<string, any>) => isObject(item),\n}\nexport type AutocompleteEmits = typeof autocompleteEmits\n\nexport type AutocompleteInstance = InstanceType<typeof Autocomplete> & unknown\n"],"mappings":";;;;;;;;;;;;;AA4GA,MAAa,oBAAoBA,6BAAW;CAC1C,GAAGC;CAIH,UAAU;EACR,MAAM;EACN,SAAS;EACV;CAID,YAAY;EACV,MAAM,CAAC,QAAQ,OAAO;EACtB,SAAS;EACV;CAID,UAAU;EACR,MAAM;EACN,SAAS;EACV;CAID,WAAW;EACT,MAAMC,iCAA0B,OAAO;EACvC,QAAQ;GACN;GACA;GACA;GACA;GACA;GACA;GACD;EACD,SAAS;EACV;CAID,kBAAkB;EAChB,MAAMA,iCAA6C,CAAC,UAAU,MAAM,CAAC;EACrE,SAASC;EACV;CAID,aAAaC,uCAAuB;CAIpC,aAAaA,uCAAuB;CAIpC,gBAAgB;EACd,MAAM;EACN,SAAS;EACV;CAID,qBAAqB;CAIrB,aAAa;CAIb,YAAYA,uCAAuB;CAInC,UAAUA,uCAAuB;CAIjC,oBAAoB;CAIpB,eAAe;CAIf,gBAAgB;EACd,MAAM;EACN,SAAS;EACV;CACF,CAAU;AASX,MAAa,oBAAoB;EAC9BC,oCAAsB,oCACZ,MAAM,IAAIC,uBAAS,MAAM;EACnCC,6BAAe,oCAAoC,MAAM,IAAID,uBAAS,MAAM;EAC5EE,8BAAgB,oCACN,MAAM,IAAIF,uBAAS,MAAM;CACpC,QAAQ,QAAoB,eAAe;CAC3C,OAAO,QAAoB,eAAe;CAC1C,aAAa;CACb,SAAS,mCAAuC,KAAK;CACtD"}
1
+ {"version":3,"file":"autocomplete.js","names":["buildProps","inputProps","definePropType","NOOP","useTooltipContentProps","UPDATE_MODEL_EVENT","isNumber","INPUT_EVENT","CHANGE_EVENT"],"sources":["../../../../../../packages/components/autocomplete/src/autocomplete.ts"],"sourcesContent":["import {\n NOOP,\n buildProps,\n definePropType,\n isNumber,\n isObject,\n isString,\n} from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { inputProps } from '@element-plus/components/input'\n\nimport type { ComponentInstance, ExtractPublicPropTypes } from 'vue'\nimport type { ComponentExposed } from 'vue-component-type-helpers'\nimport type Autocomplete from './autocomplete.vue'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Awaitable } from '@element-plus/utils'\nimport type { InputProps } from '@element-plus/components/input'\nimport type { ElTooltipContentProps } from '@element-plus/components/tooltip'\n\nexport type AutocompleteDataItem = Record<string, any>\nexport type AutocompleteData<\n T extends AutocompleteDataItem = AutocompleteDataItem,\n> = T[]\nexport type AutocompleteFetchSuggestionsCallback<\n T extends AutocompleteDataItem = AutocompleteDataItem,\n> = (data: AutocompleteData<T>) => void\nexport type AutocompleteFetchSuggestions<\n T extends AutocompleteDataItem = AutocompleteDataItem,\n> =\n | ((\n queryString: string,\n cb: AutocompleteFetchSuggestionsCallback<T>\n ) => Awaitable<AutocompleteData<T> | void>)\n | AutocompleteData<T>\n\nexport type AutocompletePlacement =\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n\nexport interface AutocompleteProps<\n T extends AutocompleteDataItem = AutocompleteDataItem,\n> extends InputProps {\n /**\n * @description key name of the input suggestion object for display\n */\n valueKey?: string\n /**\n * @description binding value\n */\n modelValue?: string | number\n /**\n * @description debounce delay when typing, in milliseconds\n */\n debounce?: number\n /**\n * @description placement of the popup menu\n */\n placement?: AutocompletePlacement\n /**\n * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n */\n fetchSuggestions?: AutocompleteFetchSuggestions<T>\n /**\n * @description custom class name for autocomplete's dropdown\n */\n popperClass?: ElTooltipContentProps['popperClass']\n /**\n * @description custom style for autocomplete's dropdown\n */\n popperStyle?: ElTooltipContentProps['popperStyle']\n /**\n * @description whether show suggestions when input focus\n */\n triggerOnFocus?: boolean\n /**\n * @description whether to emit a `select` event on enter when there is no autocomplete match\n */\n selectWhenUnmatched?: boolean\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading?: boolean\n /**\n * @description whether select dropdown is teleported to the body\n */\n teleported?: ElTooltipContentProps['teleported']\n /**\n * @description which select dropdown appends to\n */\n appendTo?: ElTooltipContentProps['appendTo']\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem?: boolean\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth?: boolean\n /**\n * @description whether keyboard navigation loops from end to start\n */\n loopNavigation?: boolean\n}\n\n/**\n * @deprecated Removed after 3.0.0, Use `AutocompleteProps` instead.\n */\nexport const autocompleteProps = buildProps({\n ...inputProps,\n /**\n * @description key name of the input suggestion object for display\n */\n valueKey: {\n type: String,\n default: 'value',\n },\n /**\n * @description binding value\n */\n modelValue: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description debounce delay when typing, in milliseconds\n */\n debounce: {\n type: Number,\n default: 300,\n },\n /**\n * @description placement of the popup menu\n */\n placement: {\n type: definePropType<Placement>(String),\n values: [\n 'top',\n 'top-start',\n 'top-end',\n 'bottom',\n 'bottom-start',\n 'bottom-end',\n ],\n default: 'bottom-start',\n },\n /**\n * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n */\n fetchSuggestions: {\n type: definePropType<AutocompleteFetchSuggestions>([Function, Array]),\n default: NOOP,\n },\n /**\n * @description custom class name for autocomplete's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for autocomplete's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description whether show suggestions when input focus\n */\n triggerOnFocus: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to emit a `select` event on enter when there is no autocomplete match\n */\n selectWhenUnmatched: Boolean,\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading: Boolean,\n /**\n * @description whether select dropdown is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description which select dropdown appends to\n */\n appendTo: useTooltipContentProps.appendTo,\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem: Boolean,\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth: Boolean,\n /**\n * @description whether keyboard navigation loops from end to start\n */\n loopNavigation: {\n type: Boolean,\n default: true,\n },\n} as const)\n\n/**\n * @deprecated Removed after 3.0.0, Use `AutocompleteProps` instead.\n */\nexport type AutocompletePropsPublic = ExtractPublicPropTypes<\n typeof autocompleteProps\n>\n\nexport const autocompleteEmits = {\n [UPDATE_MODEL_EVENT]: (value: string | number) =>\n isString(value) || isNumber(value),\n [INPUT_EVENT]: (value: string | number) => isString(value) || isNumber(value),\n [CHANGE_EVENT]: (value: string | number) =>\n isString(value) || isNumber(value),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n select: (item: Record<string, any>) => isObject(item),\n}\nexport type AutocompleteEmits = typeof autocompleteEmits\n\nexport type AutocompleteInstance = ComponentInstance<typeof Autocomplete> &\n ComponentExposed<typeof Autocomplete>\n"],"mappings":";;;;;;;;;;;;;AAoHA,MAAa,oBAAoBA,6BAAW;CAC1C,GAAGC;CAIH,UAAU;EACR,MAAM;EACN,SAAS;EACV;CAID,YAAY;EACV,MAAM,CAAC,QAAQ,OAAO;EACtB,SAAS;EACV;CAID,UAAU;EACR,MAAM;EACN,SAAS;EACV;CAID,WAAW;EACT,MAAMC,iCAA0B,OAAO;EACvC,QAAQ;GACN;GACA;GACA;GACA;GACA;GACA;GACD;EACD,SAAS;EACV;CAID,kBAAkB;EAChB,MAAMA,iCAA6C,CAAC,UAAU,MAAM,CAAC;EACrE,SAASC;EACV;CAID,aAAaC,uCAAuB;CAIpC,aAAaA,uCAAuB;CAIpC,gBAAgB;EACd,MAAM;EACN,SAAS;EACV;CAID,qBAAqB;CAIrB,aAAa;CAIb,YAAYA,uCAAuB;CAInC,UAAUA,uCAAuB;CAIjC,oBAAoB;CAIpB,eAAe;CAIf,gBAAgB;EACd,MAAM;EACN,SAAS;EACV;CACF,CAAU;AASX,MAAa,oBAAoB;EAC9BC,oCAAsB,oCACZ,MAAM,IAAIC,uBAAS,MAAM;EACnCC,6BAAe,oCAAoC,MAAM,IAAID,uBAAS,MAAM;EAC5EE,8BAAgB,oCACN,MAAM,IAAIF,uBAAS,MAAM;CACpC,QAAQ,QAAoB,eAAe;CAC3C,OAAO,QAAoB,eAAe;CAC1C,aAAa;CACb,SAAS,mCAAuC,KAAK;CACtD"}
@@ -1,91 +1,66 @@
1
- import { IconPropType } from "../../../utils/vue/icon.js";
2
- import "../../../utils/index.js";
3
- import { InputModelModifiers, InputType } from "../../input/src/input.js";
4
1
  import { InputInstance } from "../../input/src/instance.js";
5
2
  import "../../input/index.js";
6
3
  import { TooltipInstance } from "../../tooltip/src/tooltip.js";
7
4
  import "../../tooltip/index.js";
8
- import { AutocompleteData, AutocompleteFetchSuggestions, AutocompletePlacement, AutocompleteProps } from "./autocomplete.js";
5
+ import { AutocompleteData, AutocompleteDataItem, AutocompleteProps } from "./autocomplete.js";
9
6
  import * as vue from "vue";
10
- import { StyleValue } from "vue";
7
+ import { Ref } from "vue";
11
8
 
12
9
  //#region ../../packages/components/autocomplete/src/autocomplete.vue.d.ts
13
- declare var __VLS_29: {}, __VLS_32: {}, __VLS_35: {}, __VLS_38: {}, __VLS_41: {}, __VLS_49: {}, __VLS_62: {
14
- item: Record<string, any>;
15
- }, __VLS_64: {};
16
- type __VLS_Slots = {} & {
17
- prepend?: (props: typeof __VLS_29) => any;
18
- } & {
19
- append?: (props: typeof __VLS_32) => any;
20
- } & {
21
- prefix?: (props: typeof __VLS_35) => any;
22
- } & {
23
- suffix?: (props: typeof __VLS_38) => any;
24
- } & {
25
- header?: (props: typeof __VLS_41) => any;
26
- } & {
27
- loading?: (props: typeof __VLS_49) => any;
28
- } & {
29
- default?: (props: typeof __VLS_62) => any;
30
- } & {
31
- footer?: (props: typeof __VLS_64) => any;
32
- };
33
- declare const __VLS_base: vue.DefineComponent<AutocompleteProps, {
34
- /** @description the index of the currently highlighted item */highlightedIndex: vue.Ref<number, number>; /** @description autocomplete whether activated */
35
- activated: vue.Ref<boolean, boolean>; /** @description remote search loading status */
36
- loading: vue.Ref<boolean, boolean>; /** @description el-input component instance */
37
- inputRef: vue.Ref<InputInstance | undefined, InputInstance | undefined>; /** @description el-tooltip component instance */
38
- popperRef: vue.Ref<TooltipInstance | undefined, TooltipInstance | undefined>; /** @description fetch suggestions result */
39
- suggestions: vue.Ref<Record<string, any>[], Record<string, any>[] | AutocompleteData>; /** @description triggers when a suggestion is clicked */
40
- handleSelect: (item: any) => Promise<void>; /** @description handle keyboard enter event */
41
- handleKeyEnter: () => Promise<void>; /** @description focus the input element */
42
- focus: () => void; /** @description blur the input element */
43
- blur: () => void; /** @description close suggestion */
44
- close: () => void; /** @description highlight an item in a suggestion */
45
- highlight: (index: number) => void; /** @description loading suggestion list */
46
- getData: (queryString: string) => Promise<void>;
47
- }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
48
- blur: (evt: FocusEvent) => void;
49
- focus: (evt: FocusEvent) => void;
50
- select: (item: Record<string, any>) => void;
51
- clear: () => void;
52
- "update:modelValue": (value: string | number) => void;
53
- change: (value: string | number) => void;
54
- input: (value: string | number) => void;
55
- }, string, vue.PublicProps, Readonly<AutocompleteProps> & Readonly<{
56
- onBlur?: ((evt: FocusEvent) => any) | undefined;
57
- onChange?: ((value: string | number) => any) | undefined;
58
- onFocus?: ((evt: FocusEvent) => any) | undefined;
59
- onInput?: ((value: string | number) => any) | undefined;
60
- onSelect?: ((item: Record<string, any>) => any) | undefined;
61
- onClear?: (() => any) | undefined;
62
- "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
63
- }>, {
64
- type: InputType;
65
- disabled: boolean;
66
- clearIcon: IconPropType;
67
- debounce: number;
68
- placement: AutocompletePlacement;
69
- teleported: boolean;
70
- validateEvent: boolean;
71
- modelValue: string | number;
72
- modelModifiers: InputModelModifiers;
73
- autocomplete: string;
74
- wordLimitPosition: "inside" | "outside";
75
- tabindex: string | number;
76
- inputStyle: string | false | vue.CSSProperties | StyleValue[] | null;
77
- rows: number;
78
- valueKey: string;
79
- fetchSuggestions: AutocompleteFetchSuggestions;
80
- triggerOnFocus: boolean;
81
- loopNavigation: boolean;
82
- }, {}, {}, {}, string, vue.ComponentProvideOptions, false, {}, any>;
83
- declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
84
- declare const _default: typeof __VLS_export;
85
- type __VLS_WithSlots<T, S> = T & {
86
- new (): {
87
- $slots: S;
10
+ declare const __VLS_export: <T extends AutocompleteDataItem = AutocompleteDataItem>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_exposed?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
11
+ props: vue.PublicProps & __VLS_PrettifyLocal<AutocompleteProps<T> & {
12
+ onBlur?: ((evt: FocusEvent) => any) | undefined;
13
+ onChange?: ((value: string | number) => any) | undefined;
14
+ onFocus?: ((evt: FocusEvent) => any) | undefined;
15
+ onInput?: ((value: string | number) => any) | undefined;
16
+ onSelect?: ((item: Record<string, any>) => any) | undefined;
17
+ "onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
18
+ onClear?: (() => any) | undefined;
19
+ }> & (typeof globalThis extends {
20
+ __VLS_PROPS_FALLBACK: infer P;
21
+ } ? P : {});
22
+ expose: (exposed: vue.ShallowUnwrapRef<{
23
+ /** @description the index of the currently highlighted item */highlightedIndex: Ref<number, number>; /** @description autocomplete whether activated */
24
+ activated: Ref<boolean, boolean>; /** @description remote search loading status */
25
+ loading: Ref<boolean, boolean>; /** @description el-input component instance */
26
+ inputRef: Ref<InputInstance | undefined, InputInstance | undefined>; /** @description el-tooltip component instance */
27
+ popperRef: Ref<TooltipInstance | undefined, TooltipInstance | undefined>; /** @description fetch suggestions result */
28
+ suggestions: Ref<AutocompleteData<T>, AutocompleteData<T>>; /** @description triggers when a suggestion is clicked */
29
+ handleSelect: (item: T) => Promise<void>; /** @description handle keyboard enter event */
30
+ handleKeyEnter: () => Promise<void>; /** @description focus the input element */
31
+ focus: () => void; /** @description blur the input element */
32
+ blur: () => void; /** @description close suggestion */
33
+ close: () => void; /** @description highlight an item in a suggestion */
34
+ highlight: (index: number) => void; /** @description loading suggestion list */
35
+ getData: (queryString: string) => Promise<void>;
36
+ }>) => void;
37
+ attrs: any;
38
+ slots: {
39
+ prepend?: (props: {}) => any;
40
+ } & {
41
+ append?: (props: {}) => any;
42
+ } & {
43
+ prefix?: (props: {}) => any;
44
+ } & {
45
+ suffix?: (props: {}) => any;
46
+ } & {
47
+ header?: (props: {}) => any;
48
+ } & {
49
+ loading?: (props: {}) => any;
50
+ } & {
51
+ default?: (props: {
52
+ item: T;
53
+ }) => any;
54
+ } & {
55
+ footer?: (props: {}) => any;
88
56
  };
57
+ emit: ((event: "blur", evt: FocusEvent) => void) & ((event: "focus", evt: FocusEvent) => void) & ((event: "select", item: Record<string, any>) => void) & ((event: "change", value: string | number) => void) & ((event: "update:modelValue", value: string | number) => void) & ((event: "input", value: string | number) => void) & ((event: "clear") => void);
58
+ }>) => vue.VNode<vue.RendererNode, vue.RendererElement, {
59
+ [key: string]: any;
60
+ }> & {
61
+ __ctx?: Awaited<typeof __VLS_setup>;
89
62
  };
63
+ declare const _default: typeof __VLS_export;
64
+ type __VLS_PrettifyLocal<T> = (T extends any ? { [K in keyof T]: T[K] } : { [K in keyof T as K]: T[K] }) & {};
90
65
  //#endregion
91
66
  export { _default };
@@ -8,7 +8,6 @@ const require_index$1 = require('../../../hooks/use-id/index.js');
8
8
  const require_index$2 = require('../../icon/index.js');
9
9
  const require_use_form_common_props = require('../../form/src/hooks/use-form-common-props.js');
10
10
  const require_index$3 = require('../../tooltip/index.js');
11
- const require_input = require('../../input/src/input.js');
12
11
  const require_index$4 = require('../../input/index.js');
13
12
  const require_autocomplete = require('./autocomplete.js');
14
13
  const require_index$5 = require('../../scrollbar/index.js');
@@ -36,7 +35,10 @@ var autocomplete_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ (
36
35
  setup(__props, { expose: __expose, emit: __emit }) {
37
36
  const props = __props;
38
37
  const emit = __emit;
39
- const passInputProps = (0, vue.computed)(() => (0, lodash_unified.pick)(props, Object.keys(require_input.inputProps)));
38
+ const passInputProps = (0, vue.computed)(() => {
39
+ const inputProps = require_index$4.ElInput.props ?? [];
40
+ return (0, lodash_unified.pick)(props, (0, _vue_shared.isArray)(inputProps) ? inputProps : Object.keys(inputProps));
41
+ });
40
42
  const rawAttrs = (0, vue.useAttrs)();
41
43
  const disabled = require_use_form_common_props.useFormDisabled();
42
44
  const ns = require_index.useNamespace("autocomplete");
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete.vue_vue_type_script_setup_true_lang.js","names":["$slots","$attrs"],"sources":["../../../../../../packages/components/autocomplete/src/autocomplete.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"popperRef\"\n :visible=\"suggestionVisible\"\n :placement=\"placement\"\n :fallback-placements=\"['bottom-start', 'top-start']\"\n :popper-class=\"[ns.e('popper'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :teleported=\"teleported\"\n :append-to=\"appendTo\"\n :gpu-acceleration=\"false\"\n pure\n manual-mode\n effect=\"light\"\n trigger=\"click\"\n :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n persistent\n role=\"listbox\"\n @before-show=\"onSuggestionShow\"\n @hide=\"onHide\"\n >\n <div\n ref=\"listboxRef\"\n :class=\"[ns.b(), $attrs.class]\"\n :style=\"styles\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n :aria-expanded=\"suggestionVisible\"\n :aria-owns=\"listboxId\"\n >\n <el-input\n ref=\"inputRef\"\n v-bind=\"mergeProps(passInputProps, $attrs)\"\n :model-value=\"modelValue\"\n :disabled=\"disabled\"\n @input=\"handleInput\"\n @change=\"handleChange\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @clear=\"handleClear\"\n @keydown=\"handleKeydown\"\n @mousedown=\"handleMouseDown\"\n >\n <template v-if=\"$slots.prepend\" #prepend>\n <slot name=\"prepend\" />\n </template>\n <template v-if=\"$slots.append\" #append>\n <slot name=\"append\" />\n </template>\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template v-if=\"$slots.suffix\" #suffix>\n <slot name=\"suffix\" />\n </template>\n </el-input>\n </div>\n <template #content>\n <div\n ref=\"regionRef\"\n :class=\"[ns.b('suggestion'), ns.is('loading', suggestionLoading)]\"\n :style=\"{\n [fitInputWidth ? 'width' : 'minWidth']: dropdownWidth,\n outline: 'none',\n }\"\n role=\"region\"\n >\n <div\n v-if=\"$slots.header\"\n :class=\"ns.be('suggestion', 'header')\"\n @click.stop\n >\n <slot name=\"header\" />\n </div>\n <el-scrollbar\n :id=\"listboxId\"\n tag=\"ul\"\n :wrap-class=\"ns.be('suggestion', 'wrap')\"\n :view-class=\"ns.be('suggestion', 'list')\"\n role=\"listbox\"\n >\n <li v-if=\"suggestionLoading\">\n <slot name=\"loading\">\n <el-icon :class=\"ns.is('loading')\">\n <Loading />\n </el-icon>\n </slot>\n </li>\n <template v-else>\n <li\n v-for=\"(item, index) in suggestions\"\n :id=\"`${listboxId}-item-${index}`\"\n :key=\"index\"\n :class=\"{ highlighted: highlightedIndex === index }\"\n role=\"option\"\n :aria-selected=\"highlightedIndex === index\"\n @click=\"handleSelect(item)\"\n >\n <slot :item=\"item\">{{ item[valueKey] }}</slot>\n </li>\n </template>\n </el-scrollbar>\n <div\n v-if=\"$slots.footer\"\n :class=\"ns.be('suggestion', 'footer')\"\n @click.stop\n >\n <slot name=\"footer\" />\n </div>\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n mergeProps,\n onBeforeUnmount,\n onMounted,\n ref,\n useAttrs as useRawAttrs,\n} from 'vue'\nimport { pick } from 'lodash-unified'\nimport { onClickOutside, useDebounceFn } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { NOOP, getEventCode, isArray, throwError } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput, {\n inputProps,\n inputPropsDefaults,\n} from '@element-plus/components/input'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { autocompleteEmits } from './autocomplete'\n\nimport type { AutocompleteData, AutocompleteProps } from './autocomplete'\nimport type { StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\n\nconst COMPONENT_NAME = 'ElAutocomplete'\ndefineOptions({\n name: COMPONENT_NAME,\n inheritAttrs: false,\n})\n\nconst props = withDefaults(defineProps<AutocompleteProps>(), {\n ...inputPropsDefaults,\n valueKey: 'value',\n modelValue: '',\n debounce: 300,\n placement: 'bottom-start',\n fetchSuggestions: NOOP,\n triggerOnFocus: true,\n loopNavigation: true,\n teleported: true,\n})\nconst emit = defineEmits(autocompleteEmits)\n\nconst passInputProps = computed(() => pick(props, Object.keys(inputProps)))\n\nconst rawAttrs = useRawAttrs()\nconst disabled = useFormDisabled()\nconst ns = useNamespace('autocomplete')\n\nconst inputRef = ref<InputInstance>()\nconst regionRef = ref<HTMLElement>()\nconst popperRef = ref<TooltipInstance>()\nconst listboxRef = ref<HTMLElement>()\n\nlet readonly = false\nlet ignoreFocusEvent = false\nconst suggestions = ref<AutocompleteData>([])\nconst highlightedIndex = ref(-1)\nconst dropdownWidth = ref('')\nconst activated = ref(false)\nconst suggestionDisabled = ref(false)\nconst loading = ref(false)\n\nconst listboxId = useId()\nconst styles = computed(() => rawAttrs.style as StyleValue)\n\nconst suggestionVisible = computed(() => {\n const isValidData = suggestions.value.length > 0\n return (isValidData || loading.value) && activated.value\n})\n\nconst suggestionLoading = computed(() => !props.hideLoading && loading.value)\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n if (inputRef.value) {\n return Array.from<HTMLInputElement>(\n inputRef.value.$el.querySelectorAll('input')\n )\n }\n return []\n})\n\nconst onSuggestionShow = () => {\n if (suggestionVisible.value) {\n dropdownWidth.value = `${inputRef.value!.$el.offsetWidth}px`\n }\n}\n\nconst onHide = () => {\n highlightedIndex.value = -1\n}\n\nconst getData = async (queryString: string) => {\n if (suggestionDisabled.value) return\n\n const cb = (suggestionList: AutocompleteData) => {\n loading.value = false\n if (suggestionDisabled.value) return\n\n if (isArray(suggestionList)) {\n suggestions.value = suggestionList\n highlightedIndex.value = props.highlightFirstItem ? 0 : -1\n } else {\n throwError(COMPONENT_NAME, 'autocomplete suggestions must be an array')\n }\n }\n\n loading.value = true\n if (isArray(props.fetchSuggestions)) {\n cb(props.fetchSuggestions)\n } else {\n const result = await props.fetchSuggestions(queryString, cb)\n if (isArray(result)) cb(result)\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst debouncedGetData = useDebounceFn(getData, debounce)\n\nconst handleInput = (value: string) => {\n const valuePresented = !!value\n\n emit(INPUT_EVENT, value)\n emit(UPDATE_MODEL_EVENT, value)\n\n suggestionDisabled.value = false\n activated.value ||= valuePresented\n\n if (!props.triggerOnFocus && !value) {\n suggestionDisabled.value = true\n suggestions.value = []\n return\n }\n\n debouncedGetData(value)\n}\n\nconst handleMouseDown = (event: MouseEvent) => {\n if (disabled.value) return\n if (\n (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n refInput.value.includes(document.activeElement as HTMLInputElement)\n ) {\n activated.value = true\n }\n}\n\nconst handleChange = (value: string | number) => {\n emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n if (!ignoreFocusEvent) {\n activated.value = true\n emit('focus', evt)\n const queryString = props.modelValue ?? ''\n if (props.triggerOnFocus && !readonly) {\n debouncedGetData(String(queryString))\n }\n } else {\n ignoreFocusEvent = false\n }\n}\n\nconst handleBlur = (evt: FocusEvent) => {\n setTimeout(() => {\n // validate current focus event is inside el-tooltip-content\n // if so, ignore the blur event and the next focus event\n if (popperRef.value?.isFocusInsideContent()) {\n ignoreFocusEvent = true\n return\n }\n activated.value && close()\n emit('blur', evt)\n })\n}\n\nconst handleClear = () => {\n activated.value = false\n emit(UPDATE_MODEL_EVENT, '')\n emit('clear')\n}\n\nconst handleKeyEnter = async () => {\n if (inputRef.value?.isComposing) {\n return\n }\n\n if (\n suggestionVisible.value &&\n highlightedIndex.value >= 0 &&\n highlightedIndex.value < suggestions.value.length\n ) {\n handleSelect(suggestions.value[highlightedIndex.value])\n } else {\n if (props.selectWhenUnmatched) {\n emit('select', { value: props.modelValue })\n suggestions.value = []\n highlightedIndex.value = -1\n }\n activated.value = true\n debouncedGetData(String(props.modelValue))\n }\n}\n\nconst handleKeyEscape = (evt: Event) => {\n if (suggestionVisible.value) {\n evt.preventDefault()\n evt.stopPropagation()\n close()\n }\n}\n\nconst close = () => {\n activated.value = false\n}\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nconst handleSelect = async (item: any) => {\n emit(INPUT_EVENT, item[props.valueKey])\n emit(UPDATE_MODEL_EVENT, item[props.valueKey])\n emit('select', item)\n suggestions.value = []\n highlightedIndex.value = -1\n}\n\nconst highlight = (index: number) => {\n if (!suggestionVisible.value || loading.value) return\n\n if (index < 0) {\n if (!props.loopNavigation) {\n highlightedIndex.value = -1\n return\n }\n index = suggestions.value.length - 1\n }\n\n if (index >= suggestions.value.length) {\n index = props.loopNavigation ? 0 : suggestions.value.length - 1\n }\n const [suggestion, suggestionList] = getSuggestionContext()\n const highlightItem = suggestionList[index]\n const scrollTop = suggestion.scrollTop\n const { offsetTop, scrollHeight } = highlightItem\n\n if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {\n suggestion.scrollTop = offsetTop + scrollHeight - suggestion.clientHeight\n }\n if (offsetTop < scrollTop) {\n suggestion.scrollTop = offsetTop\n }\n highlightedIndex.value = index\n inputRef.value?.ref?.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n}\nconst getSuggestionContext = () => {\n const suggestion = regionRef.value!.querySelector(\n `.${ns.be('suggestion', 'wrap')}`\n )!\n const suggestionList = suggestion.querySelectorAll<HTMLElement>(\n `.${ns.be('suggestion', 'list')} li`\n )\n return [suggestion, suggestionList] as const\n}\n\nconst stopHandle = onClickOutside(listboxRef, (event: FocusEvent) => {\n // Prevent closing if focus is inside popper content\n if (popperRef.value?.isFocusInsideContent()) return\n const hadIgnoredFocus = ignoreFocusEvent\n ignoreFocusEvent = false\n if (!suggestionVisible.value) return\n if (hadIgnoredFocus) {\n handleBlur(new FocusEvent('blur', event))\n } else {\n close()\n }\n})\n\nconst handleKeydown = (e: KeyboardEvent | Event) => {\n const code = getEventCode(e as KeyboardEvent)\n switch (code) {\n case EVENT_CODE.up:\n e.preventDefault()\n highlight(highlightedIndex.value - 1)\n break\n case EVENT_CODE.down:\n e.preventDefault()\n highlight(highlightedIndex.value + 1)\n break\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n e.preventDefault()\n handleKeyEnter()\n break\n case EVENT_CODE.tab:\n close()\n break\n case EVENT_CODE.esc:\n handleKeyEscape(e)\n break\n case EVENT_CODE.home:\n e.preventDefault()\n highlight(0)\n break\n case EVENT_CODE.end:\n e.preventDefault()\n highlight(suggestions.value.length - 1)\n break\n case EVENT_CODE.pageUp:\n e.preventDefault()\n highlight(Math.max(0, highlightedIndex.value - 10))\n break\n case EVENT_CODE.pageDown:\n e.preventDefault()\n highlight(\n Math.min(suggestions.value.length - 1, highlightedIndex.value + 10)\n )\n break\n }\n}\n\nonBeforeUnmount(() => {\n stopHandle?.()\n})\n\nonMounted(() => {\n const inputElement = inputRef.value?.ref\n if (!inputElement) return\n ;[\n { key: 'role', value: 'textbox' },\n { key: 'aria-autocomplete', value: 'list' },\n { key: 'aria-controls', value: listboxId.value },\n {\n key: 'aria-activedescendant',\n value: `${listboxId.value}-item-${highlightedIndex.value}`,\n },\n ].forEach(({ key, value }) => inputElement.setAttribute(key, value))\n // get readonly attr\n readonly = inputElement.hasAttribute('readonly')\n})\n\ndefineExpose({\n /** @description the index of the currently highlighted item */\n highlightedIndex,\n /** @description autocomplete whether activated */\n activated,\n /** @description remote search loading status */\n loading,\n /** @description el-input component instance */\n inputRef,\n /** @description el-tooltip component instance */\n popperRef,\n /** @description fetch suggestions result */\n suggestions,\n /** @description triggers when a suggestion is clicked */\n handleSelect,\n /** @description handle keyboard enter event */\n handleKeyEnter,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n /** @description close suggestion */\n close,\n /** @description highlight an item in a suggestion */\n highlight,\n /** @description loading suggestion list */\n getData,\n})\n</script>\n"],"mappings":"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"}
1
+ {"version":3,"file":"autocomplete.vue_vue_type_script_setup_true_lang.js","names":["$slots","$attrs"],"sources":["../../../../../../packages/components/autocomplete/src/autocomplete.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"popperRef\"\n :visible=\"suggestionVisible\"\n :placement=\"placement\"\n :fallback-placements=\"['bottom-start', 'top-start']\"\n :popper-class=\"[ns.e('popper'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :teleported=\"teleported\"\n :append-to=\"appendTo\"\n :gpu-acceleration=\"false\"\n pure\n manual-mode\n effect=\"light\"\n trigger=\"click\"\n :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n persistent\n role=\"listbox\"\n @before-show=\"onSuggestionShow\"\n @hide=\"onHide\"\n >\n <div\n ref=\"listboxRef\"\n :class=\"[ns.b(), $attrs.class]\"\n :style=\"styles\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n :aria-expanded=\"suggestionVisible\"\n :aria-owns=\"listboxId\"\n >\n <el-input\n ref=\"inputRef\"\n v-bind=\"mergeProps(passInputProps, $attrs)\"\n :model-value=\"modelValue\"\n :disabled=\"disabled\"\n @input=\"handleInput\"\n @change=\"handleChange\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @clear=\"handleClear\"\n @keydown=\"handleKeydown\"\n @mousedown=\"handleMouseDown\"\n >\n <template v-if=\"$slots.prepend\" #prepend>\n <slot name=\"prepend\" />\n </template>\n <template v-if=\"$slots.append\" #append>\n <slot name=\"append\" />\n </template>\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template v-if=\"$slots.suffix\" #suffix>\n <slot name=\"suffix\" />\n </template>\n </el-input>\n </div>\n <template #content>\n <div\n ref=\"regionRef\"\n :class=\"[ns.b('suggestion'), ns.is('loading', suggestionLoading)]\"\n :style=\"{\n [fitInputWidth ? 'width' : 'minWidth']: dropdownWidth,\n outline: 'none',\n }\"\n role=\"region\"\n >\n <div\n v-if=\"$slots.header\"\n :class=\"ns.be('suggestion', 'header')\"\n @click.stop\n >\n <slot name=\"header\" />\n </div>\n <el-scrollbar\n :id=\"listboxId\"\n tag=\"ul\"\n :wrap-class=\"ns.be('suggestion', 'wrap')\"\n :view-class=\"ns.be('suggestion', 'list')\"\n role=\"listbox\"\n >\n <li v-if=\"suggestionLoading\">\n <slot name=\"loading\">\n <el-icon :class=\"ns.is('loading')\">\n <Loading />\n </el-icon>\n </slot>\n </li>\n <template v-else>\n <li\n v-for=\"(item, index) in suggestions\"\n :id=\"`${listboxId}-item-${index}`\"\n :key=\"index\"\n :class=\"{ highlighted: highlightedIndex === index }\"\n role=\"option\"\n :aria-selected=\"highlightedIndex === index\"\n @click=\"handleSelect(item)\"\n >\n <slot :item=\"item\">{{ item[valueKey] }}</slot>\n </li>\n </template>\n </el-scrollbar>\n <div\n v-if=\"$slots.footer\"\n :class=\"ns.be('suggestion', 'footer')\"\n @click.stop\n >\n <slot name=\"footer\" />\n </div>\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script\n lang=\"ts\"\n setup\n generic=\"T extends AutocompleteDataItem = AutocompleteDataItem\"\n>\nimport {\n computed,\n mergeProps,\n onBeforeUnmount,\n onMounted,\n ref,\n useAttrs as useRawAttrs,\n} from 'vue'\nimport { pick } from 'lodash-unified'\nimport { onClickOutside, useDebounceFn } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { NOOP, getEventCode, isArray, throwError } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput, { inputPropsDefaults } from '@element-plus/components/input'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { autocompleteEmits } from './autocomplete'\n\nimport type {\n AutocompleteData,\n AutocompleteDataItem,\n AutocompleteProps,\n} from './autocomplete'\nimport type { Ref, StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\n\nconst COMPONENT_NAME = 'ElAutocomplete'\ndefineOptions({\n name: COMPONENT_NAME,\n inheritAttrs: false,\n})\n\nconst props = withDefaults(defineProps<AutocompleteProps<T>>(), {\n ...inputPropsDefaults,\n valueKey: 'value',\n modelValue: '',\n debounce: 300,\n placement: 'bottom-start',\n fetchSuggestions: NOOP,\n triggerOnFocus: true,\n loopNavigation: true,\n teleported: true,\n})\nconst emit = defineEmits(autocompleteEmits)\nconst passInputProps = computed(() => {\n const inputProps = ElInput.props ?? []\n const keys = isArray(inputProps) ? inputProps : Object.keys(inputProps)\n return pick(props, keys)\n})\n\nconst rawAttrs = useRawAttrs()\nconst disabled = useFormDisabled()\nconst ns = useNamespace('autocomplete')\n\nconst inputRef = ref<InputInstance>()\nconst regionRef = ref<HTMLElement>()\nconst popperRef = ref<TooltipInstance>()\nconst listboxRef = ref<HTMLElement>()\n\nlet readonly = false\nlet ignoreFocusEvent = false\nconst suggestions = ref([]) as Ref<AutocompleteData<T>>\nconst highlightedIndex = ref(-1)\nconst dropdownWidth = ref('')\nconst activated = ref(false)\nconst suggestionDisabled = ref(false)\nconst loading = ref(false)\n\nconst listboxId = useId()\nconst styles = computed(() => rawAttrs.style as StyleValue)\n\nconst suggestionVisible = computed(() => {\n const isValidData = suggestions.value.length > 0\n return (isValidData || loading.value) && activated.value\n})\n\nconst suggestionLoading = computed(() => !props.hideLoading && loading.value)\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n if (inputRef.value) {\n return Array.from<HTMLInputElement>(\n inputRef.value.$el.querySelectorAll('input')\n )\n }\n return []\n})\n\nconst onSuggestionShow = () => {\n if (suggestionVisible.value) {\n dropdownWidth.value = `${inputRef.value!.$el.offsetWidth}px`\n }\n}\n\nconst onHide = () => {\n highlightedIndex.value = -1\n}\n\nconst getData = async (queryString: string) => {\n if (suggestionDisabled.value) return\n\n const cb = (suggestionList: AutocompleteData<T>) => {\n loading.value = false\n if (suggestionDisabled.value) return\n\n if (isArray(suggestionList)) {\n suggestions.value = suggestionList\n highlightedIndex.value = props.highlightFirstItem ? 0 : -1\n } else {\n throwError(COMPONENT_NAME, 'autocomplete suggestions must be an array')\n }\n }\n\n loading.value = true\n if (isArray(props.fetchSuggestions)) {\n cb(props.fetchSuggestions)\n } else {\n const result = await props.fetchSuggestions(queryString, cb)\n if (isArray(result)) cb(result)\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst debouncedGetData = useDebounceFn(getData, debounce)\n\nconst handleInput = (value: string) => {\n const valuePresented = !!value\n\n emit(INPUT_EVENT, value)\n emit(UPDATE_MODEL_EVENT, value)\n\n suggestionDisabled.value = false\n activated.value ||= valuePresented\n\n if (!props.triggerOnFocus && !value) {\n suggestionDisabled.value = true\n suggestions.value = []\n return\n }\n\n debouncedGetData(value)\n}\n\nconst handleMouseDown = (event: MouseEvent) => {\n if (disabled.value) return\n if (\n (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n refInput.value.includes(document.activeElement as HTMLInputElement)\n ) {\n activated.value = true\n }\n}\n\nconst handleChange = (value: string | number) => {\n emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n if (!ignoreFocusEvent) {\n activated.value = true\n emit('focus', evt)\n const queryString = props.modelValue ?? ''\n if (props.triggerOnFocus && !readonly) {\n debouncedGetData(String(queryString))\n }\n } else {\n ignoreFocusEvent = false\n }\n}\n\nconst handleBlur = (evt: FocusEvent) => {\n setTimeout(() => {\n // validate current focus event is inside el-tooltip-content\n // if so, ignore the blur event and the next focus event\n if (popperRef.value?.isFocusInsideContent()) {\n ignoreFocusEvent = true\n return\n }\n activated.value && close()\n emit('blur', evt)\n })\n}\n\nconst handleClear = () => {\n activated.value = false\n emit(UPDATE_MODEL_EVENT, '')\n emit('clear')\n}\n\nconst handleKeyEnter = async () => {\n if (inputRef.value?.isComposing) {\n return\n }\n\n if (\n suggestionVisible.value &&\n highlightedIndex.value >= 0 &&\n highlightedIndex.value < suggestions.value.length\n ) {\n handleSelect(suggestions.value[highlightedIndex.value])\n } else {\n if (props.selectWhenUnmatched) {\n emit('select', { value: props.modelValue })\n suggestions.value = []\n highlightedIndex.value = -1\n }\n activated.value = true\n debouncedGetData(String(props.modelValue))\n }\n}\n\nconst handleKeyEscape = (evt: Event) => {\n if (suggestionVisible.value) {\n evt.preventDefault()\n evt.stopPropagation()\n close()\n }\n}\n\nconst close = () => {\n activated.value = false\n}\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nconst handleSelect = async (item: T) => {\n emit(INPUT_EVENT, item[props.valueKey])\n emit(UPDATE_MODEL_EVENT, item[props.valueKey])\n emit('select', item)\n suggestions.value = []\n highlightedIndex.value = -1\n}\n\nconst highlight = (index: number) => {\n if (!suggestionVisible.value || loading.value) return\n\n if (index < 0) {\n if (!props.loopNavigation) {\n highlightedIndex.value = -1\n return\n }\n index = suggestions.value.length - 1\n }\n\n if (index >= suggestions.value.length) {\n index = props.loopNavigation ? 0 : suggestions.value.length - 1\n }\n const [suggestion, suggestionList] = getSuggestionContext()\n const highlightItem = suggestionList[index]\n const scrollTop = suggestion.scrollTop\n const { offsetTop, scrollHeight } = highlightItem\n\n if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {\n suggestion.scrollTop = offsetTop + scrollHeight - suggestion.clientHeight\n }\n if (offsetTop < scrollTop) {\n suggestion.scrollTop = offsetTop\n }\n highlightedIndex.value = index\n inputRef.value?.ref?.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n}\nconst getSuggestionContext = () => {\n const suggestion = regionRef.value!.querySelector(\n `.${ns.be('suggestion', 'wrap')}`\n )!\n const suggestionList = suggestion.querySelectorAll<HTMLElement>(\n `.${ns.be('suggestion', 'list')} li`\n )\n return [suggestion, suggestionList] as const\n}\n\nconst stopHandle = onClickOutside(listboxRef, (event: FocusEvent) => {\n // Prevent closing if focus is inside popper content\n if (popperRef.value?.isFocusInsideContent()) return\n const hadIgnoredFocus = ignoreFocusEvent\n ignoreFocusEvent = false\n if (!suggestionVisible.value) return\n if (hadIgnoredFocus) {\n handleBlur(new FocusEvent('blur', event))\n } else {\n close()\n }\n})\n\nconst handleKeydown = (e: KeyboardEvent | Event) => {\n const code = getEventCode(e as KeyboardEvent)\n switch (code) {\n case EVENT_CODE.up:\n e.preventDefault()\n highlight(highlightedIndex.value - 1)\n break\n case EVENT_CODE.down:\n e.preventDefault()\n highlight(highlightedIndex.value + 1)\n break\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n e.preventDefault()\n handleKeyEnter()\n break\n case EVENT_CODE.tab:\n close()\n break\n case EVENT_CODE.esc:\n handleKeyEscape(e)\n break\n case EVENT_CODE.home:\n e.preventDefault()\n highlight(0)\n break\n case EVENT_CODE.end:\n e.preventDefault()\n highlight(suggestions.value.length - 1)\n break\n case EVENT_CODE.pageUp:\n e.preventDefault()\n highlight(Math.max(0, highlightedIndex.value - 10))\n break\n case EVENT_CODE.pageDown:\n e.preventDefault()\n highlight(\n Math.min(suggestions.value.length - 1, highlightedIndex.value + 10)\n )\n break\n }\n}\n\nonBeforeUnmount(() => {\n stopHandle?.()\n})\n\nonMounted(() => {\n const inputElement = inputRef.value?.ref\n if (!inputElement) return\n ;[\n { key: 'role', value: 'textbox' },\n { key: 'aria-autocomplete', value: 'list' },\n { key: 'aria-controls', value: listboxId.value },\n {\n key: 'aria-activedescendant',\n value: `${listboxId.value}-item-${highlightedIndex.value}`,\n },\n ].forEach(({ key, value }) => inputElement.setAttribute(key, value))\n // get readonly attr\n readonly = inputElement.hasAttribute('readonly')\n})\n\ndefineExpose({\n /** @description the index of the currently highlighted item */\n highlightedIndex,\n /** @description autocomplete whether activated */\n activated,\n /** @description remote search loading status */\n loading,\n /** @description el-input component instance */\n inputRef,\n /** @description el-tooltip component instance */\n popperRef,\n /** @description fetch suggestions result */\n suggestions,\n /** @description triggers when a suggestion is clicked */\n handleSelect,\n /** @description handle keyboard enter event */\n handleKeyEnter,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n /** @description close suggestion */\n close,\n /** @description highlight an item in a suggestion */\n highlight,\n /** @description loading suggestion list */\n getData,\n})\n</script>\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete2.js","names":[],"sources":["../../../../../../packages/components/autocomplete/src/autocomplete.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"popperRef\"\n :visible=\"suggestionVisible\"\n :placement=\"placement\"\n :fallback-placements=\"['bottom-start', 'top-start']\"\n :popper-class=\"[ns.e('popper'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :teleported=\"teleported\"\n :append-to=\"appendTo\"\n :gpu-acceleration=\"false\"\n pure\n manual-mode\n effect=\"light\"\n trigger=\"click\"\n :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n persistent\n role=\"listbox\"\n @before-show=\"onSuggestionShow\"\n @hide=\"onHide\"\n >\n <div\n ref=\"listboxRef\"\n :class=\"[ns.b(), $attrs.class]\"\n :style=\"styles\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n :aria-expanded=\"suggestionVisible\"\n :aria-owns=\"listboxId\"\n >\n <el-input\n ref=\"inputRef\"\n v-bind=\"mergeProps(passInputProps, $attrs)\"\n :model-value=\"modelValue\"\n :disabled=\"disabled\"\n @input=\"handleInput\"\n @change=\"handleChange\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @clear=\"handleClear\"\n @keydown=\"handleKeydown\"\n @mousedown=\"handleMouseDown\"\n >\n <template v-if=\"$slots.prepend\" #prepend>\n <slot name=\"prepend\" />\n </template>\n <template v-if=\"$slots.append\" #append>\n <slot name=\"append\" />\n </template>\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template v-if=\"$slots.suffix\" #suffix>\n <slot name=\"suffix\" />\n </template>\n </el-input>\n </div>\n <template #content>\n <div\n ref=\"regionRef\"\n :class=\"[ns.b('suggestion'), ns.is('loading', suggestionLoading)]\"\n :style=\"{\n [fitInputWidth ? 'width' : 'minWidth']: dropdownWidth,\n outline: 'none',\n }\"\n role=\"region\"\n >\n <div\n v-if=\"$slots.header\"\n :class=\"ns.be('suggestion', 'header')\"\n @click.stop\n >\n <slot name=\"header\" />\n </div>\n <el-scrollbar\n :id=\"listboxId\"\n tag=\"ul\"\n :wrap-class=\"ns.be('suggestion', 'wrap')\"\n :view-class=\"ns.be('suggestion', 'list')\"\n role=\"listbox\"\n >\n <li v-if=\"suggestionLoading\">\n <slot name=\"loading\">\n <el-icon :class=\"ns.is('loading')\">\n <Loading />\n </el-icon>\n </slot>\n </li>\n <template v-else>\n <li\n v-for=\"(item, index) in suggestions\"\n :id=\"`${listboxId}-item-${index}`\"\n :key=\"index\"\n :class=\"{ highlighted: highlightedIndex === index }\"\n role=\"option\"\n :aria-selected=\"highlightedIndex === index\"\n @click=\"handleSelect(item)\"\n >\n <slot :item=\"item\">{{ item[valueKey] }}</slot>\n </li>\n </template>\n </el-scrollbar>\n <div\n v-if=\"$slots.footer\"\n :class=\"ns.be('suggestion', 'footer')\"\n @click.stop\n >\n <slot name=\"footer\" />\n </div>\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n mergeProps,\n onBeforeUnmount,\n onMounted,\n ref,\n useAttrs as useRawAttrs,\n} from 'vue'\nimport { pick } from 'lodash-unified'\nimport { onClickOutside, useDebounceFn } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { NOOP, getEventCode, isArray, throwError } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput, {\n inputProps,\n inputPropsDefaults,\n} from '@element-plus/components/input'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { autocompleteEmits } from './autocomplete'\n\nimport type { AutocompleteData, AutocompleteProps } from './autocomplete'\nimport type { StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\n\nconst COMPONENT_NAME = 'ElAutocomplete'\ndefineOptions({\n name: COMPONENT_NAME,\n inheritAttrs: false,\n})\n\nconst props = withDefaults(defineProps<AutocompleteProps>(), {\n ...inputPropsDefaults,\n valueKey: 'value',\n modelValue: '',\n debounce: 300,\n placement: 'bottom-start',\n fetchSuggestions: NOOP,\n triggerOnFocus: true,\n loopNavigation: true,\n teleported: true,\n})\nconst emit = defineEmits(autocompleteEmits)\n\nconst passInputProps = computed(() => pick(props, Object.keys(inputProps)))\n\nconst rawAttrs = useRawAttrs()\nconst disabled = useFormDisabled()\nconst ns = useNamespace('autocomplete')\n\nconst inputRef = ref<InputInstance>()\nconst regionRef = ref<HTMLElement>()\nconst popperRef = ref<TooltipInstance>()\nconst listboxRef = ref<HTMLElement>()\n\nlet readonly = false\nlet ignoreFocusEvent = false\nconst suggestions = ref<AutocompleteData>([])\nconst highlightedIndex = ref(-1)\nconst dropdownWidth = ref('')\nconst activated = ref(false)\nconst suggestionDisabled = ref(false)\nconst loading = ref(false)\n\nconst listboxId = useId()\nconst styles = computed(() => rawAttrs.style as StyleValue)\n\nconst suggestionVisible = computed(() => {\n const isValidData = suggestions.value.length > 0\n return (isValidData || loading.value) && activated.value\n})\n\nconst suggestionLoading = computed(() => !props.hideLoading && loading.value)\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n if (inputRef.value) {\n return Array.from<HTMLInputElement>(\n inputRef.value.$el.querySelectorAll('input')\n )\n }\n return []\n})\n\nconst onSuggestionShow = () => {\n if (suggestionVisible.value) {\n dropdownWidth.value = `${inputRef.value!.$el.offsetWidth}px`\n }\n}\n\nconst onHide = () => {\n highlightedIndex.value = -1\n}\n\nconst getData = async (queryString: string) => {\n if (suggestionDisabled.value) return\n\n const cb = (suggestionList: AutocompleteData) => {\n loading.value = false\n if (suggestionDisabled.value) return\n\n if (isArray(suggestionList)) {\n suggestions.value = suggestionList\n highlightedIndex.value = props.highlightFirstItem ? 0 : -1\n } else {\n throwError(COMPONENT_NAME, 'autocomplete suggestions must be an array')\n }\n }\n\n loading.value = true\n if (isArray(props.fetchSuggestions)) {\n cb(props.fetchSuggestions)\n } else {\n const result = await props.fetchSuggestions(queryString, cb)\n if (isArray(result)) cb(result)\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst debouncedGetData = useDebounceFn(getData, debounce)\n\nconst handleInput = (value: string) => {\n const valuePresented = !!value\n\n emit(INPUT_EVENT, value)\n emit(UPDATE_MODEL_EVENT, value)\n\n suggestionDisabled.value = false\n activated.value ||= valuePresented\n\n if (!props.triggerOnFocus && !value) {\n suggestionDisabled.value = true\n suggestions.value = []\n return\n }\n\n debouncedGetData(value)\n}\n\nconst handleMouseDown = (event: MouseEvent) => {\n if (disabled.value) return\n if (\n (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n refInput.value.includes(document.activeElement as HTMLInputElement)\n ) {\n activated.value = true\n }\n}\n\nconst handleChange = (value: string | number) => {\n emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n if (!ignoreFocusEvent) {\n activated.value = true\n emit('focus', evt)\n const queryString = props.modelValue ?? ''\n if (props.triggerOnFocus && !readonly) {\n debouncedGetData(String(queryString))\n }\n } else {\n ignoreFocusEvent = false\n }\n}\n\nconst handleBlur = (evt: FocusEvent) => {\n setTimeout(() => {\n // validate current focus event is inside el-tooltip-content\n // if so, ignore the blur event and the next focus event\n if (popperRef.value?.isFocusInsideContent()) {\n ignoreFocusEvent = true\n return\n }\n activated.value && close()\n emit('blur', evt)\n })\n}\n\nconst handleClear = () => {\n activated.value = false\n emit(UPDATE_MODEL_EVENT, '')\n emit('clear')\n}\n\nconst handleKeyEnter = async () => {\n if (inputRef.value?.isComposing) {\n return\n }\n\n if (\n suggestionVisible.value &&\n highlightedIndex.value >= 0 &&\n highlightedIndex.value < suggestions.value.length\n ) {\n handleSelect(suggestions.value[highlightedIndex.value])\n } else {\n if (props.selectWhenUnmatched) {\n emit('select', { value: props.modelValue })\n suggestions.value = []\n highlightedIndex.value = -1\n }\n activated.value = true\n debouncedGetData(String(props.modelValue))\n }\n}\n\nconst handleKeyEscape = (evt: Event) => {\n if (suggestionVisible.value) {\n evt.preventDefault()\n evt.stopPropagation()\n close()\n }\n}\n\nconst close = () => {\n activated.value = false\n}\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nconst handleSelect = async (item: any) => {\n emit(INPUT_EVENT, item[props.valueKey])\n emit(UPDATE_MODEL_EVENT, item[props.valueKey])\n emit('select', item)\n suggestions.value = []\n highlightedIndex.value = -1\n}\n\nconst highlight = (index: number) => {\n if (!suggestionVisible.value || loading.value) return\n\n if (index < 0) {\n if (!props.loopNavigation) {\n highlightedIndex.value = -1\n return\n }\n index = suggestions.value.length - 1\n }\n\n if (index >= suggestions.value.length) {\n index = props.loopNavigation ? 0 : suggestions.value.length - 1\n }\n const [suggestion, suggestionList] = getSuggestionContext()\n const highlightItem = suggestionList[index]\n const scrollTop = suggestion.scrollTop\n const { offsetTop, scrollHeight } = highlightItem\n\n if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {\n suggestion.scrollTop = offsetTop + scrollHeight - suggestion.clientHeight\n }\n if (offsetTop < scrollTop) {\n suggestion.scrollTop = offsetTop\n }\n highlightedIndex.value = index\n inputRef.value?.ref?.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n}\nconst getSuggestionContext = () => {\n const suggestion = regionRef.value!.querySelector(\n `.${ns.be('suggestion', 'wrap')}`\n )!\n const suggestionList = suggestion.querySelectorAll<HTMLElement>(\n `.${ns.be('suggestion', 'list')} li`\n )\n return [suggestion, suggestionList] as const\n}\n\nconst stopHandle = onClickOutside(listboxRef, (event: FocusEvent) => {\n // Prevent closing if focus is inside popper content\n if (popperRef.value?.isFocusInsideContent()) return\n const hadIgnoredFocus = ignoreFocusEvent\n ignoreFocusEvent = false\n if (!suggestionVisible.value) return\n if (hadIgnoredFocus) {\n handleBlur(new FocusEvent('blur', event))\n } else {\n close()\n }\n})\n\nconst handleKeydown = (e: KeyboardEvent | Event) => {\n const code = getEventCode(e as KeyboardEvent)\n switch (code) {\n case EVENT_CODE.up:\n e.preventDefault()\n highlight(highlightedIndex.value - 1)\n break\n case EVENT_CODE.down:\n e.preventDefault()\n highlight(highlightedIndex.value + 1)\n break\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n e.preventDefault()\n handleKeyEnter()\n break\n case EVENT_CODE.tab:\n close()\n break\n case EVENT_CODE.esc:\n handleKeyEscape(e)\n break\n case EVENT_CODE.home:\n e.preventDefault()\n highlight(0)\n break\n case EVENT_CODE.end:\n e.preventDefault()\n highlight(suggestions.value.length - 1)\n break\n case EVENT_CODE.pageUp:\n e.preventDefault()\n highlight(Math.max(0, highlightedIndex.value - 10))\n break\n case EVENT_CODE.pageDown:\n e.preventDefault()\n highlight(\n Math.min(suggestions.value.length - 1, highlightedIndex.value + 10)\n )\n break\n }\n}\n\nonBeforeUnmount(() => {\n stopHandle?.()\n})\n\nonMounted(() => {\n const inputElement = inputRef.value?.ref\n if (!inputElement) return\n ;[\n { key: 'role', value: 'textbox' },\n { key: 'aria-autocomplete', value: 'list' },\n { key: 'aria-controls', value: listboxId.value },\n {\n key: 'aria-activedescendant',\n value: `${listboxId.value}-item-${highlightedIndex.value}`,\n },\n ].forEach(({ key, value }) => inputElement.setAttribute(key, value))\n // get readonly attr\n readonly = inputElement.hasAttribute('readonly')\n})\n\ndefineExpose({\n /** @description the index of the currently highlighted item */\n highlightedIndex,\n /** @description autocomplete whether activated */\n activated,\n /** @description remote search loading status */\n loading,\n /** @description el-input component instance */\n inputRef,\n /** @description el-tooltip component instance */\n popperRef,\n /** @description fetch suggestions result */\n suggestions,\n /** @description triggers when a suggestion is clicked */\n handleSelect,\n /** @description handle keyboard enter event */\n handleKeyEnter,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n /** @description close suggestion */\n close,\n /** @description highlight an item in a suggestion */\n highlight,\n /** @description loading suggestion list */\n getData,\n})\n</script>\n"],"mappings":""}
1
+ {"version":3,"file":"autocomplete2.js","names":[],"sources":["../../../../../../packages/components/autocomplete/src/autocomplete.vue"],"sourcesContent":["<template>\n <el-tooltip\n ref=\"popperRef\"\n :visible=\"suggestionVisible\"\n :placement=\"placement\"\n :fallback-placements=\"['bottom-start', 'top-start']\"\n :popper-class=\"[ns.e('popper'), popperClass!]\"\n :popper-style=\"popperStyle\"\n :teleported=\"teleported\"\n :append-to=\"appendTo\"\n :gpu-acceleration=\"false\"\n pure\n manual-mode\n effect=\"light\"\n trigger=\"click\"\n :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n persistent\n role=\"listbox\"\n @before-show=\"onSuggestionShow\"\n @hide=\"onHide\"\n >\n <div\n ref=\"listboxRef\"\n :class=\"[ns.b(), $attrs.class]\"\n :style=\"styles\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n :aria-expanded=\"suggestionVisible\"\n :aria-owns=\"listboxId\"\n >\n <el-input\n ref=\"inputRef\"\n v-bind=\"mergeProps(passInputProps, $attrs)\"\n :model-value=\"modelValue\"\n :disabled=\"disabled\"\n @input=\"handleInput\"\n @change=\"handleChange\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @clear=\"handleClear\"\n @keydown=\"handleKeydown\"\n @mousedown=\"handleMouseDown\"\n >\n <template v-if=\"$slots.prepend\" #prepend>\n <slot name=\"prepend\" />\n </template>\n <template v-if=\"$slots.append\" #append>\n <slot name=\"append\" />\n </template>\n <template v-if=\"$slots.prefix\" #prefix>\n <slot name=\"prefix\" />\n </template>\n <template v-if=\"$slots.suffix\" #suffix>\n <slot name=\"suffix\" />\n </template>\n </el-input>\n </div>\n <template #content>\n <div\n ref=\"regionRef\"\n :class=\"[ns.b('suggestion'), ns.is('loading', suggestionLoading)]\"\n :style=\"{\n [fitInputWidth ? 'width' : 'minWidth']: dropdownWidth,\n outline: 'none',\n }\"\n role=\"region\"\n >\n <div\n v-if=\"$slots.header\"\n :class=\"ns.be('suggestion', 'header')\"\n @click.stop\n >\n <slot name=\"header\" />\n </div>\n <el-scrollbar\n :id=\"listboxId\"\n tag=\"ul\"\n :wrap-class=\"ns.be('suggestion', 'wrap')\"\n :view-class=\"ns.be('suggestion', 'list')\"\n role=\"listbox\"\n >\n <li v-if=\"suggestionLoading\">\n <slot name=\"loading\">\n <el-icon :class=\"ns.is('loading')\">\n <Loading />\n </el-icon>\n </slot>\n </li>\n <template v-else>\n <li\n v-for=\"(item, index) in suggestions\"\n :id=\"`${listboxId}-item-${index}`\"\n :key=\"index\"\n :class=\"{ highlighted: highlightedIndex === index }\"\n role=\"option\"\n :aria-selected=\"highlightedIndex === index\"\n @click=\"handleSelect(item)\"\n >\n <slot :item=\"item\">{{ item[valueKey] }}</slot>\n </li>\n </template>\n </el-scrollbar>\n <div\n v-if=\"$slots.footer\"\n :class=\"ns.be('suggestion', 'footer')\"\n @click.stop\n >\n <slot name=\"footer\" />\n </div>\n </div>\n </template>\n </el-tooltip>\n</template>\n\n<script\n lang=\"ts\"\n setup\n generic=\"T extends AutocompleteDataItem = AutocompleteDataItem\"\n>\nimport {\n computed,\n mergeProps,\n onBeforeUnmount,\n onMounted,\n ref,\n useAttrs as useRawAttrs,\n} from 'vue'\nimport { pick } from 'lodash-unified'\nimport { onClickOutside, useDebounceFn } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { NOOP, getEventCode, isArray, throwError } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput, { inputPropsDefaults } from '@element-plus/components/input'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { autocompleteEmits } from './autocomplete'\n\nimport type {\n AutocompleteData,\n AutocompleteDataItem,\n AutocompleteProps,\n} from './autocomplete'\nimport type { Ref, StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\n\nconst COMPONENT_NAME = 'ElAutocomplete'\ndefineOptions({\n name: COMPONENT_NAME,\n inheritAttrs: false,\n})\n\nconst props = withDefaults(defineProps<AutocompleteProps<T>>(), {\n ...inputPropsDefaults,\n valueKey: 'value',\n modelValue: '',\n debounce: 300,\n placement: 'bottom-start',\n fetchSuggestions: NOOP,\n triggerOnFocus: true,\n loopNavigation: true,\n teleported: true,\n})\nconst emit = defineEmits(autocompleteEmits)\nconst passInputProps = computed(() => {\n const inputProps = ElInput.props ?? []\n const keys = isArray(inputProps) ? inputProps : Object.keys(inputProps)\n return pick(props, keys)\n})\n\nconst rawAttrs = useRawAttrs()\nconst disabled = useFormDisabled()\nconst ns = useNamespace('autocomplete')\n\nconst inputRef = ref<InputInstance>()\nconst regionRef = ref<HTMLElement>()\nconst popperRef = ref<TooltipInstance>()\nconst listboxRef = ref<HTMLElement>()\n\nlet readonly = false\nlet ignoreFocusEvent = false\nconst suggestions = ref([]) as Ref<AutocompleteData<T>>\nconst highlightedIndex = ref(-1)\nconst dropdownWidth = ref('')\nconst activated = ref(false)\nconst suggestionDisabled = ref(false)\nconst loading = ref(false)\n\nconst listboxId = useId()\nconst styles = computed(() => rawAttrs.style as StyleValue)\n\nconst suggestionVisible = computed(() => {\n const isValidData = suggestions.value.length > 0\n return (isValidData || loading.value) && activated.value\n})\n\nconst suggestionLoading = computed(() => !props.hideLoading && loading.value)\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n if (inputRef.value) {\n return Array.from<HTMLInputElement>(\n inputRef.value.$el.querySelectorAll('input')\n )\n }\n return []\n})\n\nconst onSuggestionShow = () => {\n if (suggestionVisible.value) {\n dropdownWidth.value = `${inputRef.value!.$el.offsetWidth}px`\n }\n}\n\nconst onHide = () => {\n highlightedIndex.value = -1\n}\n\nconst getData = async (queryString: string) => {\n if (suggestionDisabled.value) return\n\n const cb = (suggestionList: AutocompleteData<T>) => {\n loading.value = false\n if (suggestionDisabled.value) return\n\n if (isArray(suggestionList)) {\n suggestions.value = suggestionList\n highlightedIndex.value = props.highlightFirstItem ? 0 : -1\n } else {\n throwError(COMPONENT_NAME, 'autocomplete suggestions must be an array')\n }\n }\n\n loading.value = true\n if (isArray(props.fetchSuggestions)) {\n cb(props.fetchSuggestions)\n } else {\n const result = await props.fetchSuggestions(queryString, cb)\n if (isArray(result)) cb(result)\n }\n}\n\nconst debounce = computed(() => props.debounce)\nconst debouncedGetData = useDebounceFn(getData, debounce)\n\nconst handleInput = (value: string) => {\n const valuePresented = !!value\n\n emit(INPUT_EVENT, value)\n emit(UPDATE_MODEL_EVENT, value)\n\n suggestionDisabled.value = false\n activated.value ||= valuePresented\n\n if (!props.triggerOnFocus && !value) {\n suggestionDisabled.value = true\n suggestions.value = []\n return\n }\n\n debouncedGetData(value)\n}\n\nconst handleMouseDown = (event: MouseEvent) => {\n if (disabled.value) return\n if (\n (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n refInput.value.includes(document.activeElement as HTMLInputElement)\n ) {\n activated.value = true\n }\n}\n\nconst handleChange = (value: string | number) => {\n emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n if (!ignoreFocusEvent) {\n activated.value = true\n emit('focus', evt)\n const queryString = props.modelValue ?? ''\n if (props.triggerOnFocus && !readonly) {\n debouncedGetData(String(queryString))\n }\n } else {\n ignoreFocusEvent = false\n }\n}\n\nconst handleBlur = (evt: FocusEvent) => {\n setTimeout(() => {\n // validate current focus event is inside el-tooltip-content\n // if so, ignore the blur event and the next focus event\n if (popperRef.value?.isFocusInsideContent()) {\n ignoreFocusEvent = true\n return\n }\n activated.value && close()\n emit('blur', evt)\n })\n}\n\nconst handleClear = () => {\n activated.value = false\n emit(UPDATE_MODEL_EVENT, '')\n emit('clear')\n}\n\nconst handleKeyEnter = async () => {\n if (inputRef.value?.isComposing) {\n return\n }\n\n if (\n suggestionVisible.value &&\n highlightedIndex.value >= 0 &&\n highlightedIndex.value < suggestions.value.length\n ) {\n handleSelect(suggestions.value[highlightedIndex.value])\n } else {\n if (props.selectWhenUnmatched) {\n emit('select', { value: props.modelValue })\n suggestions.value = []\n highlightedIndex.value = -1\n }\n activated.value = true\n debouncedGetData(String(props.modelValue))\n }\n}\n\nconst handleKeyEscape = (evt: Event) => {\n if (suggestionVisible.value) {\n evt.preventDefault()\n evt.stopPropagation()\n close()\n }\n}\n\nconst close = () => {\n activated.value = false\n}\n\nconst focus = () => {\n inputRef.value?.focus()\n}\n\nconst blur = () => {\n inputRef.value?.blur()\n}\n\nconst handleSelect = async (item: T) => {\n emit(INPUT_EVENT, item[props.valueKey])\n emit(UPDATE_MODEL_EVENT, item[props.valueKey])\n emit('select', item)\n suggestions.value = []\n highlightedIndex.value = -1\n}\n\nconst highlight = (index: number) => {\n if (!suggestionVisible.value || loading.value) return\n\n if (index < 0) {\n if (!props.loopNavigation) {\n highlightedIndex.value = -1\n return\n }\n index = suggestions.value.length - 1\n }\n\n if (index >= suggestions.value.length) {\n index = props.loopNavigation ? 0 : suggestions.value.length - 1\n }\n const [suggestion, suggestionList] = getSuggestionContext()\n const highlightItem = suggestionList[index]\n const scrollTop = suggestion.scrollTop\n const { offsetTop, scrollHeight } = highlightItem\n\n if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {\n suggestion.scrollTop = offsetTop + scrollHeight - suggestion.clientHeight\n }\n if (offsetTop < scrollTop) {\n suggestion.scrollTop = offsetTop\n }\n highlightedIndex.value = index\n inputRef.value?.ref?.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n}\nconst getSuggestionContext = () => {\n const suggestion = regionRef.value!.querySelector(\n `.${ns.be('suggestion', 'wrap')}`\n )!\n const suggestionList = suggestion.querySelectorAll<HTMLElement>(\n `.${ns.be('suggestion', 'list')} li`\n )\n return [suggestion, suggestionList] as const\n}\n\nconst stopHandle = onClickOutside(listboxRef, (event: FocusEvent) => {\n // Prevent closing if focus is inside popper content\n if (popperRef.value?.isFocusInsideContent()) return\n const hadIgnoredFocus = ignoreFocusEvent\n ignoreFocusEvent = false\n if (!suggestionVisible.value) return\n if (hadIgnoredFocus) {\n handleBlur(new FocusEvent('blur', event))\n } else {\n close()\n }\n})\n\nconst handleKeydown = (e: KeyboardEvent | Event) => {\n const code = getEventCode(e as KeyboardEvent)\n switch (code) {\n case EVENT_CODE.up:\n e.preventDefault()\n highlight(highlightedIndex.value - 1)\n break\n case EVENT_CODE.down:\n e.preventDefault()\n highlight(highlightedIndex.value + 1)\n break\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n e.preventDefault()\n handleKeyEnter()\n break\n case EVENT_CODE.tab:\n close()\n break\n case EVENT_CODE.esc:\n handleKeyEscape(e)\n break\n case EVENT_CODE.home:\n e.preventDefault()\n highlight(0)\n break\n case EVENT_CODE.end:\n e.preventDefault()\n highlight(suggestions.value.length - 1)\n break\n case EVENT_CODE.pageUp:\n e.preventDefault()\n highlight(Math.max(0, highlightedIndex.value - 10))\n break\n case EVENT_CODE.pageDown:\n e.preventDefault()\n highlight(\n Math.min(suggestions.value.length - 1, highlightedIndex.value + 10)\n )\n break\n }\n}\n\nonBeforeUnmount(() => {\n stopHandle?.()\n})\n\nonMounted(() => {\n const inputElement = inputRef.value?.ref\n if (!inputElement) return\n ;[\n { key: 'role', value: 'textbox' },\n { key: 'aria-autocomplete', value: 'list' },\n { key: 'aria-controls', value: listboxId.value },\n {\n key: 'aria-activedescendant',\n value: `${listboxId.value}-item-${highlightedIndex.value}`,\n },\n ].forEach(({ key, value }) => inputElement.setAttribute(key, value))\n // get readonly attr\n readonly = inputElement.hasAttribute('readonly')\n})\n\ndefineExpose({\n /** @description the index of the currently highlighted item */\n highlightedIndex,\n /** @description autocomplete whether activated */\n activated,\n /** @description remote search loading status */\n loading,\n /** @description el-input component instance */\n inputRef,\n /** @description el-tooltip component instance */\n popperRef,\n /** @description fetch suggestions result */\n suggestions,\n /** @description triggers when a suggestion is clicked */\n handleSelect,\n /** @description handle keyboard enter event */\n handleKeyEnter,\n /** @description focus the input element */\n focus,\n /** @description blur the input element */\n blur,\n /** @description close suggestion */\n close,\n /** @description highlight an item in a suggestion */\n highlight,\n /** @description loading suggestion list */\n getData,\n})\n</script>\n"],"mappings":""}
@@ -11,7 +11,7 @@ declare const avatarGroupProps: {
11
11
  * @description control the size of avatars in this avatar-group
12
12
  */
13
13
  readonly size: {
14
- readonly type: vue.PropType<number | "" | "default" | "large" | "small" | undefined>;
14
+ readonly type: vue.PropType<number | "" | "default" | "small" | "large" | undefined>;
15
15
  readonly values: readonly ["", "default", "small", "large"];
16
16
  readonly validator: (val: unknown) => val is number;
17
17
  };
@@ -9,7 +9,7 @@ import * as vue_jsx_runtime0 from "vue/jsx-runtime";
9
9
  //#region ../../packages/components/avatar/src/avatar-group.d.ts
10
10
  declare const _default: vue.DefineComponent<vue.ExtractPropTypes<{
11
11
  readonly size: {
12
- readonly type: vue.PropType<number | "" | "default" | "large" | "small" | undefined>;
12
+ readonly type: vue.PropType<number | "" | "default" | "small" | "large" | undefined>;
13
13
  readonly values: readonly ["", "default", "small", "large"];
14
14
  readonly validator: (val: unknown) => val is number;
15
15
  };
@@ -146,7 +146,7 @@ declare const _default: vue.DefineComponent<vue.ExtractPropTypes<{
146
146
  };
147
147
  }>, () => vue_jsx_runtime0.JSX.Element, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
148
148
  readonly size: {
149
- readonly type: vue.PropType<number | "" | "default" | "large" | "small" | undefined>;
149
+ readonly type: vue.PropType<number | "" | "default" | "small" | "large" | undefined>;
150
150
  readonly values: readonly ["", "default", "small", "large"];
151
151
  readonly validator: (val: unknown) => val is number;
152
152
  };
@@ -5,6 +5,7 @@ import { ObjectFit } from "../../../utils/typescript.js";
5
5
  import "../../../utils/index.js";
6
6
  import * as vue from "vue";
7
7
  import { ExtractPublicPropTypes } from "vue";
8
+ import * as csstype from "csstype";
8
9
 
9
10
  //#region ../../packages/components/avatar/src/avatar.d.ts
10
11
  interface AvatarProps {
@@ -42,7 +43,7 @@ interface AvatarProps {
42
43
  */
43
44
  declare const avatarProps: {
44
45
  readonly size: {
45
- readonly type: vue.PropType<EpPropMergeType<readonly [NumberConstructor, StringConstructor], "" | "default" | "large" | "small", number>>;
46
+ readonly type: vue.PropType<EpPropMergeType<readonly [NumberConstructor, StringConstructor], "" | "default" | "small" | "large", number>>;
46
47
  readonly required: false;
47
48
  readonly validator: ((val: unknown) => boolean) | undefined;
48
49
  __epPropKey: true;
@@ -62,7 +63,7 @@ declare const avatarProps: {
62
63
  readonly src: EpPropFinalized<StringConstructor, unknown, unknown, "", boolean>;
63
64
  readonly alt: StringConstructor;
64
65
  readonly srcSet: StringConstructor;
65
- readonly fit: EpPropFinalized<(new (...args: any[]) => "fill" | "contain" | "inherit" | "initial" | "revert" | "revert-layer" | "unset" | "none" | "cover" | "scale-down") | (() => ObjectFit) | (((new (...args: any[]) => "fill" | "contain" | "inherit" | "initial" | "revert" | "revert-layer" | "unset" | "none" | "cover" | "scale-down") | (() => ObjectFit)) | null)[], unknown, unknown, "cover", boolean>;
66
+ readonly fit: EpPropFinalized<(new (...args: any[]) => "fill" | "-moz-initial" | "inherit" | "initial" | "revert" | "revert-layer" | "unset" | "none" | "contain" | "cover" | "scale-down") | (() => csstype.Property.ObjectFit | undefined) | (((new (...args: any[]) => "fill" | "-moz-initial" | "inherit" | "initial" | "revert" | "revert-layer" | "unset" | "none" | "contain" | "cover" | "scale-down") | (() => csstype.Property.ObjectFit | undefined)) | null)[], unknown, unknown, "cover", boolean>;
66
67
  };
67
68
  /**
68
69
  * @deprecated Removed after 3.0.0, Use `AvatarProps` instead.
@@ -1,7 +1,6 @@
1
- import { ObjectFit } from "../../../utils/typescript.js";
2
- import "../../../utils/index.js";
3
1
  import { AvatarProps } from "./avatar.js";
4
2
  import * as vue from "vue";
3
+ import * as csstype from "csstype";
5
4
 
6
5
  //#region ../../packages/components/avatar/src/avatar.vue.d.ts
7
6
  declare var __VLS_12: {};
@@ -14,7 +13,7 @@ declare const __VLS_base: vue.DefineComponent<AvatarProps, {}, {}, {}, {}, vue.C
14
13
  onError?: ((evt: Event) => any) | undefined;
15
14
  }>, {
16
15
  src: string;
17
- fit: ObjectFit;
16
+ fit: csstype.Property.ObjectFit;
18
17
  }, {}, {}, {}, string, vue.ComponentProvideOptions, false, {}, any>;
19
18
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
20
19
  declare const _default: typeof __VLS_export;
@@ -11,9 +11,9 @@ declare const __VLS_base: vue.DefineComponent<BacktopProps, {}, {}, {}, {}, vue.
11
11
  }, string, vue.PublicProps, Readonly<BacktopProps> & Readonly<{
12
12
  onClick?: ((evt: MouseEvent) => any) | undefined;
13
13
  }>, {
14
+ target: string;
14
15
  bottom: number;
15
16
  right: number;
16
- target: string;
17
17
  visibilityHeight: number;
18
18
  }, {}, {}, {}, string, vue.ComponentProvideOptions, false, {}, any>;
19
19
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
@@ -14,9 +14,9 @@ type __VLS_Slots = {} & {
14
14
  declare const __VLS_base: vue.DefineComponent<BadgeProps, {
15
15
  /** @description badge content */content: vue.ComputedRef<string>;
16
16
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<BadgeProps> & Readonly<{}>, {
17
+ offset: [number, number];
17
18
  type: "primary" | "success" | "warning" | "info" | "danger";
18
19
  value: string | number;
19
- offset: [number, number];
20
20
  max: number;
21
21
  showZero: boolean;
22
22
  badgeStyle: string | false | vue.CSSProperties | StyleValue[] | null;
@@ -37,6 +37,23 @@ function useButtonCustomStyle(props) {
37
37
  styles[ns.cssVarBlockName("disabled-text-color")] = props.dark ? darken(color, 50) : color.tint(50).toString();
38
38
  styles[ns.cssVarBlockName("disabled-border-color")] = props.dark ? darken(color, 80) : color.tint(80).toString();
39
39
  }
40
+ } else if (props.link || props.text) {
41
+ const hoverColor = props.dark ? darken(color, 30) : color.tint(30).toString();
42
+ styles = ns.cssVarBlock({
43
+ "text-color": buttonColor,
44
+ "hover-text-color": hoverColor,
45
+ "active-text-color": activeBgColor
46
+ });
47
+ if (props.link) {
48
+ styles[ns.cssVarBlockName("hover-link-text-color")] = hoverColor;
49
+ styles[ns.cssVarBlockName("active-color")] = activeBgColor;
50
+ }
51
+ if (_disabled.value) {
52
+ const disabledColor = props.dark ? darken(color, 50) : color.tint(50).toString();
53
+ styles[ns.cssVarBlockName("disabled-bg-color")] = "transparent";
54
+ styles[ns.cssVarBlockName("disabled-text-color")] = disabledColor;
55
+ styles[ns.cssVarBlockName("disabled-border-color")] = "transparent";
56
+ }
40
57
  } else {
41
58
  const hoverBgColor = props.dark ? darken(color, 30) : color.tint(30).toString();
42
59
  const textColor = color.isDark() ? `var(${ns.cssVarName("color-white")})` : `var(${ns.cssVarName("color-black")})`;
@@ -1 +1 @@
1
- {"version":3,"file":"button-custom.js","names":["useFormDisabled","useNamespace","TinyColor"],"sources":["../../../../../../packages/components/button/src/button-custom.ts"],"sourcesContent":["import { computed } from 'vue'\nimport { TinyColor } from '@ctrl/tinycolor'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { ButtonProps } from './button'\n\nexport function darken(color: TinyColor, amount = 20) {\n return color.mix('#141414', amount).toString()\n}\n\nexport function useButtonCustomStyle(props: ButtonProps) {\n const _disabled = useFormDisabled()\n const ns = useNamespace('button')\n\n // calculate hover & active color by custom color\n // only work when custom color\n return computed(() => {\n let styles: Record<string, string> = {}\n\n let buttonColor = props.color\n\n if (buttonColor) {\n const match = (buttonColor as string).match(/var\\((.*?)\\)/)\n if (match) {\n buttonColor = window\n .getComputedStyle(window.document.documentElement)\n .getPropertyValue(match[1])\n }\n const color = new TinyColor(buttonColor)\n const activeBgColor = props.dark\n ? color.tint(20).toString()\n : darken(color, 20)\n\n if (props.plain) {\n styles = ns.cssVarBlock({\n 'bg-color': props.dark\n ? darken(color, 90)\n : color.tint(90).toString(),\n 'text-color': buttonColor,\n 'border-color': props.dark\n ? darken(color, 50)\n : color.tint(50).toString(),\n 'hover-text-color': `var(${ns.cssVarName('color-white')})`,\n 'hover-bg-color': buttonColor,\n 'hover-border-color': buttonColor,\n 'active-bg-color': activeBgColor,\n 'active-text-color': `var(${ns.cssVarName('color-white')})`,\n 'active-border-color': activeBgColor,\n })\n\n if (_disabled.value) {\n styles[ns.cssVarBlockName('disabled-bg-color')] = props.dark\n ? darken(color, 90)\n : color.tint(90).toString()\n styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n ? darken(color, 50)\n : color.tint(50).toString()\n styles[ns.cssVarBlockName('disabled-border-color')] = props.dark\n ? darken(color, 80)\n : color.tint(80).toString()\n }\n } else {\n const hoverBgColor = props.dark\n ? darken(color, 30)\n : color.tint(30).toString()\n const textColor = color.isDark()\n ? `var(${ns.cssVarName('color-white')})`\n : `var(${ns.cssVarName('color-black')})`\n styles = ns.cssVarBlock({\n 'bg-color': buttonColor,\n 'text-color': textColor,\n 'border-color': buttonColor,\n 'hover-bg-color': hoverBgColor,\n 'hover-text-color': textColor,\n 'hover-border-color': hoverBgColor,\n 'active-bg-color': activeBgColor,\n 'active-border-color': activeBgColor,\n })\n\n if (_disabled.value) {\n const disabledButtonColor = props.dark\n ? darken(color, 50)\n : color.tint(50).toString()\n styles[ns.cssVarBlockName('disabled-bg-color')] = disabledButtonColor\n styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n ? 'rgba(255, 255, 255, 0.5)'\n : `var(${ns.cssVarName('color-white')})`\n styles[ns.cssVarBlockName('disabled-border-color')] =\n disabledButtonColor\n }\n }\n }\n\n return styles\n })\n}\n"],"mappings":";;;;;;;;AAOA,SAAgB,OAAO,OAAkB,SAAS,IAAI;AACpD,QAAO,MAAM,IAAI,WAAW,OAAO,CAAC,UAAU;;AAGhD,SAAgB,qBAAqB,OAAoB;CACvD,MAAM,YAAYA,+CAAiB;CACnC,MAAM,KAAKC,2BAAa,SAAS;AAIjC,gCAAsB;EACpB,IAAI,SAAiC,EAAE;EAEvC,IAAI,cAAc,MAAM;AAExB,MAAI,aAAa;GACf,MAAM,QAAS,YAAuB,MAAM,eAAe;AAC3D,OAAI,MACF,eAAc,OACX,iBAAiB,OAAO,SAAS,gBAAgB,CACjD,iBAAiB,MAAM,GAAG;GAE/B,MAAM,QAAQ,IAAIC,0BAAU,YAAY;GACxC,MAAM,gBAAgB,MAAM,OACxB,MAAM,KAAK,GAAG,CAAC,UAAU,GACzB,OAAO,OAAO,GAAG;AAErB,OAAI,MAAM,OAAO;AACf,aAAS,GAAG,YAAY;KACtB,YAAY,MAAM,OACd,OAAO,OAAO,GAAG,GACjB,MAAM,KAAK,GAAG,CAAC,UAAU;KAC7B,cAAc;KACd,gBAAgB,MAAM,OAClB,OAAO,OAAO,GAAG,GACjB,MAAM,KAAK,GAAG,CAAC,UAAU;KAC7B,oBAAoB,OAAO,GAAG,WAAW,cAAc,CAAC;KACxD,kBAAkB;KAClB,sBAAsB;KACtB,mBAAmB;KACnB,qBAAqB,OAAO,GAAG,WAAW,cAAc,CAAC;KACzD,uBAAuB;KACxB,CAAC;AAEF,QAAI,UAAU,OAAO;AACnB,YAAO,GAAG,gBAAgB,oBAAoB,IAAI,MAAM,OACpD,OAAO,OAAO,GAAG,GACjB,MAAM,KAAK,GAAG,CAAC,UAAU;AAC7B,YAAO,GAAG,gBAAgB,sBAAsB,IAAI,MAAM,OACtD,OAAO,OAAO,GAAG,GACjB,MAAM,KAAK,GAAG,CAAC,UAAU;AAC7B,YAAO,GAAG,gBAAgB,wBAAwB,IAAI,MAAM,OACxD,OAAO,OAAO,GAAG,GACjB,MAAM,KAAK,GAAG,CAAC,UAAU;;UAE1B;IACL,MAAM,eAAe,MAAM,OACvB,OAAO,OAAO,GAAG,GACjB,MAAM,KAAK,GAAG,CAAC,UAAU;IAC7B,MAAM,YAAY,MAAM,QAAQ,GAC5B,OAAO,GAAG,WAAW,cAAc,CAAC,KACpC,OAAO,GAAG,WAAW,cAAc,CAAC;AACxC,aAAS,GAAG,YAAY;KACtB,YAAY;KACZ,cAAc;KACd,gBAAgB;KAChB,kBAAkB;KAClB,oBAAoB;KACpB,sBAAsB;KACtB,mBAAmB;KACnB,uBAAuB;KACxB,CAAC;AAEF,QAAI,UAAU,OAAO;KACnB,MAAM,sBAAsB,MAAM,OAC9B,OAAO,OAAO,GAAG,GACjB,MAAM,KAAK,GAAG,CAAC,UAAU;AAC7B,YAAO,GAAG,gBAAgB,oBAAoB,IAAI;AAClD,YAAO,GAAG,gBAAgB,sBAAsB,IAAI,MAAM,OACtD,6BACA,OAAO,GAAG,WAAW,cAAc,CAAC;AACxC,YAAO,GAAG,gBAAgB,wBAAwB,IAChD;;;;AAKR,SAAO;GACP"}
1
+ {"version":3,"file":"button-custom.js","names":["useFormDisabled","useNamespace","TinyColor"],"sources":["../../../../../../packages/components/button/src/button-custom.ts"],"sourcesContent":["import { computed } from 'vue'\nimport { TinyColor } from '@ctrl/tinycolor'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { ButtonProps } from './button'\n\nexport function darken(color: TinyColor, amount = 20) {\n return color.mix('#141414', amount).toString()\n}\n\nexport function useButtonCustomStyle(props: ButtonProps) {\n const _disabled = useFormDisabled()\n const ns = useNamespace('button')\n\n // calculate hover & active color by custom color\n // only work when custom color\n return computed(() => {\n let styles: Record<string, string> = {}\n\n let buttonColor = props.color\n\n if (buttonColor) {\n const match = (buttonColor as string).match(/var\\((.*?)\\)/)\n if (match) {\n buttonColor = window\n .getComputedStyle(window.document.documentElement)\n .getPropertyValue(match[1])\n }\n const color = new TinyColor(buttonColor)\n const activeBgColor = props.dark\n ? color.tint(20).toString()\n : darken(color, 20)\n\n if (props.plain) {\n styles = ns.cssVarBlock({\n 'bg-color': props.dark\n ? darken(color, 90)\n : color.tint(90).toString(),\n 'text-color': buttonColor,\n 'border-color': props.dark\n ? darken(color, 50)\n : color.tint(50).toString(),\n 'hover-text-color': `var(${ns.cssVarName('color-white')})`,\n 'hover-bg-color': buttonColor,\n 'hover-border-color': buttonColor,\n 'active-bg-color': activeBgColor,\n 'active-text-color': `var(${ns.cssVarName('color-white')})`,\n 'active-border-color': activeBgColor,\n })\n\n if (_disabled.value) {\n styles[ns.cssVarBlockName('disabled-bg-color')] = props.dark\n ? darken(color, 90)\n : color.tint(90).toString()\n styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n ? darken(color, 50)\n : color.tint(50).toString()\n styles[ns.cssVarBlockName('disabled-border-color')] = props.dark\n ? darken(color, 80)\n : color.tint(80).toString()\n }\n } else if (props.link || props.text) {\n const hoverColor = props.dark\n ? darken(color, 30)\n : color.tint(30).toString()\n\n styles = ns.cssVarBlock({\n 'text-color': buttonColor,\n 'hover-text-color': hoverColor,\n 'active-text-color': activeBgColor,\n })\n\n if (props.link) {\n styles[ns.cssVarBlockName('hover-link-text-color')] = hoverColor\n styles[ns.cssVarBlockName('active-color')] = activeBgColor\n }\n\n if (_disabled.value) {\n const disabledColor = props.dark\n ? darken(color, 50)\n : color.tint(50).toString()\n styles[ns.cssVarBlockName('disabled-bg-color')] = 'transparent'\n styles[ns.cssVarBlockName('disabled-text-color')] = disabledColor\n styles[ns.cssVarBlockName('disabled-border-color')] = 'transparent'\n }\n } else {\n const hoverBgColor = props.dark\n ? darken(color, 30)\n : color.tint(30).toString()\n const textColor = color.isDark()\n ? `var(${ns.cssVarName('color-white')})`\n : `var(${ns.cssVarName('color-black')})`\n styles = ns.cssVarBlock({\n 'bg-color': buttonColor,\n 'text-color': textColor,\n 'border-color': buttonColor,\n 'hover-bg-color': hoverBgColor,\n 'hover-text-color': textColor,\n 'hover-border-color': hoverBgColor,\n 'active-bg-color': activeBgColor,\n 'active-border-color': activeBgColor,\n })\n\n if (_disabled.value) {\n const disabledButtonColor = props.dark\n ? darken(color, 50)\n : color.tint(50).toString()\n styles[ns.cssVarBlockName('disabled-bg-color')] = disabledButtonColor\n styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n ? 'rgba(255, 255, 255, 0.5)'\n : `var(${ns.cssVarName('color-white')})`\n styles[ns.cssVarBlockName('disabled-border-color')] =\n disabledButtonColor\n }\n }\n }\n\n return styles\n })\n}\n"],"mappings":"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"}
@@ -93,7 +93,7 @@ interface ButtonProps {
93
93
  */
94
94
  declare const buttonProps: {
95
95
  readonly size: {
96
- readonly type: vue.PropType<EpPropMergeType<StringConstructor, "" | "default" | "large" | "small", never>>;
96
+ readonly type: vue.PropType<EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", never>>;
97
97
  readonly required: false;
98
98
  readonly validator: ((val: unknown) => boolean) | undefined;
99
99
  __epPropKey: true;
@@ -14,7 +14,7 @@ type __VLS_Slots = {} & {
14
14
  };
15
15
  declare const __VLS_base: vue.DefineComponent<ButtonProps, {
16
16
  /** @description button html element */ref: vue.Ref<HTMLButtonElement | undefined, HTMLButtonElement | undefined>; /** @description button size */
17
- size: vue.ComputedRef<"" | "default" | "large" | "small">; /** @description button type */
17
+ size: vue.ComputedRef<"" | "default" | "small" | "large">; /** @description button type */
18
18
  type: vue.ComputedRef<"default" | "" | "info" | "primary" | "success" | "warning" | "text" | "danger">; /** @description button disabled */
19
19
  disabled: vue.ComputedRef<boolean>; /** @description whether adding space */
20
20
  shouldAddSpace: vue.ComputedRef<boolean>;
@@ -24,13 +24,13 @@ declare const __VLS_base: vue.DefineComponent<ButtonProps, {
24
24
  onClick?: ((evt: MouseEvent) => any) | undefined;
25
25
  }>, {
26
26
  type: ButtonType;
27
- disabled: boolean;
28
27
  text: boolean;
28
+ disabled: boolean;
29
29
  round: boolean;
30
30
  dashed: boolean;
31
- plain: boolean;
32
31
  nativeType: ButtonNativeType;
33
32
  loadingIcon: IconPropType;
33
+ plain: boolean;
34
34
  autoInsertSpace: boolean;
35
35
  tag: string | vue.Component;
36
36
  }, {}, {}, {}, string, vue.ComponentProvideOptions, false, {}, any>;