@element-plus/nightly 0.0.20240810 → 0.0.20240811

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 (364) hide show
  1. package/dist/index.full.js +53 -24
  2. package/dist/index.full.min.js +15 -15
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +20 -20
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +53 -24
  7. package/dist/locale/af.js +1 -1
  8. package/dist/locale/af.min.js +1 -1
  9. package/dist/locale/af.min.mjs +1 -1
  10. package/dist/locale/af.mjs +1 -1
  11. package/dist/locale/ar-eg.js +1 -1
  12. package/dist/locale/ar-eg.min.js +1 -1
  13. package/dist/locale/ar-eg.min.mjs +1 -1
  14. package/dist/locale/ar-eg.mjs +1 -1
  15. package/dist/locale/ar.js +1 -1
  16. package/dist/locale/ar.min.js +1 -1
  17. package/dist/locale/ar.min.mjs +1 -1
  18. package/dist/locale/ar.mjs +1 -1
  19. package/dist/locale/az.js +1 -1
  20. package/dist/locale/az.min.js +1 -1
  21. package/dist/locale/az.min.mjs +1 -1
  22. package/dist/locale/az.mjs +1 -1
  23. package/dist/locale/bg.js +1 -1
  24. package/dist/locale/bg.min.js +1 -1
  25. package/dist/locale/bg.min.mjs +1 -1
  26. package/dist/locale/bg.mjs +1 -1
  27. package/dist/locale/bn.js +1 -1
  28. package/dist/locale/bn.min.js +1 -1
  29. package/dist/locale/bn.min.mjs +1 -1
  30. package/dist/locale/bn.mjs +1 -1
  31. package/dist/locale/ca.js +1 -1
  32. package/dist/locale/ca.min.js +1 -1
  33. package/dist/locale/ca.min.mjs +1 -1
  34. package/dist/locale/ca.mjs +1 -1
  35. package/dist/locale/ckb.js +1 -1
  36. package/dist/locale/ckb.min.js +1 -1
  37. package/dist/locale/ckb.min.mjs +1 -1
  38. package/dist/locale/ckb.mjs +1 -1
  39. package/dist/locale/cs.js +1 -1
  40. package/dist/locale/cs.min.js +1 -1
  41. package/dist/locale/cs.min.mjs +1 -1
  42. package/dist/locale/cs.mjs +1 -1
  43. package/dist/locale/da.js +1 -1
  44. package/dist/locale/da.min.js +1 -1
  45. package/dist/locale/da.min.mjs +1 -1
  46. package/dist/locale/da.mjs +1 -1
  47. package/dist/locale/de.js +1 -1
  48. package/dist/locale/de.min.js +1 -1
  49. package/dist/locale/de.min.mjs +1 -1
  50. package/dist/locale/de.mjs +1 -1
  51. package/dist/locale/el.js +1 -1
  52. package/dist/locale/el.min.js +1 -1
  53. package/dist/locale/el.min.mjs +1 -1
  54. package/dist/locale/el.mjs +1 -1
  55. package/dist/locale/en.js +1 -1
  56. package/dist/locale/en.min.js +1 -1
  57. package/dist/locale/en.min.mjs +1 -1
  58. package/dist/locale/en.mjs +1 -1
  59. package/dist/locale/eo.js +1 -1
  60. package/dist/locale/eo.min.js +1 -1
  61. package/dist/locale/eo.min.mjs +1 -1
  62. package/dist/locale/eo.mjs +1 -1
  63. package/dist/locale/es.js +1 -1
  64. package/dist/locale/es.min.js +1 -1
  65. package/dist/locale/es.min.mjs +1 -1
  66. package/dist/locale/es.mjs +1 -1
  67. package/dist/locale/et.js +1 -1
  68. package/dist/locale/et.min.js +1 -1
  69. package/dist/locale/et.min.mjs +1 -1
  70. package/dist/locale/et.mjs +1 -1
  71. package/dist/locale/eu.js +1 -1
  72. package/dist/locale/eu.min.js +1 -1
  73. package/dist/locale/eu.min.mjs +1 -1
  74. package/dist/locale/eu.mjs +1 -1
  75. package/dist/locale/fa.js +1 -1
  76. package/dist/locale/fa.min.js +1 -1
  77. package/dist/locale/fa.min.mjs +1 -1
  78. package/dist/locale/fa.mjs +1 -1
  79. package/dist/locale/fi.js +1 -1
  80. package/dist/locale/fi.min.js +1 -1
  81. package/dist/locale/fi.min.mjs +1 -1
  82. package/dist/locale/fi.mjs +1 -1
  83. package/dist/locale/fr.js +1 -1
  84. package/dist/locale/fr.min.js +1 -1
  85. package/dist/locale/fr.min.mjs +1 -1
  86. package/dist/locale/fr.mjs +1 -1
  87. package/dist/locale/he.js +1 -1
  88. package/dist/locale/he.min.js +1 -1
  89. package/dist/locale/he.min.mjs +1 -1
  90. package/dist/locale/he.mjs +1 -1
  91. package/dist/locale/hr.js +1 -1
  92. package/dist/locale/hr.min.js +1 -1
  93. package/dist/locale/hr.min.mjs +1 -1
  94. package/dist/locale/hr.mjs +1 -1
  95. package/dist/locale/hu.js +1 -1
  96. package/dist/locale/hu.min.js +1 -1
  97. package/dist/locale/hu.min.mjs +1 -1
  98. package/dist/locale/hu.mjs +1 -1
  99. package/dist/locale/hy-am.js +1 -1
  100. package/dist/locale/hy-am.min.js +1 -1
  101. package/dist/locale/hy-am.min.mjs +1 -1
  102. package/dist/locale/hy-am.mjs +1 -1
  103. package/dist/locale/id.js +1 -1
  104. package/dist/locale/id.min.js +1 -1
  105. package/dist/locale/id.min.mjs +1 -1
  106. package/dist/locale/id.mjs +1 -1
  107. package/dist/locale/it.js +1 -1
  108. package/dist/locale/it.min.js +1 -1
  109. package/dist/locale/it.min.mjs +1 -1
  110. package/dist/locale/it.mjs +1 -1
  111. package/dist/locale/ja.js +1 -1
  112. package/dist/locale/ja.min.js +1 -1
  113. package/dist/locale/ja.min.mjs +1 -1
  114. package/dist/locale/ja.mjs +1 -1
  115. package/dist/locale/kk.js +1 -1
  116. package/dist/locale/kk.min.js +1 -1
  117. package/dist/locale/kk.min.mjs +1 -1
  118. package/dist/locale/kk.mjs +1 -1
  119. package/dist/locale/km.js +1 -1
  120. package/dist/locale/km.min.js +1 -1
  121. package/dist/locale/km.min.mjs +1 -1
  122. package/dist/locale/km.mjs +1 -1
  123. package/dist/locale/ko.js +1 -1
  124. package/dist/locale/ko.min.js +1 -1
  125. package/dist/locale/ko.min.mjs +1 -1
  126. package/dist/locale/ko.mjs +1 -1
  127. package/dist/locale/ku.js +1 -1
  128. package/dist/locale/ku.min.js +1 -1
  129. package/dist/locale/ku.min.mjs +1 -1
  130. package/dist/locale/ku.mjs +1 -1
  131. package/dist/locale/ky.js +1 -1
  132. package/dist/locale/ky.min.js +1 -1
  133. package/dist/locale/ky.min.mjs +1 -1
  134. package/dist/locale/ky.mjs +1 -1
  135. package/dist/locale/lt.js +1 -1
  136. package/dist/locale/lt.min.js +1 -1
  137. package/dist/locale/lt.min.mjs +1 -1
  138. package/dist/locale/lt.mjs +1 -1
  139. package/dist/locale/lv.js +1 -1
  140. package/dist/locale/lv.min.js +1 -1
  141. package/dist/locale/lv.min.mjs +1 -1
  142. package/dist/locale/lv.mjs +1 -1
  143. package/dist/locale/mg.js +1 -1
  144. package/dist/locale/mg.min.js +1 -1
  145. package/dist/locale/mg.min.mjs +1 -1
  146. package/dist/locale/mg.mjs +1 -1
  147. package/dist/locale/mn.js +1 -1
  148. package/dist/locale/mn.min.js +1 -1
  149. package/dist/locale/mn.min.mjs +1 -1
  150. package/dist/locale/mn.mjs +1 -1
  151. package/dist/locale/nb-no.js +1 -1
  152. package/dist/locale/nb-no.min.js +1 -1
  153. package/dist/locale/nb-no.min.mjs +1 -1
  154. package/dist/locale/nb-no.mjs +1 -1
  155. package/dist/locale/nl.js +1 -1
  156. package/dist/locale/nl.min.js +1 -1
  157. package/dist/locale/nl.min.mjs +1 -1
  158. package/dist/locale/nl.mjs +1 -1
  159. package/dist/locale/pa.js +1 -1
  160. package/dist/locale/pa.min.js +1 -1
  161. package/dist/locale/pa.min.mjs +1 -1
  162. package/dist/locale/pa.mjs +1 -1
  163. package/dist/locale/pl.js +1 -1
  164. package/dist/locale/pl.min.js +1 -1
  165. package/dist/locale/pl.min.mjs +1 -1
  166. package/dist/locale/pl.mjs +1 -1
  167. package/dist/locale/pt-br.js +1 -1
  168. package/dist/locale/pt-br.min.js +1 -1
  169. package/dist/locale/pt-br.min.mjs +1 -1
  170. package/dist/locale/pt-br.mjs +1 -1
  171. package/dist/locale/pt.js +1 -1
  172. package/dist/locale/pt.min.js +1 -1
  173. package/dist/locale/pt.min.mjs +1 -1
  174. package/dist/locale/pt.mjs +1 -1
  175. package/dist/locale/ro.js +1 -1
  176. package/dist/locale/ro.min.js +1 -1
  177. package/dist/locale/ro.min.mjs +1 -1
  178. package/dist/locale/ro.mjs +1 -1
  179. package/dist/locale/ru.js +1 -1
  180. package/dist/locale/ru.min.js +1 -1
  181. package/dist/locale/ru.min.mjs +1 -1
  182. package/dist/locale/ru.mjs +1 -1
  183. package/dist/locale/sk.js +1 -1
  184. package/dist/locale/sk.min.js +1 -1
  185. package/dist/locale/sk.min.mjs +1 -1
  186. package/dist/locale/sk.mjs +1 -1
  187. package/dist/locale/sl.js +1 -1
  188. package/dist/locale/sl.min.js +1 -1
  189. package/dist/locale/sl.min.mjs +1 -1
  190. package/dist/locale/sl.mjs +1 -1
  191. package/dist/locale/sr.js +1 -1
  192. package/dist/locale/sr.min.js +1 -1
  193. package/dist/locale/sr.min.mjs +1 -1
  194. package/dist/locale/sr.mjs +1 -1
  195. package/dist/locale/sv.js +1 -1
  196. package/dist/locale/sv.min.js +1 -1
  197. package/dist/locale/sv.min.mjs +1 -1
  198. package/dist/locale/sv.mjs +1 -1
  199. package/dist/locale/sw.js +1 -1
  200. package/dist/locale/sw.min.js +1 -1
  201. package/dist/locale/sw.min.mjs +1 -1
  202. package/dist/locale/sw.mjs +1 -1
  203. package/dist/locale/ta.js +1 -1
  204. package/dist/locale/ta.min.js +1 -1
  205. package/dist/locale/ta.min.mjs +1 -1
  206. package/dist/locale/ta.mjs +1 -1
  207. package/dist/locale/th.js +1 -1
  208. package/dist/locale/th.min.js +1 -1
  209. package/dist/locale/th.min.mjs +1 -1
  210. package/dist/locale/th.mjs +1 -1
  211. package/dist/locale/tk.js +1 -1
  212. package/dist/locale/tk.min.js +1 -1
  213. package/dist/locale/tk.min.mjs +1 -1
  214. package/dist/locale/tk.mjs +1 -1
  215. package/dist/locale/tr.js +1 -1
  216. package/dist/locale/tr.min.js +1 -1
  217. package/dist/locale/tr.min.mjs +1 -1
  218. package/dist/locale/tr.mjs +1 -1
  219. package/dist/locale/ug-cn.js +1 -1
  220. package/dist/locale/ug-cn.min.js +1 -1
  221. package/dist/locale/ug-cn.min.mjs +1 -1
  222. package/dist/locale/ug-cn.mjs +1 -1
  223. package/dist/locale/uk.js +1 -1
  224. package/dist/locale/uk.min.js +1 -1
  225. package/dist/locale/uk.min.mjs +1 -1
  226. package/dist/locale/uk.mjs +1 -1
  227. package/dist/locale/uz-uz.js +1 -1
  228. package/dist/locale/uz-uz.min.js +1 -1
  229. package/dist/locale/uz-uz.min.mjs +1 -1
  230. package/dist/locale/uz-uz.mjs +1 -1
  231. package/dist/locale/vi.js +1 -1
  232. package/dist/locale/vi.min.js +1 -1
  233. package/dist/locale/vi.min.mjs +1 -1
  234. package/dist/locale/vi.mjs +1 -1
  235. package/dist/locale/zh-cn.js +1 -1
  236. package/dist/locale/zh-cn.min.js +1 -1
  237. package/dist/locale/zh-cn.min.mjs +1 -1
  238. package/dist/locale/zh-cn.mjs +1 -1
  239. package/dist/locale/zh-tw.js +1 -1
  240. package/dist/locale/zh-tw.min.js +1 -1
  241. package/dist/locale/zh-tw.min.mjs +1 -1
  242. package/dist/locale/zh-tw.mjs +1 -1
  243. package/es/components/autocomplete/index.mjs +2 -2
  244. package/es/components/autocomplete/src/autocomplete.mjs +81 -364
  245. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  246. package/es/components/autocomplete/src/autocomplete2.mjs +364 -81
  247. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  248. package/es/components/breadcrumb/index.mjs +2 -2
  249. package/es/components/breadcrumb/src/breadcrumb-item.mjs +9 -57
  250. package/es/components/breadcrumb/src/breadcrumb-item.mjs.map +1 -1
  251. package/es/components/breadcrumb/src/breadcrumb-item2.mjs +57 -9
  252. package/es/components/breadcrumb/src/breadcrumb-item2.mjs.map +1 -1
  253. package/es/components/calendar/index.mjs +2 -2
  254. package/es/components/calendar/src/calendar.mjs +18 -131
  255. package/es/components/calendar/src/calendar.mjs.map +1 -1
  256. package/es/components/calendar/src/calendar2.mjs +131 -18
  257. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  258. package/es/components/collapse/index.mjs +4 -4
  259. package/es/components/collapse/src/collapse-item.mjs +13 -89
  260. package/es/components/collapse/src/collapse-item.mjs.map +1 -1
  261. package/es/components/collapse/src/collapse-item2.mjs +89 -13
  262. package/es/components/collapse/src/collapse-item2.mjs.map +1 -1
  263. package/es/components/collapse/src/collapse.mjs +18 -28
  264. package/es/components/collapse/src/collapse.mjs.map +1 -1
  265. package/es/components/collapse/src/collapse2.mjs +28 -18
  266. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  267. package/es/components/date-picker/src/date-picker-com/basic-date-table.vue.d.ts +2 -2
  268. package/es/components/date-picker/src/date-picker-com/basic-month-table.mjs +3 -9
  269. package/es/components/date-picker/src/date-picker-com/basic-month-table.mjs.map +1 -1
  270. package/es/components/date-picker/src/date-picker-com/basic-month-table.vue.d.ts +2 -2
  271. package/es/components/date-picker/src/date-picker-com/basic-year-table.mjs +3 -1
  272. package/es/components/date-picker/src/date-picker-com/basic-year-table.mjs.map +1 -1
  273. package/es/components/date-picker/src/date-picker-com/basic-year-table.vue.d.ts +2 -2
  274. package/es/components/date-picker/src/date-picker-com/panel-date-pick.mjs +7 -4
  275. package/es/components/date-picker/src/date-picker-com/panel-date-pick.mjs.map +1 -1
  276. package/es/components/date-picker/src/props/basic-date-table.d.ts +1 -1
  277. package/es/components/date-picker/src/props/basic-month-table.d.ts +1 -1
  278. package/es/components/date-picker/src/props/basic-year-table.d.ts +1 -1
  279. package/es/components/date-picker/src/props/shared.d.ts +2 -1
  280. package/es/components/date-picker/src/props/shared.mjs.map +1 -1
  281. package/es/components/date-picker/src/utils.d.ts +4 -0
  282. package/es/components/date-picker/src/utils.mjs +34 -1
  283. package/es/components/date-picker/src/utils.mjs.map +1 -1
  284. package/es/components/index.mjs +7 -7
  285. package/es/components/steps/index.mjs +2 -2
  286. package/es/components/steps/src/item.mjs +19 -191
  287. package/es/components/steps/src/item.mjs.map +1 -1
  288. package/es/components/steps/src/item2.mjs +191 -19
  289. package/es/components/steps/src/item2.mjs.map +1 -1
  290. package/es/components/upload/index.mjs +2 -2
  291. package/es/components/upload/src/upload-content.mjs +1 -1
  292. package/es/components/upload/src/upload-content2.mjs +1 -1
  293. package/es/components/upload/src/upload-list.mjs +1 -1
  294. package/es/components/upload/src/upload.mjs +124 -98
  295. package/es/components/upload/src/upload.mjs.map +1 -1
  296. package/es/components/upload/src/upload2.mjs +98 -124
  297. package/es/components/upload/src/upload2.mjs.map +1 -1
  298. package/es/components/upload/src/use-handlers.mjs +1 -1
  299. package/es/index.mjs +7 -7
  300. package/es/version.d.ts +1 -1
  301. package/es/version.mjs +1 -1
  302. package/es/version.mjs.map +1 -1
  303. package/lib/components/autocomplete/index.js +2 -2
  304. package/lib/components/autocomplete/src/autocomplete.js +81 -363
  305. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  306. package/lib/components/autocomplete/src/autocomplete2.js +363 -81
  307. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  308. package/lib/components/breadcrumb/index.js +2 -2
  309. package/lib/components/breadcrumb/src/breadcrumb-item.js +9 -57
  310. package/lib/components/breadcrumb/src/breadcrumb-item.js.map +1 -1
  311. package/lib/components/breadcrumb/src/breadcrumb-item2.js +57 -9
  312. package/lib/components/breadcrumb/src/breadcrumb-item2.js.map +1 -1
  313. package/lib/components/calendar/index.js +2 -2
  314. package/lib/components/calendar/src/calendar.js +19 -131
  315. package/lib/components/calendar/src/calendar.js.map +1 -1
  316. package/lib/components/calendar/src/calendar2.js +131 -19
  317. package/lib/components/calendar/src/calendar2.js.map +1 -1
  318. package/lib/components/collapse/index.js +4 -4
  319. package/lib/components/collapse/src/collapse-item.js +13 -89
  320. package/lib/components/collapse/src/collapse-item.js.map +1 -1
  321. package/lib/components/collapse/src/collapse-item2.js +89 -13
  322. package/lib/components/collapse/src/collapse-item2.js.map +1 -1
  323. package/lib/components/collapse/src/collapse.js +20 -28
  324. package/lib/components/collapse/src/collapse.js.map +1 -1
  325. package/lib/components/collapse/src/collapse2.js +28 -20
  326. package/lib/components/collapse/src/collapse2.js.map +1 -1
  327. package/lib/components/date-picker/src/date-picker-com/basic-date-table.vue.d.ts +2 -2
  328. package/lib/components/date-picker/src/date-picker-com/basic-month-table.js +4 -10
  329. package/lib/components/date-picker/src/date-picker-com/basic-month-table.js.map +1 -1
  330. package/lib/components/date-picker/src/date-picker-com/basic-month-table.vue.d.ts +2 -2
  331. package/lib/components/date-picker/src/date-picker-com/basic-year-table.js +3 -1
  332. package/lib/components/date-picker/src/date-picker-com/basic-year-table.js.map +1 -1
  333. package/lib/components/date-picker/src/date-picker-com/basic-year-table.vue.d.ts +2 -2
  334. package/lib/components/date-picker/src/date-picker-com/panel-date-pick.js +10 -7
  335. package/lib/components/date-picker/src/date-picker-com/panel-date-pick.js.map +1 -1
  336. package/lib/components/date-picker/src/props/basic-date-table.d.ts +1 -1
  337. package/lib/components/date-picker/src/props/basic-month-table.d.ts +1 -1
  338. package/lib/components/date-picker/src/props/basic-year-table.d.ts +1 -1
  339. package/lib/components/date-picker/src/props/shared.d.ts +2 -1
  340. package/lib/components/date-picker/src/props/shared.js.map +1 -1
  341. package/lib/components/date-picker/src/utils.d.ts +4 -0
  342. package/lib/components/date-picker/src/utils.js +36 -0
  343. package/lib/components/date-picker/src/utils.js.map +1 -1
  344. package/lib/components/index.js +7 -7
  345. package/lib/components/steps/index.js +2 -2
  346. package/lib/components/steps/src/item.js +19 -191
  347. package/lib/components/steps/src/item.js.map +1 -1
  348. package/lib/components/steps/src/item2.js +191 -19
  349. package/lib/components/steps/src/item2.js.map +1 -1
  350. package/lib/components/upload/index.js +2 -2
  351. package/lib/components/upload/src/upload-content.js +1 -1
  352. package/lib/components/upload/src/upload-content2.js +1 -1
  353. package/lib/components/upload/src/upload-list.js +1 -1
  354. package/lib/components/upload/src/upload.js +124 -101
  355. package/lib/components/upload/src/upload.js.map +1 -1
  356. package/lib/components/upload/src/upload2.js +101 -124
  357. package/lib/components/upload/src/upload2.js.map +1 -1
  358. package/lib/components/upload/src/use-handlers.js +1 -1
  359. package/lib/index.js +7 -7
  360. package/lib/version.d.ts +1 -1
  361. package/lib/version.js +1 -1
  362. package/lib/version.js.map +1 -1
  363. package/package.json +2 -2
  364. package/web-types.json +1 -1
