@element-plus/nightly 0.0.20260505 → 0.0.20260506

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 (633) hide show
  1. package/dist/index.full.js +2 -2
  2. package/dist/index.full.min.js +2 -2
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +2 -2
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +2 -2
  7. package/dist/locale/af.js +1 -1
  8. package/dist/locale/af.min.js +1 -1
  9. package/dist/locale/af.min.mjs +1 -1
  10. package/dist/locale/af.mjs +1 -1
  11. package/dist/locale/ar-eg.js +1 -1
  12. package/dist/locale/ar-eg.min.js +1 -1
  13. package/dist/locale/ar-eg.min.mjs +1 -1
  14. package/dist/locale/ar-eg.mjs +1 -1
  15. package/dist/locale/ar.js +1 -1
  16. package/dist/locale/ar.min.js +1 -1
  17. package/dist/locale/ar.min.mjs +1 -1
  18. package/dist/locale/ar.mjs +1 -1
  19. package/dist/locale/az.js +1 -1
  20. package/dist/locale/az.min.js +1 -1
  21. package/dist/locale/az.min.mjs +1 -1
  22. package/dist/locale/az.mjs +1 -1
  23. package/dist/locale/bg.js +1 -1
  24. package/dist/locale/bg.min.js +1 -1
  25. package/dist/locale/bg.min.mjs +1 -1
  26. package/dist/locale/bg.mjs +1 -1
  27. package/dist/locale/bn.js +1 -1
  28. package/dist/locale/bn.min.js +1 -1
  29. package/dist/locale/bn.min.mjs +1 -1
  30. package/dist/locale/bn.mjs +1 -1
  31. package/dist/locale/ca.js +1 -1
  32. package/dist/locale/ca.min.js +1 -1
  33. package/dist/locale/ca.min.mjs +1 -1
  34. package/dist/locale/ca.mjs +1 -1
  35. package/dist/locale/ckb.js +1 -1
  36. package/dist/locale/ckb.min.js +1 -1
  37. package/dist/locale/ckb.min.mjs +1 -1
  38. package/dist/locale/ckb.mjs +1 -1
  39. package/dist/locale/cs.js +1 -1
  40. package/dist/locale/cs.min.js +1 -1
  41. package/dist/locale/cs.min.mjs +1 -1
  42. package/dist/locale/cs.mjs +1 -1
  43. package/dist/locale/da.js +1 -1
  44. package/dist/locale/da.min.js +1 -1
  45. package/dist/locale/da.min.mjs +1 -1
  46. package/dist/locale/da.mjs +1 -1
  47. package/dist/locale/de.js +1 -1
  48. package/dist/locale/de.min.js +1 -1
  49. package/dist/locale/de.min.mjs +1 -1
  50. package/dist/locale/de.mjs +1 -1
  51. package/dist/locale/el.js +1 -1
  52. package/dist/locale/el.min.js +1 -1
  53. package/dist/locale/el.min.mjs +1 -1
  54. package/dist/locale/el.mjs +1 -1
  55. package/dist/locale/en.js +1 -1
  56. package/dist/locale/en.min.js +1 -1
  57. package/dist/locale/en.min.mjs +1 -1
  58. package/dist/locale/en.mjs +1 -1
  59. package/dist/locale/eo.js +1 -1
  60. package/dist/locale/eo.min.js +1 -1
  61. package/dist/locale/eo.min.mjs +1 -1
  62. package/dist/locale/eo.mjs +1 -1
  63. package/dist/locale/es.js +1 -1
  64. package/dist/locale/es.min.js +1 -1
  65. package/dist/locale/es.min.mjs +1 -1
  66. package/dist/locale/es.mjs +1 -1
  67. package/dist/locale/et.js +1 -1
  68. package/dist/locale/et.min.js +1 -1
  69. package/dist/locale/et.min.mjs +1 -1
  70. package/dist/locale/et.mjs +1 -1
  71. package/dist/locale/eu.js +1 -1
  72. package/dist/locale/eu.min.js +1 -1
  73. package/dist/locale/eu.min.mjs +1 -1
  74. package/dist/locale/eu.mjs +1 -1
  75. package/dist/locale/fa.js +1 -1
  76. package/dist/locale/fa.min.js +1 -1
  77. package/dist/locale/fa.min.mjs +1 -1
  78. package/dist/locale/fa.mjs +1 -1
  79. package/dist/locale/fi.js +1 -1
  80. package/dist/locale/fi.min.js +1 -1
  81. package/dist/locale/fi.min.mjs +1 -1
  82. package/dist/locale/fi.mjs +1 -1
  83. package/dist/locale/fr.js +1 -1
  84. package/dist/locale/fr.min.js +1 -1
  85. package/dist/locale/fr.min.mjs +1 -1
  86. package/dist/locale/fr.mjs +1 -1
  87. package/dist/locale/he.js +1 -1
  88. package/dist/locale/he.min.js +1 -1
  89. package/dist/locale/he.min.mjs +1 -1
  90. package/dist/locale/he.mjs +1 -1
  91. package/dist/locale/hi.js +1 -1
  92. package/dist/locale/hi.min.js +1 -1
  93. package/dist/locale/hi.min.mjs +1 -1
  94. package/dist/locale/hi.mjs +1 -1
  95. package/dist/locale/hr.js +1 -1
  96. package/dist/locale/hr.min.js +1 -1
  97. package/dist/locale/hr.min.mjs +1 -1
  98. package/dist/locale/hr.mjs +1 -1
  99. package/dist/locale/hu.js +1 -1
  100. package/dist/locale/hu.min.js +1 -1
  101. package/dist/locale/hu.min.mjs +1 -1
  102. package/dist/locale/hu.mjs +1 -1
  103. package/dist/locale/hy-am.js +1 -1
  104. package/dist/locale/hy-am.min.js +1 -1
  105. package/dist/locale/hy-am.min.mjs +1 -1
  106. package/dist/locale/hy-am.mjs +1 -1
  107. package/dist/locale/id.js +1 -1
  108. package/dist/locale/id.min.js +1 -1
  109. package/dist/locale/id.min.mjs +1 -1
  110. package/dist/locale/id.mjs +1 -1
  111. package/dist/locale/it.js +1 -1
  112. package/dist/locale/it.min.js +1 -1
  113. package/dist/locale/it.min.mjs +1 -1
  114. package/dist/locale/it.mjs +1 -1
  115. package/dist/locale/ja.js +1 -1
  116. package/dist/locale/ja.min.js +1 -1
  117. package/dist/locale/ja.min.mjs +1 -1
  118. package/dist/locale/ja.mjs +1 -1
  119. package/dist/locale/kk.js +1 -1
  120. package/dist/locale/kk.min.js +1 -1
  121. package/dist/locale/kk.min.mjs +1 -1
  122. package/dist/locale/kk.mjs +1 -1
  123. package/dist/locale/km.js +1 -1
  124. package/dist/locale/km.min.js +1 -1
  125. package/dist/locale/km.min.mjs +1 -1
  126. package/dist/locale/km.mjs +1 -1
  127. package/dist/locale/ko.js +1 -1
  128. package/dist/locale/ko.min.js +1 -1
  129. package/dist/locale/ko.min.mjs +1 -1
  130. package/dist/locale/ko.mjs +1 -1
  131. package/dist/locale/ku.js +1 -1
  132. package/dist/locale/ku.min.js +1 -1
  133. package/dist/locale/ku.min.mjs +1 -1
  134. package/dist/locale/ku.mjs +1 -1
  135. package/dist/locale/ky.js +1 -1
  136. package/dist/locale/ky.min.js +1 -1
  137. package/dist/locale/ky.min.mjs +1 -1
  138. package/dist/locale/ky.mjs +1 -1
  139. package/dist/locale/lo.js +1 -1
  140. package/dist/locale/lo.min.js +1 -1
  141. package/dist/locale/lo.min.mjs +1 -1
  142. package/dist/locale/lo.mjs +1 -1
  143. package/dist/locale/lt.js +1 -1
  144. package/dist/locale/lt.min.js +1 -1
  145. package/dist/locale/lt.min.mjs +1 -1
  146. package/dist/locale/lt.mjs +1 -1
  147. package/dist/locale/lv.js +1 -1
  148. package/dist/locale/lv.min.js +1 -1
  149. package/dist/locale/lv.min.mjs +1 -1
  150. package/dist/locale/lv.mjs +1 -1
  151. package/dist/locale/mg.js +1 -1
  152. package/dist/locale/mg.min.js +1 -1
  153. package/dist/locale/mg.min.mjs +1 -1
  154. package/dist/locale/mg.mjs +1 -1
  155. package/dist/locale/mn.js +1 -1
  156. package/dist/locale/mn.min.js +1 -1
  157. package/dist/locale/mn.min.mjs +1 -1
  158. package/dist/locale/mn.mjs +1 -1
  159. package/dist/locale/ms.js +1 -1
  160. package/dist/locale/ms.min.js +1 -1
  161. package/dist/locale/ms.min.mjs +1 -1
  162. package/dist/locale/ms.mjs +1 -1
  163. package/dist/locale/my.js +1 -1
  164. package/dist/locale/my.min.js +1 -1
  165. package/dist/locale/my.min.mjs +1 -1
  166. package/dist/locale/my.mjs +1 -1
  167. package/dist/locale/nb-no.js +1 -1
  168. package/dist/locale/nb-no.min.js +1 -1
  169. package/dist/locale/nb-no.min.mjs +1 -1
  170. package/dist/locale/nb-no.mjs +1 -1
  171. package/dist/locale/nl.js +1 -1
  172. package/dist/locale/nl.min.js +1 -1
  173. package/dist/locale/nl.min.mjs +1 -1
  174. package/dist/locale/nl.mjs +1 -1
  175. package/dist/locale/no.js +1 -1
  176. package/dist/locale/no.min.js +1 -1
  177. package/dist/locale/no.min.mjs +1 -1
  178. package/dist/locale/no.mjs +1 -1
  179. package/dist/locale/pa.js +1 -1
  180. package/dist/locale/pa.min.js +1 -1
  181. package/dist/locale/pa.min.mjs +1 -1
  182. package/dist/locale/pa.mjs +1 -1
  183. package/dist/locale/pl.js +1 -1
  184. package/dist/locale/pl.min.js +1 -1
  185. package/dist/locale/pl.min.mjs +1 -1
  186. package/dist/locale/pl.mjs +1 -1
  187. package/dist/locale/pt-br.js +1 -1
  188. package/dist/locale/pt-br.min.js +1 -1
  189. package/dist/locale/pt-br.min.mjs +1 -1
  190. package/dist/locale/pt-br.mjs +1 -1
  191. package/dist/locale/pt.js +1 -1
  192. package/dist/locale/pt.min.js +1 -1
  193. package/dist/locale/pt.min.mjs +1 -1
  194. package/dist/locale/pt.mjs +1 -1
  195. package/dist/locale/ro.js +1 -1
  196. package/dist/locale/ro.min.js +1 -1
  197. package/dist/locale/ro.min.mjs +1 -1
  198. package/dist/locale/ro.mjs +1 -1
  199. package/dist/locale/ru.js +1 -1
  200. package/dist/locale/ru.min.js +1 -1
  201. package/dist/locale/ru.min.mjs +1 -1
  202. package/dist/locale/ru.mjs +1 -1
  203. package/dist/locale/sk.js +1 -1
  204. package/dist/locale/sk.min.js +1 -1
  205. package/dist/locale/sk.min.mjs +1 -1
  206. package/dist/locale/sk.mjs +1 -1
  207. package/dist/locale/sl.js +1 -1
  208. package/dist/locale/sl.min.js +1 -1
  209. package/dist/locale/sl.min.mjs +1 -1
  210. package/dist/locale/sl.mjs +1 -1
  211. package/dist/locale/sr.js +1 -1
  212. package/dist/locale/sr.min.js +1 -1
  213. package/dist/locale/sr.min.mjs +1 -1
  214. package/dist/locale/sr.mjs +1 -1
  215. package/dist/locale/sv.js +1 -1
  216. package/dist/locale/sv.min.js +1 -1
  217. package/dist/locale/sv.min.mjs +1 -1
  218. package/dist/locale/sv.mjs +1 -1
  219. package/dist/locale/sw.js +1 -1
  220. package/dist/locale/sw.min.js +1 -1
  221. package/dist/locale/sw.min.mjs +1 -1
  222. package/dist/locale/sw.mjs +1 -1
  223. package/dist/locale/ta.js +1 -1
  224. package/dist/locale/ta.min.js +1 -1
  225. package/dist/locale/ta.min.mjs +1 -1
  226. package/dist/locale/ta.mjs +1 -1
  227. package/dist/locale/te.js +1 -1
  228. package/dist/locale/te.min.js +1 -1
  229. package/dist/locale/te.min.mjs +1 -1
  230. package/dist/locale/te.mjs +1 -1
  231. package/dist/locale/th.js +1 -1
  232. package/dist/locale/th.min.js +1 -1
  233. package/dist/locale/th.min.mjs +1 -1
  234. package/dist/locale/th.mjs +1 -1
  235. package/dist/locale/tk.js +1 -1
  236. package/dist/locale/tk.min.js +1 -1
  237. package/dist/locale/tk.min.mjs +1 -1
  238. package/dist/locale/tk.mjs +1 -1
  239. package/dist/locale/tr.js +1 -1
  240. package/dist/locale/tr.min.js +1 -1
  241. package/dist/locale/tr.min.mjs +1 -1
  242. package/dist/locale/tr.mjs +1 -1
  243. package/dist/locale/ug-cn.js +1 -1
  244. package/dist/locale/ug-cn.min.js +1 -1
  245. package/dist/locale/ug-cn.min.mjs +1 -1
  246. package/dist/locale/ug-cn.mjs +1 -1
  247. package/dist/locale/uk.js +1 -1
  248. package/dist/locale/uk.min.js +1 -1
  249. package/dist/locale/uk.min.mjs +1 -1
  250. package/dist/locale/uk.mjs +1 -1
  251. package/dist/locale/uz-uz.js +1 -1
  252. package/dist/locale/uz-uz.min.js +1 -1
  253. package/dist/locale/uz-uz.min.mjs +1 -1
  254. package/dist/locale/uz-uz.mjs +1 -1
  255. package/dist/locale/vi.js +1 -1
  256. package/dist/locale/vi.min.js +1 -1
  257. package/dist/locale/vi.min.mjs +1 -1
  258. package/dist/locale/vi.mjs +1 -1
  259. package/dist/locale/zh-cn.js +1 -1
  260. package/dist/locale/zh-cn.min.js +1 -1
  261. package/dist/locale/zh-cn.min.mjs +1 -1
  262. package/dist/locale/zh-cn.mjs +1 -1
  263. package/dist/locale/zh-hk.js +1 -1
  264. package/dist/locale/zh-hk.min.js +1 -1
  265. package/dist/locale/zh-hk.min.mjs +1 -1
  266. package/dist/locale/zh-hk.mjs +1 -1
  267. package/dist/locale/zh-mo.js +1 -1
  268. package/dist/locale/zh-mo.min.js +1 -1
  269. package/dist/locale/zh-mo.min.mjs +1 -1
  270. package/dist/locale/zh-mo.mjs +1 -1
  271. package/dist/locale/zh-tw.js +1 -1
  272. package/dist/locale/zh-tw.min.js +1 -1
  273. package/dist/locale/zh-tw.min.mjs +1 -1
  274. package/dist/locale/zh-tw.mjs +1 -1
  275. package/es/component.mjs +3 -3
  276. package/es/components/affix/src/affix.vue.d.ts +4 -4
  277. package/es/components/alert/src/alert.d.ts +1 -1
  278. package/es/components/alert/src/alert.vue.d.ts +2 -2
  279. package/es/components/anchor/src/anchor.vue.d.ts +3 -3
  280. package/es/components/autocomplete/src/autocomplete.d.ts +3 -3
  281. package/es/components/autocomplete/src/autocomplete.vue.d.ts +5 -5
  282. package/es/components/avatar/src/avatar.d.ts +1 -1
  283. package/es/components/backtop/src/backtop.vue.d.ts +1 -1
  284. package/es/components/badge/src/badge.d.ts +1 -1
  285. package/es/components/button/src/button-group.vue.d.ts +1 -1
  286. package/es/components/button/src/button.d.ts +1 -1
  287. package/es/components/button/src/button.vue.d.ts +3 -3
  288. package/es/components/calendar/src/calendar.d.ts +1 -1
  289. package/es/components/calendar/src/calendar.vue.d.ts +1 -1
  290. package/es/components/card/src/card.d.ts +1 -1
  291. package/es/components/card/src/card.vue.d.ts +1 -1
  292. package/es/components/carousel/src/carousel-item.vue.d.ts +1 -1
  293. package/es/components/carousel/src/carousel.d.ts +1 -1
  294. package/es/components/carousel/src/carousel.vue.d.ts +2 -2
  295. package/es/components/cascader/src/cascader.d.ts +4 -4
  296. package/es/components/cascader/src/cascader.vue.d.ts +12 -12
  297. package/es/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.mjs +2 -2
  298. package/es/components/cascader-panel/src/index.vue.d.ts +6 -6
  299. package/es/components/cascader-panel/src/index.vue_vue_type_script_setup_true_lang.mjs +1 -1
  300. package/es/components/cascader-panel/src/menu.vue.d.ts +2 -2
  301. package/es/components/check-tag/src/check-tag.d.ts +1 -1
  302. package/es/components/checkbox/src/checkbox-button.vue.d.ts +5 -5
  303. package/es/components/checkbox/src/checkbox-group.vue.d.ts +5 -5
  304. package/es/components/checkbox/src/checkbox.d.ts +8 -8
  305. package/es/components/checkbox/src/checkbox.vue.d.ts +5 -5
  306. package/es/components/col/src/col.vue.d.ts +1 -1
  307. package/es/components/collapse/src/collapse.d.ts +1 -1
  308. package/es/components/collapse/src/collapse.vue.d.ts +1 -1
  309. package/es/components/color-picker/src/color-picker.vue.d.ts +8 -8
  310. package/es/components/color-picker/src/color-picker.vue_vue_type_script_setup_true_lang.mjs +1 -1
  311. package/es/components/config-provider/src/hooks/use-global-config.d.ts +1 -1
  312. package/es/components/countdown/src/countdown.vue.d.ts +2 -2
  313. package/es/components/countdown/src/countdown.vue_vue_type_script_setup_true_lang.mjs +1 -1
  314. package/es/components/date-picker/src/date-picker.d.ts +8 -8
  315. package/es/components/date-picker/src/props.d.ts +1 -1
  316. package/es/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue_vue_type_script_setup_true_lang.mjs +1 -1
  317. package/es/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.mjs +1 -1
  318. package/es/components/date-picker-panel/src/date-picker-panel.d.ts +3 -3
  319. package/es/components/descriptions/src/description-item.d.ts +19 -19
  320. package/es/components/descriptions/src/description.vue.d.ts +1 -1
  321. package/es/components/dialog/src/dialog.vue.d.ts +5 -5
  322. package/es/components/divider/src/divider.d.ts +1 -1
  323. package/es/components/divider/src/divider.vue.d.ts +1 -1
  324. package/es/components/drawer/src/drawer.vue.d.ts +6 -6
  325. package/es/components/dropdown/src/dropdown-item.vue.d.ts +4 -4
  326. package/es/components/dropdown/src/dropdown-menu.vue.d.ts +1 -1
  327. package/es/components/dropdown/src/dropdown.d.ts +3 -3
  328. package/es/components/dropdown/src/dropdown.vue.d.ts +56 -56
  329. package/es/components/focus-trap/src/focus-trap.vue.d.ts +1 -1
  330. package/es/components/form/src/form-item.d.ts +2 -2
  331. package/es/components/form/src/form-item.vue.d.ts +1 -1
  332. package/es/components/form/src/form.d.ts +2 -2
  333. package/es/components/form/src/form.vue.d.ts +1 -1
  334. package/es/components/image/src/image.d.ts +1 -1
  335. package/es/components/image/src/image.vue.d.ts +4 -4
  336. package/es/components/image-viewer/src/image-viewer.vue.d.ts +2 -2
  337. package/es/components/index.mjs +6 -6
  338. package/es/components/input/src/input.d.ts +2 -2
  339. package/es/components/input/src/input.vue.d.ts +16 -16
  340. package/es/components/input-number/src/input-number.d.ts +2 -2
  341. package/es/components/input-number/src/input-number.vue.d.ts +7 -7
  342. package/es/components/input-number/src/input-number.vue_vue_type_script_setup_true_lang.mjs +1 -1
  343. package/es/components/input-otp/src/input-otp.vue.d.ts +8 -8
  344. package/es/components/input-tag/src/input-tag.d.ts +1 -1
  345. package/es/components/input-tag/src/input-tag.vue.d.ts +10 -10
  346. package/es/components/link/src/link.d.ts +2 -2
  347. package/es/components/mention/src/mention.d.ts +2 -2
  348. package/es/components/mention/src/mention.vue.d.ts +4 -4
  349. package/es/components/menu/src/menu.d.ts +2 -2
  350. package/es/components/menu/src/menu.mjs +1 -1
  351. package/es/components/menu/src/utils/menu-item.mjs +1 -1
  352. package/es/components/menu/src/utils/submenu.mjs +1 -1
  353. package/es/components/message/src/message.d.ts +2 -2
  354. package/es/components/message/src/message.vue.d.ts +3 -3
  355. package/es/components/message-box/src/index.vue_vue_type_script_lang.mjs +1 -1
  356. package/es/components/notification/src/notification.d.ts +2 -2
  357. package/es/components/notification/src/notification.vue.d.ts +4 -4
  358. package/es/components/page-header/src/page-header.vue.d.ts +1 -1
  359. package/es/components/pagination/src/pagination.d.ts +4 -4
  360. package/es/components/popconfirm/src/popconfirm.d.ts +2 -2
  361. package/es/components/popconfirm/src/popconfirm.vue.d.ts +2 -2
  362. package/es/components/popover/src/popover.d.ts +2 -2
  363. package/es/components/popover/src/popover.vue.d.ts +5 -5
  364. package/es/components/popper/src/composables/use-content.d.ts +4 -4
  365. package/es/components/popper/src/composables/use-focus-trap.d.ts +1 -1
  366. package/es/components/popper/src/content.vue.d.ts +6 -6
  367. package/es/components/popper/src/popper.d.ts +2 -2
  368. package/es/components/progress/src/progress.vue.d.ts +1 -1
  369. package/es/components/radio/src/radio-button.d.ts +3 -3
  370. package/es/components/radio/src/radio-button.vue.d.ts +3 -3
  371. package/es/components/radio/src/radio-group.vue.d.ts +5 -5
  372. package/es/components/radio/src/radio.d.ts +6 -6
  373. package/es/components/radio/src/radio.vue.d.ts +5 -5
  374. package/es/components/rate/src/rate.vue.d.ts +2 -2
  375. package/es/components/result/src/result.d.ts +1 -1
  376. package/es/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  377. package/es/components/row/src/row.d.ts +1 -1
  378. package/es/components/row/src/row.vue.d.ts +1 -1
  379. package/es/components/scrollbar/src/scrollbar.vue.d.ts +2 -2
  380. package/es/components/segmented/index.d.ts +3 -3
  381. package/es/components/segmented/src/segmented.d.ts +1 -1
  382. package/es/components/segmented/src/segmented.vue.d.ts +1 -1
  383. package/es/components/select/src/option.d.ts +2 -2
  384. package/es/components/select/src/option.vue.d.ts +5 -5
  385. package/es/components/select/src/select.d.ts +4 -4
  386. package/es/components/select/src/select.vue.d.ts +67 -67
  387. package/es/components/select/src/select.vue_vue_type_script_lang.mjs +1 -1
  388. package/es/components/select-v2/src/defaults.d.ts +2 -2
  389. package/es/components/select-v2/src/select.vue.d.ts +48 -48
  390. package/es/components/select-v2/src/select.vue_vue_type_script_lang.mjs +1 -1
  391. package/es/components/skeleton/src/skeleton-item.d.ts +1 -1
  392. package/es/components/slider/src/button.vue.d.ts +2 -2
  393. package/es/components/slider/src/slider.vue.d.ts +6 -6
  394. package/es/components/space/src/space.d.ts +2 -2
  395. package/es/components/splitter/src/splitter.vue.d.ts +2 -2
  396. package/es/components/steps/src/item.d.ts +1 -1
  397. package/es/components/steps/src/item.vue.d.ts +1 -1
  398. package/es/components/steps/src/steps.d.ts +2 -2
  399. package/es/components/switch/src/switch.vue.d.ts +4 -4
  400. package/es/components/table/src/table-column/index.d.ts +24 -24
  401. package/es/components/table/src/table-footer/index.d.ts +1 -1
  402. package/es/components/table/src/table-header/index.d.ts +15 -15
  403. package/es/components/table/src/table.vue.d.ts +40 -40
  404. package/es/components/table/src/table.vue_vue_type_script_lang.mjs +1 -1
  405. package/es/components/table-v2/src/table-grid.d.ts +1 -1
  406. package/es/components/table-v2/src/table-v2.d.ts +2 -2
  407. package/es/components/tabs/src/tabs.d.ts +4 -4
  408. package/es/components/tag/src/tag.d.ts +1 -1
  409. package/es/components/text/src/text.d.ts +1 -1
  410. package/es/components/time-picker/src/common/picker.vue.d.ts +12 -12
  411. package/es/components/time-picker/src/common/props.d.ts +1 -1
  412. package/es/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_setup_true_lang.mjs +1 -1
  413. package/es/components/time-picker/src/time-picker.d.ts +8 -8
  414. package/es/components/time-select/src/time-select.vue.d.ts +9 -9
  415. package/es/components/timeline/src/timeline-item.d.ts +1 -1
  416. package/es/components/timeline/src/timeline-item.vue.d.ts +1 -1
  417. package/es/components/tooltip/src/content.vue.d.ts +4 -4
  418. package/es/components/tooltip/src/tooltip.d.ts +2 -2
  419. package/es/components/tooltip/src/tooltip.vue.d.ts +10 -10
  420. package/es/components/tooltip/src/trigger.d.ts +1 -1
  421. package/es/components/tour/src/content.d.ts +1 -1
  422. package/es/components/tour/src/step.d.ts +1 -1
  423. package/es/components/tour/src/tour.d.ts +1 -1
  424. package/es/components/tour/src/tour.vue.d.ts +7 -7
  425. package/es/components/transfer/src/transfer.vue.d.ts +1 -1
  426. package/es/components/tree/src/tree.vue.d.ts +27 -27
  427. package/es/components/tree-select/src/tree-select.vue.d.ts +30 -30
  428. package/es/components/tree-v2/src/tree.vue.d.ts +14 -14
  429. package/es/components/upload/src/upload-content.vue.d.ts +1 -1
  430. package/es/components/upload/src/upload.vue.d.ts +2 -2
  431. package/es/components/virtual-list/src/builders/build-grid.d.ts +7 -7
  432. package/es/components/virtual-list/src/components/dynamic-size-grid.d.ts +7 -7
  433. package/es/components/virtual-list/src/components/dynamic-size-list.d.ts +8 -8
  434. package/es/components/virtual-list/src/components/fixed-size-grid.d.ts +7 -7
  435. package/es/components/virtual-list/src/components/fixed-size-list.d.ts +8 -8
  436. package/es/components/watermark/src/watermark.vue.d.ts +1 -1
  437. package/es/constants/index.mjs +2 -2
  438. package/es/directives/trap-focus/index.mjs +1 -1
  439. package/es/hooks/use-floating/index.d.ts +8 -8
  440. package/es/hooks/use-popper/index.d.ts +4 -4
  441. package/es/index.mjs +13 -13
  442. package/es/plugin.mjs +1 -1
  443. package/es/utils/vue/vnode.d.ts +4 -4
  444. package/es/version.mjs +1 -1
  445. package/es/version.mjs.map +1 -1
  446. package/lib/component.js +109 -109
  447. package/lib/components/affix/src/affix.vue.d.ts +4 -4
  448. package/lib/components/alert/src/alert.d.ts +1 -1
  449. package/lib/components/alert/src/alert.vue.d.ts +2 -2
  450. package/lib/components/anchor/src/anchor.vue.d.ts +3 -3
  451. package/lib/components/autocomplete/src/autocomplete.d.ts +3 -3
  452. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +5 -5
  453. package/lib/components/avatar/src/avatar.d.ts +1 -1
  454. package/lib/components/backtop/src/backtop.vue.d.ts +1 -1
  455. package/lib/components/badge/src/badge.d.ts +1 -1
  456. package/lib/components/button/src/button-group.vue.d.ts +1 -1
  457. package/lib/components/button/src/button.d.ts +1 -1
  458. package/lib/components/button/src/button.vue.d.ts +3 -3
  459. package/lib/components/calendar/src/calendar.d.ts +1 -1
  460. package/lib/components/calendar/src/calendar.vue.d.ts +1 -1
  461. package/lib/components/card/src/card.d.ts +1 -1
  462. package/lib/components/card/src/card.vue.d.ts +1 -1
  463. package/lib/components/carousel/src/carousel-item.vue.d.ts +1 -1
  464. package/lib/components/carousel/src/carousel.d.ts +1 -1
  465. package/lib/components/carousel/src/carousel.vue.d.ts +2 -2
  466. package/lib/components/cascader/src/cascader.d.ts +4 -4
  467. package/lib/components/cascader/src/cascader.vue.d.ts +12 -12
  468. package/lib/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.js +40 -40
  469. package/lib/components/cascader/src/cascader.vue_vue_type_script_setup_true_lang.js.map +1 -1
  470. package/lib/components/cascader-panel/src/index.vue.d.ts +6 -6
  471. package/lib/components/cascader-panel/src/index.vue_vue_type_script_setup_true_lang.js +12 -12
  472. package/lib/components/cascader-panel/src/index.vue_vue_type_script_setup_true_lang.js.map +1 -1
  473. package/lib/components/cascader-panel/src/menu.vue.d.ts +2 -2
  474. package/lib/components/check-tag/src/check-tag.d.ts +1 -1
  475. package/lib/components/checkbox/src/checkbox-button.vue.d.ts +5 -5
  476. package/lib/components/checkbox/src/checkbox-group.vue.d.ts +5 -5
  477. package/lib/components/checkbox/src/checkbox.d.ts +8 -8
  478. package/lib/components/checkbox/src/checkbox.vue.d.ts +5 -5
  479. package/lib/components/col/src/col.vue.d.ts +1 -1
  480. package/lib/components/collapse/src/collapse.d.ts +1 -1
  481. package/lib/components/collapse/src/collapse.vue.d.ts +1 -1
  482. package/lib/components/color-picker/src/color-picker.vue.d.ts +8 -8
  483. package/lib/components/color-picker/src/color-picker.vue_vue_type_script_setup_true_lang.js +18 -18
  484. package/lib/components/color-picker/src/color-picker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  485. package/lib/components/config-provider/src/hooks/use-global-config.d.ts +1 -1
  486. package/lib/components/countdown/src/countdown.vue.d.ts +2 -2
  487. package/lib/components/countdown/src/countdown.vue_vue_type_script_setup_true_lang.js +1 -1
  488. package/lib/components/date-picker/src/date-picker.d.ts +8 -8
  489. package/lib/components/date-picker/src/props.d.ts +1 -1
  490. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue_vue_type_script_setup_true_lang.js +18 -18
  491. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-pick.vue_vue_type_script_setup_true_lang.js.map +1 -1
  492. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.js +23 -23
  493. package/lib/components/date-picker-panel/src/date-picker-com/panel-date-range.vue_vue_type_script_setup_true_lang.js.map +1 -1
  494. package/lib/components/date-picker-panel/src/date-picker-panel.d.ts +3 -3
  495. package/lib/components/descriptions/src/description-item.d.ts +19 -19
  496. package/lib/components/descriptions/src/description.vue.d.ts +1 -1
  497. package/lib/components/dialog/src/dialog.vue.d.ts +5 -5
  498. package/lib/components/divider/src/divider.d.ts +1 -1
  499. package/lib/components/divider/src/divider.vue.d.ts +1 -1
  500. package/lib/components/drawer/src/drawer.vue.d.ts +6 -6
  501. package/lib/components/dropdown/src/dropdown-item.vue.d.ts +4 -4
  502. package/lib/components/dropdown/src/dropdown-menu.vue.d.ts +1 -1
  503. package/lib/components/dropdown/src/dropdown.d.ts +3 -3
  504. package/lib/components/dropdown/src/dropdown.vue.d.ts +56 -56
  505. package/lib/components/focus-trap/src/focus-trap.vue.d.ts +1 -1
  506. package/lib/components/form/src/form-item.d.ts +2 -2
  507. package/lib/components/form/src/form-item.vue.d.ts +1 -1
  508. package/lib/components/form/src/form.d.ts +2 -2
  509. package/lib/components/form/src/form.vue.d.ts +1 -1
  510. package/lib/components/image/src/image.d.ts +1 -1
  511. package/lib/components/image/src/image.vue.d.ts +4 -4
  512. package/lib/components/image-viewer/src/image-viewer.vue.d.ts +2 -2
  513. package/lib/components/index.js +125 -125
  514. package/lib/components/input/src/input.d.ts +2 -2
  515. package/lib/components/input/src/input.vue.d.ts +16 -16
  516. package/lib/components/input-number/src/input-number.d.ts +2 -2
  517. package/lib/components/input-number/src/input-number.vue.d.ts +7 -7
  518. package/lib/components/input-number/src/input-number.vue_vue_type_script_setup_true_lang.js +12 -12
  519. package/lib/components/input-number/src/input-number.vue_vue_type_script_setup_true_lang.js.map +1 -1
  520. package/lib/components/input-otp/src/input-otp.vue.d.ts +8 -8
  521. package/lib/components/input-tag/src/input-tag.d.ts +1 -1
  522. package/lib/components/input-tag/src/input-tag.vue.d.ts +10 -10
  523. package/lib/components/link/src/link.d.ts +2 -2
  524. package/lib/components/mention/src/mention.d.ts +2 -2
  525. package/lib/components/mention/src/mention.vue.d.ts +4 -4
  526. package/lib/components/menu/src/menu.d.ts +2 -2
  527. package/lib/components/menu/src/menu.js +7 -7
  528. package/lib/components/menu/src/menu.js.map +1 -1
  529. package/lib/components/menu/src/utils/menu-item.js +11 -11
  530. package/lib/components/menu/src/utils/menu-item.js.map +1 -1
  531. package/lib/components/menu/src/utils/submenu.js +9 -9
  532. package/lib/components/menu/src/utils/submenu.js.map +1 -1
  533. package/lib/components/message/src/message.d.ts +2 -2
  534. package/lib/components/message/src/message.vue.d.ts +3 -3
  535. package/lib/components/message-box/src/index.vue_vue_type_script_lang.js +19 -19
  536. package/lib/components/message-box/src/index.vue_vue_type_script_lang.js.map +1 -1
  537. package/lib/components/notification/src/notification.d.ts +2 -2
  538. package/lib/components/notification/src/notification.vue.d.ts +4 -4
  539. package/lib/components/page-header/src/page-header.vue.d.ts +1 -1
  540. package/lib/components/pagination/src/pagination.d.ts +4 -4
  541. package/lib/components/popconfirm/src/popconfirm.d.ts +2 -2
  542. package/lib/components/popconfirm/src/popconfirm.vue.d.ts +2 -2
  543. package/lib/components/popover/src/popover.d.ts +2 -2
  544. package/lib/components/popover/src/popover.vue.d.ts +5 -5
  545. package/lib/components/popper/src/composables/use-content.d.ts +4 -4
  546. package/lib/components/popper/src/composables/use-focus-trap.d.ts +1 -1
  547. package/lib/components/popper/src/content.vue.d.ts +6 -6
  548. package/lib/components/popper/src/popper.d.ts +2 -2
  549. package/lib/components/progress/src/progress.vue.d.ts +1 -1
  550. package/lib/components/radio/src/radio-button.d.ts +3 -3
  551. package/lib/components/radio/src/radio-button.vue.d.ts +3 -3
  552. package/lib/components/radio/src/radio-group.vue.d.ts +5 -5
  553. package/lib/components/radio/src/radio.d.ts +6 -6
  554. package/lib/components/radio/src/radio.vue.d.ts +5 -5
  555. package/lib/components/rate/src/rate.vue.d.ts +2 -2
  556. package/lib/components/result/src/result.d.ts +1 -1
  557. package/lib/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  558. package/lib/components/row/src/row.d.ts +1 -1
  559. package/lib/components/row/src/row.vue.d.ts +1 -1
  560. package/lib/components/scrollbar/src/scrollbar.vue.d.ts +2 -2
  561. package/lib/components/segmented/index.d.ts +3 -3
  562. package/lib/components/segmented/src/segmented.d.ts +1 -1
  563. package/lib/components/segmented/src/segmented.vue.d.ts +1 -1
  564. package/lib/components/select/src/option.d.ts +2 -2
  565. package/lib/components/select/src/option.vue.d.ts +5 -5
  566. package/lib/components/select/src/select.d.ts +4 -4
  567. package/lib/components/select/src/select.vue.d.ts +67 -67
  568. package/lib/components/select/src/select.vue_vue_type_script_lang.js +10 -10
  569. package/lib/components/select/src/select.vue_vue_type_script_lang.js.map +1 -1
  570. package/lib/components/select-v2/src/defaults.d.ts +2 -2
  571. package/lib/components/select-v2/src/select.vue.d.ts +48 -48
  572. package/lib/components/select-v2/src/select.vue_vue_type_script_lang.js +10 -10
  573. package/lib/components/select-v2/src/select.vue_vue_type_script_lang.js.map +1 -1
  574. package/lib/components/skeleton/src/skeleton-item.d.ts +1 -1
  575. package/lib/components/slider/src/button.vue.d.ts +2 -2
  576. package/lib/components/slider/src/slider.vue.d.ts +6 -6
  577. package/lib/components/space/src/space.d.ts +2 -2
  578. package/lib/components/splitter/src/splitter.vue.d.ts +2 -2
  579. package/lib/components/steps/src/item.d.ts +1 -1
  580. package/lib/components/steps/src/item.vue.d.ts +1 -1
  581. package/lib/components/steps/src/steps.d.ts +2 -2
  582. package/lib/components/switch/src/switch.vue.d.ts +4 -4
  583. package/lib/components/table/src/table-column/index.d.ts +24 -24
  584. package/lib/components/table/src/table-footer/index.d.ts +1 -1
  585. package/lib/components/table/src/table-header/index.d.ts +15 -15
  586. package/lib/components/table/src/table.vue.d.ts +40 -40
  587. package/lib/components/table/src/table.vue_vue_type_script_lang.js +8 -8
  588. package/lib/components/table/src/table.vue_vue_type_script_lang.js.map +1 -1
  589. package/lib/components/table-v2/src/table-grid.d.ts +1 -1
  590. package/lib/components/table-v2/src/table-v2.d.ts +2 -2
  591. package/lib/components/tabs/src/tabs.d.ts +4 -4
  592. package/lib/components/tag/src/tag.d.ts +1 -1
  593. package/lib/components/text/src/text.d.ts +1 -1
  594. package/lib/components/time-picker/src/common/picker.vue.d.ts +12 -12
  595. package/lib/components/time-picker/src/common/props.d.ts +1 -1
  596. package/lib/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_setup_true_lang.js +10 -10
  597. package/lib/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_setup_true_lang.js.map +1 -1
  598. package/lib/components/time-picker/src/time-picker.d.ts +8 -8
  599. package/lib/components/time-select/src/time-select.vue.d.ts +9 -9
  600. package/lib/components/timeline/src/timeline-item.d.ts +1 -1
  601. package/lib/components/timeline/src/timeline-item.vue.d.ts +1 -1
  602. package/lib/components/tooltip/src/content.vue.d.ts +4 -4
  603. package/lib/components/tooltip/src/tooltip.d.ts +2 -2
  604. package/lib/components/tooltip/src/tooltip.vue.d.ts +10 -10
  605. package/lib/components/tooltip/src/trigger.d.ts +1 -1
  606. package/lib/components/tour/src/content.d.ts +1 -1
  607. package/lib/components/tour/src/step.d.ts +1 -1
  608. package/lib/components/tour/src/tour.d.ts +1 -1
  609. package/lib/components/tour/src/tour.vue.d.ts +7 -7
  610. package/lib/components/transfer/src/transfer.vue.d.ts +1 -1
  611. package/lib/components/tree/src/tree.vue.d.ts +27 -27
  612. package/lib/components/tree-select/src/tree-select.vue.d.ts +30 -30
  613. package/lib/components/tree-v2/src/tree.vue.d.ts +14 -14
  614. package/lib/components/upload/src/upload-content.vue.d.ts +1 -1
  615. package/lib/components/upload/src/upload.vue.d.ts +2 -2
  616. package/lib/components/virtual-list/src/builders/build-grid.d.ts +7 -7
  617. package/lib/components/virtual-list/src/components/dynamic-size-grid.d.ts +7 -7
  618. package/lib/components/virtual-list/src/components/dynamic-size-list.d.ts +8 -8
  619. package/lib/components/virtual-list/src/components/fixed-size-grid.d.ts +7 -7
  620. package/lib/components/virtual-list/src/components/fixed-size-list.d.ts +8 -8
  621. package/lib/components/watermark/src/watermark.vue.d.ts +1 -1
  622. package/lib/constants/index.js +2 -2
  623. package/lib/directives/trap-focus/index.js +5 -5
  624. package/lib/directives/trap-focus/index.js.map +1 -1
  625. package/lib/hooks/use-floating/index.d.ts +8 -8
  626. package/lib/hooks/use-popper/index.d.ts +4 -4
  627. package/lib/index.js +269 -269
  628. package/lib/plugin.js +12 -12
  629. package/lib/utils/vue/vnode.d.ts +4 -4
  630. package/lib/version.js +1 -1
  631. package/lib/version.js.map +1 -1
  632. package/package.json +1 -1
  633. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"input-number.vue_vue_type_script_setup_true_lang.js","names":["$slots"],"sources":["../../../../../../packages/components/input-number/src/input-number.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ns.b(),\n ns.m(inputNumberSize),\n ns.is('disabled', inputNumberDisabled),\n ns.is('without-controls', !controls),\n ns.is('controls-right', controlsAtRight),\n ns.is(align, !!align),\n ]\"\n @dragstart.prevent\n >\n <span\n v-if=\"controls\"\n v-repeat-click=\"decrease\"\n role=\"button\"\n :aria-label=\"t('el.inputNumber.decrease')\"\n :class=\"[ns.e('decrease'), ns.is('disabled', minDisabled)]\"\n @keydown.enter=\"decrease\"\n >\n <slot name=\"decrease-icon\">\n <el-icon>\n <arrow-down v-if=\"controlsAtRight\" />\n <minus v-else />\n </el-icon>\n </slot>\n </span>\n <span\n v-if=\"controls\"\n v-repeat-click=\"increase\"\n role=\"button\"\n :aria-label=\"t('el.inputNumber.increase')\"\n :class=\"[ns.e('increase'), ns.is('disabled', maxDisabled)]\"\n @keydown.enter=\"increase\"\n >\n <slot name=\"increase-icon\">\n <el-icon>\n <arrow-up v-if=\"controlsAtRight\" />\n <plus v-else />\n </el-icon>\n </slot>\n </span>\n <el-input\n :id=\"id\"\n ref=\"input\"\n :type=\"formatter ? 'text' : 'number'\"\n :step=\"step\"\n :model-value=\"displayValue\"\n :placeholder=\"placeholder\"\n :readonly=\"readonly\"\n :disabled=\"inputNumberDisabled\"\n :size=\"inputNumberSize\"\n :max=\"max\"\n :min=\"min\"\n :name=\"name\"\n :aria-label=\"ariaLabel\"\n :validate-event=\"false\"\n :inputmode=\"inputmode\"\n :formatter=\"formatter\"\n :parser=\"parser\"\n :tabindex=\"tabindex\"\n @keydown=\"handleKeydown\"\n @blur=\"handleBlur\"\n @focus=\"handleFocus\"\n @input=\"handleInput\"\n @change=\"handleInputChange\"\n >\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>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, onUpdated, reactive, ref, watch } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { ElInput } from '@element-plus/components/input'\nimport { ElIcon } from '@element-plus/components/icon'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { vRepeatClick } from '@element-plus/directives'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport {\n NOOP,\n debugWarn,\n getEventCode,\n getEventKey,\n isNumber,\n isString,\n isUndefined,\n throwError,\n} from '@element-plus/utils'\nimport { ArrowDown, ArrowUp, Minus, Plus } from '@element-plus/icons-vue'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { inputNumberEmits } from './input-number'\n\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { InputNumberProps } from './input-number'\n\ndefineOptions({\n name: 'ElInputNumber',\n})\n\nconst props = withDefaults(defineProps<InputNumberProps>(), {\n id: undefined,\n disabled: undefined,\n step: 1,\n max: Number.MAX_SAFE_INTEGER,\n min: Number.MIN_SAFE_INTEGER,\n stepStrictly: false,\n readonly: false,\n controls: true,\n controlsPosition: '',\n valueOnClear: null,\n validateEvent: true,\n inputmode: undefined,\n align: 'center',\n tabindex: 0,\n})\nconst emit = defineEmits(inputNumberEmits)\n\nconst { t } = useLocale()\nconst ns = useNamespace('input-number')\nconst input = ref<InputInstance>()\n\ninterface Data {\n currentValue: number | null | undefined\n userInput: null | number | string\n}\nconst data = reactive<Data>({\n currentValue: props.modelValue,\n userInput: null,\n})\n\nconst { formItem } = useFormItem()\n\nconst minDisabled = computed(\n () => isNumber(props.modelValue) && props.modelValue <= props.min\n)\nconst maxDisabled = computed(\n () => isNumber(props.modelValue) && props.modelValue >= props.max\n)\n\nconst numPrecision = computed(() => {\n const stepPrecision = getPrecision(props.step)\n if (!isUndefined(props.precision)) {\n if (stepPrecision > props.precision) {\n debugWarn(\n 'InputNumber',\n 'precision should not be less than the decimal places of step'\n )\n }\n return props.precision\n } else {\n return Math.max(getPrecision(props.modelValue), stepPrecision)\n }\n})\nconst controlsAtRight = computed(() => {\n return props.controls && props.controlsPosition === 'right'\n})\n\nconst inputNumberSize = useFormSize()\nconst inputNumberDisabled = useFormDisabled()\n\nconst displayValue = computed(() => {\n if (data.userInput !== null) {\n return data.userInput\n }\n let currentValue: number | string | undefined | null = data.currentValue\n if (isNil(currentValue)) return ''\n if (isNumber(currentValue)) {\n if (Number.isNaN(currentValue)) return ''\n if (!isUndefined(props.precision)) {\n currentValue = currentValue.toFixed(props.precision)\n }\n }\n return currentValue\n})\nconst toPrecision = (num: number, pre?: number) => {\n if (isUndefined(pre)) pre = numPrecision.value\n if (pre === 0) return Math.round(num)\n let snum = String(num)\n const pointPos = snum.indexOf('.')\n if (pointPos === -1) return num\n const nums = snum.replace('.', '').split('')\n const datum = nums[pointPos + pre]\n if (!datum) return num\n const length = snum.length\n if (snum.charAt(length - 1) === '5') {\n snum = `${snum.slice(0, Math.max(0, length - 1))}6`\n }\n return Number.parseFloat(Number(snum).toFixed(pre))\n}\nconst getPrecision = (value: number | null | undefined) => {\n if (isNil(value)) return 0\n const valueString = value.toString()\n const dotPosition = valueString.indexOf('.')\n let precision = 0\n if (dotPosition !== -1) {\n precision = valueString.length - dotPosition - 1\n }\n return precision\n}\nconst ensurePrecision = (val: number, coefficient: 1 | -1 = 1) => {\n if (!isNumber(val)) return data.currentValue\n if (val >= Number.MAX_SAFE_INTEGER && coefficient === 1) {\n debugWarn(\n 'InputNumber',\n 'The value has reached the maximum safe integer limit.'\n )\n return val\n } else if (val <= Number.MIN_SAFE_INTEGER && coefficient === -1) {\n debugWarn(\n 'InputNumber',\n 'The value has reached the minimum safe integer limit.'\n )\n return val\n }\n\n // Solve the accuracy problem of JS decimal calculation by converting the value to integer.\n return toPrecision(val + props.step * coefficient)\n}\nconst handleKeydown = (event: KeyboardEvent | Event) => {\n const code = getEventCode(event as KeyboardEvent)\n const key = getEventKey(event as KeyboardEvent)\n\n if (props.disabledScientific && ['e', 'E'].includes(key)) {\n event.preventDefault()\n return\n }\n\n switch (code) {\n case EVENT_CODE.up: {\n event.preventDefault()\n increase()\n break\n }\n case EVENT_CODE.down: {\n event.preventDefault()\n decrease()\n break\n }\n }\n}\nconst increase = () => {\n if (props.readonly || inputNumberDisabled.value || maxDisabled.value) return\n const value = Number(displayValue.value) || 0\n const newVal = ensurePrecision(value)\n setCurrentValue(newVal)\n emit(INPUT_EVENT, data.currentValue)\n setCurrentValueToModelValue()\n}\nconst decrease = () => {\n if (props.readonly || inputNumberDisabled.value || minDisabled.value) return\n const value = Number(displayValue.value) || 0\n const newVal = ensurePrecision(value, -1)\n setCurrentValue(newVal)\n emit(INPUT_EVENT, data.currentValue)\n setCurrentValueToModelValue()\n}\nconst verifyValue = (\n value: number | string | null | undefined,\n update?: boolean\n): number | null | undefined => {\n const { max, min, step, precision, stepStrictly, valueOnClear } = props\n if (max < min) {\n throwError('InputNumber', 'min should not be greater than max.')\n }\n let newVal = !value ? Number(value) : Number.parseFloat(String(value))\n if (isNil(value) || Number.isNaN(newVal)) {\n return null\n }\n if (value === '') {\n if (valueOnClear === null) {\n return null\n }\n newVal = isString(valueOnClear) ? { min, max }[valueOnClear] : valueOnClear\n }\n if (stepStrictly) {\n newVal = toPrecision(\n Math.round(toPrecision(newVal / step)) * step,\n precision\n )\n if (newVal !== value) {\n update && emit(UPDATE_MODEL_EVENT, newVal)\n }\n }\n if (!isUndefined(precision)) {\n newVal = toPrecision(newVal, precision)\n }\n if (newVal > max || newVal < min) {\n newVal = newVal > max ? max : min\n update && emit(UPDATE_MODEL_EVENT, newVal)\n }\n return newVal\n}\nconst setCurrentValue = (\n value: number | string | null | undefined,\n emitChange = true\n) => {\n const oldVal = data.currentValue\n const newVal = verifyValue(value)\n if (!emitChange) {\n emit(UPDATE_MODEL_EVENT, newVal!)\n return\n }\n data.userInput = null\n if (oldVal === newVal && value) return\n emit(UPDATE_MODEL_EVENT, newVal!)\n if (oldVal !== newVal) {\n emit(CHANGE_EVENT, newVal!, oldVal!)\n }\n if (props.validateEvent) {\n formItem?.validate?.('change').catch(NOOP)\n }\n data.currentValue = newVal\n}\nconst handleInput = (value: string) => {\n data.userInput = value\n let newVal = value === '' ? null : Number.parseFloat(value)\n if (Number.isNaN(newVal)) {\n newVal = null\n }\n emit(INPUT_EVENT, newVal)\n setCurrentValue(newVal, false)\n}\nconst handleInputChange = (value: string) => {\n const newVal = value !== '' ? Number.parseFloat(value) : ''\n if (\n (isNumber(newVal) && !Number.isNaN(newVal)) ||\n (props.formatter && Number.isNaN(newVal)) ||\n newVal === ''\n ) {\n setCurrentValue(newVal)\n }\n setCurrentValueToModelValue()\n data.userInput = null\n}\n\nconst focus = () => {\n input.value?.focus?.()\n}\n\nconst blur = () => {\n input.value?.blur?.()\n}\n\nconst handleFocus = (event: MouseEvent | FocusEvent) => {\n emit('focus', event)\n}\n\nconst handleBlur = (event: MouseEvent | FocusEvent) => {\n data.userInput = null\n // When non-numeric content is entered into a numeric input box,\n // the content displayed on the page is not cleared after the value is cleared. #18533\n // https://bugzilla.mozilla.org/show_bug.cgi?id=1398528\n if (data.currentValue === null && input.value?.input) {\n input.value.input.value = props.formatter?.('') ?? ''\n }\n emit('blur', event)\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch(NOOP)\n }\n}\n\nconst setCurrentValueToModelValue = () => {\n if (data.currentValue !== props.modelValue) {\n data.currentValue = props.modelValue\n }\n}\nconst handleWheel = (e: WheelEvent) => {\n if (document.activeElement === e.target) e.preventDefault()\n}\n\nwatch(\n () => props.modelValue,\n (value, oldValue) => {\n const newValue = verifyValue(value, true)\n if (data.userInput === null && newValue !== oldValue) {\n data.currentValue = newValue\n }\n },\n { immediate: true }\n)\n\nwatch(\n () => props.precision,\n () => {\n data.currentValue = verifyValue(props.modelValue)\n }\n)\nonMounted(() => {\n const { min, max, modelValue } = props\n const innerInput = input.value?.input as HTMLInputElement\n innerInput.setAttribute('role', 'spinbutton')\n if (Number.isFinite(max)) {\n innerInput.setAttribute('aria-valuemax', String(max))\n } else {\n innerInput.removeAttribute('aria-valuemax')\n }\n if (Number.isFinite(min)) {\n innerInput.setAttribute('aria-valuemin', String(min))\n } else {\n innerInput.removeAttribute('aria-valuemin')\n }\n innerInput.setAttribute(\n 'aria-valuenow',\n data.currentValue || data.currentValue === 0\n ? String(data.currentValue)\n : ''\n )\n innerInput.setAttribute('aria-disabled', String(inputNumberDisabled.value))\n if (!isNumber(modelValue) && modelValue != null) {\n let val: number | null = Number(modelValue)\n if (Number.isNaN(val)) {\n val = null\n }\n emit(UPDATE_MODEL_EVENT, val!)\n }\n innerInput.addEventListener('wheel', handleWheel, { passive: false })\n})\nonUpdated(() => {\n const innerInput = input.value?.input\n innerInput?.setAttribute('aria-valuenow', `${data.currentValue ?? ''}`)\n})\ndefineExpose({\n /** @description get focus the input component */\n focus,\n /** @description remove focus the input component */\n blur,\n})\n</script>\n"],"mappings":"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"}
