@element-plus/nightly 0.0.20250119 → 0.0.20250121

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 (538) hide show
  1. package/attributes.json +1 -1
  2. package/dist/index.full.js +7 -4
  3. package/dist/index.full.min.js +4 -4
  4. package/dist/index.full.min.js.map +1 -1
  5. package/dist/index.full.min.mjs +4 -4
  6. package/dist/index.full.min.mjs.map +1 -1
  7. package/dist/index.full.mjs +7 -4
  8. package/dist/locale/af.js +1 -1
  9. package/dist/locale/af.min.js +1 -1
  10. package/dist/locale/af.min.mjs +1 -1
  11. package/dist/locale/af.mjs +1 -1
  12. package/dist/locale/ar-eg.js +1 -1
  13. package/dist/locale/ar-eg.min.js +1 -1
  14. package/dist/locale/ar-eg.min.mjs +1 -1
  15. package/dist/locale/ar-eg.mjs +1 -1
  16. package/dist/locale/ar.js +1 -1
  17. package/dist/locale/ar.min.js +1 -1
  18. package/dist/locale/ar.min.mjs +1 -1
  19. package/dist/locale/ar.mjs +1 -1
  20. package/dist/locale/az.js +1 -1
  21. package/dist/locale/az.min.js +1 -1
  22. package/dist/locale/az.min.mjs +1 -1
  23. package/dist/locale/az.mjs +1 -1
  24. package/dist/locale/bg.js +1 -1
  25. package/dist/locale/bg.min.js +1 -1
  26. package/dist/locale/bg.min.mjs +1 -1
  27. package/dist/locale/bg.mjs +1 -1
  28. package/dist/locale/bn.js +1 -1
  29. package/dist/locale/bn.min.js +1 -1
  30. package/dist/locale/bn.min.mjs +1 -1
  31. package/dist/locale/bn.mjs +1 -1
  32. package/dist/locale/ca.js +1 -1
  33. package/dist/locale/ca.min.js +1 -1
  34. package/dist/locale/ca.min.mjs +1 -1
  35. package/dist/locale/ca.mjs +1 -1
  36. package/dist/locale/ckb.js +1 -1
  37. package/dist/locale/ckb.min.js +1 -1
  38. package/dist/locale/ckb.min.mjs +1 -1
  39. package/dist/locale/ckb.mjs +1 -1
  40. package/dist/locale/cs.js +1 -1
  41. package/dist/locale/cs.min.js +1 -1
  42. package/dist/locale/cs.min.mjs +1 -1
  43. package/dist/locale/cs.mjs +1 -1
  44. package/dist/locale/da.js +1 -1
  45. package/dist/locale/da.min.js +1 -1
  46. package/dist/locale/da.min.mjs +1 -1
  47. package/dist/locale/da.mjs +1 -1
  48. package/dist/locale/de.js +1 -1
  49. package/dist/locale/de.min.js +1 -1
  50. package/dist/locale/de.min.mjs +1 -1
  51. package/dist/locale/de.mjs +1 -1
  52. package/dist/locale/el.js +1 -1
  53. package/dist/locale/el.min.js +1 -1
  54. package/dist/locale/el.min.mjs +1 -1
  55. package/dist/locale/el.mjs +1 -1
  56. package/dist/locale/en.js +1 -1
  57. package/dist/locale/en.min.js +1 -1
  58. package/dist/locale/en.min.mjs +1 -1
  59. package/dist/locale/en.mjs +1 -1
  60. package/dist/locale/eo.js +1 -1
  61. package/dist/locale/eo.min.js +1 -1
  62. package/dist/locale/eo.min.mjs +1 -1
  63. package/dist/locale/eo.mjs +1 -1
  64. package/dist/locale/es.js +1 -1
  65. package/dist/locale/es.min.js +1 -1
  66. package/dist/locale/es.min.mjs +1 -1
  67. package/dist/locale/es.mjs +1 -1
  68. package/dist/locale/et.js +1 -1
  69. package/dist/locale/et.min.js +1 -1
  70. package/dist/locale/et.min.mjs +1 -1
  71. package/dist/locale/et.mjs +1 -1
  72. package/dist/locale/eu.js +1 -1
  73. package/dist/locale/eu.min.js +1 -1
  74. package/dist/locale/eu.min.mjs +1 -1
  75. package/dist/locale/eu.mjs +1 -1
  76. package/dist/locale/fa.js +1 -1
  77. package/dist/locale/fa.min.js +1 -1
  78. package/dist/locale/fa.min.mjs +1 -1
  79. package/dist/locale/fa.mjs +1 -1
  80. package/dist/locale/fi.js +1 -1
  81. package/dist/locale/fi.min.js +1 -1
  82. package/dist/locale/fi.min.mjs +1 -1
  83. package/dist/locale/fi.mjs +1 -1
  84. package/dist/locale/fr.js +1 -1
  85. package/dist/locale/fr.min.js +1 -1
  86. package/dist/locale/fr.min.mjs +1 -1
  87. package/dist/locale/fr.mjs +1 -1
  88. package/dist/locale/he.js +1 -1
  89. package/dist/locale/he.min.js +1 -1
  90. package/dist/locale/he.min.mjs +1 -1
  91. package/dist/locale/he.mjs +1 -1
  92. package/dist/locale/hi.js +1 -1
  93. package/dist/locale/hi.min.js +1 -1
  94. package/dist/locale/hi.min.mjs +1 -1
  95. package/dist/locale/hi.mjs +1 -1
  96. package/dist/locale/hr.js +1 -1
  97. package/dist/locale/hr.min.js +1 -1
  98. package/dist/locale/hr.min.mjs +1 -1
  99. package/dist/locale/hr.mjs +1 -1
  100. package/dist/locale/hu.js +1 -1
  101. package/dist/locale/hu.min.js +1 -1
  102. package/dist/locale/hu.min.mjs +1 -1
  103. package/dist/locale/hu.mjs +1 -1
  104. package/dist/locale/hy-am.js +1 -1
  105. package/dist/locale/hy-am.min.js +1 -1
  106. package/dist/locale/hy-am.min.mjs +1 -1
  107. package/dist/locale/hy-am.mjs +1 -1
  108. package/dist/locale/id.js +1 -1
  109. package/dist/locale/id.min.js +1 -1
  110. package/dist/locale/id.min.mjs +1 -1
  111. package/dist/locale/id.mjs +1 -1
  112. package/dist/locale/it.js +1 -1
  113. package/dist/locale/it.min.js +1 -1
  114. package/dist/locale/it.min.mjs +1 -1
  115. package/dist/locale/it.mjs +1 -1
  116. package/dist/locale/ja.js +1 -1
  117. package/dist/locale/ja.min.js +1 -1
  118. package/dist/locale/ja.min.mjs +1 -1
  119. package/dist/locale/ja.mjs +1 -1
  120. package/dist/locale/kk.js +1 -1
  121. package/dist/locale/kk.min.js +1 -1
  122. package/dist/locale/kk.min.mjs +1 -1
  123. package/dist/locale/kk.mjs +1 -1
  124. package/dist/locale/km.js +1 -1
  125. package/dist/locale/km.min.js +1 -1
  126. package/dist/locale/km.min.mjs +1 -1
  127. package/dist/locale/km.mjs +1 -1
  128. package/dist/locale/ko.js +1 -1
  129. package/dist/locale/ko.min.js +1 -1
  130. package/dist/locale/ko.min.mjs +1 -1
  131. package/dist/locale/ko.mjs +1 -1
  132. package/dist/locale/ku.js +1 -1
  133. package/dist/locale/ku.min.js +1 -1
  134. package/dist/locale/ku.min.mjs +1 -1
  135. package/dist/locale/ku.mjs +1 -1
  136. package/dist/locale/ky.js +1 -1
  137. package/dist/locale/ky.min.js +1 -1
  138. package/dist/locale/ky.min.mjs +1 -1
  139. package/dist/locale/ky.mjs +1 -1
  140. package/dist/locale/lt.js +1 -1
  141. package/dist/locale/lt.min.js +1 -1
  142. package/dist/locale/lt.min.mjs +1 -1
  143. package/dist/locale/lt.mjs +1 -1
  144. package/dist/locale/lv.js +1 -1
  145. package/dist/locale/lv.min.js +1 -1
  146. package/dist/locale/lv.min.mjs +1 -1
  147. package/dist/locale/lv.mjs +1 -1
  148. package/dist/locale/mg.js +1 -1
  149. package/dist/locale/mg.min.js +1 -1
  150. package/dist/locale/mg.min.mjs +1 -1
  151. package/dist/locale/mg.mjs +1 -1
  152. package/dist/locale/mn.js +1 -1
  153. package/dist/locale/mn.min.js +1 -1
  154. package/dist/locale/mn.min.mjs +1 -1
  155. package/dist/locale/mn.mjs +1 -1
  156. package/dist/locale/ms.js +1 -1
  157. package/dist/locale/ms.min.js +1 -1
  158. package/dist/locale/ms.min.mjs +1 -1
  159. package/dist/locale/ms.mjs +1 -1
  160. package/dist/locale/my.js +1 -1
  161. package/dist/locale/my.min.js +1 -1
  162. package/dist/locale/my.min.mjs +1 -1
  163. package/dist/locale/my.mjs +1 -1
  164. package/dist/locale/nb-no.js +1 -1
  165. package/dist/locale/nb-no.min.js +1 -1
  166. package/dist/locale/nb-no.min.mjs +1 -1
  167. package/dist/locale/nb-no.mjs +1 -1
  168. package/dist/locale/nl.js +1 -1
  169. package/dist/locale/nl.min.js +1 -1
  170. package/dist/locale/nl.min.mjs +1 -1
  171. package/dist/locale/nl.mjs +1 -1
  172. package/dist/locale/no.js +1 -1
  173. package/dist/locale/no.min.js +1 -1
  174. package/dist/locale/no.min.mjs +1 -1
  175. package/dist/locale/no.mjs +1 -1
  176. package/dist/locale/pa.js +1 -1
  177. package/dist/locale/pa.min.js +1 -1
  178. package/dist/locale/pa.min.mjs +1 -1
  179. package/dist/locale/pa.mjs +1 -1
  180. package/dist/locale/pl.js +1 -1
  181. package/dist/locale/pl.min.js +1 -1
  182. package/dist/locale/pl.min.mjs +1 -1
  183. package/dist/locale/pl.mjs +1 -1
  184. package/dist/locale/pt-br.js +1 -1
  185. package/dist/locale/pt-br.min.js +1 -1
  186. package/dist/locale/pt-br.min.mjs +1 -1
  187. package/dist/locale/pt-br.mjs +1 -1
  188. package/dist/locale/pt.js +1 -1
  189. package/dist/locale/pt.min.js +1 -1
  190. package/dist/locale/pt.min.mjs +1 -1
  191. package/dist/locale/pt.mjs +1 -1
  192. package/dist/locale/ro.js +1 -1
  193. package/dist/locale/ro.min.js +1 -1
  194. package/dist/locale/ro.min.mjs +1 -1
  195. package/dist/locale/ro.mjs +1 -1
  196. package/dist/locale/ru.js +1 -1
  197. package/dist/locale/ru.min.js +1 -1
  198. package/dist/locale/ru.min.mjs +1 -1
  199. package/dist/locale/ru.mjs +1 -1
  200. package/dist/locale/sk.js +1 -1
  201. package/dist/locale/sk.min.js +1 -1
  202. package/dist/locale/sk.min.mjs +1 -1
  203. package/dist/locale/sk.mjs +1 -1
  204. package/dist/locale/sl.js +1 -1
  205. package/dist/locale/sl.min.js +1 -1
  206. package/dist/locale/sl.min.mjs +1 -1
  207. package/dist/locale/sl.mjs +1 -1
  208. package/dist/locale/sr.js +1 -1
  209. package/dist/locale/sr.min.js +1 -1
  210. package/dist/locale/sr.min.mjs +1 -1
  211. package/dist/locale/sr.mjs +1 -1
  212. package/dist/locale/sv.js +1 -1
  213. package/dist/locale/sv.min.js +1 -1
  214. package/dist/locale/sv.min.mjs +1 -1
  215. package/dist/locale/sv.mjs +1 -1
  216. package/dist/locale/sw.js +1 -1
  217. package/dist/locale/sw.min.js +1 -1
  218. package/dist/locale/sw.min.mjs +1 -1
  219. package/dist/locale/sw.mjs +1 -1
  220. package/dist/locale/ta.js +1 -1
  221. package/dist/locale/ta.min.js +1 -1
  222. package/dist/locale/ta.min.mjs +1 -1
  223. package/dist/locale/ta.mjs +1 -1
  224. package/dist/locale/te.js +1 -1
  225. package/dist/locale/te.min.js +1 -1
  226. package/dist/locale/te.min.mjs +1 -1
  227. package/dist/locale/te.mjs +1 -1
  228. package/dist/locale/th.js +1 -1
  229. package/dist/locale/th.min.js +1 -1
  230. package/dist/locale/th.min.mjs +1 -1
  231. package/dist/locale/th.mjs +1 -1
  232. package/dist/locale/tk.js +1 -1
  233. package/dist/locale/tk.min.js +1 -1
  234. package/dist/locale/tk.min.mjs +1 -1
  235. package/dist/locale/tk.mjs +1 -1
  236. package/dist/locale/tr.js +1 -1
  237. package/dist/locale/tr.min.js +1 -1
  238. package/dist/locale/tr.min.mjs +1 -1
  239. package/dist/locale/tr.mjs +1 -1
  240. package/dist/locale/ug-cn.js +1 -1
  241. package/dist/locale/ug-cn.min.js +1 -1
  242. package/dist/locale/ug-cn.min.mjs +1 -1
  243. package/dist/locale/ug-cn.mjs +1 -1
  244. package/dist/locale/uk.js +1 -1
  245. package/dist/locale/uk.min.js +1 -1
  246. package/dist/locale/uk.min.mjs +1 -1
  247. package/dist/locale/uk.mjs +1 -1
  248. package/dist/locale/uz-uz.js +1 -1
  249. package/dist/locale/uz-uz.min.js +1 -1
  250. package/dist/locale/uz-uz.min.mjs +1 -1
  251. package/dist/locale/uz-uz.mjs +1 -1
  252. package/dist/locale/vi.js +1 -1
  253. package/dist/locale/vi.min.js +1 -1
  254. package/dist/locale/vi.min.mjs +1 -1
  255. package/dist/locale/vi.mjs +1 -1
  256. package/dist/locale/zh-cn.js +1 -1
  257. package/dist/locale/zh-cn.min.js +1 -1
  258. package/dist/locale/zh-cn.min.mjs +1 -1
  259. package/dist/locale/zh-cn.mjs +1 -1
  260. package/dist/locale/zh-hk.js +1 -1
  261. package/dist/locale/zh-hk.min.js +1 -1
  262. package/dist/locale/zh-hk.min.mjs +1 -1
  263. package/dist/locale/zh-hk.mjs +1 -1
  264. package/dist/locale/zh-mo.js +1 -1
  265. package/dist/locale/zh-mo.min.js +1 -1
  266. package/dist/locale/zh-mo.min.mjs +1 -1
  267. package/dist/locale/zh-mo.mjs +1 -1
  268. package/dist/locale/zh-tw.js +1 -1
  269. package/dist/locale/zh-tw.min.js +1 -1
  270. package/dist/locale/zh-tw.min.mjs +1 -1
  271. package/dist/locale/zh-tw.mjs +1 -1
  272. package/es/components/affix/index.mjs +2 -2
  273. package/es/components/affix/src/affix.mjs +25 -118
  274. package/es/components/affix/src/affix.mjs.map +1 -1
  275. package/es/components/affix/src/affix2.mjs +118 -25
  276. package/es/components/affix/src/affix2.mjs.map +1 -1
  277. package/es/components/anchor/index.mjs +2 -2
  278. package/es/components/anchor/src/anchor.mjs +192 -42
  279. package/es/components/anchor/src/anchor.mjs.map +1 -1
  280. package/es/components/anchor/src/anchor2.mjs +42 -192
  281. package/es/components/anchor/src/anchor2.mjs.map +1 -1
  282. package/es/components/autocomplete/src/autocomplete2.mjs +3 -0
  283. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  284. package/es/components/badge/index.mjs +2 -2
  285. package/es/components/badge/src/badge.mjs +71 -32
  286. package/es/components/badge/src/badge.mjs.map +1 -1
  287. package/es/components/badge/src/badge2.mjs +32 -71
  288. package/es/components/badge/src/badge2.mjs.map +1 -1
  289. package/es/components/calendar/src/calendar2.mjs +1 -1
  290. package/es/components/calendar/src/date-table.mjs +89 -31
  291. package/es/components/calendar/src/date-table.mjs.map +1 -1
  292. package/es/components/calendar/src/date-table2.mjs +31 -89
  293. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  294. package/es/components/calendar/src/use-date-table.mjs +1 -1
  295. package/es/components/card/index.mjs +2 -2
  296. package/es/components/card/src/card.mjs +42 -20
  297. package/es/components/card/src/card.mjs.map +1 -1
  298. package/es/components/card/src/card2.mjs +20 -42
  299. package/es/components/card/src/card2.mjs.map +1 -1
  300. package/es/components/carousel/index.mjs +4 -4
  301. package/es/components/carousel/src/carousel-item.mjs +69 -7
  302. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  303. package/es/components/carousel/src/carousel-item2.mjs +7 -69
  304. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  305. package/es/components/carousel/src/carousel.mjs +204 -61
  306. package/es/components/carousel/src/carousel.mjs.map +1 -1
  307. package/es/components/carousel/src/carousel2.mjs +61 -204
  308. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  309. package/es/components/cascader/src/cascader.mjs +1 -1
  310. package/es/components/check-tag/index.mjs +2 -2
  311. package/es/components/check-tag/src/check-tag.mjs +14 -38
  312. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  313. package/es/components/check-tag/src/check-tag2.mjs +38 -14
  314. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  315. package/es/components/collapse/index.mjs +2 -2
  316. package/es/components/collapse/src/collapse-item.mjs +18 -90
  317. package/es/components/collapse/src/collapse-item.mjs.map +1 -1
  318. package/es/components/collapse/src/collapse-item2.mjs +90 -18
  319. package/es/components/collapse/src/collapse-item2.mjs.map +1 -1
  320. package/es/components/collection/index.mjs +1 -1
  321. package/es/components/collection/src/collection.mjs +10 -62
  322. package/es/components/collection/src/collection.mjs.map +1 -1
  323. package/es/components/collection/src/collection2.mjs +62 -10
  324. package/es/components/collection/src/collection2.mjs.map +1 -1
  325. package/es/components/dropdown/src/dropdown-item-impl.mjs +2 -2
  326. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  327. package/es/components/dropdown/src/dropdown.mjs +1 -1
  328. package/es/components/dropdown/src/dropdown2.mjs +1 -1
  329. package/es/components/index.mjs +13 -13
  330. package/es/components/input-tag/src/input-tag.mjs +1 -1
  331. package/es/components/mention/src/mention-dropdown.mjs +15 -166
  332. package/es/components/mention/src/mention-dropdown.mjs.map +1 -1
  333. package/es/components/mention/src/mention-dropdown2.mjs +166 -15
  334. package/es/components/mention/src/mention-dropdown2.mjs.map +1 -1
  335. package/es/components/mention/src/mention2.mjs +1 -1
  336. package/es/components/pagination/src/components/prev.mjs +17 -35
  337. package/es/components/pagination/src/components/prev.mjs.map +1 -1
  338. package/es/components/pagination/src/components/prev2.mjs +35 -17
  339. package/es/components/pagination/src/components/prev2.mjs.map +1 -1
  340. package/es/components/pagination/src/components/total.mjs +26 -6
  341. package/es/components/pagination/src/components/total.mjs.map +1 -1
  342. package/es/components/pagination/src/components/total2.mjs +6 -26
  343. package/es/components/pagination/src/components/total2.mjs.map +1 -1
  344. package/es/components/pagination/src/pagination.mjs +2 -2
  345. package/es/components/popper/index.mjs +2 -2
  346. package/es/components/popper/src/content.mjs +92 -132
  347. package/es/components/popper/src/content.mjs.map +1 -1
  348. package/es/components/popper/src/content2.mjs +132 -92
  349. package/es/components/popper/src/content2.mjs.map +1 -1
  350. package/es/components/roving-focus-group/index.mjs +3 -3
  351. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  352. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -27
  353. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  354. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +27 -27
  355. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  356. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  357. package/es/components/select/src/select.mjs +1 -1
  358. package/es/components/select-v2/src/defaults.mjs +1 -1
  359. package/es/components/slider/src/button.mjs +89 -19
  360. package/es/components/slider/src/button.mjs.map +1 -1
  361. package/es/components/slider/src/button2.mjs +19 -89
  362. package/es/components/slider/src/button2.mjs.map +1 -1
  363. package/es/components/slider/src/slider2.mjs +1 -1
  364. package/es/components/table/src/store/watcher.mjs +1 -1
  365. package/es/components/table/src/store/watcher.mjs.map +1 -1
  366. package/es/components/table/src/util.mjs +1 -1
  367. package/es/components/table/src/util.mjs.map +1 -1
  368. package/es/components/tag/index.mjs +2 -2
  369. package/es/components/tag/src/tag.mjs +27 -99
  370. package/es/components/tag/src/tag.mjs.map +1 -1
  371. package/es/components/tag/src/tag2.mjs +99 -27
  372. package/es/components/tag/src/tag2.mjs.map +1 -1
  373. package/es/components/text/index.mjs +2 -2
  374. package/es/components/text/src/text.mjs +67 -21
  375. package/es/components/text/src/text.mjs.map +1 -1
  376. package/es/components/text/src/text2.mjs +21 -67
  377. package/es/components/text/src/text2.mjs.map +1 -1
  378. package/es/components/tooltip/src/content.mjs +1 -1
  379. package/es/components/tooltip/src/content2.mjs +1 -1
  380. package/es/components/tooltip-v2/src/content2.mjs +1 -1
  381. package/es/components/tour/src/mask.mjs +75 -18
  382. package/es/components/tour/src/mask.mjs.map +1 -1
  383. package/es/components/tour/src/mask2.mjs +18 -75
  384. package/es/components/tour/src/mask2.mjs.map +1 -1
  385. package/es/components/tour/src/tour2.mjs +1 -1
  386. package/es/components/upload/index.mjs +2 -2
  387. package/es/components/upload/src/upload-content.mjs +1 -1
  388. package/es/components/upload/src/upload-content2.mjs +1 -1
  389. package/es/components/upload/src/upload-list.mjs +1 -1
  390. package/es/components/upload/src/upload.mjs +125 -97
  391. package/es/components/upload/src/upload.mjs.map +1 -1
  392. package/es/components/upload/src/upload2.mjs +97 -125
  393. package/es/components/upload/src/upload2.mjs.map +1 -1
  394. package/es/components/upload/src/use-handlers.mjs +1 -1
  395. package/es/components/visual-hidden/index.mjs +3 -3
  396. package/es/components/visual-hidden/src/visual-hidden.mjs +35 -6
  397. package/es/components/visual-hidden/src/visual-hidden.mjs.map +1 -1
  398. package/es/components/visual-hidden/src/visual-hidden2.mjs +6 -35
  399. package/es/components/visual-hidden/src/visual-hidden2.mjs.map +1 -1
  400. package/es/index.mjs +13 -13
  401. package/es/version.d.ts +1 -1
  402. package/es/version.mjs +1 -1
  403. package/es/version.mjs.map +1 -1
  404. package/lib/components/affix/index.js +2 -2
  405. package/lib/components/affix/src/affix.js +26 -118
  406. package/lib/components/affix/src/affix.js.map +1 -1
  407. package/lib/components/affix/src/affix2.js +118 -26
  408. package/lib/components/affix/src/affix2.js.map +1 -1
  409. package/lib/components/anchor/index.js +2 -2
  410. package/lib/components/anchor/src/anchor.js +191 -42
  411. package/lib/components/anchor/src/anchor.js.map +1 -1
  412. package/lib/components/anchor/src/anchor2.js +42 -191
  413. package/lib/components/anchor/src/anchor2.js.map +1 -1
  414. package/lib/components/autocomplete/src/autocomplete2.js +3 -0
  415. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  416. package/lib/components/badge/index.js +2 -2
  417. package/lib/components/badge/src/badge.js +71 -32
  418. package/lib/components/badge/src/badge.js.map +1 -1
  419. package/lib/components/badge/src/badge2.js +32 -71
  420. package/lib/components/badge/src/badge2.js.map +1 -1
  421. package/lib/components/calendar/src/calendar2.js +1 -1
  422. package/lib/components/calendar/src/date-table.js +89 -35
  423. package/lib/components/calendar/src/date-table.js.map +1 -1
  424. package/lib/components/calendar/src/date-table2.js +35 -89
  425. package/lib/components/calendar/src/date-table2.js.map +1 -1
  426. package/lib/components/calendar/src/use-date-table.js +1 -1
  427. package/lib/components/card/index.js +2 -2
  428. package/lib/components/card/src/card.js +42 -20
  429. package/lib/components/card/src/card.js.map +1 -1
  430. package/lib/components/card/src/card2.js +20 -42
  431. package/lib/components/card/src/card2.js.map +1 -1
  432. package/lib/components/carousel/index.js +4 -4
  433. package/lib/components/carousel/src/carousel-item.js +69 -7
  434. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  435. package/lib/components/carousel/src/carousel-item2.js +7 -69
  436. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  437. package/lib/components/carousel/src/carousel.js +204 -62
  438. package/lib/components/carousel/src/carousel.js.map +1 -1
  439. package/lib/components/carousel/src/carousel2.js +62 -204
  440. package/lib/components/carousel/src/carousel2.js.map +1 -1
  441. package/lib/components/cascader/src/cascader.js +1 -1
  442. package/lib/components/check-tag/index.js +2 -2
  443. package/lib/components/check-tag/src/check-tag.js +15 -38
  444. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  445. package/lib/components/check-tag/src/check-tag2.js +38 -15
  446. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  447. package/lib/components/collapse/index.js +2 -2
  448. package/lib/components/collapse/src/collapse-item.js +18 -90
  449. package/lib/components/collapse/src/collapse-item.js.map +1 -1
  450. package/lib/components/collapse/src/collapse-item2.js +90 -18
  451. package/lib/components/collapse/src/collapse-item2.js.map +1 -1
  452. package/lib/components/collection/index.js +1 -1
  453. package/lib/components/collection/src/collection.js +9 -62
  454. package/lib/components/collection/src/collection.js.map +1 -1
  455. package/lib/components/collection/src/collection2.js +62 -9
  456. package/lib/components/collection/src/collection2.js.map +1 -1
  457. package/lib/components/dropdown/src/dropdown-item-impl.js +2 -2
  458. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  459. package/lib/components/dropdown/src/dropdown.js +1 -1
  460. package/lib/components/dropdown/src/dropdown2.js +1 -1
  461. package/lib/components/index.js +13 -13
  462. package/lib/components/input-tag/src/input-tag.js +1 -1
  463. package/lib/components/mention/src/mention-dropdown.js +16 -166
  464. package/lib/components/mention/src/mention-dropdown.js.map +1 -1
  465. package/lib/components/mention/src/mention-dropdown2.js +166 -16
  466. package/lib/components/mention/src/mention-dropdown2.js.map +1 -1
  467. package/lib/components/mention/src/mention2.js +1 -1
  468. package/lib/components/pagination/src/components/prev.js +18 -35
  469. package/lib/components/pagination/src/components/prev.js.map +1 -1
  470. package/lib/components/pagination/src/components/prev2.js +35 -18
  471. package/lib/components/pagination/src/components/prev2.js.map +1 -1
  472. package/lib/components/pagination/src/components/total.js +26 -6
  473. package/lib/components/pagination/src/components/total.js.map +1 -1
  474. package/lib/components/pagination/src/components/total2.js +6 -26
  475. package/lib/components/pagination/src/components/total2.js.map +1 -1
  476. package/lib/components/pagination/src/pagination.js +2 -2
  477. package/lib/components/popper/index.js +2 -2
  478. package/lib/components/popper/src/content.js +97 -132
  479. package/lib/components/popper/src/content.js.map +1 -1
  480. package/lib/components/popper/src/content2.js +132 -97
  481. package/lib/components/popper/src/content2.js.map +1 -1
  482. package/lib/components/roving-focus-group/index.js +2 -2
  483. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  484. package/lib/components/roving-focus-group/src/roving-focus-group.js +31 -27
  485. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  486. package/lib/components/roving-focus-group/src/roving-focus-group2.js +27 -31
  487. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  488. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  489. package/lib/components/select/src/select.js +1 -1
  490. package/lib/components/select-v2/src/defaults.js +1 -1
  491. package/lib/components/slider/src/button.js +89 -20
  492. package/lib/components/slider/src/button.js.map +1 -1
  493. package/lib/components/slider/src/button2.js +20 -89
  494. package/lib/components/slider/src/button2.js.map +1 -1
  495. package/lib/components/slider/src/slider2.js +1 -1
  496. package/lib/components/table/src/store/watcher.js +1 -1
  497. package/lib/components/table/src/store/watcher.js.map +1 -1
  498. package/lib/components/table/src/util.js +1 -1
  499. package/lib/components/table/src/util.js.map +1 -1
  500. package/lib/components/tag/index.js +2 -2
  501. package/lib/components/tag/src/tag.js +28 -99
  502. package/lib/components/tag/src/tag.js.map +1 -1
  503. package/lib/components/tag/src/tag2.js +99 -28
  504. package/lib/components/tag/src/tag2.js.map +1 -1
  505. package/lib/components/text/index.js +2 -2
  506. package/lib/components/text/src/text.js +67 -21
  507. package/lib/components/text/src/text.js.map +1 -1
  508. package/lib/components/text/src/text2.js +21 -67
  509. package/lib/components/text/src/text2.js.map +1 -1
  510. package/lib/components/tooltip/src/content.js +1 -1
  511. package/lib/components/tooltip/src/content2.js +1 -1
  512. package/lib/components/tooltip-v2/src/content2.js +1 -1
  513. package/lib/components/tour/src/mask.js +75 -18
  514. package/lib/components/tour/src/mask.js.map +1 -1
  515. package/lib/components/tour/src/mask2.js +18 -75
  516. package/lib/components/tour/src/mask2.js.map +1 -1
  517. package/lib/components/tour/src/tour2.js +1 -1
  518. package/lib/components/upload/index.js +2 -2
  519. package/lib/components/upload/src/upload-content.js +1 -1
  520. package/lib/components/upload/src/upload-content2.js +1 -1
  521. package/lib/components/upload/src/upload-list.js +1 -1
  522. package/lib/components/upload/src/upload.js +125 -100
  523. package/lib/components/upload/src/upload.js.map +1 -1
  524. package/lib/components/upload/src/upload2.js +100 -125
  525. package/lib/components/upload/src/upload2.js.map +1 -1
  526. package/lib/components/upload/src/use-handlers.js +1 -1
  527. package/lib/components/visual-hidden/index.js +2 -2
  528. package/lib/components/visual-hidden/src/visual-hidden.js +35 -6
  529. package/lib/components/visual-hidden/src/visual-hidden.js.map +1 -1
  530. package/lib/components/visual-hidden/src/visual-hidden2.js +6 -35
  531. package/lib/components/visual-hidden/src/visual-hidden2.js.map +1 -1
  532. package/lib/index.js +13 -13
  533. package/lib/version.d.ts +1 -1
  534. package/lib/version.js +1 -1
  535. package/lib/version.js.map +1 -1
  536. package/package.json +2 -2
  537. package/tags.json +1 -1
  538. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"anchor.js","sources":["../../../../../../packages/components/anchor/src/anchor.ts"],"sourcesContent":["import {\n buildProps,\n definePropType,\n isString,\n isUndefined,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Anchor from './anchor.vue'\n\nexport const anchorProps = buildProps({\n /**\n * @description scroll container\n */\n container: {\n type: definePropType<string | HTMLElement | Window | null>([\n String,\n Object,\n ]),\n },\n /**\n * @description Set the offset of the anchor scroll\n */\n offset: {\n type: Number,\n default: 0,\n },\n /**\n * @description The offset of the element starting to trigger the anchor\n */\n bound: {\n type: Number,\n default: 15,\n },\n /**\n * @description Set the scroll duration of the container when the anchor is clicked, in milliseconds\n */\n duration: {\n type: Number,\n default: 300,\n },\n /**\n * @description Whether to show the marker\n */\n marker: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Set Anchor type\n */\n type: {\n type: definePropType<'default' | 'underline'>(String),\n default: 'default',\n },\n /**\n * @description Set Anchor direction\n */\n direction: {\n type: definePropType<'vertical' | 'horizontal'>(String),\n default: 'vertical',\n },\n /**\n * @description Scroll whether link is selected at the top\n */\n selectScrollTop: {\n type: Boolean,\n default: false,\n },\n})\n\nexport type AnchorProps = ExtractPropTypes<typeof anchorProps>\nexport type AnchorInstance = InstanceType<typeof Anchor>\n\nexport const anchorEmits = {\n change: (href: string) => isString(href),\n click: (e: MouseEvent, href?: string) =>\n e instanceof MouseEvent && (isString(href) || isUndefined(href)),\n}\nexport type AnchorEmits = typeof anchorEmits\n"],"names":["buildProps","definePropType","isString","isUndefined"],"mappings":";;;;;;;;AAMY,MAAC,WAAW,GAAGA,kBAAU,CAAC;AACtC,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAEC,sBAAc,CAAC;AACzB,MAAM,MAAM;AACZ,MAAM,MAAM;AACZ,KAAK,CAAC;AACN,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAEA,sBAAc,CAAC,MAAM,CAAC;AAChC,IAAI,OAAO,EAAE,SAAS;AACtB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAEA,sBAAc,CAAC,MAAM,CAAC;AAChC,IAAI,OAAO,EAAE,UAAU;AACvB,GAAG;AACH,EAAE,eAAe,EAAE;AACnB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,WAAW,GAAG;AAC3B,EAAE,MAAM,EAAE,CAAC,IAAI,KAAKC,eAAQ,CAAC,IAAI,CAAC;AAClC,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,IAAI,KAAK,CAAC,YAAY,UAAU,KAAKA,eAAQ,CAAC,IAAI,CAAC,IAAIC,iBAAW,CAAC,IAAI,CAAC,CAAC;AACtF;;;;;"}