@@ -2,91 +2,373 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var shared = require('@vue/shared');
6
- require('../../../utils/index.js');
7
- require('../../tooltip/index.js');
5
+ var vue = require('vue');
6
+ var lodashUnified = require('lodash-unified');
7
+ var core = require('@vueuse/core');
8
+ var iconsVue = require('@element-plus/icons-vue');
8
9
  require('../../../hooks/index.js');
10
+ require('../../../utils/index.js');
9
11
  require('../../../constants/index.js');
10
- var runtime = require('../../../utils/vue/props/runtime.js');
11
- var content = require('../../tooltip/src/content.js');
12
- var index = require('../../../hooks/use-aria/index.js');
12
+ var index$6 = require('../../input/index.js');
13
+ var index$4 = require('../../scrollbar/index.js');
14
+ var index$3 = require('../../tooltip/index.js');
15
+ var index$5 = require('../../icon/index.js');
16
+ require('../../form/index.js');
17
+ var autocomplete = require('./autocomplete.js');
18
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
19
+ var index = require('../../../hooks/use-attrs/index.js');
20
+ var useFormCommonProps = require('../../form/src/hooks/use-form-common-props.js');
21
+ var index$1 = require('../../../hooks/use-namespace/index.js');
22
+ var index$2 = require('../../../hooks/use-id/index.js');
23
+ var shared = require('@vue/shared');
24
+ var error = require('../../../utils/error.js');
13
25
  var event = require('../../../constants/event.js');