1
+ {"version":3,"file":"input-number.vue_vue_type_script_setup_true_lang.js","names":["$slots"],"sources":["../../../../../../packages/components/input-number/src/input-number.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ns.b(),\n ns.m(inputNumberSize),\n ns.is('disabled', inputNumberDisabled),\n ns.is('without-controls', !controls),\n ns.is('controls-right', controlsAtRight),\n ns.is(align, !!align),\n ]\"\n @dragstart.prevent\n >\n <span\n v-if=\"controls\"\n v-repeat-click=\"decrease\"\n role=\"button\"\n :aria-label=\"t('el.inputNumber.decrease')\"\n :class=\"[ns.e('decrease'), ns.is('disabled', minDisabled)]\"\n @keydown.enter=\"decrease\"\n >\n <slot name=\"decrease-icon\">\n <el-icon>\n <arrow-down v-if=\"controlsAtRight\" />\n <minus v-else />\n </el-icon>\n </slot>\n </span>\n <span\n v-if=\"controls\"\n v-repeat-click=\"increase\"\n role=\"button\"\n :aria-label=\"t('el.inputNumber.increase')\"\n :class=\"[ns.e('increase'), ns.is('disabled', maxDisabled)]\"\n @keydown.enter=\"increase\"\n >\n <slot name=\"increase-icon\">\n <el-icon>\n <arrow-up v-if=\"controlsAtRight\" />\n <plus v-else />\n </el-icon>\n </slot>\n </span>\n <el-input\n :id=\"id\"\n ref=\"input\"\n :type=\"formatter ? 'text' : 'number'\"\n :step=\"step\"\n :model-value=\"displayValue\"\n :placeholder=\"placeholder\"\n :readonly=\"readonly\"\n :disabled=\"inputNumberDisabled\"\n :size=\"inputNumberSize\"\n :max=\"max\"\n :min=\"min\"\n :name=\"name\"\n :aria-label=\"ariaLabel\"\n :validate-event=\"false\"\n :inputmode=\"inputmode\"\n :formatter=\"formatter\"\n :parser=\"parser\"\n :tabindex=\"tabindex\"\n @keydown=\"handleKeydown\"\n @blur=\"handleBlur\"\n @focus=\"handleFocus\"\n @input=\"handleInput\"\n @change=\"handleInputChange\"\n >\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>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, onUpdated, reactive, ref, watch } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { ElInput } from '@element-plus/components/input'\nimport { ElIcon } from '@element-plus/components/icon'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { vRepeatClick } from '@element-plus/directives'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport {\n NOOP,\n debugWarn,\n getEventCode,\n getEventKey,\n isNumber,\n isString,\n isUndefined,\n throwError,\n} from '@element-plus/utils'\nimport { ArrowDown, ArrowUp, Minus, Plus } from '@element-plus/icons-vue'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { inputNumberEmits } from './input-number'\n\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { InputNumberProps } from './input-number'\n\ndefineOptions({\n name: 'ElInputNumber',\n})\n\nconst props = withDefaults(defineProps<InputNumberProps>(), {\n id: undefined,\n disabled: undefined,\n step: 1,\n max: Number.MAX_SAFE_INTEGER,\n min: Number.MIN_SAFE_INTEGER,\n stepStrictly: false,\n readonly: false,\n controls: true,\n controlsPosition: '',\n valueOnClear: null,\n validateEvent: true,\n inputmode: undefined,\n align: 'center',\n tabindex: 0,\n})\nconst emit = defineEmits(inputNumberEmits)\n\nconst { t } = useLocale()\nconst ns = useNamespace('input-number')\nconst input = ref<InputInstance>()\n\ninterface Data {\n currentValue: number | null | undefined\n userInput: null | number | string\n}\nconst data = reactive<Data>({\n currentValue: props.modelValue,\n userInput: null,\n})\n\nconst { formItem } = useFormItem()\n\nconst minDisabled = computed(\n () => isNumber(props.modelValue) && props.modelValue <= props.min\n)\nconst maxDisabled = computed(\n () => isNumber(props.modelValue) && props.modelValue >= props.max\n)\n\nconst numPrecision = computed(() => {\n const stepPrecision = getPrecision(props.step)\n if (!isUndefined(props.precision)) {\n if (stepPrecision > props.precision) {\n debugWarn(\n 'InputNumber',\n 'precision should not be less than the decimal places of step'\n )\n }\n return props.precision\n } else {\n return Math.max(getPrecision(props.modelValue), stepPrecision)\n }\n})\nconst controlsAtRight = computed(() => {\n return props.controls && props.controlsPosition === 'right'\n})\n\nconst inputNumberSize = useFormSize()\nconst inputNumberDisabled = useFormDisabled()\n\nconst displayValue = computed(() => {\n if (data.userInput !== null) {\n return data.userInput\n }\n let currentValue: number | string | undefined | null = data.currentValue\n if (isNil(currentValue)) return ''\n if (isNumber(currentValue)) {\n if (Number.isNaN(currentValue)) return ''\n if (!isUndefined(props.precision)) {\n currentValue = currentValue.toFixed(props.precision)\n }\n }\n return currentValue\n})\nconst toPrecision = (num: number, pre?: number) => {\n if (isUndefined(pre)) pre = numPrecision.value\n if (pre === 0) return Math.round(num)\n let snum = String(num)\n const pointPos = snum.indexOf('.')\n if (pointPos === -1) return num\n const nums = snum.replace('.', '').split('')\n const datum = nums[pointPos + pre]\n if (!datum) return num\n const length = snum.length\n if (snum.charAt(length - 1) === '5') {\n snum = `${snum.slice(0, Math.max(0, length - 1))}6`\n }\n return Number.parseFloat(Number(snum).toFixed(pre))\n}\nconst getPrecision = (value: number | null | undefined) => {\n if (isNil(value)) return 0\n const valueString = value.toString()\n const dotPosition = valueString.indexOf('.')\n let precision = 0\n if (dotPosition !== -1) {\n precision = valueString.length - dotPosition - 1\n }\n return precision\n}\nconst ensurePrecision = (val: number, coefficient: 1 | -1 = 1) => {\n if (!isNumber(val)) return data.currentValue\n if (val >= Number.MAX_SAFE_INTEGER && coefficient === 1) {\n debugWarn(\n 'InputNumber',\n 'The value has reached the maximum safe integer limit.'\n )\n return val\n } else if (val <= Number.MIN_SAFE_INTEGER && coefficient === -1) {\n debugWarn(\n 'InputNumber',\n 'The value has reached the minimum safe integer limit.'\n )\n return val\n }\n\n // Solve the accuracy problem of JS decimal calculation by converting the value to integer.\n return toPrecision(val + props.step * coefficient)\n}\nconst handleKeydown = (event: KeyboardEvent | Event) => {\n const code = getEventCode(event as KeyboardEvent)\n const key = getEventKey(event as KeyboardEvent)\n\n if (props.disabledScientific && ['e', 'E'].includes(key)) {\n event.preventDefault()\n return\n }\n\n switch (code) {\n case EVENT_CODE.up: {\n event.preventDefault()\n increase()\n break\n }\n case EVENT_CODE.down: {\n event.preventDefault()\n decrease()\n break\n }\n }\n}\nconst increase = () => {\n if (props.readonly || inputNumberDisabled.value || maxDisabled.value) return\n const value = Number(displayValue.value) || 0\n const newVal = ensurePrecision(value)\n setCurrentValue(newVal)\n emit(INPUT_EVENT, data.currentValue)\n setCurrentValueToModelValue()\n}\nconst decrease = () => {\n if (props.readonly || inputNumberDisabled.value || minDisabled.value) return\n const value = Number(displayValue.value) || 0\n const newVal = ensurePrecision(value, -1)\n setCurrentValue(newVal)\n emit(INPUT_EVENT, data.currentValue)\n setCurrentValueToModelValue()\n}\nconst verifyValue = (\n value: number | string | null | undefined,\n update?: boolean\n): number | null | undefined => {\n const { max, min, step, precision, stepStrictly, valueOnClear } = props\n if (max < min) {\n throwError('InputNumber', 'min should not be greater than max.')\n }\n let newVal = !value ? Number(value) : Number.parseFloat(String(value))\n if (isNil(value) || Number.isNaN(newVal)) {\n return null\n }\n if (value === '') {\n if (valueOnClear === null) {\n return null\n }\n newVal = isString(valueOnClear) ? { min, max }[valueOnClear] : valueOnClear\n }\n if (stepStrictly) {\n newVal = toPrecision(\n Math.round(toPrecision(newVal / step)) * step,\n precision\n )\n if (newVal !== value) {\n update && emit(UPDATE_MODEL_EVENT, newVal)\n }\n }\n if (!isUndefined(precision)) {\n newVal = toPrecision(newVal, precision)\n }\n if (newVal > max || newVal < min) {\n newVal = newVal > max ? max : min\n update && emit(UPDATE_MODEL_EVENT, newVal)\n }\n return newVal\n}\nconst setCurrentValue = (\n value: number | string | null | undefined,\n emitChange = true\n) => {\n const oldVal = data.currentValue\n const newVal = verifyValue(value)\n if (!emitChange) {\n emit(UPDATE_MODEL_EVENT, newVal!)\n return\n }\n data.userInput = null\n if (oldVal === newVal && value) return\n emit(UPDATE_MODEL_EVENT, newVal!)\n if (oldVal !== newVal) {\n emit(CHANGE_EVENT, newVal!, oldVal!)\n }\n if (props.validateEvent) {\n formItem?.validate?.('change').catch(NOOP)\n }\n data.currentValue = newVal\n}\nconst handleInput = (value: string) => {\n data.userInput = value\n let newVal = value === '' ? null : Number.parseFloat(value)\n if (Number.isNaN(newVal)) {\n newVal = null\n }\n emit(INPUT_EVENT, newVal)\n setCurrentValue(newVal, false)\n}\nconst handleInputChange = (value: string) => {\n const newVal = value !== '' ? Number.parseFloat(value) : ''\n if (\n (isNumber(newVal) && !Number.isNaN(newVal)) ||\n (props.formatter && Number.isNaN(newVal)) ||\n newVal === ''\n ) {\n setCurrentValue(newVal)\n }\n setCurrentValueToModelValue()\n data.userInput = null\n}\n\nconst focus = () => {\n input.value?.focus?.()\n}\n\nconst blur = () => {\n input.value?.blur?.()\n}\n\nconst handleFocus = (event: MouseEvent | FocusEvent) => {\n emit('focus', event)\n}\n\nconst handleBlur = (event: MouseEvent | FocusEvent) => {\n data.userInput = null\n // When non-numeric content is entered into a numeric input box,\n // the content displayed on the page is not cleared after the value is cleared. #18533\n // https://bugzilla.mozilla.org/show_bug.cgi?id=1398528\n if (data.currentValue === null && input.value?.input) {\n input.value.input.value = props.formatter?.('') ?? ''\n }\n emit('blur', event)\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch(NOOP)\n }\n}\n\nconst setCurrentValueToModelValue = () => {\n if (data.currentValue !== props.modelValue) {\n data.currentValue = props.modelValue\n }\n}\nconst handleWheel = (e: WheelEvent) => {\n if (document.activeElement === e.target) e.preventDefault()\n}\n\nwatch(\n () => props.modelValue,\n (value, oldValue) => {\n const newValue = verifyValue(value, true)\n if (data.userInput === null && newValue !== oldValue) {\n data.currentValue = newValue\n }\n },\n { immediate: true }\n)\n\nwatch(\n () => props.precision,\n () => {\n data.currentValue = verifyValue(props.modelValue)\n }\n)\nonMounted(() => {\n const { min, max, modelValue } = props\n const innerInput = input.value?.input as HTMLInputElement\n innerInput.setAttribute('role', 'spinbutton')\n if (Number.isFinite(max)) {\n innerInput.setAttribute('aria-valuemax', String(max))\n } else {\n innerInput.removeAttribute('aria-valuemax')\n }\n if (Number.isFinite(min)) {\n innerInput.setAttribute('aria-valuemin', String(min))\n } else {\n innerInput.removeAttribute('aria-valuemin')\n }\n innerInput.setAttribute(\n 'aria-valuenow',\n data.currentValue || data.currentValue === 0\n ? String(data.currentValue)\n : ''\n )\n innerInput.setAttribute('aria-disabled', String(inputNumberDisabled.value))\n if (!isNumber(modelValue) && modelValue != null) {\n let val: number | null = Number(modelValue)\n if (Number.isNaN(val)) {\n val = null\n }\n emit(UPDATE_MODEL_EVENT, val!)\n }\n innerInput.addEventListener('wheel', handleWheel, { passive: false })\n})\nonUpdated(() => {\n const innerInput = input.value?.input\n innerInput?.setAttribute('aria-valuenow', `${data.currentValue ?? ''}`)\n})\ndefineExpose({\n /** @description get focus the input component */\n focus,\n /** @description remove focus the input component */\n blur,\n})\n</script>\n"],"mappings":"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"}
@@ -24,23 +24,23 @@ declare const __VLS_base: vue.DefineComponent<InputOtpProps, {
24
24
  */
25
25
  blur: () => void;
26
26
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
27
- finish: (value: string) => void;
28
- focus: (eve: FocusEvent) => void;
29
- blur: (eve: FocusEvent) => void;
30
27
  "update:modelValue": (value: string) => void;
31
28
  change: (value: string) => void;
29
+ focus: (eve: FocusEvent) => void;
30
+ blur: (eve: FocusEvent) => void;
31
+ finish: (value: string) => void;
32
32
  }, string, vue.PublicProps, Readonly<InputOtpProps> & Readonly<{
33
- onFinish?: ((value: string) => any) | undefined;
33
+ "onUpdate:modelValue"?: ((value: string) => any) | undefined;
34
+ onChange?: ((value: string) => any) | undefined;
34
35
  onFocus?: ((eve: FocusEvent) => any) | undefined;
35
36
  onBlur?: ((eve: FocusEvent) => any) | undefined;
36
- onChange?: ((value: string) => any) | undefined;
37
- "onUpdate:modelValue"?: ((value: string) => any) | undefined;
37
+ onFinish?: ((value: string) => any) | undefined;
38
38
  }>, {
39
39
  type: "outlined" | "filled" | "underlined";
40
- size: ComponentSize;
41
- disabled: boolean;
42
40
  length: number;
43
41
  validator: (char: string, index: number) => boolean;
42
+ size: ComponentSize;
43
+ disabled: boolean;
44
44
  validateEvent: boolean;
45
45
  }, {}, {}, {}, string, vue.ComponentProvideOptions, false, {}, any>;