1
+ {"version":3,"file":"anchor.js","sources":["../../../../../../packages/components/anchor/src/anchor.vue"],"sourcesContent":["<template>\n <div ref=\"anchorRef\" :class=\"cls\">\n <div\n v-if=\"marker\"\n ref=\"markerRef\"\n :class=\"ns.e('marker')\"\n :style=\"markerStyle\"\n />\n <div :class=\"ns.e('list')\">\n <slot />\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, provide, ref, watch } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n animateScrollTo,\n getElement,\n getOffsetTopDistance,\n getScrollElement,\n getScrollTop,\n isUndefined,\n isWindow,\n throttleByRaf,\n} from '@element-plus/utils'\nimport { anchorEmits, anchorProps } from './anchor'\nimport { anchorKey } from './constants'\n\nimport type { AnchorLinkState } from './constants'\n\ndefineOptions({\n name: 'ElAnchor',\n})\n\nconst props = defineProps(anchorProps)\nconst emit = defineEmits(anchorEmits)\n\nconst currentAnchor = ref('')\nconst anchorRef = ref<HTMLElement | null>(null)\nconst markerRef = ref<HTMLElement | null>(null)\nconst containerEl = ref<HTMLElement | Window>()\n\nconst links: Record<string, HTMLElement> = {}\nlet isScrolling = false\nlet currentScrollTop = 0\n\nconst ns = useNamespace('anchor')\n\nconst cls = computed(() => [\n ns.b(),\n props.type === 'underline' ? ns.m('underline') : '',\n ns.m(props.direction),\n])\n\nconst addLink = (state: AnchorLinkState) => {\n links[state.href] = state.el\n}\n\nconst removeLink = (href: string) => {\n delete links[href]\n}\n\nconst setCurrentAnchor = (href: string) => {\n const activeHref = currentAnchor.value\n if (activeHref !== href) {\n currentAnchor.value = href\n emit('change', href)\n }\n}\n\nlet clearAnimate: (() => void) | null = null\n\nconst scrollToAnchor = (href: string) => {\n if (!containerEl.value) return\n const target = getElement(href)\n if (!target) return\n if (clearAnimate) clearAnimate()\n isScrolling = true\n const scrollEle = getScrollElement(target, containerEl.value)\n const distance = getOffsetTopDistance(target, scrollEle)\n const max = scrollEle.scrollHeight - scrollEle.clientHeight\n const to = Math.min(distance - props.offset, max)\n clearAnimate = animateScrollTo(\n containerEl.value,\n currentScrollTop,\n to,\n props.duration,\n () => {\n // make sure it is executed after throttleByRaf's handleScroll\n setTimeout(() => {\n isScrolling = false\n }, 20)\n }\n )\n}\n\nconst scrollTo = (href?: string) => {\n if (href) {\n setCurrentAnchor(href)\n scrollToAnchor(href)\n }\n}\n\nconst handleClick = (e: MouseEvent, href?: string) => {\n emit('click', e, href)\n scrollTo(href)\n}\n\nconst handleScroll = throttleByRaf(() => {\n if (containerEl.value) {\n currentScrollTop = getScrollTop(containerEl.value)\n }\n const currentHref = getCurrentHref()\n if (isScrolling || isUndefined(currentHref)) return\n setCurrentAnchor(currentHref)\n})\n\nconst getCurrentHref = () => {\n if (!containerEl.value) return\n const scrollTop = getScrollTop(containerEl.value)\n const anchorTopList: { top: number; href: string }[] = []\n\n for (const href of Object.keys(links)) {\n const target = getElement(href)\n if (!target) continue\n const scrollEle = getScrollElement(target, containerEl.value)\n const distance = getOffsetTopDistance(target, scrollEle)\n anchorTopList.push({\n top: distance - props.offset - props.bound,\n href,\n })\n }\n anchorTopList.sort((prev, next) => prev.top - next.top)\n for (let i = 0; i < anchorTopList.length; i++) {\n const item = anchorTopList[i]\n const next = anchorTopList[i + 1]\n\n if (i === 0 && scrollTop === 0) {\n return props.selectScrollTop ? item.href : ''\n }\n if (item.top <= scrollTop && (!next || next.top > scrollTop)) {\n return item.href\n }\n }\n}\n\nconst getContainer = () => {\n const el = getElement(props.container)\n if (!el || isWindow(el)) {\n containerEl.value = window\n } else {\n containerEl.value = el\n }\n}\n\nuseEventListener(containerEl, 'scroll', handleScroll)\n\nconst markerStyle = computed(() => {\n if (!anchorRef.value || !markerRef.value || !currentAnchor.value) return {}\n const currentLinkEl = links[currentAnchor.value]\n if (!currentLinkEl) return {}\n const anchorRect = anchorRef.value.getBoundingClientRect()\n const markerRect = markerRef.value.getBoundingClientRect()\n const linkRect = currentLinkEl.getBoundingClientRect()\n\n if (props.direction === 'horizontal') {\n const left = linkRect.left - anchorRect.left\n return {\n left: `${left}px`,\n width: `${linkRect.width}px`,\n opacity: 1,\n }\n } else {\n const top =\n linkRect.top - anchorRect.top + (linkRect.height - markerRect.height) / 2\n return {\n top: `${top}px`,\n opacity: 1,\n }\n }\n})\n\nonMounted(() => {\n getContainer()\n const hash = decodeURIComponent(window.location.hash)\n const target = getElement(hash)\n if (target) {\n scrollTo(hash)\n } else {\n handleScroll()\n }\n})\n\nwatch(\n () => props.container,\n () => {\n getContainer()\n }\n)\n\nprovide(anchorKey, {\n ns,\n direction: props.direction,\n currentAnchor,\n addLink,\n removeLink,\n handleClick,\n})\n\ndefineExpose({\n scrollTo,\n})\n</script>\n"],"names":["ref","useNamespace","computed","getElement","getScrollElement","getOffsetTopDistance","animateScrollTo","throttleByRaf","getScrollTop","isUndefined","isWindow","useEventListener","onMounted","watch","provide","anchorKey"],"mappings":";;;;;;;;;;;;;;;;uCAiCc,CAAA;AAAA,EACZ,IAAM,EAAA,UAAA;AACR,CAAA,CAAA,CAAA;;;;;;;AAKA,IAAM,MAAA,aAAA,GAAgBA,QAAI,EAAE,CAAA,CAAA;AAC5B,IAAM,MAAA,SAAA,GAAYA,QAAwB,IAAI,CAAA,CAAA;AAC9C,IAAM,MAAA,SAAA,GAAYA,QAAwB,IAAI,CAAA,CAAA;AAC9C,IAAA,MAAM,cAAcA,OAA0B,EAAA,CAAA;AAE9C,IAAA,MAAM,QAAqC,EAAC,CAAA;AAC5C,IAAA,IAAI,WAAc,GAAA,KAAA,CAAA;AAClB,IAAA,IAAI,gBAAmB,GAAA,CAAA,CAAA;AAEvB,IAAM,MAAA,EAAA,GAAKC,mBAAa,QAAQ,CAAA,CAAA;AAEhC,IAAM,MAAA,GAAA,GAAMC,aAAS,MAAM;AAAA,MACzB,GAAG,CAAE,EAAA;AAAA,MACL,MAAM,IAAS,KAAA,WAAA,GAAc,EAAG,CAAA,CAAA,CAAE,WAAW,CAAI,GAAA,EAAA;AAAA,MACjD,EAAA,CAAG,CAAE,CAAA,KAAA,CAAM,SAAS,CAAA;AAAA,KACrB,CAAA,CAAA;AAED,IAAM,MAAA,OAAA,GAAU,CAAC,KAA2B,KAAA;AAC1C,MAAM,KAAA,CAAA,KAAA,CAAM,IAAI,CAAA,GAAI,KAAM,CAAA,EAAA,CAAA;AAAA,KAC5B,CAAA;AAEA,IAAM,MAAA,UAAA,GAAa,CAAC,IAAiB,KAAA;AACnC,MAAA,OAAO,MAAM,IAAI,CAAA,CAAA;AAAA,KACnB,CAAA;AAEA,IAAM,MAAA,gBAAA,GAAmB,CAAC,IAAiB,KAAA;AACzC,MAAA,MAAM,aAAa,aAAc,CAAA,KAAA,CAAA;AACjC,MAAA,IAAI,eAAe,IAAM,EAAA;AACvB,QAAA,aAAA,CAAc,KAAQ,GAAA,IAAA,CAAA;AACtB,QAAA,IAAA,CAAK,UAAU,IAAI,CAAA,CAAA;AAAA,OACrB;AAAA,KACF,CAAA;AAEA,IAAA,IAAI,YAAoC,GAAA,IAAA,CAAA;AAExC,IAAM,MAAA,cAAA,GAAiB,CAAC,IAAiB,KAAA;AACvC,MAAI,IAAA,CAAC,YAAY,KAAO;AACxB,QAAM,OAAA;AACN,MAAA,MAAa,MAAA,GAAAC,kBAAA,CAAA,IAAA,CAAA,CAAA;AACb,MAAA,IAAI;AACJ,QAAc,OAAA;AACd,MAAA,IAAA,YAAkB;AAClB,QAAM,YAAA,EAAA,CAAW;AACjB,MAAM,WAAA,GAAgB,IAAA,CAAA;AACtB,MAAA,MAAM,SAAU,GAAAC,uBAAe,CAAA,mBAAiB,CAAA,KAAA,CAAA,CAAA;AAChD,MAAe,MAAA,QAAA,GAAAC,6BAAA,CAAA,MAAA,EAAA,SAAA,CAAA,CAAA;AAAA,MAAA,MACD,GAAA,GAAA,SAAA,CAAA,YAAA,GAAA,SAAA,CAAA,YAAA,CAAA;AAAA,MACZ,MAAA,EAAA,GAAA,IAAA,CAAA,GAAA,CAAA,QAAA,GAAA,KAAA,CAAA,MAAA,EAAA,GAAA,CAAA,CAAA;AAAA,MACA,YAAA,GAAAC,sBAAA,CAAA,WAAA,CAAA,KAAA,EAAA,gBAAA,EAAA,EAAA,EAAA,KAAA,CAAA,QAAA,EAAA,MAAA;AAAA,QACA,UAAM,CAAA,MAAA;AAAA,UACA,WAAA,GAAA,KAAA,CAAA;AAEJ,SAAA,EAAA,EAAA,CAAA,CAAA;AACE,OAAc,CAAA,CAAA;AAAA,KAAA,CAAA;AACX,IACP,MAAA,QAAA,GAAA,CAAA,IAAA,KAAA;AAAA,MACF,IAAA,IAAA,EAAA;AAAA,QACF,gBAAA,CAAA,IAAA,CAAA,CAAA;AAEA,QAAM,cAAY,CAAkB,IAAA,CAAA,CAAA;AAClC,OAAA;AACE,KAAA,CAAA;AACA,IAAA,MAAA,WAAA,GAAmB,CAAA,CAAA,EAAA,IAAA,KAAA;AAAA,MACrB,IAAA,CAAA,OAAA,EAAA,CAAA,EAAA,IAAA,CAAA,CAAA;AAAA,MACF,QAAA,CAAA,IAAA,CAAA,CAAA;AAEA,KAAM,CAAA;AACJ,IAAK,MAAA,eAAgBC,2BAAA,CAAA,MAAA;AACrB,MAAA,IAAA,WAAa,CAAA,KAAA,EAAA;AAAA,QACf,gBAAA,GAAAC,mBAAA,CAAA,WAAA,CAAA,KAAA,CAAA,CAAA;AAEA,OAAM;AACJ,MAAA,iBAAuB,GAAA,cAAA,EAAA,CAAA;AACrB,MAAmB,IAAA,WAAA,IAAAC,iBAAA,CAAA;AAA8B,QACnD,OAAA;AACA,MAAA,4BAAmC,CAAA,CAAA;AACnC,KAAI,CAAA,CAAA;AACJ,IAAA,MAAA,cAA4B,GAAA,MAAA;AAAA,MAC7B,IAAA,CAAA,WAAA,CAAA,KAAA;AAED,QAAA;AACE,MAAI,kBAAoBD,mBAAA,CAAA,WAAA,CAAA,KAAA,CAAA,CAAA;AACxB,MAAM,MAAA,aAAyB,GAAA,EAAA,CAAA;AAC/B,MAAA,KAAA,oBAAwD,CAAA,IAAA,CAAA,KAAA,CAAA,EAAA;AAExD,QAAA,MAAA,MAAmB,GAAAL,kBAAY,CAAA,IAAA,CAAA,CAAA;AAC7B,QAAM,IAAA,CAAA,MAAA;AACN,UAAA,SAAa;AACb,QAAA,MAAM,SAAY,GAAAC,uBAAA,CAAiB,MAAQ,EAAA,WAAA,CAAY,KAAK,CAAA,CAAA;AAC5D,QAAM,MAAA,QAAA,GAAWC,6BAAqB,CAAA,MAAA,EAAQ,SAAS,CAAA,CAAA;AACvD,QAAA,aAAA,CAAc,IAAK,CAAA;AAAA,UACjB,GAAK,EAAA,QAAA,GAAW,KAAM,CAAA,MAAA,GAAS,KAAM,CAAA,KAAA;AAAA,UACrC,IAAA;AAAA,SACD,CAAA,CAAA;AAAA,OACH;AACA,MAAA,aAAA,CAAc,KAAK,CAAC,IAAA,EAAM,SAAS,IAAK,CAAA,GAAA,GAAM,KAAK,GAAG,CAAA,CAAA;AACtD,MAAA,KAAA,IAAS,CAAI,GAAA,CAAA,EAAG,CAAI,GAAA,aAAA,CAAc,QAAQ,CAAK,EAAA,EAAA;AAC7C,QAAM,MAAA,IAAA,GAAO,cAAc,CAAC,CAAA,CAAA;AAC5B,QAAM,MAAA,IAAA,GAAO,aAAc,CAAA,CAAA,GAAI,CAAC,CAAA,CAAA;AAEhC,QAAI,IAAA,CAAA,KAAM,CAAK,IAAA,SAAA,KAAc,CAAG,EAAA;AAC9B,UAAO,OAAA,KAAA,CAAM,eAAkB,GAAA,IAAA,CAAK,IAAO,GAAA,EAAA,CAAA;AAAA,SAC7C;AACA,QAAA,IAAI,KAAK,GAAO,IAAA,SAAA,KAAc,CAAC,IAAQ,IAAA,IAAA,CAAK,MAAM,SAAY,CAAA,EAAA;AAC5D,UAAA,OAAO,IAAK,CAAA,IAAA,CAAA;AAAA,SACd;AAAA,OACF;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,eAAe,MAAM;AACzB,MAAM,MAAA,EAAA,GAAKF,kBAAW,CAAA,KAAA,CAAM,SAAS,CAAA,CAAA;AACrC,MAAA,IAAI,CAAC,EAAA,IAAMO,cAAS,CAAA,EAAE,CAAG,EAAA;AACvB,QAAA,WAAA,CAAY,KAAQ,GAAA,MAAA,CAAA;AAAA,OACf,MAAA;AACL,QAAA,WAAA,CAAY,KAAQ,GAAA,EAAA,CAAA;AAAA,OACtB;AAAA,KACF,CAAA;AAEA,IAAiBC,qBAAA,CAAA,WAAA,EAAa,UAAU,YAAY,CAAA,CAAA;AAEpD,IAAM,MAAA,WAAA,GAAcT,aAAS,MAAM;AACjC,MAAI,IAAA,CAAC,SAAU,CAAA,KAAA,IAAS,CAAC,SAAA,CAAU,SAAS,CAAC,aAAA,CAAc,KAAO;AAClE,QAAM,OAAA,EAAA,CAAA;AACN,MAAI,MAAgB,aAAA,GAAA,KAAO,CAAC,aAAA,CAAA,KAAA,CAAA,CAAA;AAC5B,MAAM,IAAA,CAAA,aAAA;AACN,QAAM,OAAA,EAAA,CAAA;AACN,MAAM,MAAA,UAAA,kBAA+C,CAAA,qBAAA,EAAA,CAAA;AAErD,MAAI,MAAA,sBAAkC,CAAA,KAAA,CAAA,qBAAA,EAAA,CAAA;AACpC,MAAM,MAAA,QAAA,GAAgB,aAAA,CAAO,qBAAW,EAAA,CAAA;AACxC,MAAO,IAAA,KAAA,CAAA,SAAA,KAAA,YAAA,EAAA;AAAA,QACL,MAAA,OAAa,QAAA,CAAA,IAAA,GAAA,UAAA,CAAA,IAAA,CAAA;AAAA,QACb,OAAA;AAAwB,UACxB,IAAS,EAAA,CAAA,EAAA,IAAA,CAAA,EAAA,CAAA;AAAA,UACX,KAAA,EAAA,CAAA,EAAA,QAAA,CAAA,KAAA,CAAA,EAAA,CAAA;AAAA,UACK,OAAA,EAAA,CAAA;AACL,SAAM,CAAA;AAEN,OAAO,MAAA;AAAA,QACL,MAAA,MAAW,QAAA,CAAA,GAAA,GAAA,UAAA,CAAA,GAAA,GAAA,CAAA,QAAA,CAAA,MAAA,GAAA,UAAA,CAAA,MAAA,IAAA,CAAA,CAAA;AAAA,QAAA,OACF;AAAA,UACX,GAAA,EAAA,CAAA,EAAA,GAAA,CAAA,EAAA,CAAA;AAAA,UACF,OAAA,EAAA,CAAA;AAAA,SACD,CAAA;AAED,OAAA;AACE,KAAa,CAAA,CAAA;AACb,IAAAU,aAAa,CAAA,MAAA;AACb,MAAM,YAAA,EAAA,CAAS;AACf,MAAA,MAAY,IAAA,GAAA,kBAAA,CAAA,MAAA,CAAA,QAAA,CAAA,IAAA,CAAA,CAAA;AACV,MAAA,MAAA,MAAa,GAAAT,kBAAA,CAAA,IAAA,CAAA,CAAA;AAAA,MACf,IAAO,MAAA,EAAA;AACL,QAAa,QAAA,CAAA,IAAA,CAAA,CAAA;AAAA,OACf,MAAA;AAAA,QACD,YAAA,EAAA,CAAA;AAED,OAAA;AAAA,KAAA,CACE;AAAY,IAAAU,SACN,CAAA,MAAA,KAAA,CAAA,SAAA,EAAA,MAAA;AACJ,MAAa,YAAA,EAAA,CAAA;AAAA,KACf,CAAA,CAAA;AAAA,IACFC,WAAA,CAAAC,mBAAA,EAAA;AAEA,MAAA,EAAA;AAAmB,MACjB,SAAA,EAAA,KAAA,CAAA,SAAA;AAAA,MACA,aAAiB;AAAA,MACjB,OAAA;AAAA,MACA,UAAA;AAAA,MACA,WAAA;AAAA,KACA,CAAA,CAAA;AAAA,IACF,MAAC,CAAA;AAED,MAAa,QAAA;AAAA,KACX,CAAA,CAAA;AAAA,IACF,OAAC,CAAA,IAAA,EAAA,MAAA,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -2,200 +2,51 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var vue = require('vue');
6
- var core = require('@vueuse/core');
7
- var anchor = require('./anchor.js');
8
- var constants = require('./constants.js');
9
- var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
10
- var element = require('../../../utils/dom/element.js');
11
- var throttleByRaf = require('../../../utils/throttleByRaf.js');
5
+ var runtime = require('../../../utils/vue/props/runtime.js');
6
+ var shared = require('@vue/shared');
12
7
  var types = require('../../../utils/types.js');
13
- var scroll = require('../../../utils/dom/scroll.js');
14
- var position = require('../../../utils/dom/position.js');
15
- var index = require('../../../hooks/use-namespace/index.js');
16
8
 
17
- const __default__ = vue.defineComponent({
18
- name: "ElAnchor"
19
- });
20
- const _sfc_main = /* @__PURE__ */ vue.defineComponent({
21
- ...__default__,
22
- props: anchor.anchorProps,
23
- emits: anchor.anchorEmits,
24
- setup(__props, { expose, emit }) {
25
- const props = __props;
26
- const currentAnchor = vue.ref("");
27
- const anchorRef = vue.ref(null);
28
- const markerRef = vue.ref(null);
29
- const containerEl = vue.ref();
30
- const links = {};
31
- let isScrolling = false;
32
- let currentScrollTop = 0;
33
- const ns = index.useNamespace("anchor");
34
- const cls = vue.computed(() => [
35
- ns.b(),
36
- props.type === "underline" ? ns.m("underline") : "",
37
- ns.m(props.direction)
38
- ]);
39
- const addLink = (state) => {
40
- links[state.href] = state.el;
41
- };
42
- const removeLink = (href) => {
43
- delete links[href];
44
- };
45
- const setCurrentAnchor = (href) => {
46
- const activeHref = currentAnchor.value;
47
- if (activeHref !== href) {
48
- currentAnchor.value = href;
49
- emit("change", href);
50
- }
51
- };
52
- let clearAnimate = null;
53
- const scrollToAnchor = (href) => {
54
- if (!containerEl.value)
55
- return;
56
- const target = element.getElement(href);
57
- if (!target)
58
- return;
59
- if (clearAnimate)
60
- clearAnimate();
61
- isScrolling = true;
62
- const scrollEle = scroll.getScrollElement(target, containerEl.value);
63
- const distance = position.getOffsetTopDistance(target, scrollEle);
64
- const max = scrollEle.scrollHeight - scrollEle.clientHeight;
65
- const to = Math.min(distance - props.offset, max);
66
- clearAnimate = scroll.animateScrollTo(containerEl.value, currentScrollTop, to, props.duration, () => {
67
- setTimeout(() => {
68
- isScrolling = false;
69
- }, 20);
70
- });
71
- };
72
- const scrollTo = (href) => {
73
- if (href) {
74
- setCurrentAnchor(href);
75
- scrollToAnchor(href);
76
- }
77
- };
78
- const handleClick = (e, href) => {
79
- emit("click", e, href);
80
- scrollTo(href);
81
- };
82
- const handleScroll = throttleByRaf.throttleByRaf(() => {
83
- if (containerEl.value) {
84
- currentScrollTop = scroll.getScrollTop(containerEl.value);
85
- }
86
- const currentHref = getCurrentHref();
87
- if (isScrolling || types.isUndefined(currentHref))
88
- return;
89
- setCurrentAnchor(currentHref);
90
- });
91
- const getCurrentHref = () => {
92
- if (!containerEl.value)
93
- return;
94
- const scrollTop = scroll.getScrollTop(containerEl.value);
95
- const anchorTopList = [];
96
- for (const href of Object.keys(links)) {
97
- const target = element.getElement(href);
98
- if (!target)
99
- continue;
100
- const scrollEle = scroll.getScrollElement(target, containerEl.value);
101
- const distance = position.getOffsetTopDistance(target, scrollEle);
102
- anchorTopList.push({
103
- top: distance - props.offset - props.bound,
104
- href
105
- });
106
- }
107
- anchorTopList.sort((prev, next) => prev.top - next.top);
108
- for (let i = 0; i < anchorTopList.length; i++) {
109
- const item = anchorTopList[i];
110
- const next = anchorTopList[i + 1];
111
- if (i === 0 && scrollTop === 0) {
112
- return props.selectScrollTop ? item.href : "";
113
- }
114
- if (item.top <= scrollTop && (!next || next.top > scrollTop)) {
115
- return item.href;
116
- }
117
- }
118
- };
119
- const getContainer = () => {
120
- const el = element.getElement(props.container);
121
- if (!el || types.isWindow(el)) {
122
- containerEl.value = window;
123
- } else {
124
- containerEl.value = el;
125
- }
126
- };
127
- core.useEventListener(containerEl, "scroll", handleScroll);
128
- const markerStyle = vue.computed(() => {
129
- if (!anchorRef.value || !markerRef.value || !currentAnchor.value)
130
- return {};
131
- const currentLinkEl = links[currentAnchor.value];
132
- if (!currentLinkEl)
133
- return {};
134
- const anchorRect = anchorRef.value.getBoundingClientRect();
135
- const markerRect = markerRef.value.getBoundingClientRect();
136
- const linkRect = currentLinkEl.getBoundingClientRect();
137
- if (props.direction === "horizontal") {
138
- const left = linkRect.left - anchorRect.left;
139
- return {
140
- left: `${left}px`,
141
- width: `${linkRect.width}px`,
142
- opacity: 1
143
- };
144
- } else {
145
- const top = linkRect.top - anchorRect.top + (linkRect.height - markerRect.height) / 2;
146
- return {
147
- top: `${top}px`,
148
- opacity: 1
149
- };
150
- }
151
- });
152
- vue.onMounted(() => {
153
- getContainer();
154
- const hash = decodeURIComponent(window.location.hash);
155
- const target = element.getElement(hash);
156
- if (target) {
157
- scrollTo(hash);
158
- } else {
159
- handleScroll();
160
- }
161
- });
162
- vue.watch(() => props.container, () => {
163
- getContainer();
164
- });
165
- vue.provide(constants.anchorKey, {
166
- ns,
167
- direction: props.direction,
168
- currentAnchor,
169
- addLink,
170
- removeLink,
171
- handleClick
172
- });
173
- expose({
174
- scrollTo
175
- });
176
- return (_ctx, _cache) => {
177
- return vue.openBlock(), vue.createElementBlock("div", {
178
- ref_key: "anchorRef",
179
- ref: anchorRef,
180
- class: vue.normalizeClass(vue.unref(cls))
181
- }, [
182
- _ctx.marker ? (vue.openBlock(), vue.createElementBlock("div", {
183
- key: 0,
184
- ref_key: "markerRef",
185
- ref: markerRef,
186
- class: vue.normalizeClass(vue.unref(ns).e("marker")),
187
- style: vue.normalizeStyle(vue.unref(markerStyle))
188
- }, null, 6)) : vue.createCommentVNode("v-if", true),
189
- vue.createElementVNode("div", {
190
- class: vue.normalizeClass(vue.unref(ns).e("list"))
191
- }, [
192
- vue.renderSlot(_ctx.$slots, "default")
193
- ], 2)
194
- ], 2);
195
- };
9
+ const anchorProps = runtime.buildProps({
10
+ container: {
11
+ type: runtime.definePropType([
12
+ String,
13
+ Object
14
+ ])
15
+ },
16
+ offset: {
17
+ type: Number,
18
+ default: 0
19
+ },
20
+ bound: {
21
+ type: Number,
22
+ default: 15
23
+ },
24
+ duration: {
25
+ type: Number,
26
+ default: 300
27
+ },
28
+ marker: {
29
+ type: Boolean,
30
+ default: true
31
+ },
32
+ type: {
33
+ type: runtime.definePropType(String),
34
+ default: "default"
35
+ },
36
+ direction: {
37
+ type: runtime.definePropType(String),
38
+ default: "vertical"
39
+ },
40
+ selectScrollTop: {
41
+ type: Boolean,
42
+ default: false
196
43
  }
197
44
  });
198
- var Anchor = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "anchor.vue"]]);
45
+ const anchorEmits = {
46
+ change: (href) => shared.isString(href),
47
+ click: (e, href) => e instanceof MouseEvent && (shared.isString(href) || types.isUndefined(href))
48
+ };
199
49
 
200
- exports["default"] = Anchor;
50
+ exports.anchorEmits = anchorEmits;
51
+ exports.anchorProps = anchorProps;
201
52
  //# sourceMappingURL=anchor2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"anchor2.js","sources":["../../../../../../packages/components/anchor/src/anchor.vue"],"sourcesContent":["<template>\n <div ref=\"anchorRef\" :class=\"cls\">\n <div\n v-if=\"marker\"\n ref=\"markerRef\"\n :class=\"ns.e('marker')\"\n :style=\"markerStyle\"\n />\n <div :class=\"ns.e('list')\">\n <slot />\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, provide, ref, watch } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n animateScrollTo,\n getElement,\n getOffsetTopDistance,\n getScrollElement,\n getScrollTop,\n isUndefined,\n isWindow,\n throttleByRaf,\n} from '@element-plus/utils'\nimport { anchorEmits, anchorProps } from './anchor'\nimport { anchorKey } from './constants'\n\nimport type { AnchorLinkState } from './constants'\n\ndefineOptions({\n name: 'ElAnchor',\n})\n\nconst props = defineProps(anchorProps)\nconst emit = defineEmits(anchorEmits)\n\nconst currentAnchor = ref('')\nconst anchorRef = ref<HTMLElement | null>(null)\nconst markerRef = ref<HTMLElement | null>(null)\nconst containerEl = ref<HTMLElement | Window>()\n\nconst links: Record<string, HTMLElement> = {}\nlet isScrolling = false\nlet currentScrollTop = 0\n\nconst ns = useNamespace('anchor')\n\nconst cls = computed(() => [\n ns.b(),\n props.type === 'underline' ? ns.m('underline') : '',\n ns.m(props.direction),\n])\n\nconst addLink = (state: AnchorLinkState) => {\n links[state.href] = state.el\n}\n\nconst removeLink = (href: string) => {\n delete links[href]\n}\n\nconst setCurrentAnchor = (href: string) => {\n const activeHref = currentAnchor.value\n if (activeHref !== href) {\n currentAnchor.value = href\n emit('change', href)\n }\n}\n\nlet clearAnimate: (() => void) | null = null\n\nconst scrollToAnchor = (href: string) => {\n if (!containerEl.value) return\n const target = getElement(href)\n if (!target) return\n if (clearAnimate) clearAnimate()\n isScrolling = true\n const scrollEle = getScrollElement(target, containerEl.value)\n const distance = getOffsetTopDistance(target, scrollEle)\n const max = scrollEle.scrollHeight - scrollEle.clientHeight\n const to = Math.min(distance - props.offset, max)\n clearAnimate = animateScrollTo(\n containerEl.value,\n currentScrollTop,\n to,\n props.duration,\n () => {\n // make sure it is executed after throttleByRaf's handleScroll\n setTimeout(() => {\n isScrolling = false\n }, 20)\n }\n )\n}\n\nconst scrollTo = (href?: string) => {\n if (href) {\n setCurrentAnchor(href)\n scrollToAnchor(href)\n }\n}\n\nconst handleClick = (e: MouseEvent, href?: string) => {\n emit('click', e, href)\n scrollTo(href)\n}\n\nconst handleScroll = throttleByRaf(() => {\n if (containerEl.value) {\n currentScrollTop = getScrollTop(containerEl.value)\n }\n const currentHref = getCurrentHref()\n if (isScrolling || isUndefined(currentHref)) return\n setCurrentAnchor(currentHref)\n})\n\nconst getCurrentHref = () => {\n if (!containerEl.value) return\n const scrollTop = getScrollTop(containerEl.value)\n const anchorTopList: { top: number; href: string }[] = []\n\n for (const href of Object.keys(links)) {\n const target = getElement(href)\n if (!target) continue\n const scrollEle = getScrollElement(target, containerEl.value)\n const distance = getOffsetTopDistance(target, scrollEle)\n anchorTopList.push({\n top: distance - props.offset - props.bound,\n href,\n })\n }\n anchorTopList.sort((prev, next) => prev.top - next.top)\n for (let i = 0; i < anchorTopList.length; i++) {\n const item = anchorTopList[i]\n const next = anchorTopList[i + 1]\n\n if (i === 0 && scrollTop === 0) {\n return props.selectScrollTop ? item.href : ''\n }\n if (item.top <= scrollTop && (!next || next.top > scrollTop)) {\n return item.href\n }\n }\n}\n\nconst getContainer = () => {\n const el = getElement(props.container)\n if (!el || isWindow(el)) {\n containerEl.value = window\n } else {\n containerEl.value = el\n }\n}\n\nuseEventListener(containerEl, 'scroll', handleScroll)\n\nconst markerStyle = computed(() => {\n if (!anchorRef.value || !markerRef.value || !currentAnchor.value) return {}\n const currentLinkEl = links[currentAnchor.value]\n if (!currentLinkEl) return {}\n const anchorRect = anchorRef.value.getBoundingClientRect()\n const markerRect = markerRef.value.getBoundingClientRect()\n const linkRect = currentLinkEl.getBoundingClientRect()\n\n if (props.direction === 'horizontal') {\n const left = linkRect.left - anchorRect.left\n return {\n left: `${left}px`,\n width: `${linkRect.width}px`,\n opacity: 1,\n }\n } else {\n const top =\n linkRect.top - anchorRect.top + (linkRect.height - markerRect.height) / 2\n return {\n top: `${top}px`,\n opacity: 1,\n }\n }\n})\n\nonMounted(() => {\n getContainer()\n const hash = decodeURIComponent(window.location.hash)\n const target = getElement(hash)\n if (target) {\n scrollTo(hash)\n } else {\n handleScroll()\n }\n})\n\nwatch(\n () => props.container,\n () => {\n getContainer()\n }\n)\n\nprovide(anchorKey, {\n ns,\n direction: props.direction,\n currentAnchor,\n addLink,\n removeLink,\n handleClick,\n})\n\ndefineExpose({\n scrollTo,\n})\n</script>\n"],"names":["ref","useNamespace","computed","getElement","getScrollElement","getOffsetTopDistance","animateScrollTo","throttleByRaf","getScrollTop","isUndefined","isWindow","useEventListener","onMounted","watch","provide","anchorKey"],"mappings":"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"}
1
+ {"version":3,"file":"anchor2.js","sources":["../../../../../../packages/components/anchor/src/anchor.ts"],"sourcesContent":["import {\n buildProps,\n definePropType,\n isString,\n isUndefined,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Anchor from './anchor.vue'\n\nexport const anchorProps = buildProps({\n /**\n * @description scroll container\n */\n container: {\n type: definePropType<string | HTMLElement | Window | null>([\n String,\n Object,\n ]),\n },\n /**\n * @description Set the offset of the anchor scroll\n */\n offset: {\n type: Number,\n default: 0,\n },\n /**\n * @description The offset of the element starting to trigger the anchor\n */\n bound: {\n type: Number,\n default: 15,\n },\n /**\n * @description Set the scroll duration of the container when the anchor is clicked, in milliseconds\n */\n duration: {\n type: Number,\n default: 300,\n },\n /**\n * @description Whether to show the marker\n */\n marker: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Set Anchor type\n */\n type: {\n type: definePropType<'default' | 'underline'>(String),\n default: 'default',\n },\n /**\n * @description Set Anchor direction\n */\n direction: {\n type: definePropType<'vertical' | 'horizontal'>(String),\n default: 'vertical',\n },\n /**\n * @description Scroll whether link is selected at the top\n */\n selectScrollTop: {\n type: Boolean,\n default: false,\n },\n})\n\nexport type AnchorProps = ExtractPropTypes<typeof anchorProps>\nexport type AnchorInstance = InstanceType<typeof Anchor>\n\nexport const anchorEmits = {\n change: (href: string) => isString(href),\n click: (e: MouseEvent, href?: string) =>\n e instanceof MouseEvent && (isString(href) || isUndefined(href)),\n}\nexport type AnchorEmits = typeof anchorEmits\n"],"names":["buildProps","definePropType","isString","isUndefined"],"mappings":";;;;;;;;AAMY,MAAC,WAAW,GAAGA,kBAAU,CAAC;AACtC,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAEC,sBAAc,CAAC;AACzB,MAAM,MAAM;AACZ,MAAM,MAAM;AACZ,KAAK,CAAC;AACN,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAEA,sBAAc,CAAC,MAAM,CAAC;AAChC,IAAI,OAAO,EAAE,SAAS;AACtB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAEA,sBAAc,CAAC,MAAM,CAAC;AAChC,IAAI,OAAO,EAAE,UAAU;AACvB,GAAG;AACH,EAAE,eAAe,EAAE;AACnB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,WAAW,GAAG;AAC3B,EAAE,MAAM,EAAE,CAAC,IAAI,KAAKC,eAAQ,CAAC,IAAI,CAAC;AAClC,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,IAAI,KAAK,CAAC,YAAY,UAAU,KAAKA,eAAQ,CAAC,IAAI,CAAC,IAAIC,iBAAW,CAAC,IAAI,CAAC,CAAC;AACtF;;;;;"}
@@ -202,6 +202,9 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
202
202
  inputRef.value.ref.setAttribute("aria-activedescendant", `${listboxId.value}-item-${highlightedIndex.value}`);
203
203
  };