14
26
 
15
- const autocompleteProps = runtime.buildProps({
16
- valueKey: {
17
- type: String,
18
- default: "value"
19
- },
20
- modelValue: {
21
- type: [String, Number],
22
- default: ""
23
- },
24
- debounce: {
25
- type: Number,
26
- default: 300
27
- },
28
- placement: {
29
- type: runtime.definePropType(String),
30
- values: [
31
- "top",
32
- "top-start",
33
- "top-end",
34
- "bottom",
35
- "bottom-start",
36
- "bottom-end"
37
- ],
38
- default: "bottom-start"
39
- },
40
- fetchSuggestions: {
41
- type: runtime.definePropType([Function, Array]),
42
- default: shared.NOOP
43
- },
44
- popperClass: {
45
- type: String,
46
- default: ""
47
- },
48
- triggerOnFocus: {
49
- type: Boolean,
50
- default: true
51
- },
52
- selectWhenUnmatched: {
53
- type: Boolean,
54
- default: false
55
- },
56
- hideLoading: {
57
- type: Boolean,
58
- default: false
59
- },
60
- teleported: content.useTooltipContentProps.teleported,
61
- highlightFirstItem: {
62
- type: Boolean,
63
- default: false
64
- },
65
- fitInputWidth: {
66
- type: Boolean,
67
- default: false
68
- },
69
- clearable: {
70
- type: Boolean,
71
- default: false
72
- },
73
- disabled: {
74
- type: Boolean,
75
- default: false
76
- },
77
- name: String,
78
- ...index.useAriaProps(["ariaLabel"])
27
+ const COMPONENT_NAME = "ElAutocomplete";
28
+ const __default__ = vue.defineComponent({
29
+ name: COMPONENT_NAME,
30
+ inheritAttrs: false
31
+ });
32
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
33
+ ...__default__,
34
+ props: autocomplete.autocompleteProps,
35
+ emits: autocomplete.autocompleteEmits,
36
+ setup(__props, { expose, emit }) {
37
+ const props = __props;
38
+ const attrs = index.useAttrs();
39
+ const rawAttrs = vue.useAttrs();
40
+ const disabled = useFormCommonProps.useFormDisabled();
41
+ const ns = index$1.useNamespace("autocomplete");
42
+ const inputRef = vue.ref();
43
+ const regionRef = vue.ref();
44
+ const popperRef = vue.ref();
45
+ const listboxRef = vue.ref();
46
+ let readonly = false;
47
+ let ignoreFocusEvent = false;
48
+ const suggestions = vue.ref([]);
49
+ const highlightedIndex = vue.ref(-1);
50
+ const dropdownWidth = vue.ref("");
51
+ const activated = vue.ref(false);
52
+ const suggestionDisabled = vue.ref(false);
53
+ const loading = vue.ref(false);
54
+ const listboxId = index$2.useId();
55
+ const styles = vue.computed(() => rawAttrs.style);
56
+ const suggestionVisible = vue.computed(() => {
57
+ const isValidData = suggestions.value.length > 0;
58
+ return (isValidData || loading.value) && activated.value;
59
+ });
60
+ const suggestionLoading = vue.computed(() => !props.hideLoading && loading.value);
61
+ const refInput = vue.computed(() => {
62
+ if (inputRef.value) {
63
+ return Array.from(inputRef.value.$el.querySelectorAll("input"));
64
+ }
65
+ return [];
66
+ });
67
+ const onSuggestionShow = () => {
68
+ if (suggestionVisible.value) {
69
+ dropdownWidth.value = `${inputRef.value.$el.offsetWidth}px`;
70
+ }
71
+ };
72
+ const onHide = () => {
73
+ highlightedIndex.value = -1;
74
+ };
75
+ const getData = async (queryString) => {
76
+ if (suggestionDisabled.value)
77
+ return;
78
+ const cb = (suggestionList) => {
79
+ loading.value = false;
80
+ if (suggestionDisabled.value)
81
+ return;
82
+ if (shared.isArray(suggestionList)) {
83
+ suggestions.value = suggestionList;
84
+ highlightedIndex.value = props.highlightFirstItem ? 0 : -1;
85
+ } else {
86
+ error.throwError(COMPONENT_NAME, "autocomplete suggestions must be an array");
87
+ }
88
+ };
89
+ loading.value = true;
90
+ if (shared.isArray(props.fetchSuggestions)) {
91
+ cb(props.fetchSuggestions);
92
+ } else {
93
+ const result = await props.fetchSuggestions(queryString, cb);
94
+ if (shared.isArray(result))
95
+ cb(result);
96
+ }
97
+ };
98
+ const debouncedGetData = lodashUnified.debounce(getData, props.debounce);
99
+ const handleInput = (value) => {
100
+ const valuePresented = !!value;
101
+ emit(event.INPUT_EVENT, value);
102
+ emit(event.UPDATE_MODEL_EVENT, value);
103
+ suggestionDisabled.value = false;
104
+ activated.value || (activated.value = valuePresented);
105
+ if (!props.triggerOnFocus && !value) {
106
+ suggestionDisabled.value = true;
107
+ suggestions.value = [];
108
+ return;
109
+ }
110
+ debouncedGetData(value);
111
+ };
112
+ const handleMouseDown = (event) => {
113
+ var _a;
114
+ if (disabled.value)
115
+ return;
116
+ if (((_a = event.target) == null ? void 0 : _a.tagName) !== "INPUT" || refInput.value.includes(document.activeElement)) {
117
+ activated.value = true;
118
+ }
119
+ };
120
+ const handleChange = (value) => {
121
+ emit(event.CHANGE_EVENT, value);
122
+ };
123
+ const handleFocus = (evt) => {
124
+ if (!ignoreFocusEvent) {
125
+ activated.value = true;
126
+ emit("focus", evt);
127
+ if (props.triggerOnFocus && !readonly) {
128
+ debouncedGetData(String(props.modelValue));
129
+ }
130
+ } else {
131
+ ignoreFocusEvent = false;
132
+ }
133
+ };
134
+ const handleBlur = (evt) => {
135
+ setTimeout(() => {
136
+ var _a;
137
+ if ((_a = popperRef.value) == null ? void 0 : _a.isFocusInsideContent()) {
138
+ ignoreFocusEvent = true;
139
+ return;
140
+ }
141
+ activated.value && close();
142
+ emit("blur", evt);
143
+ });
144
+ };
145
+ const handleClear = () => {
146
+ activated.value = false;
147
+ emit(event.UPDATE_MODEL_EVENT, "");
148
+ emit("clear");
149
+ };
150
+ const handleKeyEnter = async () => {
151
+ if (suggestionVisible.value && highlightedIndex.value >= 0 && highlightedIndex.value < suggestions.value.length) {
152
+ handleSelect(suggestions.value[highlightedIndex.value]);
153
+ } else if (props.selectWhenUnmatched) {
154
+ emit("select", { value: props.modelValue });
155
+ suggestions.value = [];
156
+ highlightedIndex.value = -1;
157
+ }
158
+ };
159
+ const handleKeyEscape = (evt) => {
160
+ if (suggestionVisible.value) {
161
+ evt.preventDefault();
162
+ evt.stopPropagation();
163
+ close();
164
+ }
165
+ };
166
+ const close = () => {
167
+ activated.value = false;
168
+ };
169
+ const focus = () => {
170
+ var _a;
171
+ (_a = inputRef.value) == null ? void 0 : _a.focus();
172
+ };
173
+ const blur = () => {
174
+ var _a;
175
+ (_a = inputRef.value) == null ? void 0 : _a.blur();
176
+ };
177
+ const handleSelect = async (item) => {
178
+ emit(event.INPUT_EVENT, item[props.valueKey]);
179
+ emit(event.UPDATE_MODEL_EVENT, item[props.valueKey]);
180
+ emit("select", item);
181
+ suggestions.value = [];
182
+ highlightedIndex.value = -1;
183
+ };
184
+ const highlight = (index) => {
185
+ if (!suggestionVisible.value || loading.value)
186
+ return;
187
+ if (index < 0) {
188
+ highlightedIndex.value = -1;
189
+ return;
190
+ }
191
+ if (index >= suggestions.value.length) {
192
+ index = suggestions.value.length - 1;
193
+ }
194
+ const suggestion = regionRef.value.querySelector(`.${ns.be("suggestion", "wrap")}`);
195
+ const suggestionList = suggestion.querySelectorAll(`.${ns.be("suggestion", "list")} li`);
196
+ const highlightItem = suggestionList[index];
197
+ const scrollTop = suggestion.scrollTop;
198
+ const { offsetTop, scrollHeight } = highlightItem;
199
+ if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {
200
+ suggestion.scrollTop += scrollHeight;
201
+ }
202
+ if (offsetTop < scrollTop) {
203
+ suggestion.scrollTop -= scrollHeight;
204
+ }
205
+ highlightedIndex.value = index;
206
+ inputRef.value.ref.setAttribute("aria-activedescendant", `${listboxId.value}-item-${highlightedIndex.value}`);
207
+ };
208
+ const stopHandle = core.onClickOutside(listboxRef, () => {
209
+ suggestionVisible.value && close();
210
+ });
211
+ vue.onBeforeUnmount(() => {
212
+ stopHandle == null ? void 0 : stopHandle();
213
+ });
214
+ vue.onMounted(() => {
215
+ ;
216
+ inputRef.value.ref.setAttribute("role", "textbox");
217
+ inputRef.value.ref.setAttribute("aria-autocomplete", "list");
218
+ inputRef.value.ref.setAttribute("aria-controls", "id");
219
+ inputRef.value.ref.setAttribute("aria-activedescendant", `${listboxId.value}-item-${highlightedIndex.value}`);
220
+ readonly = inputRef.value.ref.hasAttribute("readonly");
221
+ });
222
+ expose({
223
+ highlightedIndex,
224
+ activated,
225
+ loading,
226
+ inputRef,
227
+ popperRef,
228
+ suggestions,
229
+ handleSelect,
230
+ handleKeyEnter,
231
+ focus,
232
+ blur,
233
+ close,
234
+ highlight
235
+ });
236
+ return (_ctx, _cache) => {
237
+ return vue.openBlock(), vue.createBlock(vue.unref(index$3.ElTooltip), {
238
+ ref_key: "popperRef",
239
+ ref: popperRef,
240
+ visible: vue.unref(suggestionVisible),
241
+ placement: _ctx.placement,
242
+ "fallback-placements": ["bottom-start", "top-start"],
243
+ "popper-class": [vue.unref(ns).e("popper"), _ctx.popperClass],
244
+ teleported: _ctx.teleported,
245
+ "gpu-acceleration": false,
246
+ pure: "",
247
+ "manual-mode": "",
248
+ effect: "light",
249
+ trigger: "click",
250
+ transition: `${vue.unref(ns).namespace.value}-zoom-in-top`,
251
+ persistent: "",
252
+ role: "listbox",
253
+ onBeforeShow: onSuggestionShow,
254
+ onHide
255
+ }, {
256
+ content: vue.withCtx(() => [
257
+ vue.createElementVNode("div", {
258
+ ref_key: "regionRef",
259
+ ref: regionRef,
260
+ class: vue.normalizeClass([vue.unref(ns).b("suggestion"), vue.unref(ns).is("loading", vue.unref(suggestionLoading))]),
261
+ style: vue.normalizeStyle({
262
+ [_ctx.fitInputWidth ? "width" : "minWidth"]: dropdownWidth.value,
263
+ outline: "none"
264
+ }),
265
+ role: "region"
266
+ }, [
267
+ vue.createVNode(vue.unref(index$4.ElScrollbar), {
268
+ id: vue.unref(listboxId),
269
+ tag: "ul",
270
+ "wrap-class": vue.unref(ns).be("suggestion", "wrap"),
271
+ "view-class": vue.unref(ns).be("suggestion", "list"),
272
+ role: "listbox"
273
+ }, {
274
+ default: vue.withCtx(() => [
275
+ vue.unref(suggestionLoading) ? (vue.openBlock(), vue.createElementBlock("li", { key: 0 }, [
276
+ vue.renderSlot(_ctx.$slots, "loading", {}, () => [
277
+ vue.createVNode(vue.unref(index$5.ElIcon), {
278
+ class: vue.normalizeClass(vue.unref(ns).is("loading"))
279
+ }, {
280
+ default: vue.withCtx(() => [
281
+ vue.createVNode(vue.unref(iconsVue.Loading))
282
+ ]),
283
+ _: 1
284
+ }, 8, ["class"])
285
+ ])
286
+ ])) : (vue.openBlock(true), vue.createElementBlock(vue.Fragment, { key: 1 }, vue.renderList(suggestions.value, (item, index) => {
287
+ return vue.openBlock(), vue.createElementBlock("li", {
288
+ id: `${vue.unref(listboxId)}-item-${index}`,
289
+ key: index,
290
+ class: vue.normalizeClass({ highlighted: highlightedIndex.value === index }),
291
+ role: "option",
292
+ "aria-selected": highlightedIndex.value === index,
293
+ onClick: ($event) => handleSelect(item)
294
+ }, [
295
+ vue.renderSlot(_ctx.$slots, "default", { item }, () => [
296
+ vue.createTextVNode(vue.toDisplayString(item[_ctx.valueKey]), 1)
297
+ ])
298
+ ], 10, ["id", "aria-selected", "onClick"]);
299
+ }), 128))
300
+ ]),
301
+ _: 3
302
+ }, 8, ["id", "wrap-class", "view-class"])
303
+ ], 6)
304
+ ]),
305
+ default: vue.withCtx(() => [
306
+ vue.createElementVNode("div", {
307
+ ref_key: "listboxRef",
308
+ ref: listboxRef,
309
+ class: vue.normalizeClass([vue.unref(ns).b(), _ctx.$attrs.class]),
310
+ style: vue.normalizeStyle(vue.unref(styles)),
311
+ role: "combobox",
312
+ "aria-haspopup": "listbox",
313
+ "aria-expanded": vue.unref(suggestionVisible),
314
+ "aria-owns": vue.unref(listboxId)
315
+ }, [
316
+ vue.createVNode(vue.unref(index$6.ElInput), vue.mergeProps({
317
+ ref_key: "inputRef",
318
+ ref: inputRef
319
+ }, vue.unref(attrs), {
320
+ clearable: _ctx.clearable,
321
+ disabled: vue.unref(disabled),
322
+ name: _ctx.name,
323
+ "model-value": _ctx.modelValue,
324
+ "aria-label": _ctx.ariaLabel,
325
+ onInput: handleInput,
326
+ onChange: handleChange,
327
+ onFocus: handleFocus,
328
+ onBlur: handleBlur,
329
+ onClear: handleClear,
330
+ onKeydown: [
331
+ vue.withKeys(vue.withModifiers(($event) => highlight(highlightedIndex.value - 1), ["prevent"]), ["up"]),
332
+ vue.withKeys(vue.withModifiers(($event) => highlight(highlightedIndex.value + 1), ["prevent"]), ["down"]),
333
+ vue.withKeys(handleKeyEnter, ["enter"]),
334
+ vue.withKeys(close, ["tab"]),
335
+ vue.withKeys(handleKeyEscape, ["esc"])
336
+ ],
337
+ onMousedown: handleMouseDown
338
+ }), vue.createSlots({ _: 2 }, [
339
+ _ctx.$slots.prepend ? {
340
+ name: "prepend",
341
+ fn: vue.withCtx(() => [
342
+ vue.renderSlot(_ctx.$slots, "prepend")
343
+ ])
344
+ } : void 0,
345
+ _ctx.$slots.append ? {
346
+ name: "append",
347
+ fn: vue.withCtx(() => [
348
+ vue.renderSlot(_ctx.$slots, "append")
349
+ ])
350
+ } : void 0,
351
+ _ctx.$slots.prefix ? {
352
+ name: "prefix",
353
+ fn: vue.withCtx(() => [
354
+ vue.renderSlot(_ctx.$slots, "prefix")
355
+ ])
356
+ } : void 0,
357
+ _ctx.$slots.suffix ? {
358
+ name: "suffix",
359
+ fn: vue.withCtx(() => [
360
+ vue.renderSlot(_ctx.$slots, "suffix")
361
+ ])
362
+ } : void 0
363
+ ]), 1040, ["clearable", "disabled", "name", "model-value", "aria-label", "onKeydown"])
364
+ ], 14, ["aria-expanded", "aria-owns"])
365
+ ]),
366
+ _: 3
367
+ }, 8, ["visible", "placement", "popper-class", "teleported", "transition"]);
368
+ };
369
+ }
79
370
  });