46
46
  declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
@@ -130,7 +130,7 @@ declare const inputTagProps: {
130
130
  readonly max: NumberConstructor;
131
131
  readonly tagType: {
132
132
  readonly default: "info";
133
- readonly type: vue.PropType<EpPropMergeType<StringConstructor, "primary" | "success" | "warning" | "danger" | "info", unknown>>;
133
+ readonly type: vue.PropType<EpPropMergeType<StringConstructor, "info" | "primary" | "success" | "warning" | "danger", unknown>>;
134
134
  readonly required: false;
135
135
  readonly validator: ((val: unknown) => boolean) | undefined;
136
136
  readonly __epPropKey: true;
@@ -26,36 +26,36 @@ declare const __VLS_base: vue.DefineComponent<InputTagProps, {
26
26
  focus: () => void;
27
27
  blur: () => void;
28
28
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
29
- clear: () => void;
30
- focus: (evt: FocusEvent) => void;
31
- blur: (evt: FocusEvent) => void;
32
29
  "update:modelValue": (value?: string[] | undefined) => void;
33
30
  change: (value?: string[] | undefined) => void;
31
+ clear: () => void;
34
32
  input: (value: string) => void;
33
+ focus: (evt: FocusEvent) => void;
34
+ blur: (evt: FocusEvent) => void;
35
35
  "add-tag": (value: string | string[]) => void;
36
36
  "remove-tag": (value: string, index: number) => void;
37
37
  "drag-tag": (oldIndex: number, newIndex: number, value: string) => void;
38
38
  }, string, vue.PublicProps, Readonly<InputTagProps> & Readonly<{
39
+ "onUpdate:modelValue"?: ((value?: string[] | undefined) => any) | undefined;
40
+ onChange?: ((value?: string[] | undefined) => any) | undefined;
39
41
  onClear?: (() => any) | undefined;
42
+ onInput?: ((value: string) => any) | undefined;
40
43
  onFocus?: ((evt: FocusEvent) => any) | undefined;
41
44
  onBlur?: ((evt: FocusEvent) => any) | undefined;
42
- onInput?: ((value: string) => any) | undefined;
43
- onChange?: ((value?: string[] | undefined) => any) | undefined;
44
- "onUpdate:modelValue"?: ((value?: string[] | undefined) => any) | undefined;
45
45
  "onAdd-tag"?: ((value: string | string[]) => any) | undefined;
46
46
  "onRemove-tag"?: ((value: string, index: number) => any) | undefined;
47
47
  "onDrag-tag"?: ((oldIndex: number, newIndex: number, value: string) => any) | undefined;
48
48
  }>, {
49
49
  disabled: boolean;
50
- id: string;
51
50
  effect: PopperEffect;
52
- trigger: "Enter" | "Space";
53
- validateEvent: boolean;
51
+ id: string;
54
52
  autocomplete: string;
55
53
  clearIcon: IconPropType;
56
54
  tabindex: string | number;
55
+ validateEvent: boolean;
56
+ trigger: "Enter" | "Space";
57
57
  maxCollapseTags: number;
58
- tagType: "primary" | "success" | "warning" | "danger" | "info";
58
+ tagType: "info" | "primary" | "success" | "warning" | "danger";
59
59
  tagEffect: "dark" | "light" | "plain";
60
60
  saveOnBlur: boolean;
61
61
  delimiter: string | RegExp;
@@ -36,8 +36,8 @@ interface LinkProps {
36
36
  * @deprecated Removed after 3.0.0, Use `LinkProps` instead.
37
37
  */
38
38
  declare const linkProps: {
39
- readonly type: EpPropFinalized<StringConstructor, "default" | "primary" | "success" | "warning" | "danger" | "info", unknown, undefined, boolean>;
40
- readonly underline: EpPropFinalized<readonly [BooleanConstructor, StringConstructor], boolean | "hover" | "always" | "never", unknown, undefined, boolean>;
39
+ readonly type: EpPropFinalized<StringConstructor, "default" | "info" | "primary" | "success" | "warning" | "danger", unknown, undefined, boolean>;
40
+ readonly underline: EpPropFinalized<readonly [BooleanConstructor, StringConstructor], boolean | "always" | "never" | "hover", unknown, undefined, boolean>;
41
41
  readonly disabled: BooleanConstructor;
42
42
  readonly href: EpPropFinalized<StringConstructor, unknown, unknown, "", boolean>;
43
43
  readonly target: EpPropFinalized<(new (...args: any[]) => string) | (() => string) | (((new (...args: any[]) => string) | (() => string)) | null)[], unknown, unknown, "_self", boolean>;
@@ -202,7 +202,7 @@ declare const mentionProps: {
202
202
  popperStyle: EpPropFinalized<(new (...args: any[]) => string | false | vue.CSSProperties | vue.StyleValue[]) | (() => vue.StyleValue) | (((new (...args: any[]) => string | false | vue.CSSProperties | vue.StyleValue[]) | (() => vue.StyleValue)) | null)[], unknown, unknown, undefined, boolean>;
203
203
  popperOptions: EpPropFinalized<(new (...args: any[]) => Partial<Options>) | (() => Partial<Options>) | (((new (...args: any[]) => Partial<Options>) | (() => Partial<Options>)) | null)[], unknown, unknown, () => Partial<Options>, boolean>;
204
204
  props: EpPropFinalized<(new (...args: any[]) => MentionOptionProps) | (() => MentionOptionProps) | (((new (...args: any[]) => MentionOptionProps) | (() => MentionOptionProps)) | null)[], unknown, unknown, () => Required<MentionOptionProps>, boolean>;
205
- inputmode: EpPropFinalized<(new (...args: any[]) => "none" | "text" | "search" | "email" | "tel" | "url" | "numeric" | "decimal") | (() => "none" | "text" | "search" | "email" | "tel" | "url" | "numeric" | "decimal" | undefined) | (((new (...args: any[]) => "none" | "text" | "search" | "email" | "tel" | "url" | "numeric" | "decimal") | (() => "none" | "text" | "search" | "email" | "tel" | "url" | "numeric" | "decimal" | undefined)) | null)[], unknown, unknown, undefined, boolean>;
205
+ inputmode: EpPropFinalized<(new (...args: any[]) => "none" | "text" | "email" | "search" | "tel" | "url" | "numeric" | "decimal") | (() => "none" | "text" | "email" | "search" | "tel" | "url" | "numeric" | "decimal" | undefined) | (((new (...args: any[]) => "none" | "text" | "email" | "search" | "tel" | "url" | "numeric" | "decimal") | (() => "none" | "text" | "email" | "search" | "tel" | "url" | "numeric" | "decimal" | undefined)) | null)[], unknown, unknown, undefined, boolean>;
206
206
  name: StringConstructor;
207
207
  ariaLabel: StringConstructor;
208
208
  id: EpPropFinalized<StringConstructor, unknown, unknown, undefined, boolean>;
@@ -228,7 +228,7 @@ declare const mentionProps: {
228
228
  };
229
229
  type: EpPropFinalized<(new (...args: any[]) => string) | (() => InputType) | (((new (...args: any[]) => string) | (() => InputType)) | null)[], unknown, unknown, "text", boolean>;
230
230
  resize: {
231
- readonly type: vue.PropType<EpPropMergeType<StringConstructor, "none" | "both" | "horizontal" | "vertical", unknown>>;
231
+ readonly type: vue.PropType<EpPropMergeType<StringConstructor, "horizontal" | "vertical" | "none" | "both", unknown>>;
232
232
  readonly required: false;
233
233
  readonly validator: ((val: unknown) => boolean) | undefined;
234
234
  __epPropKey: true;
@@ -9,12 +9,12 @@ import * as vue from "vue";
9
9
  //#region ../../packages/components/mention/src/mention.vue.d.ts
10
10
  declare const __VLS_export: <T extends MentionOption = MentionOption>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_exposed?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
11
11
  props: vue.PublicProps & __VLS_PrettifyLocal<MentionProps<T> & {
12
- onSelect?: ((option: MentionOption, prefix: string) => any) | undefined;
12
+ "onUpdate:modelValue"?: ((value: string) => any) | undefined;
13
+ onInput?: ((value: string) => any) | undefined;
13
14
  onFocus?: ((evt: FocusEvent) => any) | undefined;
14
15
  onBlur?: ((evt: FocusEvent) => any) | undefined;
15
- onInput?: ((value: string) => any) | undefined;
16
+ onSelect?: ((option: MentionOption, prefix: string) => any) | undefined;
16
17
  onSearch?: ((pattern: string, prefix: string) => any) | undefined;
17
- "onUpdate:modelValue"?: ((value: string) => any) | undefined;
18
18
  "onWhole-remove"?: ((pattern: string, prefix: string) => any) | undefined;
19
19
  }> & (typeof globalThis extends {
20
20
  __VLS_PROPS_FALLBACK: infer P;
@@ -48,7 +48,7 @@ declare const __VLS_export: <T extends MentionOption = MentionOption>(__VLS_prop
48
48
  index: number;
49
49
  }) => any;
50
50
  };
51
- emit: ((event: "select", option: MentionOption, prefix: string) => void) & ((event: "focus", evt: FocusEvent) => void) & ((event: "blur", evt: FocusEvent) => void) & ((event: "input", value: string) => void) & ((event: "search", pattern: string, prefix: string) => void) & ((event: "update:modelValue", value: string) => void) & ((event: "whole-remove", pattern: string, prefix: string) => void);
51
+ emit: ((event: "update:modelValue", value: string) => void) & ((event: "input", value: string) => void) & ((event: "focus", evt: FocusEvent) => void) & ((event: "blur", evt: FocusEvent) => void) & ((event: "select", option: MentionOption, prefix: string) => void) & ((event: "search", pattern: string, prefix: string) => void) & ((event: "whole-remove", pattern: string, prefix: string) => void);
52
52
  }>) => vue.VNode & {
53
53
  __ctx?: Awaited<typeof __VLS_setup>;
54
54
  };
@@ -105,13 +105,13 @@ declare const _default: vue.DefineComponent<ExtractPropTypes<{
105
105
  readonly hideTimeout: EpPropFinalized<NumberConstructor, unknown, unknown, 300, boolean>;
106
106
  readonly persistent: EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
107
107
  }>> & Readonly<{
108
- onSelect?: ((index: string, indexPath: string[], item: MenuItemClicked, routerResult?: Promise<void | NavigationFailure> | undefined) => any) | undefined;
109
108
  onClose?: ((index: string, indexPath: string[]) => any) | undefined;
110
109
  onOpen?: ((index: string, indexPath: string[]) => any) | undefined;
110
+ onSelect?: ((index: string, indexPath: string[], item: MenuItemClicked, routerResult?: Promise<void | NavigationFailure> | undefined) => any) | undefined;
111
111
  }>, {
112
- readonly persistent: EpPropMergeType<BooleanConstructor, unknown, unknown>;
113
112
  readonly collapse: boolean;
114
113
  readonly ellipsis: EpPropMergeType<BooleanConstructor, unknown, unknown>;
114
+ readonly persistent: EpPropMergeType<BooleanConstructor, unknown, unknown>;
115
115
  readonly mode: EpPropMergeType<StringConstructor, "horizontal" | "vertical", unknown>;
116
116
  readonly showTimeout: number;
117
117
  readonly hideTimeout: number;
@@ -5,9 +5,9 @@ const require_runtime$1 = require('../../../utils/vue/props/runtime.js');
5
5
  const require_icon = require('../../../utils/vue/icon.js');
6
6
  const require_vnode = require('../../../utils/vue/vnode.js');
7
7
  const require_typescript = require('../../../utils/typescript.js');
8
- const require_index = require('../../../hooks/use-namespace/index.js');
9
- const require_index$1 = require('../../icon/index.js');
10
- const require_index$2 = require('../../../directives/click-outside/index.js');
8
+ const require_index = require('../../../directives/click-outside/index.js');
9
+ const require_index$1 = require('../../../hooks/use-namespace/index.js');
10
+ const require_index$2 = require('../../icon/index.js');
11
11
  const require_menu_bar = require('./utils/menu-bar.js');
12
12
  const require_menu_collapse_transition = require('./menu-collapse-transition.js');
13
13
  const require_use_menu_css_var = require('./use-menu-css-var.js');
@@ -97,8 +97,8 @@ var menu_default = (0, vue.defineComponent)({
97
97
  const router = instance.appContext.config.globalProperties.$router;
98
98
  const menu = (0, vue.ref)();
99
99
  const subMenu = (0, vue.ref)();
100
- const nsMenu = require_index.useNamespace("menu");
101
- const nsSubMenu = require_index.useNamespace("sub-menu");
100
+ const nsMenu = require_index$1.useNamespace("menu");
101
+ const nsSubMenu = require_index$1.useNamespace("sub-menu");
102
102
  let moreItemWidth = DEFAULT_MORE_ITEM_WIDTH;
103
103
  const sliceIndex = (0, vue.ref)(-1);
104
104
  const openedMenus = (0, vue.ref)(props.defaultOpeneds && !props.collapse ? props.defaultOpeneds.slice(0) : []);
@@ -286,12 +286,12 @@ var menu_default = (0, vue.defineComponent)({
286
286
  class: nsSubMenu.e("hide-arrow"),
287
287
  popperOffset: props.popperOffset
288
288
  }, {
289
- title: () => (0, vue.h)(require_index$1.ElIcon, { class: nsSubMenu.e("icon-more") }, { default: () => (0, vue.h)(props.ellipsisIcon) }),
289
+ title: () => (0, vue.h)(require_index$2.ElIcon, { class: nsSubMenu.e("icon-more") }, { default: () => (0, vue.h)(props.ellipsisIcon) }),
290
290
  default: () => slotMore
291
291
  }));
292
292
  }
293
293
  }
294
- const directives = props.closeOnClickOutside ? [[require_index$2.default, () => {
294
+ const directives = props.closeOnClickOutside ? [[require_index.default, () => {
295
295
  if (!openedMenus.value.length) return;
296
296
  if (!mouseInChild.value) {
297
297
  openedMenus.value.forEach((openedMenu) => emit("close", openedMenu, getIndexPath(openedMenu)));
@@ -1 +1 @@
1
- {"version":3,"file":"menu.js","names":["buildProps","definePropType","mutable","iconPropType","More","isUndefined","useNamespace","MENU_INJECTION_KEY","SUB_MENU_INJECTION_KEY","Menubar","useMenuCssVar","flattedChildren","ElSubMenu","ElIcon","vClickoutside","ElMenuCollapseTransition"],"sources":["../../../../../../packages/components/menu/src/menu.ts"],"sourcesContent":["import {\n computed,\n defineComponent,\n getCurrentInstance,\n h,\n nextTick,\n onMounted,\n provide,\n reactive,\n ref,\n watch,\n watchEffect,\n withDirectives,\n} from 'vue'\nimport { unrefElement, useResizeObserver } from '@vueuse/core'\nimport { isNil } from 'lodash-unified'\nimport ElIcon from '@element-plus/components/icon'\nimport { More } from '@element-plus/icons-vue'\nimport {\n buildProps,\n definePropType,\n flattedChildren,\n iconPropType,\n isArray,\n isObject,\n isString,\n isUndefined,\n mutable,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport Menubar from './utils/menu-bar'\nimport ElMenuCollapseTransition from './menu-collapse-transition.vue'\nimport ElSubMenu from './sub-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\nimport { MENU_INJECTION_KEY, SUB_MENU_INJECTION_KEY } from './tokens'\n\nimport type { PopperEffect } from '@element-plus/components/popper'\nimport type { MenuItemClicked, MenuProvider, SubMenuProvider } from './types'\nimport type { NavigationFailure, Router } from 'vue-router'\nimport type {\n CSSProperties,\n Component,\n DirectiveArguments,\n ExtractPropTypes,\n ExtractPublicPropTypes,\n VNode,\n VNodeArrayChildren,\n} from 'vue'\nimport type { UseResizeObserverReturn } from '@vueuse/core'\n\nexport const menuProps = buildProps({\n /**\n * @description menu display mode\n */\n mode: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'vertical',\n },\n /**\n * @description index of active menu on page load\n */\n defaultActive: {\n type: String,\n default: '',\n },\n /**\n * @description array that contains indexes of currently active sub-menus\n */\n defaultOpeneds: {\n type: definePropType<string[]>(Array),\n default: () => mutable([] as const),\n },\n /**\n * @description whether only one sub-menu can be active\n */\n uniqueOpened: Boolean,\n /**\n * @description whether `vue-router` mode is activated. If true, index will be used as 'path' to activate the route action. Use with `default-active` to set the active item on load.\n */\n router: Boolean,\n /**\n * @description how sub-menus are triggered, only works when `mode` is 'horizontal'\n */\n menuTrigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n /**\n * @description whether the menu is collapsed (available only in vertical mode)\n */\n collapse: Boolean,\n /**\n * @description background color of Menu (hex format) (deprecated, use `--bg-color` instead)\n * @deprecated use `--bg-color` instead\n */\n backgroundColor: String,\n /**\n * @description text color of Menu (hex format) (deprecated, use `--text-color` instead)\n * @deprecated use `--text-color` instead\n */\n textColor: String,\n /**\n * @description text color of currently active menu item (hex format) (deprecated, use `--active-color` instead)\n * @deprecated use `--active-color` instead\n */\n activeTextColor: String,\n /**\n * @description optional, whether menu is collapsed when clicking outside\n */\n closeOnClickOutside: Boolean,\n /**\n * @description whether to enable the collapse transition\n */\n collapseTransition: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether the menu is ellipsis (available only in horizontal mode)\n */\n ellipsis: {\n type: Boolean,\n default: true,\n },\n /**\n * @description offset of the popper (effective for all submenus)\n */\n popperOffset: {\n type: Number,\n default: 6,\n },\n /**\n * @description custom ellipsis icon (available only in horizontal mode and ellipsis is true)\n */\n ellipsisIcon: {\n type: iconPropType,\n default: () => More,\n },\n /**\n * @description Tooltip theme, built-in theme: `dark` / `light` when menu is collapsed\n */\n popperEffect: {\n type: definePropType<PopperEffect>(String),\n default: 'dark',\n },\n /**\n * @description custom class name for all popup menus\n */\n popperClass: String,\n /**\n * @description custom style for all popup menus\n */\n popperStyle: {\n type: definePropType<string | CSSProperties>([String, Object]),\n },\n /**\n * @description control timeout for all menus before showing\n */\n showTimeout: {\n type: Number,\n default: 300,\n },\n /**\n * @description control timeout for all menus before hiding\n */\n hideTimeout: {\n type: Number,\n default: 300,\n },\n /**\n * @description when menu inactive and `persistent` is `false` , dropdown menu will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n} as const)\nexport type MenuProps = ExtractPropTypes<typeof menuProps>\nexport type MenuPropsPublic = ExtractPublicPropTypes<typeof menuProps>\n\nconst checkIndexPath = (indexPath: unknown): indexPath is string[] =>\n isArray(indexPath) && indexPath.every((path) => isString(path))\n\nexport const menuEmits = {\n close: (index: string, indexPath: string[]) =>\n isString(index) && checkIndexPath(indexPath),\n\n open: (index: string, indexPath: string[]) =>\n isString(index) && checkIndexPath(indexPath),\n\n select: (\n index: string,\n indexPath: string[],\n item: MenuItemClicked,\n routerResult?: Promise<void | NavigationFailure>\n ) =>\n isString(index) &&\n checkIndexPath(indexPath) &&\n isObject(item) &&\n (isUndefined(routerResult) || routerResult instanceof Promise),\n}\nexport type MenuEmits = typeof menuEmits\n\nconst DEFAULT_MORE_ITEM_WIDTH = 64\n\nexport default defineComponent({\n name: 'ElMenu',\n\n props: menuProps,\n emits: menuEmits,\n\n setup(props, { emit, slots, expose }) {\n const instance = getCurrentInstance()!\n const router = instance.appContext.config.globalProperties.$router as Router\n const menu = ref<HTMLUListElement>()\n const subMenu = ref<HTMLElement>()\n const nsMenu = useNamespace('menu')\n const nsSubMenu = useNamespace('sub-menu')\n let moreItemWidth = DEFAULT_MORE_ITEM_WIDTH\n\n // data\n const sliceIndex = ref(-1)\n\n const openedMenus = ref<MenuProvider['openedMenus']>(\n props.defaultOpeneds && !props.collapse\n ? props.defaultOpeneds.slice(0)\n : []\n )\n const activeIndex = ref<MenuProvider['activeIndex']>(props.defaultActive)\n const items = ref<MenuProvider['items']>({})\n const subMenus = ref<MenuProvider['subMenus']>({})\n\n // computed\n const isMenuPopup = computed<MenuProvider['isMenuPopup']>(\n () =>\n props.mode === 'horizontal' ||\n (props.mode === 'vertical' && props.collapse)\n )\n\n // methods\n const initMenu = () => {\n const activeItem = activeIndex.value && items.value[activeIndex.value]\n if (!activeItem || props.mode === 'horizontal' || props.collapse) return\n\n const indexPath = activeItem.indexPath\n\n // 展开该菜单项的路径上所有子菜单\n // expand all subMenus of the menu item\n indexPath.forEach((index) => {\n const subMenu = subMenus.value[index]\n subMenu && openMenu(index, subMenu.indexPath)\n })\n }\n\n const openMenu: MenuProvider['openMenu'] = (index, indexPath) => {\n if (openedMenus.value.includes(index)) return\n // 将不在该菜单路径下的其余菜单收起\n // collapse all menu that are not under current menu item\n if (props.uniqueOpened) {\n openedMenus.value = openedMenus.value.filter((index: string) =>\n indexPath.includes(index)\n )\n }\n openedMenus.value.push(index)\n emit('open', index, indexPath)\n }\n\n const close = (index: string) => {\n const i = openedMenus.value.indexOf(index)\n if (i !== -1) {\n openedMenus.value.splice(i, 1)\n }\n }\n\n const closeMenu: MenuProvider['closeMenu'] = (index, indexPath) => {\n close(index)\n emit('close', index, indexPath)\n }\n\n const handleSubMenuClick: MenuProvider['handleSubMenuClick'] = ({\n index,\n indexPath,\n }) => {\n const isOpened = openedMenus.value.includes(index)\n\n isOpened ? closeMenu(index, indexPath) : openMenu(index, indexPath)\n }\n\n const handleMenuItemClick: MenuProvider['handleMenuItemClick'] = (\n menuItem\n ) => {\n if (props.mode === 'horizontal' || props.collapse) {\n openedMenus.value = []\n }\n const { index, indexPath } = menuItem\n if (isNil(index) || isNil(indexPath)) return\n\n if (props.router && router) {\n const route = menuItem.route || index\n const routerResult = router.push(route).then((res) => {\n if (!res) activeIndex.value = index\n return res\n })\n emit(\n 'select',\n index,\n indexPath,\n { index, indexPath, route },\n routerResult\n )\n } else {\n activeIndex.value = index\n emit('select', index, indexPath, { index, indexPath })\n }\n }\n\n const updateActiveIndex = (val: string) => {\n const itemsInData = items.value\n const item =\n itemsInData[val] ||\n (activeIndex.value && itemsInData[activeIndex.value]) ||\n itemsInData[props.defaultActive]\n\n activeIndex.value = item?.index ?? val\n }\n\n const calcMenuItemWidth = (menuItem: HTMLElement) => {\n const computedStyle = getComputedStyle(menuItem)\n const marginLeft = Number.parseInt(computedStyle.marginLeft, 10)\n const marginRight = Number.parseInt(computedStyle.marginRight, 10)\n return menuItem.offsetWidth + marginLeft + marginRight || 0\n }\n\n const calcSliceIndex = () => {\n if (!menu.value) return -1\n\n const items = Array.from(menu.value.childNodes).filter(\n (item) =>\n item.nodeName !== '#comment' &&\n (item.nodeName !== '#text' || item.nodeValue)\n ) as HTMLElement[]\n\n const computedMenuStyle = getComputedStyle(menu.value)\n const paddingLeft = Number.parseInt(computedMenuStyle.paddingLeft, 10)\n const paddingRight = Number.parseInt(computedMenuStyle.paddingRight, 10)\n const menuWidth = menu.value.clientWidth - paddingLeft - paddingRight\n\n let calcWidth = 0\n let sliceIndex = 0\n items.forEach((item, index) => {\n calcWidth += calcMenuItemWidth(item)\n if (calcWidth <= menuWidth - moreItemWidth) {\n sliceIndex = index + 1\n }\n })\n return sliceIndex === items.length ? -1 : sliceIndex\n }\n\n const getIndexPath = (index: string) => subMenus.value[index].indexPath\n\n // Common computer monitor FPS is 60Hz, which means 60 redraws per second. Calculation formula: 1000ms/60 ≈ 16.67ms, In order to avoid a certain chance of repeated triggering when `resize`, set wait to 16.67 * 2 = 33.34\n const debounce = (fn: () => void, wait = 33.34) => {\n let timer: ReturnType<typeof setTimeout> | null\n return () => {\n timer && clearTimeout(timer)\n timer = setTimeout(() => {\n fn()\n }, wait)\n }\n }\n\n let isFirstTimeRender = true\n const handleResize = () => {\n const el = unrefElement(subMenu)\n if (el) moreItemWidth = calcMenuItemWidth(el) || DEFAULT_MORE_ITEM_WIDTH\n if (sliceIndex.value === calcSliceIndex()) return\n const callback = () => {\n sliceIndex.value = -1\n nextTick(() => {\n sliceIndex.value = calcSliceIndex()\n })\n }\n // execute callback directly when first time resize to avoid shaking\n isFirstTimeRender ? callback() : debounce(callback)()\n isFirstTimeRender = false\n }\n\n watch(\n () => props.defaultActive,\n (currentActive) => {\n if (!items.value[currentActive]) {\n activeIndex.value = ''\n }\n updateActiveIndex(currentActive)\n }\n )\n\n watch(\n () => props.collapse,\n (value) => {\n if (value) openedMenus.value = []\n }\n )\n\n watch(items.value, initMenu)\n\n let resizeStopper: UseResizeObserverReturn['stop']\n watchEffect(() => {\n if (props.mode === 'horizontal' && props.ellipsis)\n resizeStopper = useResizeObserver(menu, handleResize).stop\n else resizeStopper?.()\n })\n\n const mouseInChild = ref(false)\n\n // provide\n {\n const addSubMenu: MenuProvider['addSubMenu'] = (item) => {\n subMenus.value[item.index] = item\n }\n\n const removeSubMenu: MenuProvider['removeSubMenu'] = (item) => {\n delete subMenus.value[item.index]\n }\n\n const addMenuItem: MenuProvider['addMenuItem'] = (item) => {\n items.value[item.index] = item\n }\n\n const removeMenuItem: MenuProvider['removeMenuItem'] = (item) => {\n delete items.value[item.index]\n }\n\n provide<MenuProvider>(\n MENU_INJECTION_KEY,\n reactive({\n props,\n openedMenus,\n items,\n subMenus,\n activeIndex,\n isMenuPopup,\n\n addMenuItem,\n removeMenuItem,\n addSubMenu,\n removeSubMenu,\n openMenu,\n closeMenu,\n handleMenuItemClick,\n handleSubMenuClick,\n })\n )\n\n provide<SubMenuProvider>(`${SUB_MENU_INJECTION_KEY}${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n mouseInChild,\n level: 0,\n })\n }\n\n // lifecycle\n onMounted(() => {\n if (props.mode === 'horizontal') {\n new Menubar(instance.vnode.el!, nsMenu.namespace.value)\n }\n })\n\n {\n const open = (index: string) => {\n const { indexPath } = subMenus.value[index]\n indexPath.forEach((i) => openMenu(i, indexPath))\n }\n\n expose({\n open,\n close,\n updateActiveIndex,\n handleResize,\n })\n }\n\n const ulStyle = useMenuCssVar(props, 0)\n\n return () => {\n let slot: VNodeArrayChildren = slots.default?.() ?? []\n const vShowMore: VNode[] = []\n\n if (props.mode === 'horizontal' && menu.value) {\n const originalSlot = (\n flattedChildren(slot) as VNodeArrayChildren\n ).filter((vnode) => {\n // Filter text and comment nodes (https://github.com/vuejs/core/blob/c875019d49b4c36a88d929ccadc31ad414747c7b/packages/shared/src/shapeFlags.ts#L5)\n return (vnode as VNode)?.shapeFlag !== 8\n })\n const slotDefault =\n sliceIndex.value === -1\n ? originalSlot\n : originalSlot.slice(0, sliceIndex.value)\n\n const slotMore =\n sliceIndex.value === -1 ? [] : originalSlot.slice(sliceIndex.value)\n\n if (slotMore?.length && props.ellipsis) {\n slot = slotDefault\n vShowMore.push(\n h(\n ElSubMenu,\n {\n ref: subMenu,\n index: 'sub-menu-more',\n class: nsSubMenu.e('hide-arrow'),\n popperOffset: props.popperOffset,\n },\n {\n title: () =>\n h(\n ElIcon,\n {\n class: nsSubMenu.e('icon-more'),\n },\n {\n default: () => h(props.ellipsisIcon as Component),\n }\n ),\n default: () => slotMore,\n }\n )\n )\n }\n }\n\n const directives: DirectiveArguments = props.closeOnClickOutside\n ? [\n [\n vClickoutside,\n () => {\n if (!openedMenus.value.length) return\n\n if (!mouseInChild.value) {\n openedMenus.value.forEach((openedMenu) =>\n emit('close', openedMenu, getIndexPath(openedMenu))\n )\n\n openedMenus.value = []\n }\n },\n ],\n ]\n : []\n\n const vMenu = withDirectives(\n h(\n 'ul',\n {\n key: String(props.collapse),\n role: 'menubar',\n ref: menu,\n style: ulStyle.value,\n class: {\n [nsMenu.b()]: true,\n [nsMenu.m(props.mode)]: true,\n [nsMenu.m('collapse')]: props.collapse,\n },\n },\n [...slot, ...vShowMore]\n ),\n directives\n )\n\n if (props.collapseTransition && props.mode === 'vertical') {\n return h(ElMenuCollapseTransition, () => vMenu)\n }\n\n return vMenu\n }\n },\n})\n"],"mappings":"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"}
1
+ {"version":3,"file":"menu.js","names":["buildProps","definePropType","mutable","iconPropType","More","isUndefined","useNamespace","MENU_INJECTION_KEY","SUB_MENU_INJECTION_KEY","Menubar","useMenuCssVar","flattedChildren","ElSubMenu","ElIcon","vClickoutside","ElMenuCollapseTransition"],"sources":["../../../../../../packages/components/menu/src/menu.ts"],"sourcesContent":["import {\n computed,\n defineComponent,\n getCurrentInstance,\n h,\n nextTick,\n onMounted,\n provide,\n reactive,\n ref,\n watch,\n watchEffect,\n withDirectives,\n} from 'vue'\nimport { unrefElement, useResizeObserver } from '@vueuse/core'\nimport { isNil } from 'lodash-unified'\nimport ElIcon from '@element-plus/components/icon'\nimport { More } from '@element-plus/icons-vue'\nimport {\n buildProps,\n definePropType,\n flattedChildren,\n iconPropType,\n isArray,\n isObject,\n isString,\n isUndefined,\n mutable,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport Menubar from './utils/menu-bar'\nimport ElMenuCollapseTransition from './menu-collapse-transition.vue'\nimport ElSubMenu from './sub-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\nimport { MENU_INJECTION_KEY, SUB_MENU_INJECTION_KEY } from './tokens'\n\nimport type { PopperEffect } from '@element-plus/components/popper'\nimport type { MenuItemClicked, MenuProvider, SubMenuProvider } from './types'\nimport type { NavigationFailure, Router } from 'vue-router'\nimport type {\n CSSProperties,\n Component,\n DirectiveArguments,\n ExtractPropTypes,\n ExtractPublicPropTypes,\n VNode,\n VNodeArrayChildren,\n} from 'vue'\nimport type { UseResizeObserverReturn } from '@vueuse/core'\n\nexport const menuProps = buildProps({\n /**\n * @description menu display mode\n */\n mode: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'vertical',\n },\n /**\n * @description index of active menu on page load\n */\n defaultActive: {\n type: String,\n default: '',\n },\n /**\n * @description array that contains indexes of currently active sub-menus\n */\n defaultOpeneds: {\n type: definePropType<string[]>(Array),\n default: () => mutable([] as const),\n },\n /**\n * @description whether only one sub-menu can be active\n */\n uniqueOpened: Boolean,\n /**\n * @description whether `vue-router` mode is activated. If true, index will be used as 'path' to activate the route action. Use with `default-active` to set the active item on load.\n */\n router: Boolean,\n /**\n * @description how sub-menus are triggered, only works when `mode` is 'horizontal'\n */\n menuTrigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n /**\n * @description whether the menu is collapsed (available only in vertical mode)\n */\n collapse: Boolean,\n /**\n * @description background color of Menu (hex format) (deprecated, use `--bg-color` instead)\n * @deprecated use `--bg-color` instead\n */\n backgroundColor: String,\n /**\n * @description text color of Menu (hex format) (deprecated, use `--text-color` instead)\n * @deprecated use `--text-color` instead\n */\n textColor: String,\n /**\n * @description text color of currently active menu item (hex format) (deprecated, use `--active-color` instead)\n * @deprecated use `--active-color` instead\n */\n activeTextColor: String,\n /**\n * @description optional, whether menu is collapsed when clicking outside\n */\n closeOnClickOutside: Boolean,\n /**\n * @description whether to enable the collapse transition\n */\n collapseTransition: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether the menu is ellipsis (available only in horizontal mode)\n */\n ellipsis: {\n type: Boolean,\n default: true,\n },\n /**\n * @description offset of the popper (effective for all submenus)\n */\n popperOffset: {\n type: Number,\n default: 6,\n },\n /**\n * @description custom ellipsis icon (available only in horizontal mode and ellipsis is true)\n */\n ellipsisIcon: {\n type: iconPropType,\n default: () => More,\n },\n /**\n * @description Tooltip theme, built-in theme: `dark` / `light` when menu is collapsed\n */\n popperEffect: {\n type: definePropType<PopperEffect>(String),\n default: 'dark',\n },\n /**\n * @description custom class name for all popup menus\n */\n popperClass: String,\n /**\n * @description custom style for all popup menus\n */\n popperStyle: {\n type: definePropType<string | CSSProperties>([String, Object]),\n },\n /**\n * @description control timeout for all menus before showing\n */\n showTimeout: {\n type: Number,\n default: 300,\n },\n /**\n * @description control timeout for all menus before hiding\n */\n hideTimeout: {\n type: Number,\n default: 300,\n },\n /**\n * @description when menu inactive and `persistent` is `false` , dropdown menu will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n} as const)\nexport type MenuProps = ExtractPropTypes<typeof menuProps>\nexport type MenuPropsPublic = ExtractPublicPropTypes<typeof menuProps>\n\nconst checkIndexPath = (indexPath: unknown): indexPath is string[] =>\n isArray(indexPath) && indexPath.every((path) => isString(path))\n\nexport const menuEmits = {\n close: (index: string, indexPath: string[]) =>\n isString(index) && checkIndexPath(indexPath),\n\n open: (index: string, indexPath: string[]) =>\n isString(index) && checkIndexPath(indexPath),\n\n select: (\n index: string,\n indexPath: string[],\n item: MenuItemClicked,\n routerResult?: Promise<void | NavigationFailure>\n ) =>\n isString(index) &&\n checkIndexPath(indexPath) &&\n isObject(item) &&\n (isUndefined(routerResult) || routerResult instanceof Promise),\n}\nexport type MenuEmits = typeof menuEmits\n\nconst DEFAULT_MORE_ITEM_WIDTH = 64\n\nexport default defineComponent({\n name: 'ElMenu',\n\n props: menuProps,\n emits: menuEmits,\n\n setup(props, { emit, slots, expose }) {\n const instance = getCurrentInstance()!\n const router = instance.appContext.config.globalProperties.$router as Router\n const menu = ref<HTMLUListElement>()\n const subMenu = ref<HTMLElement>()\n const nsMenu = useNamespace('menu')\n const nsSubMenu = useNamespace('sub-menu')\n let moreItemWidth = DEFAULT_MORE_ITEM_WIDTH\n\n // data\n const sliceIndex = ref(-1)\n\n const openedMenus = ref<MenuProvider['openedMenus']>(\n props.defaultOpeneds && !props.collapse\n ? props.defaultOpeneds.slice(0)\n : []\n )\n const activeIndex = ref<MenuProvider['activeIndex']>(props.defaultActive)\n const items = ref<MenuProvider['items']>({})\n const subMenus = ref<MenuProvider['subMenus']>({})\n\n // computed\n const isMenuPopup = computed<MenuProvider['isMenuPopup']>(\n () =>\n props.mode === 'horizontal' ||\n (props.mode === 'vertical' && props.collapse)\n )\n\n // methods\n const initMenu = () => {\n const activeItem = activeIndex.value && items.value[activeIndex.value]\n if (!activeItem || props.mode === 'horizontal' || props.collapse) return\n\n const indexPath = activeItem.indexPath\n\n // 展开该菜单项的路径上所有子菜单\n // expand all subMenus of the menu item\n indexPath.forEach((index) => {\n const subMenu = subMenus.value[index]\n subMenu && openMenu(index, subMenu.indexPath)\n })\n }\n\n const openMenu: MenuProvider['openMenu'] = (index, indexPath) => {\n if (openedMenus.value.includes(index)) return\n // 将不在该菜单路径下的其余菜单收起\n // collapse all menu that are not under current menu item\n if (props.uniqueOpened) {\n openedMenus.value = openedMenus.value.filter((index: string) =>\n indexPath.includes(index)\n )\n }\n openedMenus.value.push(index)\n emit('open', index, indexPath)\n }\n\n const close = (index: string) => {\n const i = openedMenus.value.indexOf(index)\n if (i !== -1) {\n openedMenus.value.splice(i, 1)\n }\n }\n\n const closeMenu: MenuProvider['closeMenu'] = (index, indexPath) => {\n close(index)\n emit('close', index, indexPath)\n }\n\n const handleSubMenuClick: MenuProvider['handleSubMenuClick'] = ({\n index,\n indexPath,\n }) => {\n const isOpened = openedMenus.value.includes(index)\n\n isOpened ? closeMenu(index, indexPath) : openMenu(index, indexPath)\n }\n\n const handleMenuItemClick: MenuProvider['handleMenuItemClick'] = (\n menuItem\n ) => {\n if (props.mode === 'horizontal' || props.collapse) {\n openedMenus.value = []\n }\n const { index, indexPath } = menuItem\n if (isNil(index) || isNil(indexPath)) return\n\n if (props.router && router) {\n const route = menuItem.route || index\n const routerResult = router.push(route).then((res) => {\n if (!res) activeIndex.value = index\n return res\n })\n emit(\n 'select',\n index,\n indexPath,\n { index, indexPath, route },\n routerResult\n )\n } else {\n activeIndex.value = index\n emit('select', index, indexPath, { index, indexPath })\n }\n }\n\n const updateActiveIndex = (val: string) => {\n const itemsInData = items.value\n const item =\n itemsInData[val] ||\n (activeIndex.value && itemsInData[activeIndex.value]) ||\n itemsInData[props.defaultActive]\n\n activeIndex.value = item?.index ?? val\n }\n\n const calcMenuItemWidth = (menuItem: HTMLElement) => {\n const computedStyle = getComputedStyle(menuItem)\n const marginLeft = Number.parseInt(computedStyle.marginLeft, 10)\n const marginRight = Number.parseInt(computedStyle.marginRight, 10)\n return menuItem.offsetWidth + marginLeft + marginRight || 0\n }\n\n const calcSliceIndex = () => {\n if (!menu.value) return -1\n\n const items = Array.from(menu.value.childNodes).filter(\n (item) =>\n item.nodeName !== '#comment' &&\n (item.nodeName !== '#text' || item.nodeValue)\n ) as HTMLElement[]\n\n const computedMenuStyle = getComputedStyle(menu.value)\n const paddingLeft = Number.parseInt(computedMenuStyle.paddingLeft, 10)\n const paddingRight = Number.parseInt(computedMenuStyle.paddingRight, 10)\n const menuWidth = menu.value.clientWidth - paddingLeft - paddingRight\n\n let calcWidth = 0\n let sliceIndex = 0\n items.forEach((item, index) => {\n calcWidth += calcMenuItemWidth(item)\n if (calcWidth <= menuWidth - moreItemWidth) {\n sliceIndex = index + 1\n }\n })\n return sliceIndex === items.length ? -1 : sliceIndex\n }\n\n const getIndexPath = (index: string) => subMenus.value[index].indexPath\n\n // Common computer monitor FPS is 60Hz, which means 60 redraws per second. Calculation formula: 1000ms/60 ≈ 16.67ms, In order to avoid a certain chance of repeated triggering when `resize`, set wait to 16.67 * 2 = 33.34\n const debounce = (fn: () => void, wait = 33.34) => {\n let timer: ReturnType<typeof setTimeout> | null\n return () => {\n timer && clearTimeout(timer)\n timer = setTimeout(() => {\n fn()\n }, wait)\n }\n }\n\n let isFirstTimeRender = true\n const handleResize = () => {\n const el = unrefElement(subMenu)\n if (el) moreItemWidth = calcMenuItemWidth(el) || DEFAULT_MORE_ITEM_WIDTH\n if (sliceIndex.value === calcSliceIndex()) return\n const callback = () => {\n sliceIndex.value = -1\n nextTick(() => {\n sliceIndex.value = calcSliceIndex()\n })\n }\n // execute callback directly when first time resize to avoid shaking\n isFirstTimeRender ? callback() : debounce(callback)()\n isFirstTimeRender = false\n }\n\n watch(\n () => props.defaultActive,\n (currentActive) => {\n if (!items.value[currentActive]) {\n activeIndex.value = ''\n }\n updateActiveIndex(currentActive)\n }\n )\n\n watch(\n () => props.collapse,\n (value) => {\n if (value) openedMenus.value = []\n }\n )\n\n watch(items.value, initMenu)\n\n let resizeStopper: UseResizeObserverReturn['stop']\n watchEffect(() => {\n if (props.mode === 'horizontal' && props.ellipsis)\n resizeStopper = useResizeObserver(menu, handleResize).stop\n else resizeStopper?.()\n })\n\n const mouseInChild = ref(false)\n\n // provide\n {\n const addSubMenu: MenuProvider['addSubMenu'] = (item) => {\n subMenus.value[item.index] = item\n }\n\n const removeSubMenu: MenuProvider['removeSubMenu'] = (item) => {\n delete subMenus.value[item.index]\n }\n\n const addMenuItem: MenuProvider['addMenuItem'] = (item) => {\n items.value[item.index] = item\n }\n\n const removeMenuItem: MenuProvider['removeMenuItem'] = (item) => {\n delete items.value[item.index]\n }\n\n provide<MenuProvider>(\n MENU_INJECTION_KEY,\n reactive({\n props,\n openedMenus,\n items,\n subMenus,\n activeIndex,\n isMenuPopup,\n\n addMenuItem,\n removeMenuItem,\n addSubMenu,\n removeSubMenu,\n openMenu,\n closeMenu,\n handleMenuItemClick,\n handleSubMenuClick,\n })\n )\n\n provide<SubMenuProvider>(`${SUB_MENU_INJECTION_KEY}${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n mouseInChild,\n level: 0,\n })\n }\n\n // lifecycle\n onMounted(() => {\n if (props.mode === 'horizontal') {\n new Menubar(instance.vnode.el!, nsMenu.namespace.value)\n }\n })\n\n {\n const open = (index: string) => {\n const { indexPath } = subMenus.value[index]\n indexPath.forEach((i) => openMenu(i, indexPath))\n }\n\n expose({\n open,\n close,\n updateActiveIndex,\n handleResize,\n })\n }\n\n const ulStyle = useMenuCssVar(props, 0)\n\n return () => {\n let slot: VNodeArrayChildren = slots.default?.() ?? []\n const vShowMore: VNode[] = []\n\n if (props.mode === 'horizontal' && menu.value) {\n const originalSlot = (\n flattedChildren(slot) as VNodeArrayChildren\n ).filter((vnode) => {\n // Filter text and comment nodes (https://github.com/vuejs/core/blob/c875019d49b4c36a88d929ccadc31ad414747c7b/packages/shared/src/shapeFlags.ts#L5)\n return (vnode as VNode)?.shapeFlag !== 8\n })\n const slotDefault =\n sliceIndex.value === -1\n ? originalSlot\n : originalSlot.slice(0, sliceIndex.value)\n\n const slotMore =\n sliceIndex.value === -1 ? [] : originalSlot.slice(sliceIndex.value)\n\n if (slotMore?.length && props.ellipsis) {\n slot = slotDefault\n vShowMore.push(\n h(\n ElSubMenu,\n {\n ref: subMenu,\n index: 'sub-menu-more',\n class: nsSubMenu.e('hide-arrow'),\n popperOffset: props.popperOffset,\n },\n {\n title: () =>\n h(\n ElIcon,\n {\n class: nsSubMenu.e('icon-more'),\n },\n {\n default: () => h(props.ellipsisIcon as Component),\n }\n ),\n default: () => slotMore,\n }\n )\n )\n }\n }\n\n const directives: DirectiveArguments = props.closeOnClickOutside\n ? [\n [\n vClickoutside,\n () => {\n if (!openedMenus.value.length) return\n\n if (!mouseInChild.value) {\n openedMenus.value.forEach((openedMenu) =>\n emit('close', openedMenu, getIndexPath(openedMenu))\n )\n\n openedMenus.value = []\n }\n },\n ],\n ]\n : []\n\n const vMenu = withDirectives(\n h(\n 'ul',\n {\n key: String(props.collapse),\n role: 'menubar',\n ref: menu,\n style: ulStyle.value,\n class: {\n [nsMenu.b()]: true,\n [nsMenu.m(props.mode)]: true,\n [nsMenu.m('collapse')]: props.collapse,\n },\n },\n [...slot, ...vShowMore]\n ),\n directives\n )\n\n if (props.collapseTransition && props.mode === 'vertical') {\n return h(ElMenuCollapseTransition, () => vMenu)\n }\n\n return vMenu\n }\n },\n})\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });
2
- const require_aria = require('../../../../utils/dom/aria.js');
3
- const require_aria$1 = require('../../../../constants/aria.js');
2
+ const require_aria = require('../../../../constants/aria.js');
3
+ const require_aria$1 = require('../../../../utils/dom/aria.js');
4
4
  const require_event = require('../../../../utils/dom/event.js');
5
5
  const require_submenu = require('./submenu.js');
6
6
 
@@ -22,22 +22,22 @@ var MenuItem = class {
22
22
  const code = require_event.getEventCode(event);
23
23
  let prevDef = false;
24
24
  switch (code) {
25
- case require_aria$1.EVENT_CODE.down:
26
- require_aria.triggerEvent(event.currentTarget, "mouseenter");
25
+ case require_aria.EVENT_CODE.down:
26
+ require_aria$1.triggerEvent(event.currentTarget, "mouseenter");
27
27
  this.submenu?.gotoSubIndex(0);
28
28
  prevDef = true;
29
29
  break;
30
- case require_aria$1.EVENT_CODE.up:
31
- require_aria.triggerEvent(event.currentTarget, "mouseenter");
30
+ case require_aria.EVENT_CODE.up:
31
+ require_aria$1.triggerEvent(event.currentTarget, "mouseenter");
32
32
  this.submenu?.gotoSubIndex(this.submenu.subMenuItems.length - 1);
33
33
  prevDef = true;
34
34
  break;
35
- case require_aria$1.EVENT_CODE.tab:
36
- require_aria.triggerEvent(event.currentTarget, "mouseleave");
35
+ case require_aria.EVENT_CODE.tab:
36
+ require_aria$1.triggerEvent(event.currentTarget, "mouseleave");
37
37
  break;
38
- case require_aria$1.EVENT_CODE.enter:
39
- case require_aria$1.EVENT_CODE.numpadEnter:
40
- case require_aria$1.EVENT_CODE.space:
38
+ case require_aria.EVENT_CODE.enter:
39
+ case require_aria.EVENT_CODE.numpadEnter:
40
+ case require_aria.EVENT_CODE.space:
41
41
  prevDef = true;
42
42
  event.currentTarget.click();
43
43
  break;
@@ -1 +1 @@
1
- {"version":3,"file":"menu-item.js","names":["SubMenu","getEventCode","EVENT_CODE"],"sources":["../../../../../../../packages/components/menu/src/utils/menu-item.ts"],"sourcesContent":["import { getEventCode, triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport SubMenu from './submenu'\n\nclass MenuItem {\n public submenu: SubMenu | null\n constructor(\n public domNode: HTMLElement,\n namespace: string\n ) {\n this.submenu = null\n this.init(namespace)\n }\n\n init(namespace: string): void {\n this.domNode.setAttribute('tabindex', '0')\n const menuChild = this.domNode.querySelector(`.${namespace}-menu`)\n if (menuChild) {\n this.submenu = new SubMenu(this, menuChild)\n }\n this.addListeners()\n }\n\n addListeners() {\n this.domNode.addEventListener('keydown', (event: KeyboardEvent) => {\n const code = getEventCode(event)\n let prevDef = false\n\n switch (code) {\n case EVENT_CODE.down: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n this.submenu?.gotoSubIndex(0)\n prevDef = true\n break\n }\n case EVENT_CODE.up: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n this.submenu?.gotoSubIndex(this.submenu.subMenuItems.length - 1)\n prevDef = true\n break\n }\n case EVENT_CODE.tab: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseleave')\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n case EVENT_CODE.space: {\n prevDef = true\n ;(event.currentTarget as HTMLElement).click()\n break\n }\n }\n if (prevDef) {\n event.preventDefault()\n }\n })\n }\n}\n\nexport default MenuItem\n"],"mappings":";;;;;;;AAIA,IAAM,WAAN,MAAe;CAEb,YACE,AAAO,SACP,WACA;EAFO;AAGP,OAAK,UAAU;AACf,OAAK,KAAK,UAAU;;CAGtB,KAAK,WAAyB;AAC5B,OAAK,QAAQ,aAAa,YAAY,IAAI;EAC1C,MAAM,YAAY,KAAK,QAAQ,cAAc,IAAI,UAAU,OAAO;AAClE,MAAI,UACF,MAAK,UAAU,IAAIA,wBAAQ,MAAM,UAAU;AAE7C,OAAK,cAAc;;CAGrB,eAAe;AACb,OAAK,QAAQ,iBAAiB,YAAY,UAAyB;GACjE,MAAM,OAAOC,2BAAa,MAAM;GAChC,IAAI,UAAU;AAEd,WAAQ,MAAR;IACE,KAAKC,0BAAW;AACd,+BAAa,MAAM,eAA8B,aAAa;AAC9D,UAAK,SAAS,aAAa,EAAE;AAC7B,eAAU;AACV;IAEF,KAAKA,0BAAW;AACd,+BAAa,MAAM,eAA8B,aAAa;AAC9D,UAAK,SAAS,aAAa,KAAK,QAAQ,aAAa,SAAS,EAAE;AAChE,eAAU;AACV;IAEF,KAAKA,0BAAW;AACd,+BAAa,MAAM,eAA8B,aAAa;AAC9D;IAEF,KAAKA,0BAAW;IAChB,KAAKA,0BAAW;IAChB,KAAKA,0BAAW;AACd,eAAU;AACT,KAAC,MAAM,cAA8B,OAAO;AAC7C;;AAGJ,OAAI,QACF,OAAM,gBAAgB;IAExB"}
1
+ {"version":3,"file":"menu-item.js","names":["SubMenu","getEventCode","EVENT_CODE"],"sources":["../../../../../../../packages/components/menu/src/utils/menu-item.ts"],"sourcesContent":["import { getEventCode, triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport SubMenu from './submenu'\n\nclass MenuItem {\n public submenu: SubMenu | null\n constructor(\n public domNode: HTMLElement,\n namespace: string\n ) {\n this.submenu = null\n this.init(namespace)\n }\n\n init(namespace: string): void {\n this.domNode.setAttribute('tabindex', '0')\n const menuChild = this.domNode.querySelector(`.${namespace}-menu`)\n if (menuChild) {\n this.submenu = new SubMenu(this, menuChild)\n }\n this.addListeners()\n }\n\n addListeners() {\n this.domNode.addEventListener('keydown', (event: KeyboardEvent) => {\n const code = getEventCode(event)\n let prevDef = false\n\n switch (code) {\n case EVENT_CODE.down: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n this.submenu?.gotoSubIndex(0)\n prevDef = true\n break\n }\n case EVENT_CODE.up: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n this.submenu?.gotoSubIndex(this.submenu.subMenuItems.length - 1)\n prevDef = true\n break\n }\n case EVENT_CODE.tab: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseleave')\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n case EVENT_CODE.space: {\n prevDef = true\n ;(event.currentTarget as HTMLElement).click()\n break\n }\n }\n if (prevDef) {\n event.preventDefault()\n }\n })\n }\n}\n\nexport default MenuItem\n"],"mappings":";;;;;;;AAIA,IAAM,WAAN,MAAe;CAEb,YACE,AAAO,SACP,WACA;EAFO;AAGP,OAAK,UAAU;AACf,OAAK,KAAK,UAAU;;CAGtB,KAAK,WAAyB;AAC5B,OAAK,QAAQ,aAAa,YAAY,IAAI;EAC1C,MAAM,YAAY,KAAK,QAAQ,cAAc,IAAI,UAAU,OAAO;AAClE,MAAI,UACF,MAAK,UAAU,IAAIA,wBAAQ,MAAM,UAAU;AAE7C,OAAK,cAAc;;CAGrB,eAAe;AACb,OAAK,QAAQ,iBAAiB,YAAY,UAAyB;GACjE,MAAM,OAAOC,2BAAa,MAAM;GAChC,IAAI,UAAU;AAEd,WAAQ,MAAR;IACE,KAAKC,wBAAW;AACd,iCAAa,MAAM,eAA8B,aAAa;AAC9D,UAAK,SAAS,aAAa,EAAE;AAC7B,eAAU;AACV;IAEF,KAAKA,wBAAW;AACd,iCAAa,MAAM,eAA8B,aAAa;AAC9D,UAAK,SAAS,aAAa,KAAK,QAAQ,aAAa,SAAS,EAAE;AAChE,eAAU;AACV;IAEF,KAAKA,wBAAW;AACd,iCAAa,MAAM,eAA8B,aAAa;AAC9D;IAEF,KAAKA,wBAAW;IAChB,KAAKA,wBAAW;IAChB,KAAKA,wBAAW;AACd,eAAU;AACT,KAAC,MAAM,cAA8B,OAAO;AAC7C;;AAGJ,OAAI,QACF,OAAM,gBAAgB;IAExB"}
@@ -1,6 +1,6 @@
1
1
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });
2
- const require_aria = require('../../../../utils/dom/aria.js');
3
- const require_aria$1 = require('../../../../constants/aria.js');
2
+ const require_aria = require('../../../../constants/aria.js');
3
+ const require_aria$1 = require('../../../../utils/dom/aria.js');
4
4
  const require_event = require('../../../../utils/dom/event.js');
5
5
 
6
6
  //#region ../../packages/components/menu/src/utils/submenu.ts
@@ -25,20 +25,20 @@ var SubMenu = class {
25
25
  const code = require_event.getEventCode(event);
26
26
  let prevDef = false;
27
27
  switch (code) {
28
- case require_aria$1.EVENT_CODE.down:
28
+ case require_aria.EVENT_CODE.down:
29
29
  this.gotoSubIndex(this.subIndex + 1);
30
30
  prevDef = true;
31
31
  break;
32
- case require_aria$1.EVENT_CODE.up:
32
+ case require_aria.EVENT_CODE.up:
33
33
  this.gotoSubIndex(this.subIndex - 1);
34
34
  prevDef = true;
35
35
  break;
36
- case require_aria$1.EVENT_CODE.tab:
37
- require_aria.triggerEvent(parentNode, "mouseleave");
36
+ case require_aria.EVENT_CODE.tab:
37
+ require_aria$1.triggerEvent(parentNode, "mouseleave");
38
38
  break;
39
- case require_aria$1.EVENT_CODE.enter:
40
- case require_aria$1.EVENT_CODE.numpadEnter:
41
- case require_aria$1.EVENT_CODE.space:
39
+ case require_aria.EVENT_CODE.enter:
40
+ case require_aria.EVENT_CODE.numpadEnter:
41
+ case require_aria.EVENT_CODE.space:
42
42
  prevDef = true;
43
43
  event.currentTarget.click();
44
44
  break;
@@ -1 +1 @@
1
- {"version":3,"file":"submenu.js","names":["getEventCode","EVENT_CODE"],"sources":["../../../../../../../packages/components/menu/src/utils/submenu.ts"],"sourcesContent":["import { getEventCode, triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\n\nimport type MenuItem from './menu-item'\n\nclass SubMenu {\n public subMenuItems: NodeListOf<HTMLLIElement>\n public subIndex: number\n constructor(\n public parent: MenuItem,\n public domNode: ParentNode\n ) {\n this.subIndex = 0\n this.subMenuItems = this.domNode.querySelectorAll('li')\n this.addListeners()\n }\n\n gotoSubIndex(idx: number) {\n if (idx === this.subMenuItems.length) {\n idx = 0\n } else if (idx < 0) {\n idx = this.subMenuItems.length - 1\n }\n this.subMenuItems[idx].focus()\n this.subIndex = idx\n }\n\n addListeners() {\n const parentNode = this.parent.domNode\n this.subMenuItems.forEach((el) => {\n el.addEventListener('keydown', (event: KeyboardEvent) => {\n const code = getEventCode(event)\n let prevDef = false\n\n switch (code) {\n case EVENT_CODE.down: {\n this.gotoSubIndex(this.subIndex + 1)\n prevDef = true\n break\n }\n case EVENT_CODE.up: {\n this.gotoSubIndex(this.subIndex - 1)\n prevDef = true\n break\n }\n case EVENT_CODE.tab: {\n triggerEvent(parentNode, 'mouseleave')\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n case EVENT_CODE.space: {\n prevDef = true\n ;(event.currentTarget as HTMLElement).click()\n break\n }\n }\n if (prevDef) {\n event.preventDefault()\n event.stopPropagation()\n }\n return false\n })\n })\n }\n}\n\nexport default SubMenu\n"],"mappings":";;;;;;AAKA,IAAM,UAAN,MAAc;CAGZ,YACE,AAAO,QACP,AAAO,SACP;EAFO;EACA;AAEP,OAAK,WAAW;AAChB,OAAK,eAAe,KAAK,QAAQ,iBAAiB,KAAK;AACvD,OAAK,cAAc;;CAGrB,aAAa,KAAa;AACxB,MAAI,QAAQ,KAAK,aAAa,OAC5B,OAAM;WACG,MAAM,EACf,OAAM,KAAK,aAAa,SAAS;AAEnC,OAAK,aAAa,KAAK,OAAO;AAC9B,OAAK,WAAW;;CAGlB,eAAe;EACb,MAAM,aAAa,KAAK,OAAO;AAC/B,OAAK,aAAa,SAAS,OAAO;AAChC,MAAG,iBAAiB,YAAY,UAAyB;IACvD,MAAM,OAAOA,2BAAa,MAAM;IAChC,IAAI,UAAU;AAEd,YAAQ,MAAR;KACE,KAAKC,0BAAW;AACd,WAAK,aAAa,KAAK,WAAW,EAAE;AACpC,gBAAU;AACV;KAEF,KAAKA,0BAAW;AACd,WAAK,aAAa,KAAK,WAAW,EAAE;AACpC,gBAAU;AACV;KAEF,KAAKA,0BAAW;AACd,gCAAa,YAAY,aAAa;AACtC;KAEF,KAAKA,0BAAW;KAChB,KAAKA,0BAAW;KAChB,KAAKA,0BAAW;AACd,gBAAU;AACT,MAAC,MAAM,cAA8B,OAAO;AAC7C;;AAGJ,QAAI,SAAS;AACX,WAAM,gBAAgB;AACtB,WAAM,iBAAiB;;AAEzB,WAAO;KACP;IACF"}
1
+ {"version":3,"file":"submenu.js","names":["getEventCode","EVENT_CODE"],"sources":["../../../../../../../packages/components/menu/src/utils/submenu.ts"],"sourcesContent":["import { getEventCode, triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\n\nimport type MenuItem from './menu-item'\n\nclass SubMenu {\n public subMenuItems: NodeListOf<HTMLLIElement>\n public subIndex: number\n constructor(\n public parent: MenuItem,\n public domNode: ParentNode\n ) {\n this.subIndex = 0\n this.subMenuItems = this.domNode.querySelectorAll('li')\n this.addListeners()\n }\n\n gotoSubIndex(idx: number) {\n if (idx === this.subMenuItems.length) {\n idx = 0\n } else if (idx < 0) {\n idx = this.subMenuItems.length - 1\n }\n this.subMenuItems[idx].focus()\n this.subIndex = idx\n }\n\n addListeners() {\n const parentNode = this.parent.domNode\n this.subMenuItems.forEach((el) => {\n el.addEventListener('keydown', (event: KeyboardEvent) => {\n const code = getEventCode(event)\n let prevDef = false\n\n switch (code) {\n case EVENT_CODE.down: {\n this.gotoSubIndex(this.subIndex + 1)\n prevDef = true\n break\n }\n case EVENT_CODE.up: {\n this.gotoSubIndex(this.subIndex - 1)\n prevDef = true\n break\n }\n case EVENT_CODE.tab: {\n triggerEvent(parentNode, 'mouseleave')\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n case EVENT_CODE.space: {\n prevDef = true\n ;(event.currentTarget as HTMLElement).click()\n break\n }\n }\n if (prevDef) {\n event.preventDefault()\n event.stopPropagation()\n }\n return false\n })\n })\n }\n}\n\nexport default SubMenu\n"],"mappings":";;;;;;AAKA,IAAM,UAAN,MAAc;CAGZ,YACE,AAAO,QACP,AAAO,SACP;EAFO;EACA;AAEP,OAAK,WAAW;AAChB,OAAK,eAAe,KAAK,QAAQ,iBAAiB,KAAK;AACvD,OAAK,cAAc;;CAGrB,aAAa,KAAa;AACxB,MAAI,QAAQ,KAAK,aAAa,OAC5B,OAAM;WACG,MAAM,EACf,OAAM,KAAK,aAAa,SAAS;AAEnC,OAAK,aAAa,KAAK,OAAO;AAC9B,OAAK,WAAW;;CAGlB,eAAe;EACb,MAAM,aAAa,KAAK,OAAO;AAC/B,OAAK,aAAa,SAAS,OAAO;AAChC,MAAG,iBAAiB,YAAY,UAAyB;IACvD,MAAM,OAAOA,2BAAa,MAAM;IAChC,IAAI,UAAU;AAEd,YAAQ,MAAR;KACE,KAAKC,wBAAW;AACd,WAAK,aAAa,KAAK,WAAW,EAAE;AACpC,gBAAU;AACV;KAEF,KAAKA,wBAAW;AACd,WAAK,aAAa,KAAK,WAAW,EAAE;AACpC,gBAAU;AACV;KAEF,KAAKA,wBAAW;AACd,kCAAa,YAAY,aAAa;AACtC;KAEF,KAAKA,wBAAW;KAChB,KAAKA,wBAAW;KAChB,KAAKA,wBAAW;AACd,gBAAU;AACT,MAAC,MAAM,cAA8B,OAAO;AAC7C;;AAGJ,QAAI,SAAS;AACX,WAAM,gBAAgB;AACtB,WAAM,iBAAiB;;AAEzB,WAAO;KACP;IACF"}
@@ -131,10 +131,10 @@ declare const messageProps: {
131
131
  readonly prototype: any;
132
132
  }) | null)[], unknown, unknown, undefined, boolean>;
133
133
  readonly showClose: EpPropFinalized<BooleanConstructor, unknown, unknown, false, boolean>;
134
- readonly type: EpPropFinalized<StringConstructor, "error" | "primary" | "success" | "warning" | "info", unknown, "info", boolean>;
134
+ readonly type: EpPropFinalized<StringConstructor, "info" | "primary" | "success" | "warning" | "error", unknown, "info", boolean>;
135
135
  readonly plain: EpPropFinalized<BooleanConstructor, unknown, unknown, false, boolean>;
136
136
  readonly offset: EpPropFinalized<NumberConstructor, unknown, unknown, 16, boolean>;
137
- readonly placement: EpPropFinalized<StringConstructor, "bottom" | "top" | "top-right" | "top-left" | "bottom-right" | "bottom-left", unknown, undefined, boolean>;
137
+ readonly placement: EpPropFinalized<StringConstructor, "bottom" | "top" | "top-left" | "top-right" | "bottom-left" | "bottom-right", unknown, undefined, boolean>;
138
138
  readonly zIndex: EpPropFinalized<NumberConstructor, unknown, unknown, 0, boolean>;
139
139
  readonly grouping: EpPropFinalized<BooleanConstructor, unknown, unknown, false, boolean>;
140
140
  readonly repeatNum: EpPropFinalized<NumberConstructor, unknown, unknown, 1, boolean>;
@@ -21,14 +21,14 @@ declare const __VLS_base: vue.DefineComponent<MessageProps, {
21
21
  }>, {
22
22
  type: MessageType;
23
23
  icon: IconPropType;
24
- id: string;
24
+ onClose: () => void;
25
25
  zIndex: number;
26
26
  offset: number;
27
+ id: string;
27
28
  placement: MessagePlacement;
28
- onClose: () => void;
29
- showClose: boolean;
30
29
  plain: boolean;
31
30
  message: string | vue.VNode | (() => vue.VNode);
31
+ showClose: boolean;
32
32
  duration: number;
33
33
  customClass: string;
34
34
  dangerouslyUseHTMLString: boolean;