204
204
  const stopHandle = core.onClickOutside(listboxRef, () => {
205
+ var _a;
206
+ if ((_a = popperRef.value) == null ? void 0 : _a.isFocusInsideContent())
207
+ return;
205
208
  suggestionVisible.value && close();
206
209
  });
207
210
  vue.onBeforeUnmount(() => {
@@ -1 +1 @@
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 { 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 = 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 highlightedIndex: Ref<number>\n activated: Ref<boolean>\n loading: Ref<boolean>\n inputRef: Ref<InputInstance | undefined>\n popperRef: Ref<TooltipInstance | undefined>\n suggestions: Ref<AutocompleteData>\n handleSelect: (item: any) => void\n handleKeyEnter: () => void\n focus: () => void\n blur: () => void\n close: () => void\n highlight: (index: number) => void\n getData: (queryString: string) => void\n}>({\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"],"names":["useAttrs","useRawAttrs","useFormDisabled","useNamespace","ref","useId","computed","isArray","throwError","debounce","INPUT_EVENT","UPDATE_MODEL_EVENT","CHANGE_EVENT","onClickOutside","onBeforeUnmount","onMounted","_openBlock","_createBlock","_unref","ElTooltip"],"mappings":"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"}
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 { 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 = 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 // Prevent closing if focus is inside popper content\n if (popperRef.value?.isFocusInsideContent()) return\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 highlightedIndex: Ref<number>\n activated: Ref<boolean>\n loading: Ref<boolean>\n inputRef: Ref<InputInstance | undefined>\n popperRef: Ref<TooltipInstance | undefined>\n suggestions: Ref<AutocompleteData>\n handleSelect: (item: any) => void\n handleKeyEnter: () => void\n focus: () => void\n blur: () => void\n close: () => void\n highlight: (index: number) => void\n getData: (queryString: string) => void\n}>({\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"],"names":["useAttrs","useRawAttrs","useFormDisabled","useNamespace","ref","useId","computed","isArray","throwError","debounce","INPUT_EVENT","UPDATE_MODEL_EVENT","CHANGE_EVENT","onClickOutside","onBeforeUnmount","onMounted","_openBlock","_createBlock","_unref","ElTooltip"],"mappings":"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"}
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var badge$1 = require('./src/badge2.js');
6
- var badge = require('./src/badge.js');
5
+ var badge$1 = require('./src/badge.js');
6
+ var badge = require('./src/badge2.js');
7
7
  var install = require('../../utils/vue/install.js');
8
8
 
9
9
  const ElBadge = install.withInstall(badge$1["default"]);
@@ -2,40 +2,79 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var runtime = require('../../../utils/vue/props/runtime.js');
5
+ var vue = require('vue');
6
+ var badge = require('./badge2.js');
7
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
8
+ var index = require('../../../hooks/use-namespace/index.js');
9
+ var types = require('../../../utils/types.js');
10
+ var style = require('../../../utils/dom/style.js');
6
11
 
7
- const badgeProps = runtime.buildProps({
8
- value: {
9
- type: [String, Number],
10
- default: ""
11
- },
12
- max: {
13
- type: Number,
14
- default: 99
15
- },
16
- isDot: Boolean,
17
- hidden: Boolean,
18
- type: {
19
- type: String,
20
- values: ["primary", "success", "warning", "info", "danger"],
21
- default: "danger"
22
- },
23
- showZero: {
24
- type: Boolean,
25
- default: true
26
- },
27
- color: String,
28
- badgeStyle: {
29
- type: runtime.definePropType([String, Object, Array])
30
- },
31
- offset: {
32
- type: runtime.definePropType(Array),
33
- default: [0, 0]
34
- },
35
- badgeClass: {
36
- type: String
12
+ const __default__ = vue.defineComponent({
13
+ name: "ElBadge"
14
+ });
15
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
16
+ ...__default__,
17
+ props: badge.badgeProps,
18
+ setup(__props, { expose }) {
19
+ const props = __props;
20
+ const ns = index.useNamespace("badge");
21
+ const content = vue.computed(() => {
22
+ if (props.isDot)
23
+ return "";
24
+ if (types.isNumber(props.value) && types.isNumber(props.max)) {
25
+ return props.max < props.value ? `${props.max}+` : `${props.value}`;
26
+ }
27
+ return `${props.value}`;
28
+ });
29
+ const style$1 = vue.computed(() => {
30
+ var _a, _b, _c, _d, _e;
31
+ return [
32
+ {
33
+ backgroundColor: props.color,
34
+ marginRight: style.addUnit(-((_b = (_a = props.offset) == null ? void 0 : _a[0]) != null ? _b : 0)),
35
+ marginTop: style.addUnit((_d = (_c = props.offset) == null ? void 0 : _c[1]) != null ? _d : 0)
36
+ },
37
+ (_e = props.badgeStyle) != null ? _e : {}
38
+ ];
39
+ });
40
+ expose({
41
+ content
42
+ });
43
+ return (_ctx, _cache) => {
44
+ return vue.openBlock(), vue.createElementBlock("div", {
45
+ class: vue.normalizeClass(vue.unref(ns).b())
46
+ }, [
47
+ vue.renderSlot(_ctx.$slots, "default"),
48
+ vue.createVNode(vue.Transition, {
49
+ name: `${vue.unref(ns).namespace.value}-zoom-in-center`,
50
+ persisted: ""
51
+ }, {
52
+ default: vue.withCtx(() => [
53
+ vue.withDirectives(vue.createElementVNode("sup", {
54
+ class: vue.normalizeClass([
55
+ vue.unref(ns).e("content"),
56
+ vue.unref(ns).em("content", _ctx.type),
57
+ vue.unref(ns).is("fixed", !!_ctx.$slots.default),
58
+ vue.unref(ns).is("dot", _ctx.isDot),
59
+ vue.unref(ns).is("hide-zero", !_ctx.showZero && props.value === 0),
60
+ _ctx.badgeClass
61
+ ]),
62
+ style: vue.normalizeStyle(vue.unref(style$1))
63
+ }, [
64
+ vue.renderSlot(_ctx.$slots, "content", { value: vue.unref(content) }, () => [
65
+ vue.createTextVNode(vue.toDisplayString(vue.unref(content)), 1)
66
+ ])
67
+ ], 6), [
68
+ [vue.vShow, !_ctx.hidden && (vue.unref(content) || _ctx.isDot || _ctx.$slots.content)]
69
+ ])
70
+ ]),
71
+ _: 3
72
+ }, 8, ["name"])
73
+ ], 2);
74
+ };
37
75
  }
38
76
  });
77
+ var Badge = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "badge.vue"]]);
39
78
 
40
- exports.badgeProps = badgeProps;
79
+ exports["default"] = Badge;
41
80
  //# sourceMappingURL=badge.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"badge.js","sources":["../../../../../../packages/components/badge/src/badge.ts"],"sourcesContent":["import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes, StyleValue } from 'vue'\n\nexport const badgeProps = buildProps({\n /**\n * @description display value.\n */\n value: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description maximum value, shows `{max}+` when exceeded. Only works if value is a number.\n */\n max: {\n type: Number,\n default: 99,\n },\n /**\n * @description if a little dot is displayed.\n */\n isDot: Boolean,\n /**\n * @description hidden badge.\n */\n hidden: Boolean,\n /**\n * @description badge type.\n */\n type: {\n type: String,\n values: ['primary', 'success', 'warning', 'info', 'danger'],\n default: 'danger',\n },\n /**\n * @description whether to show badge when value is zero.\n */\n showZero: {\n type: Boolean,\n default: true,\n },\n /**\n * @description customize dot background color\n */\n color: String,\n /**\n * @description CSS style of badge\n */\n badgeStyle: {\n type: definePropType<StyleValue>([String, Object, Array]),\n },\n /**\n * @description set offset of the badge\n */\n offset: {\n type: definePropType<[number, number]>(Array),\n default: [0, 0],\n },\n /**\n * @description custom class name of badge\n */\n badgeClass: {\n type: String,\n },\n} as const)\nexport type BadgeProps = ExtractPropTypes<typeof badgeProps>\n"],"names":["buildProps","definePropType"],"mappings":";;;;;;AACY,MAAC,UAAU,GAAGA,kBAAU,CAAC;AACrC,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,GAAG,EAAE;AACP,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,KAAK,EAAE,OAAO;AAChB,EAAE,MAAM,EAAE,OAAO;AACjB,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC;AAC/D,IAAI,OAAO,EAAE,QAAQ;AACrB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAEC,sBAAc,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AACjD,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAEA,sBAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;AACnB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,MAAM;AAChB,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"badge.js","sources":["../../../../../../packages/components/badge/src/badge.vue"],"sourcesContent":["<template>\n <div :class=\"ns.b()\">\n <slot />\n <transition :name=\"`${ns.namespace.value}-zoom-in-center`\">\n <sup\n v-show=\"!hidden && (content || isDot || $slots.content)\"\n :class=\"[\n ns.e('content'),\n ns.em('content', type),\n ns.is('fixed', !!$slots.default),\n ns.is('dot', isDot),\n ns.is('hide-zero', !showZero && props.value === 0),\n badgeClass,\n ]\"\n :style=\"style\"\n >\n <slot name=\"content\" :value=\"content\">\n {{ content }}\n </slot>\n </sup>\n </transition>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { addUnit, isNumber } from '@element-plus/utils'\nimport { badgeProps } from './badge'\nimport type { StyleValue } from 'vue'\n\ndefineOptions({\n name: 'ElBadge',\n})\n\nconst props = defineProps(badgeProps)\n\nconst ns = useNamespace('badge')\n\nconst content = computed<string>(() => {\n if (props.isDot) return ''\n if (isNumber(props.value) && isNumber(props.max)) {\n return props.max < props.value ? `${props.max}+` : `${props.value}`\n }\n return `${props.value}`\n})\n\nconst style = computed<StyleValue>(() => {\n return [\n {\n backgroundColor: props.color,\n marginRight: addUnit(-(props.offset?.[0] ?? 0)),\n marginTop: addUnit(props.offset?.[1] ?? 0),\n },\n props.badgeStyle ?? {},\n ]\n})\n\ndefineExpose({\n /** @description badge content */\n content,\n})\n</script>\n"],"names":["useNamespace","computed","isNumber","style","addUnit"],"mappings":";;;;;;;;;;;uCA+Bc,CAAA;AAAA,EACZ,IAAM,EAAA,SAAA;AACR,CAAA,CAAA,CAAA;;;;;;AAIA,IAAM,MAAA,EAAA,GAAKA,mBAAa,OAAO,CAAA,CAAA;AAE/B,IAAM,MAAA,OAAA,GAAUC,aAAiB,MAAM;AACrC,MAAI,IAAA,KAAA,CAAM;AACV,QAAA;AACE,MAAO,IAAAC,cAAA,CAAA,KAAY,CAAA,KAAA,CAAA,IAAcA,cAAA,CAAG,MAAM,GAAG,CAAA,EAAA;AAAoB,QACnE,OAAA,KAAA,CAAA,GAAA,GAAA,KAAA,CAAA,KAAA,GAAA,CAAA,EAAA,KAAA,CAAA,GAAA,CAAA,CAAA,CAAA,GAAA,CAAA,EAAA,KAAA,CAAA,KAAA,CAAA,CAAA,CAAA;AACA,OAAO;AAAc,MACtB,OAAA,CAAA,EAAA,KAAA,CAAA,KAAA,CAAA,CAAA,CAAA;AAED,KAAM,CAAA,CAAA;AACJ,IAAO,MAAAC,OAAA,GAAAF,YAAA,CAAA,MAAA;AAAA,MACL,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,CAAA;AAAA,MAAA;AACyB,QAAA;AACuB,UAC9C,eAAmB,EAAA,KAAA,CAAA,KAAe;AAAO,UAC3C,WAAA,EAAAG,aAAA,CAAA,EAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,KAAA,CAAA,MAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,CAAA,CAAA,KAAA,IAAA,GAAA,EAAA,GAAA,CAAA,CAAA,CAAA;AAAA,UACA,wBAAoB,CAAC,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,KAAA,CAAA,MAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,CAAA,CAAA,KAAA,IAAA,GAAA,EAAA,GAAA,CAAA,CAAA;AAAA,SACvB;AAAA,QACD,CAAA,EAAA,GAAA,KAAA,CAAA,UAAA,KAAA,IAAA,GAAA,EAAA,GAAA,EAAA;AAED,OAAa,CAAA;AAAA,KAAA,CAAA,CAAA;AAAA,IAEX,MAAA,CAAA;AAAA,MACD,OAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}