80
- const autocompleteEmits = {
81
- [event.UPDATE_MODEL_EVENT]: (value) => shared.isString(value),
82
- [event.INPUT_EVENT]: (value) => shared.isString(value),
83
- [event.CHANGE_EVENT]: (value) => shared.isString(value),
84
- focus: (evt) => evt instanceof FocusEvent,
85
- blur: (evt) => evt instanceof FocusEvent,
86
- clear: () => true,
87
- select: (item) => shared.isObject(item)
88
- };
371
+ var Autocomplete = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "autocomplete.vue"]]);
89
372
 
90
- exports.autocompleteEmits = autocompleteEmits;
91
- exports.autocompleteProps = autocompleteProps;
373
+ exports["default"] = Autocomplete;
92
374
  //# sourceMappingURL=autocomplete2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete2.js","sources":["../../../../../../packages/components/autocomplete/src/autocomplete.ts"],"sourcesContent":["import { NOOP } from '@vue/shared'\nimport {\n buildProps,\n definePropType,\n isObject,\n isString,\n} from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { useAriaProps } from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Autocomplete from './autocomplete.vue'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Awaitable } from '@element-plus/utils'\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 const autocompleteProps = buildProps({\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: {\n type: String,\n default: '',\n },\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: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading: {\n type: Boolean,\n default: false,\n },\n teleported: useTooltipContentProps.teleported,\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to show clear button\n */\n clearable: {\n type: Boolean,\n default: false,\n },\n /**\n * @description whether to disable\n */\n disabled: {\n type: Boolean,\n default: false,\n },\n /**\n * @description same as `name` in native input\n */\n name: String,\n ...useAriaProps(['ariaLabel']),\n} as const)\nexport type AutocompleteProps = ExtractPropTypes<typeof autocompleteProps>\n\nexport const autocompleteEmits = {\n [UPDATE_MODEL_EVENT]: (value: string) => isString(value),\n [INPUT_EVENT]: (value: string) => isString(value),\n [CHANGE_EVENT]: (value: string) => isString(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>\n"],"names":["buildProps","definePropType","NOOP","useTooltipContentProps","useAriaProps","UPDATE_MODEL_EVENT","isString","INPUT_EVENT","CHANGE_EVENT","isObject"],"mappings":";;;;;;;;;;;;;;AAcY,MAAC,iBAAiB,GAAGA,kBAAU,CAAC;AAC5C,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAEC,sBAAc,CAAC,MAAM,CAAC;AAChC,IAAI,MAAM,EAAE;AACZ,MAAM,KAAK;AACX,MAAM,WAAW;AACjB,MAAM,SAAS;AACf,MAAM,QAAQ;AACd,MAAM,cAAc;AACpB,MAAM,YAAY;AAClB,KAAK;AACL,IAAI,OAAO,EAAE,cAAc;AAC3B,GAAG;AACH,EAAE,gBAAgB,EAAE;AACpB,IAAI,IAAI,EAAEA,sBAAc,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC3C,IAAI,OAAO,EAAEC,WAAI;AACjB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,cAAc,EAAE;AAClB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,mBAAmB,EAAE;AACvB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,UAAU,EAAEC,8BAAsB,CAAC,UAAU;AAC/C,EAAE,kBAAkB,EAAE;AACtB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,IAAI,EAAE,MAAM;AACd,EAAE,GAAGC,kBAAY,CAAC,CAAC,WAAW,CAAC,CAAC;AAChC,CAAC,EAAE;AACS,MAAC,iBAAiB,GAAG;AACjC,EAAE,CAACC,wBAAkB,GAAG,CAAC,KAAK,KAAKC,eAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,CAACC,iBAAW,GAAG,CAAC,KAAK,KAAKD,eAAQ,CAAC,KAAK,CAAC;AAC3C,EAAE,CAACE,kBAAY,GAAG,CAAC,KAAK,KAAKF,eAAQ,CAAC,KAAK,CAAC;AAC5C,EAAE,KAAK,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC3C,EAAE,IAAI,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC1C,EAAE,KAAK,EAAE,MAAM,IAAI;AACnB,EAAE,MAAM,EAAE,CAAC,IAAI,KAAKG,eAAQ,CAAC,IAAI,CAAC;AAClC;;;;;"}
1
+ {"version":3,"file":"autocomplete2.js","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 :teleported=\"teleported\"\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=\"attrs\"\n :clearable=\"clearable\"\n :disabled=\"disabled\"\n :name=\"name\"\n :model-value=\"modelValue\"\n :aria-label=\"ariaLabel\"\n @input=\"handleInput\"\n @change=\"handleChange\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @clear=\"handleClear\"\n @keydown.up.prevent=\"highlight(highlightedIndex - 1)\"\n @keydown.down.prevent=\"highlight(highlightedIndex + 1)\"\n @keydown.enter=\"handleKeyEnter\"\n @keydown.tab=\"close\"\n @keydown.esc=\"handleKeyEscape\"\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 <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 </template>\n </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n onBeforeUnmount,\n onMounted,\n ref,\n useAttrs as useRawAttrs,\n} from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { onClickOutside } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useAttrs, useId, useNamespace } from '@element-plus/hooks'\nimport { isArray, throwError } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput 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, autocompleteProps } from './autocomplete'\nimport type { AutocompleteData } from './autocomplete'\n\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 = defineProps(autocompleteProps)\nconst emit = defineEmits(autocompleteEmits)\n\nconst attrs = useAttrs()\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}\nconst debouncedGetData = debounce(getData, props.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) => {\n emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n if (!ignoreFocusEvent) {\n activated.value = true\n emit('focus', evt)\n\n if (props.triggerOnFocus && !readonly) {\n debouncedGetData(String(props.modelValue))\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 (\n suggestionVisible.value &&\n highlightedIndex.value >= 0 &&\n highlightedIndex.value < suggestions.value.length\n ) {\n handleSelect(suggestions.value[highlightedIndex.value])\n } else if (props.selectWhenUnmatched) {\n emit('select', { value: props.modelValue })\n suggestions.value = []\n highlightedIndex.value = -1\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 highlightedIndex.value = -1\n return\n }\n\n if (index >= suggestions.value.length) {\n index = suggestions.value.length - 1\n }\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 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 += scrollHeight\n }\n if (offsetTop < scrollTop) {\n suggestion.scrollTop -= scrollHeight\n }\n highlightedIndex.value = index\n // TODO: use Volar generate dts to fix it.\n ;(inputRef.value as any).ref!.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n}\n\nconst stopHandle = onClickOutside(listboxRef, () => {\n suggestionVisible.value && close()\n})\n\nonBeforeUnmount(() => {\n stopHandle?.()\n})\n\nonMounted(() => {\n // TODO: use Volar generate dts to fix it.\n ;(inputRef.value as any).ref!.setAttribute('role', 'textbox')\n ;(inputRef.value as any).ref!.setAttribute('aria-autocomplete', 'list')\n ;(inputRef.value as any).ref!.setAttribute('aria-controls', 'id')\n ;(inputRef.value as any).ref!.setAttribute(\n 'aria-activedescendant',\n `${listboxId.value}-item-${highlightedIndex.value}`\n )\n // get readonly attr\n readonly = (inputRef.value as any).ref!.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})\n</script>\n"],"names":["useAttrs","useRawAttrs","useFormDisabled","useNamespace","ref","useId","computed","isArray","throwError","debounce","INPUT_EVENT","UPDATE_MODEL_EVENT","CHANGE_EVENT","onClickOutside","onBeforeUnmount","onMounted"],"mappings":"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"}
@@ -4,9 +4,9 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  require('../../utils/index.js');
6
6
  var breadcrumb$1 = require('./src/breadcrumb2.js');
7
- var breadcrumbItem$1 = require('./src/breadcrumb-item.js');
7
+ var breadcrumbItem$1 = require('./src/breadcrumb-item2.js');
8
8
  var breadcrumb = require('./src/breadcrumb.js');
9
- var breadcrumbItem = require('./src/breadcrumb-item2.js');
9
+ var breadcrumbItem = require('./src/breadcrumb-item.js');
10
10
  var constants = require('./src/constants.js');
11
11
  var install = require('../../utils/vue/install.js');
12
12
 
@@ -2,64 +2,16 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var vue = require('vue');
6
- var index$1 = require('../../icon/index.js');
7
- require('../../../hooks/index.js');
8
- var constants = require('./constants.js');
9
- var breadcrumbItem = require('./breadcrumb-item2.js');
10
- var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
11
- var index = require('../../../hooks/use-namespace/index.js');
5
+ require('../../../utils/index.js');
6
+ var runtime = require('../../../utils/vue/props/runtime.js');
12
7
 
13
- const __default__ = vue.defineComponent({
14
- name: "ElBreadcrumbItem"
8
+ const breadcrumbItemProps = runtime.buildProps({
9
+ to: {
10
+ type: runtime.definePropType([String, Object]),
11
+ default: ""
12
+ },
13
+ replace: Boolean
15
14
  });
16
- const _sfc_main = /* @__PURE__ */ vue.defineComponent({
17
- ...__default__,
18
- props: breadcrumbItem.breadcrumbItemProps,
19
- setup(__props) {
20
- const props = __props;
21
- const instance = vue.getCurrentInstance();
22
- const breadcrumbContext = vue.inject(constants.breadcrumbKey, void 0);
23
- const ns = index.useNamespace("breadcrumb");
24
- const router = instance.appContext.config.globalProperties.$router;
25
- const link = vue.ref();
26
- const onClick = () => {
27
- if (!props.to || !router)
28
- return;
29
- props.replace ? router.replace(props.to) : router.push(props.to);
30
- };
31
- return (_ctx, _cache) => {
32
- var _a, _b;
33
- return vue.openBlock(), vue.createElementBlock("span", {
34
- class: vue.normalizeClass(vue.unref(ns).e("item"))
35
- }, [
36
- vue.createElementVNode("span", {
37
- ref_key: "link",
38
- ref: link,
39
- class: vue.normalizeClass([vue.unref(ns).e("inner"), vue.unref(ns).is("link", !!_ctx.to)]),
40
- role: "link",
41
- onClick
42
- }, [
43
- vue.renderSlot(_ctx.$slots, "default")
44
- ], 2),
45
- ((_a = vue.unref(breadcrumbContext)) == null ? void 0 : _a.separatorIcon) ? (vue.openBlock(), vue.createBlock(vue.unref(index$1.ElIcon), {
46
- key: 0,
47
- class: vue.normalizeClass(vue.unref(ns).e("separator"))
48
- }, {
49
- default: vue.withCtx(() => [
50
- (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(vue.unref(breadcrumbContext).separatorIcon)))
51
- ]),
52
- _: 1
53
- }, 8, ["class"])) : (vue.openBlock(), vue.createElementBlock("span", {
54
- key: 1,
55
- class: vue.normalizeClass(vue.unref(ns).e("separator")),
56
- role: "presentation"
57
- }, vue.toDisplayString((_b = vue.unref(breadcrumbContext)) == null ? void 0 : _b.separator), 3))
58
- ], 2);
59
- };
60
- }
61
- });
62
- var BreadcrumbItem = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "breadcrumb-item.vue"]]);
63
15
 
64
- exports["default"] = BreadcrumbItem;
16
+ exports.breadcrumbItemProps = breadcrumbItemProps;
65
17
  //# sourceMappingURL=breadcrumb-item.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"breadcrumb-item.js","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb-item.vue"],"sourcesContent":["<template>\n <span :class=\"ns.e('item')\">\n <span\n ref=\"link\"\n :class=\"[ns.e('inner'), ns.is('link', !!to)]\"\n role=\"link\"\n @click=\"onClick\"\n >\n <slot />\n </span>\n <el-icon v-if=\"breadcrumbContext?.separatorIcon\" :class=\"ns.e('separator')\">\n <component :is=\"breadcrumbContext.separatorIcon\" />\n </el-icon>\n <span v-else :class=\"ns.e('separator')\" role=\"presentation\">\n {{ breadcrumbContext?.separator }}\n </span>\n </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { getCurrentInstance, inject, ref } from 'vue'\nimport ElIcon from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { breadcrumbKey } from './constants'\nimport { breadcrumbItemProps } from './breadcrumb-item'\n\nimport type { Router } from 'vue-router'\n\ndefineOptions({\n name: 'ElBreadcrumbItem',\n})\n\nconst props = defineProps(breadcrumbItemProps)\n\nconst instance = getCurrentInstance()!\nconst breadcrumbContext = inject(breadcrumbKey, undefined)\nconst ns = useNamespace('breadcrumb')\n\nconst router = instance.appContext.config.globalProperties.$router as Router\n\nconst link = ref<HTMLSpanElement>()\n\nconst onClick = () => {\n if (!props.to || !router) return\n props.replace ? router.replace(props.to) : router.push(props.to)\n}\n</script>\n"],"names":["getCurrentInstance","inject","breadcrumbKey","useNamespace","ref"],"mappings":";;;;;;;;;;;;uCA4Bc,CAAA;AAAA,EACZ,IAAM,EAAA,kBAAA;AACR,CAAA,CAAA,CAAA;;;;;;AAIA,IAAA,MAAM,WAAWA,sBAAmB,EAAA,CAAA;AACpC,IAAM,MAAA,iBAAA,GAAoBC,UAAO,CAAAC,uBAAA,EAAe,KAAS,CAAA,CAAA,CAAA;AACzD,IAAM,MAAA,EAAA,GAAKC,mBAAa,YAAY,CAAA,CAAA;AAEpC,IAAA,MAAM,MAAS,GAAA,QAAA,CAAS,UAAW,CAAA,MAAA,CAAO,gBAAiB,CAAA,OAAA,CAAA;AAE3D,IAAA,MAAM,OAAOC,OAAqB,EAAA,CAAA;AAElC,IAAA,MAAM,UAAU,MAAM;AACpB,MAAI,IAAA,CAAC,KAAM,CAAA,EAAA,IAAM,CAAC,MAAA;AAAQ,QAAA,OAAA;AAC1B,MAAM,KAAA,CAAA,OAAA,GAAU,OAAO,OAAQ,CAAA,KAAA,CAAM,EAAE,CAAI,GAAA,MAAA,CAAO,IAAK,CAAA,KAAA,CAAM,EAAE,CAAA,CAAA;AAAA,KACjE,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"breadcrumb-item.js","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb-item.ts"],"sourcesContent":["import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { RouteLocationRaw } from 'vue-router'\n\nexport const breadcrumbItemProps = buildProps({\n /**\n * @description target route of the link, same as `to` of `vue-router`\n */\n to: {\n type: definePropType<RouteLocationRaw>([String, Object]),\n default: '',\n },\n /**\n * @description if `true`, the navigation will not leave a history record\n */\n replace: Boolean,\n} as const)\nexport type BreadcrumbItemProps = ExtractPropTypes<typeof breadcrumbItemProps>\n"],"names":["buildProps","definePropType"],"mappings":";;;;;;;AACY,MAAC,mBAAmB,GAAGA,kBAAU,CAAC;AAC9C,EAAE,EAAE,EAAE;AACN,IAAI,IAAI,EAAEC,sBAAc,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC1C,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,OAAO,EAAE,OAAO;AAClB,CAAC;;;;"}