element-plus 1.2.0-beta.5 → 1.2.0-beta.6

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 (984) hide show
  1. package/README.md +5 -174
  2. package/attributes.json +1 -1
  3. package/dist/index.css +1 -1
  4. package/dist/index.full.js +1568 -1607
  5. package/dist/index.full.min.js +8 -8
  6. package/dist/index.full.min.js.map +1 -1
  7. package/dist/index.full.min.mjs +11 -11
  8. package/dist/index.full.min.mjs.map +1 -1
  9. package/dist/index.full.mjs +1563 -1612
  10. package/es/component.d.ts +3 -0
  11. package/es/component.mjs.map +1 -1
  12. package/es/components/affix/index.d.ts +48 -0
  13. package/es/components/affix/src/affix.vue.d.ts +48 -0
  14. package/es/components/alert/index.d.ts +5 -5
  15. package/es/components/alert/src/alert.d.ts +1 -1
  16. package/es/components/alert/src/alert.vue.d.ts +5 -5
  17. package/es/components/autocomplete/index.d.ts +4 -4
  18. package/es/components/autocomplete/src/index.vue.d.ts +2 -2
  19. package/es/components/autocomplete/src/index.vue_vue_type_script_lang.mjs +1 -1
  20. package/es/components/autocomplete/src/index.vue_vue_type_script_lang.mjs.map +1 -1
  21. package/es/components/autocomplete/src/index.vue_vue_type_template_id_2f09f285_lang.mjs.map +1 -1
  22. package/es/components/avatar/index.d.ts +1 -1
  23. package/es/components/avatar/src/avatar.vue.d.ts +1 -1
  24. package/es/components/backtop/src/backtop.vue_vue_type_script_lang.mjs +1 -1
  25. package/es/components/backtop/src/backtop.vue_vue_type_script_lang.mjs.map +1 -1
  26. package/es/components/backtop/src/backtop.vue_vue_type_template_id_63a7fea6_lang.mjs.map +1 -1
  27. package/es/components/button/index.d.ts +18 -18
  28. package/es/components/button/src/button-group.d.ts +1 -1
  29. package/es/components/button/src/button-group.vue.d.ts +3 -3
  30. package/es/components/button/src/button.d.ts +3 -3
  31. package/es/components/button/src/button.mjs +5 -3
  32. package/es/components/button/src/button.mjs.map +1 -1
  33. package/es/components/button/src/button.vue.d.ts +12 -12
  34. package/es/components/button/src/button.vue_vue_type_script_lang.mjs +9 -12
  35. package/es/components/button/src/button.vue_vue_type_script_lang.mjs.map +1 -1
  36. package/es/components/button/src/button.vue_vue_type_template_id_802c5c76_lang.mjs.map +1 -1
  37. package/es/components/calendar/index.d.ts +20 -47
  38. package/es/components/calendar/index.mjs +6 -8
  39. package/es/components/calendar/index.mjs.map +1 -1
  40. package/es/components/calendar/src/calendar.d.ts +11 -0
  41. package/es/components/calendar/src/calendar.mjs +19 -0
  42. package/es/components/calendar/src/calendar.mjs.map +1 -0
  43. package/es/components/calendar/src/calendar.vue.d.ts +34 -0
  44. package/es/components/calendar/src/{index.vue_vue_type_script_lang.mjs → calendar.vue_vue_type_script_lang.mjs} +12 -23
  45. package/es/components/calendar/src/calendar.vue_vue_type_script_lang.mjs.map +1 -0
  46. package/es/components/calendar/src/{index.vue_vue_type_template_id_819aa44a_lang.mjs → calendar.vue_vue_type_template_id_76705c76_lang.mjs} +1 -1
  47. package/es/components/calendar/src/calendar.vue_vue_type_template_id_76705c76_lang.mjs.map +1 -0
  48. package/es/components/calendar/src/calendar2.mjs +7 -0
  49. package/es/components/calendar/src/calendar2.mjs.map +1 -0
  50. package/es/components/calendar/src/date-table.d.ts +13 -0
  51. package/es/components/calendar/src/date-table.mjs +23 -5
  52. package/es/components/calendar/src/date-table.mjs.map +1 -1
  53. package/es/components/calendar/src/date-table.vue.d.ts +29 -38
  54. package/es/components/calendar/src/date-table.vue_vue_type_script_lang.mjs +54 -71
  55. package/es/components/calendar/src/date-table.vue_vue_type_script_lang.mjs.map +1 -1
  56. package/es/components/calendar/src/date-table.vue_vue_type_template_id_297fdb36_lang.mjs +1 -1
  57. package/es/components/calendar/src/date-table.vue_vue_type_template_id_297fdb36_lang.mjs.map +1 -1
  58. package/es/components/calendar/src/date-table2.mjs +7 -0
  59. package/es/components/calendar/src/date-table2.mjs.map +1 -0
  60. package/es/components/carousel/src/main.vue_vue_type_script_lang.mjs +1 -1
  61. package/es/components/carousel/src/main.vue_vue_type_script_lang.mjs.map +1 -1
  62. package/es/components/carousel/src/main.vue_vue_type_template_id_1303d144_lang.mjs.map +1 -1
  63. package/es/components/cascader/index.d.ts +8756 -0
  64. package/es/components/cascader/src/index.vue.d.ts +4384 -0
  65. package/es/components/cascader/src/index.vue_vue_type_script_lang.mjs +3 -4
  66. package/es/components/cascader/src/index.vue_vue_type_script_lang.mjs.map +1 -1
  67. package/es/components/cascader/src/index.vue_vue_type_template_id_0429c2db_lang.mjs.map +1 -1
  68. package/es/components/cascader-panel/src/node.vue_vue_type_script_lang.mjs +1 -1
  69. package/es/components/cascader-panel/src/node.vue_vue_type_script_lang.mjs.map +1 -1
  70. package/es/components/cascader-panel/src/node.vue_vue_type_template_id_18b09cb2_lang.mjs.map +1 -1
  71. package/es/components/checkbox/index.d.ts +10 -10
  72. package/es/components/checkbox/src/checkbox-button.vue.d.ts +3 -3
  73. package/es/components/checkbox/src/checkbox-group.vue_vue_type_script_lang.mjs +5 -3
  74. package/es/components/checkbox/src/checkbox-group.vue_vue_type_script_lang.mjs.map +1 -1
  75. package/es/components/checkbox/src/checkbox-group.vue_vue_type_template_id_9944d4d2_lang.mjs.map +1 -1
  76. package/es/components/checkbox/src/checkbox.type.d.ts +2 -2
  77. package/es/components/checkbox/src/checkbox.vue.d.ts +4 -4
  78. package/es/components/checkbox/src/useCheckbox.d.ts +2 -3
  79. package/es/components/checkbox/src/useCheckbox.mjs +9 -18
  80. package/es/components/checkbox/src/useCheckbox.mjs.map +1 -1
  81. package/es/components/collapse/index.d.ts +4 -4
  82. package/es/components/collapse/src/collapse-item.vue.d.ts +2 -2
  83. package/es/components/collapse/src/collapse-item.vue_vue_type_script_lang.mjs +1 -1
  84. package/es/components/collapse/src/collapse-item.vue_vue_type_script_lang.mjs.map +1 -1
  85. package/es/components/collapse/src/collapse-item.vue_vue_type_template_id_80da782a_lang.mjs.map +1 -1
  86. package/es/components/color-picker/index.d.ts +2 -2
  87. package/es/components/color-picker/src/components/alpha-slider.vue.d.ts +30 -0
  88. package/es/components/color-picker/src/index.vue.d.ts +1 -1
  89. package/es/components/color-picker/src/index.vue_vue_type_script_lang.mjs +3 -6
  90. package/es/components/color-picker/src/index.vue_vue_type_script_lang.mjs.map +1 -1
  91. package/es/components/color-picker/src/index.vue_vue_type_template_id_46a474d5_lang.mjs.map +1 -1
  92. package/es/components/config-provider/index.d.ts +10 -9
  93. package/es/components/config-provider/src/config-provider.d.ts +3 -4
  94. package/es/components/config-provider/src/config-provider.mjs +10 -11
  95. package/es/components/config-provider/src/config-provider.mjs.map +1 -1
  96. package/es/components/config-provider/src/index.d.ts +10 -9
  97. package/es/components/date-picker/index.d.ts +10 -10
  98. package/es/components/date-picker/src/date-picker-com/basic-date-table.vue.d.ts +3 -3
  99. package/es/components/date-picker/src/date-picker-com/panel-date-pick.vue.d.ts +2 -2
  100. package/es/components/date-picker/src/date-picker-com/panel-date-pick.vue_vue_type_script_lang.mjs +1 -1
  101. package/es/components/date-picker/src/date-picker-com/panel-date-pick.vue_vue_type_script_lang.mjs.map +1 -1
  102. package/es/components/date-picker/src/date-picker-com/panel-date-pick.vue_vue_type_template_id_78e07aa7_lang.mjs.map +1 -1
  103. package/es/components/date-picker/src/date-picker-com/panel-date-range.vue.d.ts +3 -3
  104. package/es/components/date-picker/src/date-picker-com/panel-date-range.vue_vue_type_script_lang.mjs +1 -1
  105. package/es/components/date-picker/src/date-picker-com/panel-date-range.vue_vue_type_script_lang.mjs.map +1 -1
  106. package/es/components/date-picker/src/date-picker-com/panel-date-range.vue_vue_type_template_id_62b45ab2_lang.mjs.map +1 -1
  107. package/es/components/date-picker/src/date-picker-com/panel-month-range.vue.d.ts +2 -2
  108. package/es/components/date-picker/src/date-picker-com/panel-month-range.vue_vue_type_script_lang.mjs +1 -1
  109. package/es/components/date-picker/src/date-picker-com/panel-month-range.vue_vue_type_script_lang.mjs.map +1 -1
  110. package/es/components/date-picker/src/date-picker-com/panel-month-range.vue_vue_type_template_id_2e377892_lang.mjs.map +1 -1
  111. package/es/components/date-picker/src/date-picker.d.ts +5 -5
  112. package/es/components/descriptions/index.d.ts +1 -1
  113. package/es/components/descriptions/src/index.vue.d.ts +1 -1
  114. package/es/components/descriptions/src/index.vue_vue_type_script_lang.mjs +4 -6
  115. package/es/components/descriptions/src/index.vue_vue_type_script_lang.mjs.map +1 -1
  116. package/es/components/descriptions/src/index.vue_vue_type_template_id_788d3854_lang.mjs.map +1 -1
  117. package/es/components/dialog/index.d.ts +8 -2
  118. package/es/components/dialog/src/dialog.d.ts +2 -1
  119. package/es/components/dialog/src/dialog.mjs +4 -0
  120. package/es/components/dialog/src/dialog.mjs.map +1 -1
  121. package/es/components/dialog/src/dialog.vue.d.ts +8 -2
  122. package/es/components/dialog/src/dialog.vue_vue_type_script_lang.mjs.map +1 -1
  123. package/es/components/dialog/src/dialog.vue_vue_type_template_id_02672805_lang.mjs +2 -3
  124. package/es/components/dialog/src/dialog.vue_vue_type_template_id_02672805_lang.mjs.map +1 -1
  125. package/es/components/dialog/src/use-dialog.d.ts +2 -0
  126. package/es/components/dialog/src/use-dialog.mjs +2 -0
  127. package/es/components/dialog/src/use-dialog.mjs.map +1 -1
  128. package/es/components/divider/index.d.ts +4 -0
  129. package/es/components/divider/src/divider.d.ts +2 -0
  130. package/es/components/divider/src/divider.mjs +5 -1
  131. package/es/components/divider/src/divider.mjs.map +1 -1
  132. package/es/components/divider/src/divider.vue.d.ts +4 -0
  133. package/es/components/divider/src/divider.vue_vue_type_script_lang.mjs.map +1 -1
  134. package/es/components/divider/src/divider.vue_vue_type_template_id_6ddd3543_lang.mjs +4 -3
  135. package/es/components/divider/src/divider.vue_vue_type_template_id_6ddd3543_lang.mjs.map +1 -1
  136. package/es/components/drawer/index.d.ts +66 -208
  137. package/es/components/drawer/index.mjs +6 -8
  138. package/es/components/drawer/index.mjs.map +1 -1
  139. package/es/components/drawer/src/drawer.d.ts +35 -0
  140. package/es/components/drawer/src/drawer.mjs +28 -0
  141. package/es/components/drawer/src/drawer.mjs.map +1 -0
  142. package/es/components/drawer/src/drawer.vue.d.ts +129 -0
  143. package/es/components/drawer/src/drawer.vue_vue_type_script_lang.mjs +37 -0
  144. package/es/components/drawer/src/drawer.vue_vue_type_script_lang.mjs.map +1 -0
  145. package/es/components/drawer/src/{index.vue_vue_type_template_id_052d0d8e_lang.mjs → drawer.vue_vue_type_template_id_e0557736_lang.mjs} +1 -1
  146. package/es/components/drawer/src/drawer.vue_vue_type_template_id_e0557736_lang.mjs.map +1 -0
  147. package/es/components/drawer/src/drawer2.mjs +7 -0
  148. package/es/components/drawer/src/drawer2.mjs.map +1 -0
  149. package/es/components/dropdown/index.d.ts +3 -3
  150. package/es/components/dropdown/src/dropdown-item.vue.d.ts +1 -1
  151. package/es/components/dropdown/src/dropdown.vue.d.ts +1 -1
  152. package/es/components/dropdown/src/dropdown.vue_vue_type_script_lang.mjs +4 -4
  153. package/es/components/dropdown/src/dropdown.vue_vue_type_script_lang.mjs.map +1 -1
  154. package/es/components/dropdown/src/dropdown.vue_vue_type_template_id_3ed790a5_lang.mjs.map +1 -1
  155. package/es/components/dropdown/src/useDropdown.d.ts +0 -1
  156. package/es/components/dropdown/src/useDropdown.mjs +1 -3
  157. package/es/components/dropdown/src/useDropdown.mjs.map +1 -1
  158. package/es/components/form/index.d.ts +4 -4
  159. package/es/components/form/src/form-item.vue.d.ts +2 -2
  160. package/es/components/form/src/form-item.vue_vue_type_script_lang.mjs +4 -6
  161. package/es/components/form/src/form-item.vue_vue_type_script_lang.mjs.map +1 -1
  162. package/es/components/form/src/form-item.vue_vue_type_template_id_24eda48b_lang.mjs.map +1 -1
  163. package/es/components/image-viewer/src/image-viewer.vue_vue_type_script_lang.mjs +1 -1
  164. package/es/components/image-viewer/src/image-viewer.vue_vue_type_script_lang.mjs.map +1 -1
  165. package/es/components/image-viewer/src/image-viewer.vue_vue_type_template_id_4b22ad85_lang.mjs.map +1 -1
  166. package/es/components/index.mjs +5 -1
  167. package/es/components/index.mjs.map +1 -1
  168. package/es/components/input/index.d.ts +10 -10
  169. package/es/components/input/src/input.d.ts +2 -2
  170. package/es/components/input/src/input.mjs +4 -3
  171. package/es/components/input/src/input.mjs.map +1 -1
  172. package/es/components/input/src/input.vue.d.ts +10 -10
  173. package/es/components/input/src/input.vue_vue_type_script_lang.mjs +10 -11
  174. package/es/components/input/src/input.vue_vue_type_script_lang.mjs.map +1 -1
  175. package/es/components/input/src/input.vue_vue_type_template_id_3290dcb6_lang.mjs.map +1 -1
  176. package/es/components/input-number/index.d.ts +23 -23
  177. package/es/components/input-number/src/input-number.vue.d.ts +23 -23
  178. package/es/components/input-number/src/input-number.vue_vue_type_script_lang.mjs +6 -5
  179. package/es/components/input-number/src/input-number.vue_vue_type_script_lang.mjs.map +1 -1
  180. package/es/components/input-number/src/input-number.vue_vue_type_template_id_dec60af6_lang.mjs +2 -1
  181. package/es/components/input-number/src/input-number.vue_vue_type_template_id_dec60af6_lang.mjs.map +1 -1
  182. package/es/components/link/index.d.ts +2 -2
  183. package/es/components/link/src/link.vue.d.ts +2 -2
  184. package/es/components/loading/index.d.ts +52 -13
  185. package/es/components/loading/index.mjs +3 -3
  186. package/es/components/loading/index.mjs.map +1 -1
  187. package/es/components/loading/src/directive.d.ts +11 -10
  188. package/es/components/loading/src/directive.mjs +45 -26
  189. package/es/components/loading/src/directive.mjs.map +1 -1
  190. package/es/components/loading/src/loading.d.ts +24 -0
  191. package/es/components/loading/src/loading.mjs +112 -0
  192. package/es/components/loading/src/loading.mjs.map +1 -0
  193. package/es/components/loading/src/service.d.ts +3 -0
  194. package/es/components/loading/src/service.mjs +101 -0
  195. package/es/components/loading/src/service.mjs.map +1 -0
  196. package/es/components/loading/src/types.d.ts +23 -0
  197. package/es/components/loading/src/types.mjs +2 -0
  198. package/es/components/loading/src/types.mjs.map +1 -0
  199. package/es/components/menu/src/menu.mjs +1 -1
  200. package/es/components/menu/src/menu.mjs.map +1 -1
  201. package/es/components/menu/src/sub-menu.mjs +1 -1
  202. package/es/components/menu/src/sub-menu.mjs.map +1 -1
  203. package/es/components/message/src/message.d.ts +1 -1
  204. package/es/components/message/src/message.vue.d.ts +4 -3
  205. package/es/components/message/src/message.vue_vue_type_script_lang.mjs +2 -0
  206. package/es/components/message/src/message.vue_vue_type_script_lang.mjs.map +1 -1
  207. package/es/components/message/src/message.vue_vue_type_template_id_031967c2_lang.mjs +51 -54
  208. package/es/components/message/src/message.vue_vue_type_template_id_031967c2_lang.mjs.map +1 -1
  209. package/es/components/message-box/src/index.vue.d.ts +1840 -0
  210. package/es/components/notification/src/notification.d.ts +1 -1
  211. package/es/components/notification/src/notification.vue.d.ts +5 -5
  212. package/es/components/page-header/src/page-header.mjs +1 -1
  213. package/es/components/page-header/src/page-header.mjs.map +1 -1
  214. package/es/components/pagination/src/components/next.vue_vue_type_script_lang.mjs +1 -1
  215. package/es/components/pagination/src/components/next.vue_vue_type_script_lang.mjs.map +1 -1
  216. package/es/components/pagination/src/components/next.vue_vue_type_template_id_93fbb39e_lang.mjs.map +1 -1
  217. package/es/components/pagination/src/components/pager.vue_vue_type_script_lang.mjs +1 -1
  218. package/es/components/pagination/src/components/pager.vue_vue_type_script_lang.mjs.map +1 -1
  219. package/es/components/pagination/src/components/pager.vue_vue_type_template_id_0bfc9916_lang.mjs.map +1 -1
  220. package/es/components/pagination/src/components/prev.vue_vue_type_script_lang.mjs +1 -1
  221. package/es/components/pagination/src/components/prev.vue_vue_type_script_lang.mjs.map +1 -1
  222. package/es/components/pagination/src/components/prev.vue_vue_type_template_id_15259d71_lang.mjs.map +1 -1
  223. package/es/components/popconfirm/index.d.ts +2 -2
  224. package/es/components/popconfirm/src/popconfirm.mjs +1 -1
  225. package/es/components/popconfirm/src/popconfirm.mjs.map +1 -1
  226. package/es/components/popconfirm/src/popconfirm.vue.d.ts +2 -2
  227. package/es/components/popover/index.d.ts +2 -2
  228. package/es/components/popover/src/index.vue.d.ts +1 -1
  229. package/es/components/popper/index.d.ts +3480 -0
  230. package/es/components/popper/src/index.vue.d.ts +1737 -0
  231. package/es/components/popper/src/use-popper/index.d.ts +1540 -1
  232. package/es/components/progress/index.d.ts +81 -4
  233. package/es/components/progress/index.mjs +6 -8
  234. package/es/components/progress/index.mjs.map +1 -1
  235. package/es/components/progress/src/progress.d.ts +22 -0
  236. package/es/components/progress/src/progress.mjs +62 -0
  237. package/es/components/progress/src/progress.mjs.map +1 -0
  238. package/es/components/progress/src/progress.vue.d.ts +81 -0
  239. package/es/components/progress/src/{index.vue_vue_type_script_lang.mjs → progress.vue_vue_type_script_lang.mjs} +27 -94
  240. package/es/components/progress/src/progress.vue_vue_type_script_lang.mjs.map +1 -0
  241. package/es/components/progress/src/{index.vue_vue_type_template_id_556e268a_lang.mjs → progress.vue_vue_type_template_id_9158c3b6_lang.mjs} +1 -1
  242. package/es/components/progress/src/progress.vue_vue_type_template_id_9158c3b6_lang.mjs.map +1 -0
  243. package/es/components/progress/src/progress2.mjs +7 -0
  244. package/es/components/progress/src/progress2.mjs.map +1 -0
  245. package/es/components/radio/index.d.ts +36 -40
  246. package/es/components/radio/src/radio-button.d.ts +2 -2
  247. package/es/components/radio/src/radio-button.vue.d.ts +8 -8
  248. package/es/components/radio/src/radio-group.d.ts +2 -2
  249. package/es/components/radio/src/radio-group.mjs +3 -2
  250. package/es/components/radio/src/radio-group.mjs.map +1 -1
  251. package/es/components/radio/src/radio-group.vue.d.ts +6 -8
  252. package/es/components/radio/src/radio-group.vue_vue_type_script_lang.mjs +1 -3
  253. package/es/components/radio/src/radio-group.vue_vue_type_script_lang.mjs.map +1 -1
  254. package/es/components/radio/src/radio-group.vue_vue_type_template_id_53ef81f9_lang.mjs.map +1 -1
  255. package/es/components/radio/src/radio.d.ts +5 -5
  256. package/es/components/radio/src/radio.mjs +5 -6
  257. package/es/components/radio/src/radio.mjs.map +1 -1
  258. package/es/components/radio/src/radio.vue.d.ts +8 -8
  259. package/es/components/rate/src/rate.mjs +1 -1
  260. package/es/components/rate/src/rate.mjs.map +1 -1
  261. package/es/components/rate/src/rate.vue_vue_type_script_lang.mjs +1 -1
  262. package/es/components/rate/src/rate.vue_vue_type_script_lang.mjs.map +1 -1
  263. package/es/components/rate/src/rate.vue_vue_type_template_id_38c42df6_lang.mjs.map +1 -1
  264. package/es/components/result/index.d.ts +3 -3
  265. package/es/components/result/src/result.d.ts +1 -1
  266. package/es/components/result/src/result.mjs +1 -1
  267. package/es/components/result/src/result.mjs.map +1 -1
  268. package/es/components/result/src/result.vue.d.ts +3 -3
  269. package/es/components/select/index.d.ts +14 -7
  270. package/es/components/select/src/select.vue.d.ts +14 -7
  271. package/es/components/select/src/select.vue_vue_type_script_lang.mjs +5 -1
  272. package/es/components/select/src/select.vue_vue_type_script_lang.mjs.map +1 -1
  273. package/es/components/select/src/select.vue_vue_type_template_id_33774f85_lang.mjs +6 -6
  274. package/es/components/select/src/select.vue_vue_type_template_id_33774f85_lang.mjs.map +1 -1
  275. package/es/components/select/src/useSelect.d.ts +76 -0
  276. package/es/components/select/src/useSelect.mjs +3 -3
  277. package/es/components/select/src/useSelect.mjs.map +1 -1
  278. package/es/components/select-v2/index.d.ts +14 -14
  279. package/es/components/select-v2/src/defaults.mjs +1 -1
  280. package/es/components/select-v2/src/defaults.mjs.map +1 -1
  281. package/es/components/select-v2/src/select.vue.d.ts +7 -7
  282. package/es/components/select-v2/src/useSelect.d.ts +1 -1
  283. package/es/components/select-v2/src/useSelect.mjs +5 -6
  284. package/es/components/select-v2/src/useSelect.mjs.map +1 -1
  285. package/es/components/skeleton/index.d.ts +6 -6
  286. package/es/components/skeleton/src/skeleton-item.d.ts +1 -1
  287. package/es/components/skeleton/src/skeleton-item.vue.d.ts +3 -3
  288. package/es/components/slider/index.d.ts +307 -0
  289. package/es/components/slider/src/index.vue.d.ts +155 -0
  290. package/es/components/slider/src/useSlide.d.ts +21 -0
  291. package/es/components/steps/index.d.ts +4 -4
  292. package/es/components/steps/src/item.vue.d.ts +2 -2
  293. package/es/components/steps/src/item.vue_vue_type_script_lang.mjs +1 -1
  294. package/es/components/steps/src/item.vue_vue_type_script_lang.mjs.map +1 -1
  295. package/es/components/steps/src/item.vue_vue_type_template_id_6ec47f4b_lang.mjs.map +1 -1
  296. package/es/components/switch/index.d.ts +99 -4
  297. package/es/components/switch/index.mjs +6 -8
  298. package/es/components/switch/index.mjs.map +1 -1
  299. package/es/components/switch/src/switch.d.ts +31 -0
  300. package/es/components/switch/src/switch.mjs +87 -0
  301. package/es/components/switch/src/switch.mjs.map +1 -0
  302. package/es/components/switch/src/switch.vue.d.ts +98 -0
  303. package/es/components/switch/src/switch.vue_vue_type_script_lang.mjs +117 -0
  304. package/es/components/switch/src/switch.vue_vue_type_script_lang.mjs.map +1 -0
  305. package/es/components/switch/src/{index.vue_vue_type_template_id_ee4fcade_lang.mjs → switch.vue_vue_type_template_id_538fbc85_lang.mjs} +1 -1
  306. package/es/components/switch/src/switch.vue_vue_type_template_id_538fbc85_lang.mjs.map +1 -0
  307. package/es/components/switch/src/switch2.mjs +7 -0
  308. package/es/components/switch/src/switch2.mjs.map +1 -0
  309. package/es/components/table/index.d.ts +9 -9
  310. package/es/components/table/src/config.mjs +1 -1
  311. package/es/components/table/src/config.mjs.map +1 -1
  312. package/es/components/table/src/filter-panel.vue_vue_type_script_lang.mjs +1 -1
  313. package/es/components/table/src/filter-panel.vue_vue_type_script_lang.mjs.map +1 -1
  314. package/es/components/table/src/filter-panel.vue_vue_type_template_id_fde1c940_lang.mjs.map +1 -1
  315. package/es/components/table/src/table/style-helper.d.ts +1 -1
  316. package/es/components/table/src/table/style-helper.mjs +3 -5
  317. package/es/components/table/src/table/style-helper.mjs.map +1 -1
  318. package/es/components/table/src/table-column/defaults.d.ts +2 -2
  319. package/es/components/table/src/table-column/defaults.mjs.map +1 -1
  320. package/es/components/table/src/table-column/index.d.ts +3 -3
  321. package/es/components/table/src/table.vue.d.ts +3 -3
  322. package/es/components/table/src/util.mjs +0 -1
  323. package/es/components/table/src/util.mjs.map +1 -1
  324. package/es/components/tabs/index.d.ts +4 -4
  325. package/es/components/tabs/src/tab-nav.mjs +1 -1
  326. package/es/components/tabs/src/tab-nav.mjs.map +1 -1
  327. package/es/components/tabs/src/tab-pane.vue.d.ts +2 -2
  328. package/es/components/tabs/src/tabs.mjs +1 -1
  329. package/es/components/tabs/src/tabs.mjs.map +1 -1
  330. package/es/components/tag/src/tag.vue_vue_type_script_lang.mjs +4 -4
  331. package/es/components/tag/src/tag.vue_vue_type_script_lang.mjs.map +1 -1
  332. package/es/components/tag/src/tag.vue_vue_type_template_id_525996c5_lang.mjs.map +1 -1
  333. package/es/components/time-picker/index.d.ts +10 -10
  334. package/es/components/time-picker/src/common/date-utils.d.ts +1 -1
  335. package/es/components/time-picker/src/common/date-utils.mjs +1 -3
  336. package/es/components/time-picker/src/common/date-utils.mjs.map +1 -1
  337. package/es/components/time-picker/src/common/picker.vue.d.ts +6 -6
  338. package/es/components/time-picker/src/common/picker.vue_vue_type_script_lang.mjs +6 -8
  339. package/es/components/time-picker/src/common/picker.vue_vue_type_script_lang.mjs.map +1 -1
  340. package/es/components/time-picker/src/common/picker.vue_vue_type_template_id_1d54be91_lang.mjs.map +1 -1
  341. package/es/components/time-picker/src/common/props.d.ts +1 -1
  342. package/es/components/time-picker/src/common/props.mjs +1 -1
  343. package/es/components/time-picker/src/common/props.mjs.map +1 -1
  344. package/es/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_lang.mjs +1 -1
  345. package/es/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_lang.mjs.map +1 -1
  346. package/es/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_template_id_4fb3c576_lang.mjs.map +1 -1
  347. package/es/components/time-picker/src/time-picker-com/panel-time-pick.vue.d.ts +1 -1
  348. package/es/components/time-picker/src/time-picker-com/panel-time-range.vue.d.ts +1 -1
  349. package/es/components/time-picker/src/time-picker-com/useTimePicker.d.ts +2 -2
  350. package/es/components/time-picker/src/time-picker.d.ts +5 -5
  351. package/es/components/time-select/index.d.ts +4 -4
  352. package/es/components/time-select/src/time-select.vue.d.ts +2 -2
  353. package/es/components/time-select/src/time-select.vue_vue_type_script_lang.mjs +1 -1
  354. package/es/components/time-select/src/time-select.vue_vue_type_script_lang.mjs.map +1 -1
  355. package/es/components/time-select/src/time-select.vue_vue_type_template_id_5beb6389_lang.mjs.map +1 -1
  356. package/es/components/timeline/index.d.ts +4 -4
  357. package/es/components/timeline/src/item.vue.d.ts +2 -2
  358. package/es/components/tooltip/src/index.mjs +4 -2
  359. package/es/components/tooltip/src/index.mjs.map +1 -1
  360. package/es/components/transfer/index.d.ts +8 -8
  361. package/es/components/transfer/src/index.vue.d.ts +4 -4
  362. package/es/components/transfer/src/index.vue_vue_type_script_lang.mjs +1 -1
  363. package/es/components/transfer/src/index.vue_vue_type_script_lang.mjs.map +1 -1
  364. package/es/components/transfer/src/index.vue_vue_type_template_id_6c8b9070_lang.mjs.map +1 -1
  365. package/es/components/transfer/src/transfer-panel.vue.d.ts +2 -2
  366. package/es/components/transfer/src/transfer-panel.vue_vue_type_script_lang.mjs +1 -1
  367. package/es/components/transfer/src/transfer-panel.vue_vue_type_script_lang.mjs.map +1 -1
  368. package/es/components/transfer/src/transfer-panel.vue_vue_type_template_id_1a7d1f9c_lang.mjs.map +1 -1
  369. package/es/components/tree/index.d.ts +2 -2
  370. package/es/components/tree/src/tree-node.vue_vue_type_script_lang.mjs +1 -1
  371. package/es/components/tree/src/tree-node.vue_vue_type_script_lang.mjs.map +1 -1
  372. package/es/components/tree/src/tree-node.vue_vue_type_template_id_62959aba_lang.mjs.map +1 -1
  373. package/es/components/tree/src/tree.vue.d.ts +1 -1
  374. package/es/components/tree-v2/index.d.ts +2 -2
  375. package/es/components/tree-v2/src/composables/useTree.d.ts +29 -0
  376. package/es/components/tree-v2/src/tree-node.vue.d.ts +2 -2
  377. package/es/components/tree-v2/src/tree-node.vue_vue_type_script_lang.mjs +1 -1
  378. package/es/components/tree-v2/src/tree-node.vue_vue_type_script_lang.mjs.map +1 -1
  379. package/es/components/tree-v2/src/tree-node.vue_vue_type_template_id_71d8f826_lang.mjs.map +1 -1
  380. package/es/components/tree-v2/src/tree.vue.d.ts +2 -2
  381. package/es/components/upload/src/upload-list.vue_vue_type_script_lang.mjs +3 -3
  382. package/es/components/upload/src/upload-list.vue_vue_type_script_lang.mjs.map +1 -1
  383. package/es/components/upload/src/upload-list.vue_vue_type_template_id_192277b6_lang.mjs.map +1 -1
  384. package/es/components/virtual-list/src/builders/build-list.d.ts +1 -1
  385. package/es/components/virtual-list/src/components/dynamic-size-list.d.ts +1 -1
  386. package/es/components/virtual-list/src/components/fixed-size-list.d.ts +1 -1
  387. package/es/components/virtual-list/src/components/scrollbar.d.ts +1 -1
  388. package/es/defaults.mjs +1 -1
  389. package/es/defaults.mjs.map +1 -1
  390. package/es/hooks/index.d.ts +2 -0
  391. package/es/hooks/index.mjs +3 -1
  392. package/es/hooks/index.mjs.map +1 -1
  393. package/es/hooks/use-common-props/index.d.ts +5 -0
  394. package/es/hooks/use-common-props/index.mjs +31 -0
  395. package/es/hooks/use-common-props/index.mjs.map +1 -0
  396. package/es/hooks/use-form-item/index.d.ts +1 -14
  397. package/es/hooks/use-form-item/index.mjs +3 -24
  398. package/es/hooks/use-form-item/index.mjs.map +1 -1
  399. package/es/hooks/use-global-config/index.d.ts +4 -1
  400. package/es/hooks/use-global-config/index.mjs +8 -6
  401. package/es/hooks/use-global-config/index.mjs.map +1 -1
  402. package/es/hooks/use-locale/index.d.ts +6 -5
  403. package/es/hooks/use-locale/index.mjs +11 -8
  404. package/es/hooks/use-locale/index.mjs.map +1 -1
  405. package/es/hooks/use-lockscreen/index.mjs +5 -1
  406. package/es/hooks/use-lockscreen/index.mjs.map +1 -1
  407. package/es/hooks/use-prop/index.d.ts +2 -0
  408. package/es/hooks/use-prop/index.mjs +12 -0
  409. package/es/hooks/use-prop/index.mjs.map +1 -0
  410. package/es/index.d.ts +1 -1
  411. package/es/index.mjs +9 -3
  412. package/es/index.mjs.map +1 -1
  413. package/es/locale/index.d.ts +0 -5
  414. package/es/locale/index.mjs +0 -52
  415. package/es/locale/index.mjs.map +1 -1
  416. package/es/locale/lang/ca.mjs +2 -2
  417. package/es/locale/lang/ca.mjs.map +1 -1
  418. package/es/locale/lang/en.mjs +2 -2
  419. package/es/locale/lang/en.mjs.map +1 -1
  420. package/es/make-installer.d.ts +1 -2
  421. package/es/make-installer.mjs +2 -4
  422. package/es/make-installer.mjs.map +1 -1
  423. package/es/plugin.d.ts +2 -47
  424. package/es/plugin.mjs +1 -1
  425. package/es/plugin.mjs.map +1 -1
  426. package/es/tokens/form.d.ts +1 -1
  427. package/es/tokens/form.mjs.map +1 -1
  428. package/es/utils/aria.d.ts +1 -0
  429. package/es/utils/aria.mjs +2 -1
  430. package/es/utils/aria.mjs.map +1 -1
  431. package/es/utils/config.d.ts +1 -1
  432. package/es/utils/config.mjs.map +1 -1
  433. package/es/utils/icon.mjs +1 -1
  434. package/es/utils/icon.mjs.map +1 -1
  435. package/es/utils/util.d.ts +8 -2
  436. package/es/utils/util.mjs.map +1 -1
  437. package/es/version.d.ts +1 -1
  438. package/es/version.mjs +1 -1
  439. package/es/version.mjs.map +1 -1
  440. package/lib/component.d.ts +3 -0
  441. package/lib/component.js.map +1 -1
  442. package/lib/components/affix/index.d.ts +48 -0
  443. package/lib/components/affix/src/affix.vue.d.ts +48 -0
  444. package/lib/components/alert/index.d.ts +5 -5
  445. package/lib/components/alert/src/alert.d.ts +1 -1
  446. package/lib/components/alert/src/alert.vue.d.ts +5 -5
  447. package/lib/components/autocomplete/index.d.ts +4 -4
  448. package/lib/components/autocomplete/src/index.vue.d.ts +2 -2
  449. package/lib/components/autocomplete/src/index.vue_vue_type_script_lang.js +2 -2
  450. package/lib/components/autocomplete/src/index.vue_vue_type_script_lang.js.map +1 -1
  451. package/lib/components/autocomplete/src/index.vue_vue_type_template_id_2f09f285_lang.js.map +1 -1
  452. package/lib/components/avatar/index.d.ts +1 -1
  453. package/lib/components/avatar/src/avatar.vue.d.ts +1 -1
  454. package/lib/components/backtop/src/backtop.vue_vue_type_script_lang.js +2 -2
  455. package/lib/components/backtop/src/backtop.vue_vue_type_script_lang.js.map +1 -1
  456. package/lib/components/backtop/src/backtop.vue_vue_type_template_id_63a7fea6_lang.js.map +1 -1
  457. package/lib/components/button/index.d.ts +18 -18
  458. package/lib/components/button/src/button-group.d.ts +1 -1
  459. package/lib/components/button/src/button-group.vue.d.ts +3 -3
  460. package/lib/components/button/src/button.d.ts +3 -3
  461. package/lib/components/button/src/button.js +5 -3
  462. package/lib/components/button/src/button.js.map +1 -1
  463. package/lib/components/button/src/button.vue.d.ts +12 -12
  464. package/lib/components/button/src/button.vue_vue_type_script_lang.js +10 -13
  465. package/lib/components/button/src/button.vue_vue_type_script_lang.js.map +1 -1
  466. package/lib/components/button/src/button.vue_vue_type_template_id_802c5c76_lang.js.map +1 -1
  467. package/lib/components/calendar/index.d.ts +20 -47
  468. package/lib/components/calendar/index.js +8 -8
  469. package/lib/components/calendar/index.js.map +1 -1
  470. package/lib/components/calendar/src/calendar.d.ts +11 -0
  471. package/lib/components/calendar/src/calendar.js +24 -0
  472. package/lib/components/calendar/src/calendar.js.map +1 -0
  473. package/lib/components/calendar/src/calendar.vue.d.ts +34 -0
  474. package/lib/components/calendar/src/{index.vue_vue_type_script_lang.js → calendar.vue_vue_type_script_lang.js} +12 -23
  475. package/lib/components/calendar/src/calendar.vue_vue_type_script_lang.js.map +1 -0
  476. package/lib/components/calendar/src/{index.vue_vue_type_template_id_819aa44a_lang.js → calendar.vue_vue_type_template_id_76705c76_lang.js} +1 -1
  477. package/lib/components/calendar/src/calendar.vue_vue_type_template_id_76705c76_lang.js.map +1 -0
  478. package/lib/components/calendar/src/calendar2.js +12 -0
  479. package/lib/components/calendar/src/calendar2.js.map +1 -0
  480. package/lib/components/calendar/src/date-table.d.ts +13 -0
  481. package/lib/components/calendar/src/date-table.js +23 -7
  482. package/lib/components/calendar/src/date-table.js.map +1 -1
  483. package/lib/components/calendar/src/date-table.vue.d.ts +29 -38
  484. package/lib/components/calendar/src/date-table.vue_vue_type_script_lang.js +53 -70
  485. package/lib/components/calendar/src/date-table.vue_vue_type_script_lang.js.map +1 -1
  486. package/lib/components/calendar/src/date-table.vue_vue_type_template_id_297fdb36_lang.js +1 -1
  487. package/lib/components/calendar/src/date-table.vue_vue_type_template_id_297fdb36_lang.js.map +1 -1
  488. package/lib/components/calendar/src/date-table2.js +14 -0
  489. package/lib/components/calendar/src/date-table2.js.map +1 -0
  490. package/lib/components/carousel/src/main.vue_vue_type_script_lang.js +3 -3
  491. package/lib/components/carousel/src/main.vue_vue_type_script_lang.js.map +1 -1
  492. package/lib/components/carousel/src/main.vue_vue_type_template_id_1303d144_lang.js.map +1 -1
  493. package/lib/components/cascader/index.d.ts +8756 -0
  494. package/lib/components/cascader/src/index.vue.d.ts +4384 -0
  495. package/lib/components/cascader/src/index.vue_vue_type_script_lang.js +6 -7
  496. package/lib/components/cascader/src/index.vue_vue_type_script_lang.js.map +1 -1
  497. package/lib/components/cascader/src/index.vue_vue_type_template_id_0429c2db_lang.js.map +1 -1
  498. package/lib/components/cascader-panel/src/node.vue_vue_type_script_lang.js +4 -4
  499. package/lib/components/cascader-panel/src/node.vue_vue_type_script_lang.js.map +1 -1
  500. package/lib/components/cascader-panel/src/node.vue_vue_type_template_id_18b09cb2_lang.js.map +1 -1
  501. package/lib/components/checkbox/index.d.ts +10 -10
  502. package/lib/components/checkbox/src/checkbox-button.vue.d.ts +3 -3
  503. package/lib/components/checkbox/src/checkbox-group.vue_vue_type_script_lang.js +4 -2
  504. package/lib/components/checkbox/src/checkbox-group.vue_vue_type_script_lang.js.map +1 -1
  505. package/lib/components/checkbox/src/checkbox-group.vue_vue_type_template_id_9944d4d2_lang.js.map +1 -1
  506. package/lib/components/checkbox/src/checkbox.type.d.ts +2 -2
  507. package/lib/components/checkbox/src/checkbox.vue.d.ts +4 -4
  508. package/lib/components/checkbox/src/useCheckbox.d.ts +2 -3
  509. package/lib/components/checkbox/src/useCheckbox.js +9 -18
  510. package/lib/components/checkbox/src/useCheckbox.js.map +1 -1
  511. package/lib/components/collapse/index.d.ts +4 -4
  512. package/lib/components/collapse/src/collapse-item.vue.d.ts +2 -2
  513. package/lib/components/collapse/src/collapse-item.vue_vue_type_script_lang.js +2 -2
  514. package/lib/components/collapse/src/collapse-item.vue_vue_type_script_lang.js.map +1 -1
  515. package/lib/components/collapse/src/collapse-item.vue_vue_type_template_id_80da782a_lang.js.map +1 -1
  516. package/lib/components/color-picker/index.d.ts +2 -2
  517. package/lib/components/color-picker/src/components/alpha-slider.vue.d.ts +30 -0
  518. package/lib/components/color-picker/src/index.vue.d.ts +1 -1
  519. package/lib/components/color-picker/src/index.vue_vue_type_script_lang.js +5 -8
  520. package/lib/components/color-picker/src/index.vue_vue_type_script_lang.js.map +1 -1
  521. package/lib/components/color-picker/src/index.vue_vue_type_template_id_46a474d5_lang.js.map +1 -1
  522. package/lib/components/config-provider/index.d.ts +10 -9
  523. package/lib/components/config-provider/src/config-provider.d.ts +3 -4
  524. package/lib/components/config-provider/src/config-provider.js +9 -10
  525. package/lib/components/config-provider/src/config-provider.js.map +1 -1
  526. package/lib/components/config-provider/src/index.d.ts +10 -9
  527. package/lib/components/date-picker/index.d.ts +10 -10
  528. package/lib/components/date-picker/src/date-picker-com/basic-date-table.vue.d.ts +3 -3
  529. package/lib/components/date-picker/src/date-picker-com/panel-date-pick.vue.d.ts +2 -2
  530. package/lib/components/date-picker/src/date-picker-com/panel-date-pick.vue_vue_type_script_lang.js +5 -5
  531. package/lib/components/date-picker/src/date-picker-com/panel-date-pick.vue_vue_type_script_lang.js.map +1 -1
  532. package/lib/components/date-picker/src/date-picker-com/panel-date-pick.vue_vue_type_template_id_78e07aa7_lang.js.map +1 -1
  533. package/lib/components/date-picker/src/date-picker-com/panel-date-range.vue.d.ts +3 -3
  534. package/lib/components/date-picker/src/date-picker-com/panel-date-range.vue_vue_type_script_lang.js +5 -5
  535. package/lib/components/date-picker/src/date-picker-com/panel-date-range.vue_vue_type_script_lang.js.map +1 -1
  536. package/lib/components/date-picker/src/date-picker-com/panel-date-range.vue_vue_type_template_id_62b45ab2_lang.js.map +1 -1
  537. package/lib/components/date-picker/src/date-picker-com/panel-month-range.vue.d.ts +2 -2
  538. package/lib/components/date-picker/src/date-picker-com/panel-month-range.vue_vue_type_script_lang.js +2 -2
  539. package/lib/components/date-picker/src/date-picker-com/panel-month-range.vue_vue_type_script_lang.js.map +1 -1
  540. package/lib/components/date-picker/src/date-picker-com/panel-month-range.vue_vue_type_template_id_2e377892_lang.js.map +1 -1
  541. package/lib/components/date-picker/src/date-picker.d.ts +5 -5
  542. package/lib/components/descriptions/index.d.ts +1 -1
  543. package/lib/components/descriptions/src/index.vue.d.ts +1 -1
  544. package/lib/components/descriptions/src/index.vue_vue_type_script_lang.js +3 -5
  545. package/lib/components/descriptions/src/index.vue_vue_type_script_lang.js.map +1 -1
  546. package/lib/components/descriptions/src/index.vue_vue_type_template_id_788d3854_lang.js.map +1 -1
  547. package/lib/components/dialog/index.d.ts +8 -2
  548. package/lib/components/dialog/src/dialog.d.ts +2 -1
  549. package/lib/components/dialog/src/dialog.js +4 -0
  550. package/lib/components/dialog/src/dialog.js.map +1 -1
  551. package/lib/components/dialog/src/dialog.vue.d.ts +8 -2
  552. package/lib/components/dialog/src/dialog.vue_vue_type_script_lang.js.map +1 -1
  553. package/lib/components/dialog/src/dialog.vue_vue_type_template_id_02672805_lang.js +1 -2
  554. package/lib/components/dialog/src/dialog.vue_vue_type_template_id_02672805_lang.js.map +1 -1
  555. package/lib/components/dialog/src/use-dialog.d.ts +2 -0
  556. package/lib/components/dialog/src/use-dialog.js +2 -0
  557. package/lib/components/dialog/src/use-dialog.js.map +1 -1
  558. package/lib/components/divider/index.d.ts +4 -0
  559. package/lib/components/divider/src/divider.d.ts +2 -0
  560. package/lib/components/divider/src/divider.js +4 -0
  561. package/lib/components/divider/src/divider.js.map +1 -1
  562. package/lib/components/divider/src/divider.vue.d.ts +4 -0
  563. package/lib/components/divider/src/divider.vue_vue_type_script_lang.js.map +1 -1
  564. package/lib/components/divider/src/divider.vue_vue_type_template_id_6ddd3543_lang.js +3 -2
  565. package/lib/components/divider/src/divider.vue_vue_type_template_id_6ddd3543_lang.js.map +1 -1
  566. package/lib/components/drawer/index.d.ts +66 -208
  567. package/lib/components/drawer/index.js +8 -8
  568. package/lib/components/drawer/index.js.map +1 -1
  569. package/lib/components/drawer/src/drawer.d.ts +35 -0
  570. package/lib/components/drawer/src/drawer.js +33 -0
  571. package/lib/components/drawer/src/drawer.js.map +1 -0
  572. package/lib/components/drawer/src/drawer.vue.d.ts +129 -0
  573. package/lib/components/drawer/src/drawer.vue_vue_type_script_lang.js +41 -0
  574. package/lib/components/drawer/src/drawer.vue_vue_type_script_lang.js.map +1 -0
  575. package/lib/components/drawer/src/{index.vue_vue_type_template_id_052d0d8e_lang.js → drawer.vue_vue_type_template_id_e0557736_lang.js} +1 -1
  576. package/lib/components/drawer/src/drawer.vue_vue_type_template_id_e0557736_lang.js.map +1 -0
  577. package/lib/components/drawer/src/drawer2.js +12 -0
  578. package/lib/components/drawer/src/drawer2.js.map +1 -0
  579. package/lib/components/dropdown/index.d.ts +3 -3
  580. package/lib/components/dropdown/src/dropdown-item.vue.d.ts +1 -1
  581. package/lib/components/dropdown/src/dropdown.vue.d.ts +1 -1
  582. package/lib/components/dropdown/src/dropdown.vue_vue_type_script_lang.js +5 -5
  583. package/lib/components/dropdown/src/dropdown.vue_vue_type_script_lang.js.map +1 -1
  584. package/lib/components/dropdown/src/dropdown.vue_vue_type_template_id_3ed790a5_lang.js.map +1 -1
  585. package/lib/components/dropdown/src/useDropdown.d.ts +0 -1
  586. package/lib/components/dropdown/src/useDropdown.js +0 -2
  587. package/lib/components/dropdown/src/useDropdown.js.map +1 -1
  588. package/lib/components/form/index.d.ts +4 -4
  589. package/lib/components/form/src/form-item.vue.d.ts +2 -2
  590. package/lib/components/form/src/form-item.vue_vue_type_script_lang.js +3 -5
  591. package/lib/components/form/src/form-item.vue_vue_type_script_lang.js.map +1 -1
  592. package/lib/components/form/src/form-item.vue_vue_type_template_id_24eda48b_lang.js.map +1 -1
  593. package/lib/components/image-viewer/src/image-viewer.vue_vue_type_script_lang.js +10 -10
  594. package/lib/components/image-viewer/src/image-viewer.vue_vue_type_script_lang.js.map +1 -1
  595. package/lib/components/image-viewer/src/image-viewer.vue_vue_type_template_id_4b22ad85_lang.js.map +1 -1
  596. package/lib/components/index.js +12 -1
  597. package/lib/components/index.js.map +1 -1
  598. package/lib/components/input/index.d.ts +10 -10
  599. package/lib/components/input/src/input.d.ts +2 -2
  600. package/lib/components/input/src/input.js +4 -3
  601. package/lib/components/input/src/input.js.map +1 -1
  602. package/lib/components/input/src/input.vue.d.ts +10 -10
  603. package/lib/components/input/src/input.vue_vue_type_script_lang.js +10 -11
  604. package/lib/components/input/src/input.vue_vue_type_script_lang.js.map +1 -1
  605. package/lib/components/input/src/input.vue_vue_type_template_id_3290dcb6_lang.js.map +1 -1
  606. package/lib/components/input-number/index.d.ts +23 -23
  607. package/lib/components/input-number/src/input-number.vue.d.ts +23 -23
  608. package/lib/components/input-number/src/input-number.vue_vue_type_script_lang.js +10 -9
  609. package/lib/components/input-number/src/input-number.vue_vue_type_script_lang.js.map +1 -1
  610. package/lib/components/input-number/src/input-number.vue_vue_type_template_id_dec60af6_lang.js +2 -1
  611. package/lib/components/input-number/src/input-number.vue_vue_type_template_id_dec60af6_lang.js.map +1 -1
  612. package/lib/components/link/index.d.ts +2 -2
  613. package/lib/components/link/src/link.vue.d.ts +2 -2
  614. package/lib/components/loading/index.d.ts +52 -13
  615. package/lib/components/loading/index.js +8 -8
  616. package/lib/components/loading/index.js.map +1 -1
  617. package/lib/components/loading/src/directive.d.ts +11 -10
  618. package/lib/components/loading/src/directive.js +45 -26
  619. package/lib/components/loading/src/directive.js.map +1 -1
  620. package/lib/components/loading/src/loading.d.ts +24 -0
  621. package/lib/components/loading/src/loading.js +116 -0
  622. package/lib/components/loading/src/loading.js.map +1 -0
  623. package/lib/components/loading/src/service.d.ts +3 -0
  624. package/lib/components/loading/src/service.js +105 -0
  625. package/lib/components/loading/src/service.js.map +1 -0
  626. package/lib/components/loading/src/types.d.ts +23 -0
  627. package/lib/components/loading/src/types.js +3 -0
  628. package/lib/components/loading/src/types.js.map +1 -0
  629. package/lib/components/menu/src/menu.js +2 -2
  630. package/lib/components/menu/src/menu.js.map +1 -1
  631. package/lib/components/menu/src/sub-menu.js +2 -2
  632. package/lib/components/menu/src/sub-menu.js.map +1 -1
  633. package/lib/components/message/src/message.d.ts +1 -1
  634. package/lib/components/message/src/message.vue.d.ts +4 -3
  635. package/lib/components/message/src/message.vue_vue_type_script_lang.js +2 -0
  636. package/lib/components/message/src/message.vue_vue_type_script_lang.js.map +1 -1
  637. package/lib/components/message/src/message.vue_vue_type_template_id_031967c2_lang.js +51 -54
  638. package/lib/components/message/src/message.vue_vue_type_template_id_031967c2_lang.js.map +1 -1
  639. package/lib/components/message-box/src/index.vue.d.ts +1840 -0
  640. package/lib/components/notification/src/notification.d.ts +1 -1
  641. package/lib/components/notification/src/notification.vue.d.ts +5 -5
  642. package/lib/components/page-header/src/page-header.js +2 -2
  643. package/lib/components/page-header/src/page-header.js.map +1 -1
  644. package/lib/components/pagination/src/components/next.vue_vue_type_script_lang.js +2 -2
  645. package/lib/components/pagination/src/components/next.vue_vue_type_script_lang.js.map +1 -1
  646. package/lib/components/pagination/src/components/next.vue_vue_type_template_id_93fbb39e_lang.js.map +1 -1
  647. package/lib/components/pagination/src/components/pager.vue_vue_type_script_lang.js +4 -4
  648. package/lib/components/pagination/src/components/pager.vue_vue_type_script_lang.js.map +1 -1
  649. package/lib/components/pagination/src/components/pager.vue_vue_type_template_id_0bfc9916_lang.js.map +1 -1
  650. package/lib/components/pagination/src/components/prev.vue_vue_type_script_lang.js +2 -2
  651. package/lib/components/pagination/src/components/prev.vue_vue_type_script_lang.js.map +1 -1
  652. package/lib/components/pagination/src/components/prev.vue_vue_type_template_id_15259d71_lang.js.map +1 -1
  653. package/lib/components/popconfirm/index.d.ts +2 -2
  654. package/lib/components/popconfirm/src/popconfirm.js +2 -2
  655. package/lib/components/popconfirm/src/popconfirm.js.map +1 -1
  656. package/lib/components/popconfirm/src/popconfirm.vue.d.ts +2 -2
  657. package/lib/components/popover/index.d.ts +2 -2
  658. package/lib/components/popover/src/index.vue.d.ts +1 -1
  659. package/lib/components/popper/index.d.ts +3480 -0
  660. package/lib/components/popper/src/index.vue.d.ts +1737 -0
  661. package/lib/components/popper/src/use-popper/index.d.ts +1540 -1
  662. package/lib/components/progress/index.d.ts +81 -4
  663. package/lib/components/progress/index.js +7 -8
  664. package/lib/components/progress/index.js.map +1 -1
  665. package/lib/components/progress/src/progress.d.ts +22 -0
  666. package/lib/components/progress/src/progress.js +66 -0
  667. package/lib/components/progress/src/progress.js.map +1 -0
  668. package/lib/components/progress/src/progress.vue.d.ts +81 -0
  669. package/lib/components/progress/src/progress.vue_vue_type_script_lang.js +146 -0
  670. package/lib/components/progress/src/progress.vue_vue_type_script_lang.js.map +1 -0
  671. package/lib/components/progress/src/{index.vue_vue_type_template_id_556e268a_lang.js → progress.vue_vue_type_template_id_9158c3b6_lang.js} +1 -1
  672. package/lib/components/progress/src/progress.vue_vue_type_template_id_9158c3b6_lang.js.map +1 -0
  673. package/lib/components/progress/src/progress2.js +12 -0
  674. package/lib/components/progress/src/progress2.js.map +1 -0
  675. package/lib/components/radio/index.d.ts +36 -40
  676. package/lib/components/radio/src/radio-button.d.ts +2 -2
  677. package/lib/components/radio/src/radio-button.vue.d.ts +8 -8
  678. package/lib/components/radio/src/radio-group.d.ts +2 -2
  679. package/lib/components/radio/src/radio-group.js +3 -2
  680. package/lib/components/radio/src/radio-group.js.map +1 -1
  681. package/lib/components/radio/src/radio-group.vue.d.ts +6 -8
  682. package/lib/components/radio/src/radio-group.vue_vue_type_script_lang.js +1 -3
  683. package/lib/components/radio/src/radio-group.vue_vue_type_script_lang.js.map +1 -1
  684. package/lib/components/radio/src/radio-group.vue_vue_type_template_id_53ef81f9_lang.js.map +1 -1
  685. package/lib/components/radio/src/radio.d.ts +5 -5
  686. package/lib/components/radio/src/radio.js +5 -6
  687. package/lib/components/radio/src/radio.js.map +1 -1
  688. package/lib/components/radio/src/radio.vue.d.ts +8 -8
  689. package/lib/components/rate/src/rate.js +4 -4
  690. package/lib/components/rate/src/rate.js.map +1 -1
  691. package/lib/components/rate/src/rate.vue_vue_type_script_lang.js +3 -3
  692. package/lib/components/rate/src/rate.vue_vue_type_script_lang.js.map +1 -1
  693. package/lib/components/rate/src/rate.vue_vue_type_template_id_38c42df6_lang.js.map +1 -1
  694. package/lib/components/result/index.d.ts +3 -3
  695. package/lib/components/result/src/result.d.ts +1 -1
  696. package/lib/components/result/src/result.js +5 -5
  697. package/lib/components/result/src/result.js.map +1 -1
  698. package/lib/components/result/src/result.vue.d.ts +3 -3
  699. package/lib/components/select/index.d.ts +14 -7
  700. package/lib/components/select/src/select.vue.d.ts +14 -7
  701. package/lib/components/select/src/select.vue_vue_type_script_lang.js +7 -3
  702. package/lib/components/select/src/select.vue_vue_type_script_lang.js.map +1 -1
  703. package/lib/components/select/src/select.vue_vue_type_template_id_33774f85_lang.js +6 -6
  704. package/lib/components/select/src/select.vue_vue_type_template_id_33774f85_lang.js.map +1 -1
  705. package/lib/components/select/src/useSelect.d.ts +76 -0
  706. package/lib/components/select/src/useSelect.js +2 -2
  707. package/lib/components/select/src/useSelect.js.map +1 -1
  708. package/lib/components/select-v2/index.d.ts +14 -14
  709. package/lib/components/select-v2/src/defaults.js +2 -2
  710. package/lib/components/select-v2/src/defaults.js.map +1 -1
  711. package/lib/components/select-v2/src/select.vue.d.ts +7 -7
  712. package/lib/components/select-v2/src/useSelect.d.ts +1 -1
  713. package/lib/components/select-v2/src/useSelect.js +9 -10
  714. package/lib/components/select-v2/src/useSelect.js.map +1 -1
  715. package/lib/components/skeleton/index.d.ts +6 -6
  716. package/lib/components/skeleton/src/skeleton-item.d.ts +1 -1
  717. package/lib/components/skeleton/src/skeleton-item.vue.d.ts +3 -3
  718. package/lib/components/slider/index.d.ts +307 -0
  719. package/lib/components/slider/src/index.vue.d.ts +155 -0
  720. package/lib/components/slider/src/useSlide.d.ts +21 -0
  721. package/lib/components/steps/index.d.ts +4 -4
  722. package/lib/components/steps/src/item.vue.d.ts +2 -2
  723. package/lib/components/steps/src/item.vue_vue_type_script_lang.js +3 -3
  724. package/lib/components/steps/src/item.vue_vue_type_script_lang.js.map +1 -1
  725. package/lib/components/steps/src/item.vue_vue_type_template_id_6ec47f4b_lang.js.map +1 -1
  726. package/lib/components/switch/index.d.ts +99 -4
  727. package/lib/components/switch/index.js +8 -8
  728. package/lib/components/switch/index.js.map +1 -1
  729. package/lib/components/switch/src/switch.d.ts +31 -0
  730. package/lib/components/switch/src/switch.js +92 -0
  731. package/lib/components/switch/src/switch.js.map +1 -0
  732. package/lib/components/switch/src/switch.vue.d.ts +98 -0
  733. package/lib/components/switch/src/{index.vue_vue_type_script_lang.js → switch.vue_vue_type_script_lang.js} +28 -101
  734. package/lib/components/switch/src/switch.vue_vue_type_script_lang.js.map +1 -0
  735. package/lib/components/switch/src/{index.vue_vue_type_template_id_ee4fcade_lang.js → switch.vue_vue_type_template_id_538fbc85_lang.js} +1 -1
  736. package/lib/components/switch/src/switch.vue_vue_type_template_id_538fbc85_lang.js.map +1 -0
  737. package/lib/components/switch/src/switch2.js +12 -0
  738. package/lib/components/switch/src/switch2.js.map +1 -0
  739. package/lib/components/table/index.d.ts +9 -9
  740. package/lib/components/table/src/config.js +4 -4
  741. package/lib/components/table/src/config.js.map +1 -1
  742. package/lib/components/table/src/filter-panel.vue_vue_type_script_lang.js +3 -3
  743. package/lib/components/table/src/filter-panel.vue_vue_type_script_lang.js.map +1 -1
  744. package/lib/components/table/src/filter-panel.vue_vue_type_template_id_fde1c940_lang.js.map +1 -1
  745. package/lib/components/table/src/table/style-helper.d.ts +1 -1
  746. package/lib/components/table/src/table/style-helper.js +6 -8
  747. package/lib/components/table/src/table/style-helper.js.map +1 -1
  748. package/lib/components/table/src/table-column/defaults.d.ts +2 -2
  749. package/lib/components/table/src/table-column/defaults.js.map +1 -1
  750. package/lib/components/table/src/table-column/index.d.ts +3 -3
  751. package/lib/components/table/src/table.vue.d.ts +3 -3
  752. package/lib/components/table/src/util.js +0 -1
  753. package/lib/components/table/src/util.js.map +1 -1
  754. package/lib/components/tabs/index.d.ts +4 -4
  755. package/lib/components/tabs/src/tab-nav.js +4 -4
  756. package/lib/components/tabs/src/tab-nav.js.map +1 -1
  757. package/lib/components/tabs/src/tab-pane.vue.d.ts +2 -2
  758. package/lib/components/tabs/src/tabs.js +2 -2
  759. package/lib/components/tabs/src/tabs.js.map +1 -1
  760. package/lib/components/tag/src/tag.vue_vue_type_script_lang.js +5 -5
  761. package/lib/components/tag/src/tag.vue_vue_type_script_lang.js.map +1 -1
  762. package/lib/components/tag/src/tag.vue_vue_type_template_id_525996c5_lang.js.map +1 -1
  763. package/lib/components/time-picker/index.d.ts +10 -10
  764. package/lib/components/time-picker/src/common/date-utils.d.ts +1 -1
  765. package/lib/components/time-picker/src/common/date-utils.js +1 -3
  766. package/lib/components/time-picker/src/common/date-utils.js.map +1 -1
  767. package/lib/components/time-picker/src/common/picker.vue.d.ts +6 -6
  768. package/lib/components/time-picker/src/common/picker.vue_vue_type_script_lang.js +6 -8
  769. package/lib/components/time-picker/src/common/picker.vue_vue_type_script_lang.js.map +1 -1
  770. package/lib/components/time-picker/src/common/picker.vue_vue_type_template_id_1d54be91_lang.js.map +1 -1
  771. package/lib/components/time-picker/src/common/props.d.ts +1 -1
  772. package/lib/components/time-picker/src/common/props.js +2 -2
  773. package/lib/components/time-picker/src/common/props.js.map +1 -1
  774. package/lib/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_lang.js +3 -3
  775. package/lib/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_script_lang.js.map +1 -1
  776. package/lib/components/time-picker/src/time-picker-com/basic-time-spinner.vue_vue_type_template_id_4fb3c576_lang.js.map +1 -1
  777. package/lib/components/time-picker/src/time-picker-com/panel-time-pick.vue.d.ts +1 -1
  778. package/lib/components/time-picker/src/time-picker-com/panel-time-range.vue.d.ts +1 -1
  779. package/lib/components/time-picker/src/time-picker-com/useTimePicker.d.ts +2 -2
  780. package/lib/components/time-picker/src/time-picker.d.ts +5 -5
  781. package/lib/components/time-select/index.d.ts +4 -4
  782. package/lib/components/time-select/src/time-select.vue.d.ts +2 -2
  783. package/lib/components/time-select/src/time-select.vue_vue_type_script_lang.js +3 -3
  784. package/lib/components/time-select/src/time-select.vue_vue_type_script_lang.js.map +1 -1
  785. package/lib/components/time-select/src/time-select.vue_vue_type_template_id_5beb6389_lang.js.map +1 -1
  786. package/lib/components/timeline/index.d.ts +4 -4
  787. package/lib/components/timeline/src/item.vue.d.ts +2 -2
  788. package/lib/components/tooltip/src/index.js +4 -2
  789. package/lib/components/tooltip/src/index.js.map +1 -1
  790. package/lib/components/transfer/index.d.ts +8 -8
  791. package/lib/components/transfer/src/index.vue.d.ts +4 -4
  792. package/lib/components/transfer/src/index.vue_vue_type_script_lang.js +3 -3
  793. package/lib/components/transfer/src/index.vue_vue_type_script_lang.js.map +1 -1
  794. package/lib/components/transfer/src/index.vue_vue_type_template_id_6c8b9070_lang.js.map +1 -1
  795. package/lib/components/transfer/src/transfer-panel.vue.d.ts +2 -2
  796. package/lib/components/transfer/src/transfer-panel.vue_vue_type_script_lang.js +3 -3
  797. package/lib/components/transfer/src/transfer-panel.vue_vue_type_script_lang.js.map +1 -1
  798. package/lib/components/transfer/src/transfer-panel.vue_vue_type_template_id_1a7d1f9c_lang.js.map +1 -1
  799. package/lib/components/tree/index.d.ts +2 -2
  800. package/lib/components/tree/src/tree-node.vue_vue_type_script_lang.js +3 -3
  801. package/lib/components/tree/src/tree-node.vue_vue_type_script_lang.js.map +1 -1
  802. package/lib/components/tree/src/tree-node.vue_vue_type_template_id_62959aba_lang.js.map +1 -1
  803. package/lib/components/tree/src/tree.vue.d.ts +1 -1
  804. package/lib/components/tree-v2/index.d.ts +2 -2
  805. package/lib/components/tree-v2/src/composables/useTree.d.ts +29 -0
  806. package/lib/components/tree-v2/src/tree-node.vue.d.ts +2 -2
  807. package/lib/components/tree-v2/src/tree-node.vue_vue_type_script_lang.js +2 -2
  808. package/lib/components/tree-v2/src/tree-node.vue_vue_type_script_lang.js.map +1 -1
  809. package/lib/components/tree-v2/src/tree-node.vue_vue_type_template_id_71d8f826_lang.js.map +1 -1
  810. package/lib/components/tree-v2/src/tree.vue.d.ts +2 -2
  811. package/lib/components/upload/src/upload-list.vue_vue_type_script_lang.js +8 -8
  812. package/lib/components/upload/src/upload-list.vue_vue_type_script_lang.js.map +1 -1
  813. package/lib/components/upload/src/upload-list.vue_vue_type_template_id_192277b6_lang.js.map +1 -1
  814. package/lib/components/virtual-list/src/builders/build-list.d.ts +1 -1
  815. package/lib/components/virtual-list/src/components/dynamic-size-list.d.ts +1 -1
  816. package/lib/components/virtual-list/src/components/fixed-size-list.d.ts +1 -1
  817. package/lib/components/virtual-list/src/components/scrollbar.d.ts +1 -1
  818. package/lib/defaults.js +1 -1
  819. package/lib/defaults.js.map +1 -1
  820. package/lib/hooks/index.d.ts +2 -0
  821. package/lib/hooks/index.js +46 -41
  822. package/lib/hooks/index.js.map +1 -1
  823. package/lib/hooks/use-common-props/index.d.ts +5 -0
  824. package/lib/hooks/use-common-props/index.js +37 -0
  825. package/lib/hooks/use-common-props/index.js.map +1 -0
  826. package/lib/hooks/use-form-item/index.d.ts +1 -14
  827. package/lib/hooks/use-form-item/index.js +1 -23
  828. package/lib/hooks/use-form-item/index.js.map +1 -1
  829. package/lib/hooks/use-global-config/index.d.ts +4 -1
  830. package/lib/hooks/use-global-config/index.js +7 -5
  831. package/lib/hooks/use-global-config/index.js.map +1 -1
  832. package/lib/hooks/use-locale/index.d.ts +6 -5
  833. package/lib/hooks/use-locale/index.js +8 -5
  834. package/lib/hooks/use-locale/index.js.map +1 -1
  835. package/lib/hooks/use-lockscreen/index.js +4 -0
  836. package/lib/hooks/use-lockscreen/index.js.map +1 -1
  837. package/lib/hooks/use-prop/index.d.ts +2 -0
  838. package/lib/hooks/use-prop/index.js +16 -0
  839. package/lib/hooks/use-prop/index.js.map +1 -0
  840. package/lib/index.d.ts +1 -1
  841. package/lib/index.js +59 -43
  842. package/lib/index.js.map +1 -1
  843. package/lib/locale/index.d.ts +0 -5
  844. package/lib/locale/index.js +0 -63
  845. package/lib/locale/index.js.map +1 -1
  846. package/lib/locale/lang/ca.js +2 -2
  847. package/lib/locale/lang/ca.js.map +1 -1
  848. package/lib/locale/lang/en.js +2 -2
  849. package/lib/locale/lang/en.js.map +1 -1
  850. package/lib/make-installer.d.ts +1 -2
  851. package/lib/make-installer.js +2 -4
  852. package/lib/make-installer.js.map +1 -1
  853. package/lib/plugin.d.ts +2 -47
  854. package/lib/plugin.js +1 -1
  855. package/lib/plugin.js.map +1 -1
  856. package/lib/tokens/form.d.ts +1 -1
  857. package/lib/tokens/form.js.map +1 -1
  858. package/lib/utils/aria.d.ts +1 -0
  859. package/lib/utils/aria.js +2 -1
  860. package/lib/utils/aria.js.map +1 -1
  861. package/lib/utils/config.d.ts +1 -1
  862. package/lib/utils/config.js.map +1 -1
  863. package/lib/utils/icon.js +14 -14
  864. package/lib/utils/icon.js.map +1 -1
  865. package/lib/utils/util.d.ts +8 -2
  866. package/lib/utils/util.js.map +1 -1
  867. package/lib/version.d.ts +1 -1
  868. package/lib/version.js +1 -1
  869. package/lib/version.js.map +1 -1
  870. package/package.json +3 -3
  871. package/tags.json +1 -1
  872. package/theme-chalk/base.css +1 -1
  873. package/theme-chalk/el-autocomplete.css +1 -1
  874. package/theme-chalk/el-cascader-panel.css +1 -1
  875. package/theme-chalk/el-cascader.css +1 -1
  876. package/theme-chalk/el-check-tag.css +1 -1
  877. package/theme-chalk/el-date-picker.css +1 -1
  878. package/theme-chalk/el-divider.css +1 -1
  879. package/theme-chalk/el-dropdown.css +1 -1
  880. package/theme-chalk/el-icon.css +1 -1
  881. package/theme-chalk/el-image.css +1 -1
  882. package/theme-chalk/el-input-number.css +1 -1
  883. package/theme-chalk/el-input.css +1 -1
  884. package/theme-chalk/el-menu.css +1 -1
  885. package/theme-chalk/el-option-item.css +1 -1
  886. package/theme-chalk/el-option.css +1 -1
  887. package/theme-chalk/el-select-dropdown.css +1 -1
  888. package/theme-chalk/el-select-v2.css +1 -1
  889. package/theme-chalk/el-select.css +1 -1
  890. package/theme-chalk/el-steps.css +1 -1
  891. package/theme-chalk/el-table.css +1 -1
  892. package/theme-chalk/el-tabs.css +1 -1
  893. package/theme-chalk/el-time-picker.css +1 -1
  894. package/theme-chalk/el-time-select.css +1 -1
  895. package/theme-chalk/el-transfer.css +1 -1
  896. package/theme-chalk/el-tree.css +1 -1
  897. package/theme-chalk/el-upload.css +1 -1
  898. package/theme-chalk/el-var.css +1 -1
  899. package/theme-chalk/index.css +1 -1
  900. package/theme-chalk/src/check-tag.scss +1 -1
  901. package/theme-chalk/src/common/var.scss +7 -7
  902. package/theme-chalk/src/date-picker/date-table.scss +1 -1
  903. package/theme-chalk/src/date-picker/month-table.scss +1 -1
  904. package/theme-chalk/src/date-picker/time-spinner.scss +1 -1
  905. package/theme-chalk/src/date-picker/year-table.scss +1 -1
  906. package/theme-chalk/src/divider.scss +2 -1
  907. package/theme-chalk/src/dropdown.scss +0 -4
  908. package/theme-chalk/src/icon.scss +1 -2
  909. package/theme-chalk/src/image.scss +4 -4
  910. package/theme-chalk/src/input-number.scss +1 -1
  911. package/theme-chalk/src/input.scss +5 -1
  912. package/theme-chalk/src/menu.scss +1 -1
  913. package/theme-chalk/src/mixins/mixins.scss +1 -1
  914. package/theme-chalk/src/select-v2.scss +1 -1
  915. package/theme-chalk/src/select.scss +22 -18
  916. package/theme-chalk/src/steps.scss +1 -1
  917. package/theme-chalk/src/table.scss +1 -1
  918. package/theme-chalk/src/tabs.scss +1 -1
  919. package/theme-chalk/src/time-select.scss +1 -1
  920. package/theme-chalk/src/upload.scss +1 -1
  921. package/theme-chalk/src/var.scss +1 -1
  922. package/web-types.json +1 -1
  923. package/es/components/calendar/src/index.mjs +0 -7
  924. package/es/components/calendar/src/index.mjs.map +0 -1
  925. package/es/components/calendar/src/index.vue.d.ts +0 -33
  926. package/es/components/calendar/src/index.vue_vue_type_script_lang.mjs.map +0 -1
  927. package/es/components/calendar/src/index.vue_vue_type_template_id_819aa44a_lang.mjs.map +0 -1
  928. package/es/components/drawer/src/index.mjs +0 -7
  929. package/es/components/drawer/src/index.mjs.map +0 -1
  930. package/es/components/drawer/src/index.vue.d.ts +0 -138
  931. package/es/components/drawer/src/index.vue_vue_type_script_lang.mjs +0 -56
  932. package/es/components/drawer/src/index.vue_vue_type_script_lang.mjs.map +0 -1
  933. package/es/components/drawer/src/index.vue_vue_type_template_id_052d0d8e_lang.mjs.map +0 -1
  934. package/es/components/loading/src/createLoadingComponent.d.ts +0 -2
  935. package/es/components/loading/src/createLoadingComponent.mjs +0 -121
  936. package/es/components/loading/src/createLoadingComponent.mjs.map +0 -1
  937. package/es/components/loading/src/index.d.ts +0 -3
  938. package/es/components/loading/src/index.mjs +0 -106
  939. package/es/components/loading/src/index.mjs.map +0 -1
  940. package/es/components/loading/src/loading.type.d.ts +0 -44
  941. package/es/components/loading/src/loading.type.mjs +0 -2
  942. package/es/components/loading/src/loading.type.mjs.map +0 -1
  943. package/es/components/progress/src/index.mjs +0 -7
  944. package/es/components/progress/src/index.mjs.map +0 -1
  945. package/es/components/progress/src/index.vue.d.ts +0 -2
  946. package/es/components/progress/src/index.vue_vue_type_script_lang.mjs.map +0 -1
  947. package/es/components/progress/src/index.vue_vue_type_template_id_556e268a_lang.mjs.map +0 -1
  948. package/es/components/switch/src/index.mjs +0 -7
  949. package/es/components/switch/src/index.mjs.map +0 -1
  950. package/es/components/switch/src/index.vue.d.ts +0 -2
  951. package/es/components/switch/src/index.vue_vue_type_script_lang.mjs +0 -190
  952. package/es/components/switch/src/index.vue_vue_type_script_lang.mjs.map +0 -1
  953. package/es/components/switch/src/index.vue_vue_type_template_id_ee4fcade_lang.mjs.map +0 -1
  954. package/lib/components/calendar/src/index.js +0 -12
  955. package/lib/components/calendar/src/index.js.map +0 -1
  956. package/lib/components/calendar/src/index.vue.d.ts +0 -33
  957. package/lib/components/calendar/src/index.vue_vue_type_script_lang.js.map +0 -1
  958. package/lib/components/calendar/src/index.vue_vue_type_template_id_819aa44a_lang.js.map +0 -1
  959. package/lib/components/drawer/src/index.js +0 -12
  960. package/lib/components/drawer/src/index.js.map +0 -1
  961. package/lib/components/drawer/src/index.vue.d.ts +0 -138
  962. package/lib/components/drawer/src/index.vue_vue_type_script_lang.js +0 -60
  963. package/lib/components/drawer/src/index.vue_vue_type_script_lang.js.map +0 -1
  964. package/lib/components/drawer/src/index.vue_vue_type_template_id_052d0d8e_lang.js.map +0 -1
  965. package/lib/components/loading/src/createLoadingComponent.d.ts +0 -2
  966. package/lib/components/loading/src/createLoadingComponent.js +0 -125
  967. package/lib/components/loading/src/createLoadingComponent.js.map +0 -1
  968. package/lib/components/loading/src/index.d.ts +0 -3
  969. package/lib/components/loading/src/index.js +0 -110
  970. package/lib/components/loading/src/index.js.map +0 -1
  971. package/lib/components/loading/src/loading.type.d.ts +0 -44
  972. package/lib/components/loading/src/loading.type.js +0 -3
  973. package/lib/components/loading/src/loading.type.js.map +0 -1
  974. package/lib/components/progress/src/index.js +0 -12
  975. package/lib/components/progress/src/index.js.map +0 -1
  976. package/lib/components/progress/src/index.vue.d.ts +0 -2
  977. package/lib/components/progress/src/index.vue_vue_type_script_lang.js +0 -213
  978. package/lib/components/progress/src/index.vue_vue_type_script_lang.js.map +0 -1
  979. package/lib/components/progress/src/index.vue_vue_type_template_id_556e268a_lang.js.map +0 -1
  980. package/lib/components/switch/src/index.js +0 -12
  981. package/lib/components/switch/src/index.js.map +0 -1
  982. package/lib/components/switch/src/index.vue.d.ts +0 -2
  983. package/lib/components/switch/src/index.vue_vue_type_script_lang.js.map +0 -1
  984. package/lib/components/switch/src/index.vue_vue_type_template_id_ee4fcade_lang.js.map +0 -1
@@ -0,0 +1,105 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var vue = require('vue');
6
+ var shared = require('@vue/shared');
7
+ var core = require('@vueuse/core');
8
+ var dom = require('../../../utils/dom.js');
9
+ var popupManager = require('../../../utils/popup-manager.js');
10
+ var loading = require('./loading.js');
11
+
12
+ let fullscreenInstance = void 0;
13
+ const Loading = function(options = {}) {
14
+ if (!core.isClient)
15
+ return void 0;
16
+ const resolved = resolveOptions(options);
17
+ if (resolved.fullscreen && fullscreenInstance) {
18
+ fullscreenInstance.close();
19
+ }
20
+ const instance = loading.createLoadingComponent({
21
+ ...resolved,
22
+ closed: () => {
23
+ var _a;
24
+ (_a = resolved.closed) == null ? void 0 : _a.call(resolved);
25
+ if (resolved.fullscreen)
26
+ fullscreenInstance = void 0;
27
+ }
28
+ });
29
+ addStyle(resolved, resolved.parent, instance);
30
+ addClassList(resolved, resolved.parent, instance);
31
+ resolved.parent.vLoadingAddClassList = () => addClassList(resolved, resolved.parent, instance);
32
+ let loadingNumber = resolved.parent.getAttribute("loading-number");
33
+ if (!loadingNumber) {
34
+ loadingNumber = "1";
35
+ } else {
36
+ loadingNumber = `${Number.parseInt(loadingNumber) + 1}`;
37
+ }
38
+ resolved.parent.setAttribute("loading-number", loadingNumber);
39
+ resolved.parent.appendChild(instance.$el);
40
+ vue.nextTick(() => instance.visible.value = resolved.visible);
41
+ if (resolved.fullscreen) {
42
+ fullscreenInstance = instance;
43
+ }
44
+ return instance;
45
+ };
46
+ const resolveOptions = (options) => {
47
+ var _a, _b, _c, _d;
48
+ let target;
49
+ if (shared.isString(options.target)) {
50
+ target = (_a = document.querySelector(options.target)) != null ? _a : document.body;
51
+ } else {
52
+ target = options.target || document.body;
53
+ }
54
+ return {
55
+ parent: target === document.body || options.body ? document.body : target,
56
+ background: options.background || "",
57
+ svg: options.svg || "",
58
+ svgViewBox: options.svgViewBox || "",
59
+ spinner: options.spinner || false,
60
+ text: options.text || "",
61
+ fullscreen: target === document.body && ((_b = options.fullscreen) != null ? _b : true),
62
+ lock: (_c = options.lock) != null ? _c : false,
63
+ customClass: options.customClass || "",
64
+ visible: (_d = options.visible) != null ? _d : true,
65
+ target
66
+ };
67
+ };
68
+ const addStyle = async (options, parent, instance) => {
69
+ const maskStyle = {};
70
+ if (options.fullscreen) {
71
+ instance.originalPosition.value = dom.getStyle(document.body, "position");
72
+ instance.originalOverflow.value = dom.getStyle(document.body, "overflow");
73
+ maskStyle.zIndex = popupManager["default"].nextZIndex();
74
+ } else if (options.parent === document.body) {
75
+ instance.originalPosition.value = dom.getStyle(document.body, "position");
76
+ await vue.nextTick();
77
+ for (const property of ["top", "left"]) {
78
+ const scroll = property === "top" ? "scrollTop" : "scrollLeft";
79
+ maskStyle[property] = `${options.target.getBoundingClientRect()[property] + document.body[scroll] + document.documentElement[scroll] - parseInt(dom.getStyle(document.body, `margin-${property}`), 10)}px`;
80
+ }
81
+ for (const property of ["height", "width"]) {
82
+ maskStyle[property] = `${options.target.getBoundingClientRect()[property]}px`;
83
+ }
84
+ } else {
85
+ instance.originalPosition.value = dom.getStyle(parent, "position");
86
+ }
87
+ for (const [key, value] of Object.entries(maskStyle)) {
88
+ instance.$el.style[key] = value;
89
+ }
90
+ };
91
+ const addClassList = (options, parent, instance) => {
92
+ if (instance.originalPosition.value !== "absolute" && instance.originalPosition.value !== "fixed") {
93
+ dom.addClass(parent, "el-loading-parent--relative");
94
+ } else {
95
+ dom.removeClass(parent, "el-loading-parent--relative");
96
+ }
97
+ if (options.fullscreen && options.lock) {
98
+ dom.addClass(parent, "el-loading-parent--hidden");
99
+ } else {
100
+ dom.removeClass(parent, "el-loading-parent--hidden");
101
+ }
102
+ };
103
+
104
+ exports.Loading = Loading;
105
+ //# sourceMappingURL=service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.js","sources":["../../../../../../packages/components/loading/src/service.ts"],"sourcesContent":["import { nextTick } from 'vue'\nimport { isString } from '@vue/shared'\nimport { isClient } from '@vueuse/core'\nimport { addClass, getStyle, removeClass } from '@element-plus/utils/dom'\nimport PopupManager from '@element-plus/utils/popup-manager'\nimport { createLoadingComponent } from './loading'\nimport type { LoadingInstance } from './loading'\nimport type { LoadingOptionsResolved } from '..'\nimport type { LoadingOptions } from './types'\nimport type { CSSProperties } from 'vue'\n\nlet fullscreenInstance: LoadingInstance | undefined = undefined\n\nexport const Loading = function (\n options: LoadingOptions = {}\n): LoadingInstance {\n if (!isClient) return undefined as any\n\n const resolved = resolveOptions(options)\n\n if (resolved.fullscreen && fullscreenInstance) {\n fullscreenInstance.close()\n }\n\n const instance = createLoadingComponent({\n ...resolved,\n closed: () => {\n resolved.closed?.()\n if (resolved.fullscreen) fullscreenInstance = undefined\n },\n })\n\n addStyle(resolved, resolved.parent, instance)\n addClassList(resolved, resolved.parent, instance)\n\n resolved.parent.vLoadingAddClassList = () =>\n addClassList(resolved, resolved.parent, instance)\n\n /**\n * add loading-number to parent.\n * because if a fullscreen loading is triggered when somewhere\n * a v-loading.body was triggered before and it's parent is\n * document.body which with a margin , the fullscreen loading's\n * destroySelf function will remove 'el-loading-parent--relative',\n * and then the position of v-loading.body will be error.\n */\n let loadingNumber: string | null =\n resolved.parent.getAttribute('loading-number')\n if (!loadingNumber) {\n loadingNumber = '1'\n } else {\n loadingNumber = `${Number.parseInt(loadingNumber) + 1}`\n }\n resolved.parent.setAttribute('loading-number', loadingNumber)\n\n resolved.parent.appendChild(instance.$el)\n\n // after instance render, then modify visible to trigger transition\n nextTick(() => (instance.visible.value = resolved.visible))\n\n if (resolved.fullscreen) {\n fullscreenInstance = instance\n }\n return instance\n}\n\nconst resolveOptions = (options: LoadingOptions): LoadingOptionsResolved => {\n let target: HTMLElement\n if (isString(options.target)) {\n target =\n document.querySelector<HTMLElement>(options.target) ?? document.body\n } else {\n target = options.target || document.body\n }\n return {\n parent: target === document.body || options.body ? document.body : target,\n background: options.background || '',\n svg: options.svg || '',\n svgViewBox: options.svgViewBox || '',\n spinner: options.spinner || false,\n text: options.text || '',\n fullscreen: target === document.body && (options.fullscreen ?? true),\n lock: options.lock ?? false,\n customClass: options.customClass || '',\n visible: options.visible ?? true,\n target,\n }\n}\n\nconst addStyle = async (\n options: LoadingOptionsResolved,\n parent: HTMLElement,\n instance: LoadingInstance\n) => {\n const maskStyle: CSSProperties = {}\n if (options.fullscreen) {\n instance.originalPosition.value = getStyle(document.body, 'position')\n instance.originalOverflow.value = getStyle(document.body, 'overflow')\n maskStyle.zIndex = PopupManager.nextZIndex()\n } else if (options.parent === document.body) {\n instance.originalPosition.value = getStyle(document.body, 'position')\n /**\n * await dom render when visible is true in init,\n * because some component's height maybe 0.\n * e.g. el-table.\n */\n await nextTick()\n for (const property of ['top', 'left']) {\n const scroll = property === 'top' ? 'scrollTop' : 'scrollLeft'\n maskStyle[property] = `${\n (options.target as HTMLElement).getBoundingClientRect()[property] +\n document.body[scroll] +\n document.documentElement[scroll] -\n parseInt(getStyle(document.body, `margin-${property}`), 10)\n }px`\n }\n for (const property of ['height', 'width']) {\n maskStyle[property] = `${\n (options.target as HTMLElement).getBoundingClientRect()[property]\n }px`\n }\n } else {\n instance.originalPosition.value = getStyle(parent, 'position')\n }\n for (const [key, value] of Object.entries(maskStyle)) {\n instance.$el.style[key] = value\n }\n}\n\nconst addClassList = (\n options: LoadingOptions,\n parent: HTMLElement,\n instance: LoadingInstance\n) => {\n if (\n instance.originalPosition.value !== 'absolute' &&\n instance.originalPosition.value !== 'fixed'\n ) {\n addClass(parent, 'el-loading-parent--relative')\n } else {\n removeClass(parent, 'el-loading-parent--relative')\n }\n if (options.fullscreen && options.lock) {\n addClass(parent, 'el-loading-parent--hidden')\n } else {\n removeClass(parent, 'el-loading-parent--hidden')\n }\n}\n"],"names":["isClient","createLoadingComponent","isString","getStyle","PopupManager","nextTick"],"mappings":";;;;;;;;;;;AAWA,IAAI,qBAAkD;MAEzC,UAAU,SACrB,UAA0B,IACT;AACjB,MAAI,CAACA;AAAU,WAAO;AAEtB,QAAM,WAAW,eAAe;AAEhC,MAAI,SAAS,cAAc,oBAAoB;AAC7C,uBAAmB;AAAA;AAGrB,QAAM,WAAWC,+BAAuB;AAAA,OACnC;AAAA,IACH,QAAQ,MAAM;AA1BlB;AA2BM,qBAAS,WAAT;AACA,UAAI,SAAS;AAAY,6BAAqB;AAAA;AAAA;AAIlD,WAAS,UAAU,SAAS,QAAQ;AACpC,eAAa,UAAU,SAAS,QAAQ;AAExC,WAAS,OAAO,uBAAuB,MACrC,aAAa,UAAU,SAAS,QAAQ;AAU1C,MAAI,gBACF,SAAS,OAAO,aAAa;AAC/B,MAAI,CAAC,eAAe;AAClB,oBAAgB;AAAA,SACX;AACL,oBAAgB,GAAG,OAAO,SAAS,iBAAiB;AAAA;AAEtD,WAAS,OAAO,aAAa,kBAAkB;AAE/C,WAAS,OAAO,YAAY,SAAS;AAGrC,eAAS,MAAO,SAAS,QAAQ,QAAQ,SAAS;AAElD,MAAI,SAAS,YAAY;AACvB,yBAAqB;AAAA;AAEvB,SAAO;AAAA;AAGT,MAAM,iBAAiB,CAAC,YAAoD;AAlE5E;AAmEE,MAAI;AACJ,MAAIC,gBAAS,QAAQ,SAAS;AAC5B,aACE,eAAS,cAA2B,QAAQ,YAA5C,YAAuD,SAAS;AAAA,SAC7D;AACL,aAAS,QAAQ,UAAU,SAAS;AAAA;AAEtC,SAAO;AAAA,IACL,QAAQ,WAAW,SAAS,QAAQ,QAAQ,OAAO,SAAS,OAAO;AAAA,IACnE,YAAY,QAAQ,cAAc;AAAA,IAClC,KAAK,QAAQ,OAAO;AAAA,IACpB,YAAY,QAAQ,cAAc;AAAA,IAClC,SAAS,QAAQ,WAAW;AAAA,IAC5B,MAAM,QAAQ,QAAQ;AAAA,IACtB,YAAY,WAAW,SAAS,uBAAiB,eAAR,YAAsB;AAAA,IAC/D,MAAM,cAAQ,SAAR,YAAgB;AAAA,IACtB,aAAa,QAAQ,eAAe;AAAA,IACpC,SAAS,cAAQ,YAAR,YAAmB;AAAA,IAC5B;AAAA;AAAA;AAIJ,MAAM,WAAW,OACf,SACA,QACA,aACG;AACH,QAAM,YAA2B;AACjC,MAAI,QAAQ,YAAY;AACtB,aAAS,iBAAiB,QAAQC,aAAS,SAAS,MAAM;AAC1D,aAAS,iBAAiB,QAAQA,aAAS,SAAS,MAAM;AAC1D,cAAU,SAASC,wBAAa;AAAA,aACvB,QAAQ,WAAW,SAAS,MAAM;AAC3C,aAAS,iBAAiB,QAAQD,aAAS,SAAS,MAAM;AAM1D,UAAME;AACN,eAAW,YAAY,CAAC,OAAO,SAAS;AACtC,YAAM,SAAS,aAAa,QAAQ,cAAc;AAClD,gBAAU,YAAY,GACnB,QAAQ,OAAuB,wBAAwB,YACxD,SAAS,KAAK,UACd,SAAS,gBAAgB,UACzB,SAASF,aAAS,SAAS,MAAM,UAAU,aAAa;AAAA;AAG5D,eAAW,YAAY,CAAC,UAAU,UAAU;AAC1C,gBAAU,YAAY,GACnB,QAAQ,OAAuB,wBAAwB;AAAA;AAAA,SAGvD;AACL,aAAS,iBAAiB,QAAQA,aAAS,QAAQ;AAAA;AAErD,aAAW,CAAC,KAAK,UAAU,OAAO,QAAQ,YAAY;AACpD,aAAS,IAAI,MAAM,OAAO;AAAA;AAAA;AAI9B,MAAM,eAAe,CACnB,SACA,QACA,aACG;AACH,MACE,SAAS,iBAAiB,UAAU,cACpC,SAAS,iBAAiB,UAAU,SACpC;AACA,iBAAS,QAAQ;AAAA,SACZ;AACL,oBAAY,QAAQ;AAAA;AAEtB,MAAI,QAAQ,cAAc,QAAQ,MAAM;AACtC,iBAAS,QAAQ;AAAA,SACZ;AACL,oBAAY,QAAQ;AAAA;AAAA;;;;"}
@@ -0,0 +1,23 @@
1
+ import type { MaybeRef } from '@vueuse/core';
2
+ export declare type LoadingOptionsResolved = {
3
+ parent: LoadingParentElement;
4
+ background: MaybeRef<string>;
5
+ svg: MaybeRef<string>;
6
+ svgViewBox: MaybeRef<string>;
7
+ spinner: MaybeRef<boolean | string>;
8
+ text: MaybeRef<string>;
9
+ fullscreen: boolean;
10
+ lock: boolean;
11
+ customClass: MaybeRef<string>;
12
+ visible: boolean;
13
+ target: HTMLElement;
14
+ beforeClose?: () => boolean;
15
+ closed?: () => void;
16
+ };
17
+ export declare type LoadingOptions = Partial<Omit<LoadingOptionsResolved, 'parent' | 'target'> & {
18
+ target: HTMLElement | string;
19
+ body: boolean;
20
+ }>;
21
+ export interface LoadingParentElement extends HTMLElement {
22
+ vLoadingAddClassList?: () => void;
23
+ }
@@ -0,0 +1,3 @@
1
+ 'use strict';
2
+
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
@@ -5,7 +5,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  var vue = require('vue');
6
6
  require('../../../directives/index.js');
7
7
  var index$1 = require('../../icon/index.js');
8
- var icons = require('@element-plus/icons');
8
+ var iconsVue = require('@element-plus/icons-vue');
9
9
  var menuBar = require('../../../utils/menu/menu-bar.js');
10
10
  var props = require('../../../utils/props.js');
11
11
  require('../../../utils/util.js');
@@ -253,7 +253,7 @@ var Menu = vue.defineComponent({
253
253
  }, {
254
254
  title: () => vue.h(index$1.ElIcon, {
255
255
  class: ["el-sub-menu__icon-more"]
256
- }, { default: () => vue.h(icons.More) }),
256
+ }, { default: () => vue.h(iconsVue.More) }),
257
257
  default: () => slotMore
258
258
  }));
259
259
  }
@@ -1 +1 @@
1
- {"version":3,"file":"menu.js","sources":["../../../../../../packages/components/menu/src/menu.ts"],"sourcesContent":["import {\n defineComponent,\n getCurrentInstance,\n watch,\n computed,\n ref,\n provide,\n onMounted,\n h,\n withDirectives,\n reactive,\n nextTick,\n} from 'vue'\nimport { Resize } from '@element-plus/directives'\nimport ElIcon from '@element-plus/components/icon'\nimport { More } from '@element-plus/icons'\nimport Menubar from '@element-plus/utils/menu/menu-bar'\nimport { buildProps, definePropType, mutable } from '@element-plus/utils/props'\nimport { isString, isObject } from '@element-plus/utils/util'\nimport ElMenuCollapseTransition from './menu-collapse-transition.vue'\nimport ElSubMenu from './sub-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\n\nimport type { MenuItemClicked, MenuProvider, SubMenuProvider } from './types'\nimport type { NavigationFailure, Router } from 'vue-router'\nimport type { VNode, ExtractPropTypes, VNodeNormalizedChildren } from 'vue'\n\nexport const menuProps = buildProps({\n mode: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'vertical',\n },\n defaultActive: {\n type: String,\n default: '',\n },\n defaultOpeneds: {\n type: definePropType<string[]>(Array),\n default: () => mutable([] as const),\n },\n uniqueOpened: Boolean,\n router: Boolean,\n menuTrigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n collapse: Boolean,\n backgroundColor: String,\n textColor: String,\n activeTextColor: String,\n collapseTransition: {\n type: Boolean,\n default: true,\n },\n ellipsis: {\n type: Boolean,\n default: true,\n },\n} as const)\nexport type MenuProps = ExtractPropTypes<typeof menuProps>\n\nconst checkIndexPath = (indexPath: unknown): indexPath is string[] =>\n Array.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 (routerResult === undefined || routerResult instanceof Promise),\n}\nexport type MenuEmits = typeof menuEmits\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\n // data\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 const alteredCollapse = ref(false)\n\n // computed\n const isMenuPopup = computed<MenuProvider['isMenuPopup']>(() => {\n return (\n props.mode === 'horizontal' ||\n (props.mode === 'vertical' && props.collapse)\n )\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 closeMenu: MenuProvider['closeMenu'] = (index, indexPath) => {\n const i = openedMenus.value.indexOf(index)\n if (i !== -1) {\n openedMenus.value.splice(i, 1)\n }\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 if (isOpened) {\n closeMenu(index, indexPath)\n } else {\n openMenu(index, indexPath)\n }\n }\n\n const handleMenuItemClick: MenuProvider['handleMenuItemClick'] = (\n menuItem\n ) => {\n if (props.mode === 'horizontal' || props.collapse) {\n openedMenus.value = []\n }\n\n const { index, indexPath } = menuItem\n if (index === undefined || indexPath === undefined) 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 if (item) {\n activeIndex.value = item.index\n initMenu()\n } else {\n // Can't find item when collapsing\n // and activeIndex shouldn't be changed when 'collapse' was changed.\n // Then reset 'alteredCollapse' immediately.\n if (!alteredCollapse.value) {\n activeIndex.value = undefined\n } else {\n alteredCollapse.value = false\n }\n }\n }\n const handleResize = () => {\n nextTick(() => instance.proxy!.$forceUpdate())\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(items.value, () => initMenu())\n\n watch(\n () => props.collapse,\n (value, prev) => {\n if (value !== prev) {\n alteredCollapse.value = true\n }\n if (value) openedMenus.value = []\n }\n )\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 provide<MenuProvider>(\n 'rootMenu',\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 provide<SubMenuProvider>(`subMenu:${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n })\n }\n\n // lifecycle\n onMounted(() => {\n initMenu()\n if (props.mode === 'horizontal') {\n new Menubar(instance.vnode.el!)\n }\n })\n\n {\n const open = (index: string) => {\n const { indexPath } = subMenus.value[index]\n indexPath.forEach((i) => openMenu(i, indexPath))\n }\n expose({\n open,\n close: closeMenu,\n handleResize,\n })\n }\n\n const flattedChildren = (children: VNodeNormalizedChildren) => {\n const vnodes = Array.isArray(children) ? children : [children]\n const result: any[] = []\n vnodes.forEach((child: any) => {\n if (Array.isArray(child.children)) {\n result.push(...flattedChildren(child.children))\n } else {\n result.push(child)\n }\n })\n return result\n }\n\n const useVNodeResize = (vnode: VNode) =>\n props.mode === 'horizontal'\n ? withDirectives(vnode, [[Resize, handleResize]])\n : vnode\n return () => {\n let slot = slots.default?.() ?? []\n const vShowMore: VNode[] = []\n\n if (props.mode === 'horizontal' && menu.value) {\n const items = Array.from(menu.value?.childNodes ?? []).filter(\n (item) => item.nodeName !== '#text' || item.nodeValue\n ) as HTMLElement[]\n const originalSlot = flattedChildren(slot)\n const moreItemWidth = 64\n const paddingLeft = parseInt(\n getComputedStyle(menu.value).paddingLeft,\n 10\n )\n const paddingRight = parseInt(\n getComputedStyle(menu.value).paddingRight,\n 10\n )\n const menuWidth = menu.value.clientWidth - paddingLeft - paddingRight\n let calcWidth = 0\n let sliceIndex = 0\n items.forEach((item, index) => {\n calcWidth += item.offsetWidth || 0\n if (calcWidth <= menuWidth - moreItemWidth) {\n sliceIndex = index + 1\n }\n })\n const slotDefault = originalSlot.slice(0, sliceIndex)\n const slotMore = originalSlot.slice(sliceIndex)\n if (slotMore?.length && props.ellipsis) {\n slot = slotDefault\n vShowMore.push(\n h(\n ElSubMenu,\n {\n index: 'sub-menu-more',\n class: 'el-sub-menu__hide-arrow',\n },\n {\n title: () =>\n h(\n ElIcon,\n {\n class: ['el-sub-menu__icon-more'],\n },\n { default: () => h(More) }\n ),\n default: () => slotMore,\n }\n )\n )\n }\n }\n\n const ulStyle = useMenuCssVar(props)\n\n const resizeMenu = (vNode: VNode) =>\n props.ellipsis ? useVNodeResize(vNode) : vNode\n\n const vMenu = resizeMenu(\n h(\n 'ul',\n {\n key: String(props.collapse),\n role: 'menubar',\n ref: menu,\n style: ulStyle.value,\n class: {\n 'el-menu': true,\n 'el-menu--horizontal': props.mode === 'horizontal',\n 'el-menu--collapse': props.collapse,\n },\n },\n [...slot.map((vnode) => resizeMenu(vnode)), ...vShowMore]\n )\n )\n\n if (props.collapseTransition && props.mode === 'vertical') {\n return h(ElMenuCollapseTransition, () => vMenu)\n }\n\n return vMenu\n }\n },\n})\n"],"names":["buildProps","definePropType","mutable","isString","isObject","defineComponent","getCurrentInstance","ref","computed","reactive","Menubar","withDirectives","Resize","h","ElSubMenu","ElIcon","More","useMenuCssVar","ElMenuCollapseTransition"],"mappings":"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"}
1
+ {"version":3,"file":"menu.js","sources":["../../../../../../packages/components/menu/src/menu.ts"],"sourcesContent":["import {\n defineComponent,\n getCurrentInstance,\n watch,\n computed,\n ref,\n provide,\n onMounted,\n h,\n withDirectives,\n reactive,\n nextTick,\n} from 'vue'\nimport { Resize } from '@element-plus/directives'\nimport ElIcon from '@element-plus/components/icon'\nimport { More } from '@element-plus/icons-vue'\nimport Menubar from '@element-plus/utils/menu/menu-bar'\nimport { buildProps, definePropType, mutable } from '@element-plus/utils/props'\nimport { isString, isObject } from '@element-plus/utils/util'\nimport ElMenuCollapseTransition from './menu-collapse-transition.vue'\nimport ElSubMenu from './sub-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\n\nimport type { MenuItemClicked, MenuProvider, SubMenuProvider } from './types'\nimport type { NavigationFailure, Router } from 'vue-router'\nimport type { VNode, ExtractPropTypes, VNodeNormalizedChildren } from 'vue'\n\nexport const menuProps = buildProps({\n mode: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'vertical',\n },\n defaultActive: {\n type: String,\n default: '',\n },\n defaultOpeneds: {\n type: definePropType<string[]>(Array),\n default: () => mutable([] as const),\n },\n uniqueOpened: Boolean,\n router: Boolean,\n menuTrigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n collapse: Boolean,\n backgroundColor: String,\n textColor: String,\n activeTextColor: String,\n collapseTransition: {\n type: Boolean,\n default: true,\n },\n ellipsis: {\n type: Boolean,\n default: true,\n },\n} as const)\nexport type MenuProps = ExtractPropTypes<typeof menuProps>\n\nconst checkIndexPath = (indexPath: unknown): indexPath is string[] =>\n Array.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 (routerResult === undefined || routerResult instanceof Promise),\n}\nexport type MenuEmits = typeof menuEmits\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\n // data\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 const alteredCollapse = ref(false)\n\n // computed\n const isMenuPopup = computed<MenuProvider['isMenuPopup']>(() => {\n return (\n props.mode === 'horizontal' ||\n (props.mode === 'vertical' && props.collapse)\n )\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 closeMenu: MenuProvider['closeMenu'] = (index, indexPath) => {\n const i = openedMenus.value.indexOf(index)\n if (i !== -1) {\n openedMenus.value.splice(i, 1)\n }\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 if (isOpened) {\n closeMenu(index, indexPath)\n } else {\n openMenu(index, indexPath)\n }\n }\n\n const handleMenuItemClick: MenuProvider['handleMenuItemClick'] = (\n menuItem\n ) => {\n if (props.mode === 'horizontal' || props.collapse) {\n openedMenus.value = []\n }\n\n const { index, indexPath } = menuItem\n if (index === undefined || indexPath === undefined) 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 if (item) {\n activeIndex.value = item.index\n initMenu()\n } else {\n // Can't find item when collapsing\n // and activeIndex shouldn't be changed when 'collapse' was changed.\n // Then reset 'alteredCollapse' immediately.\n if (!alteredCollapse.value) {\n activeIndex.value = undefined\n } else {\n alteredCollapse.value = false\n }\n }\n }\n const handleResize = () => {\n nextTick(() => instance.proxy!.$forceUpdate())\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(items.value, () => initMenu())\n\n watch(\n () => props.collapse,\n (value, prev) => {\n if (value !== prev) {\n alteredCollapse.value = true\n }\n if (value) openedMenus.value = []\n }\n )\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 provide<MenuProvider>(\n 'rootMenu',\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 provide<SubMenuProvider>(`subMenu:${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n })\n }\n\n // lifecycle\n onMounted(() => {\n initMenu()\n if (props.mode === 'horizontal') {\n new Menubar(instance.vnode.el!)\n }\n })\n\n {\n const open = (index: string) => {\n const { indexPath } = subMenus.value[index]\n indexPath.forEach((i) => openMenu(i, indexPath))\n }\n expose({\n open,\n close: closeMenu,\n handleResize,\n })\n }\n\n const flattedChildren = (children: VNodeNormalizedChildren) => {\n const vnodes = Array.isArray(children) ? children : [children]\n const result: any[] = []\n vnodes.forEach((child: any) => {\n if (Array.isArray(child.children)) {\n result.push(...flattedChildren(child.children))\n } else {\n result.push(child)\n }\n })\n return result\n }\n\n const useVNodeResize = (vnode: VNode) =>\n props.mode === 'horizontal'\n ? withDirectives(vnode, [[Resize, handleResize]])\n : vnode\n return () => {\n let slot = slots.default?.() ?? []\n const vShowMore: VNode[] = []\n\n if (props.mode === 'horizontal' && menu.value) {\n const items = Array.from(menu.value?.childNodes ?? []).filter(\n (item) => item.nodeName !== '#text' || item.nodeValue\n ) as HTMLElement[]\n const originalSlot = flattedChildren(slot)\n const moreItemWidth = 64\n const paddingLeft = parseInt(\n getComputedStyle(menu.value).paddingLeft,\n 10\n )\n const paddingRight = parseInt(\n getComputedStyle(menu.value).paddingRight,\n 10\n )\n const menuWidth = menu.value.clientWidth - paddingLeft - paddingRight\n let calcWidth = 0\n let sliceIndex = 0\n items.forEach((item, index) => {\n calcWidth += item.offsetWidth || 0\n if (calcWidth <= menuWidth - moreItemWidth) {\n sliceIndex = index + 1\n }\n })\n const slotDefault = originalSlot.slice(0, sliceIndex)\n const slotMore = originalSlot.slice(sliceIndex)\n if (slotMore?.length && props.ellipsis) {\n slot = slotDefault\n vShowMore.push(\n h(\n ElSubMenu,\n {\n index: 'sub-menu-more',\n class: 'el-sub-menu__hide-arrow',\n },\n {\n title: () =>\n h(\n ElIcon,\n {\n class: ['el-sub-menu__icon-more'],\n },\n { default: () => h(More) }\n ),\n default: () => slotMore,\n }\n )\n )\n }\n }\n\n const ulStyle = useMenuCssVar(props)\n\n const resizeMenu = (vNode: VNode) =>\n props.ellipsis ? useVNodeResize(vNode) : vNode\n\n const vMenu = resizeMenu(\n h(\n 'ul',\n {\n key: String(props.collapse),\n role: 'menubar',\n ref: menu,\n style: ulStyle.value,\n class: {\n 'el-menu': true,\n 'el-menu--horizontal': props.mode === 'horizontal',\n 'el-menu--collapse': props.collapse,\n },\n },\n [...slot.map((vnode) => resizeMenu(vnode)), ...vShowMore]\n )\n )\n\n if (props.collapseTransition && props.mode === 'vertical') {\n return h(ElMenuCollapseTransition, () => vMenu)\n }\n\n return vMenu\n }\n },\n})\n"],"names":["buildProps","definePropType","mutable","isString","isObject","defineComponent","getCurrentInstance","ref","computed","reactive","Menubar","withDirectives","Resize","h","ElSubMenu","ElIcon","More","useMenuCssVar","ElMenuCollapseTransition"],"mappings":"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"}
@@ -8,7 +8,7 @@ var index$2 = require('../../collapse-transition/index.js');
8
8
  var index$1 = require('../../popper/index.js');
9
9
  var props = require('../../../utils/props.js');
10
10
  var error = require('../../../utils/error.js');
11
- var icons = require('@element-plus/icons');
11
+ var iconsVue = require('@element-plus/icons-vue');
12
12
  var index = require('../../icon/index.js');
13
13
  var useMenu = require('./use-menu.js');
14
14
  var useMenuCssVar = require('./use-menu-css-var.js');
@@ -54,7 +54,7 @@ var SubMenu = vue.defineComponent({
54
54
  const verticalTitleRef = vue.ref();
55
55
  const vPopper = vue.ref();
56
56
  const subMenuTitleIcon = vue.computed(() => {
57
- return mode.value === "horizontal" && isFirstLevel.value || mode.value === "vertical" && !rootMenu.props.collapse ? icons.ArrowDown : icons.ArrowRight;
57
+ return mode.value === "horizontal" && isFirstLevel.value || mode.value === "vertical" && !rootMenu.props.collapse ? iconsVue.ArrowDown : iconsVue.ArrowRight;
58
58
  });
59
59
  const isFirstLevel = vue.computed(() => {
60
60
  let isFirstLevel2 = true;
@@ -1 +1 @@
1
- {"version":3,"file":"sub-menu.js","sources":["../../../../../../packages/components/menu/src/sub-menu.ts"],"sourcesContent":["import {\n defineComponent,\n computed,\n ref,\n provide,\n inject,\n getCurrentInstance,\n watch,\n onMounted,\n onBeforeUnmount,\n withDirectives,\n Fragment,\n vShow,\n h,\n reactive,\n} from 'vue'\nimport { useTimeoutFn } from '@vueuse/core'\nimport ElCollapseTransition from '@element-plus/components/collapse-transition'\nimport ElPopper from '@element-plus/components/popper'\nimport { buildProps } from '@element-plus/utils/props'\nimport { throwError } from '@element-plus/utils/error'\nimport { ArrowDown, ArrowRight } from '@element-plus/icons'\nimport { ElIcon } from '@element-plus/components/icon'\nimport useMenu from './use-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\n\nimport type { Placement } from '@element-plus/components/popper'\nimport type { ExtractPropTypes, VNodeArrayChildren, CSSProperties } from 'vue'\nimport type { MenuProvider, SubMenuProvider } from './types'\n\nexport const subMenuProps = buildProps({\n index: {\n type: String,\n required: true,\n },\n showTimeout: {\n type: Number,\n default: 300,\n },\n hideTimeout: {\n type: Number,\n default: 300,\n },\n popperClass: String,\n disabled: Boolean,\n popperAppendToBody: {\n type: Boolean,\n default: undefined,\n },\n} as const)\nexport type SubMenuProps = ExtractPropTypes<typeof subMenuProps>\n\nconst COMPONENT_NAME = 'ElSubMenu'\nexport default defineComponent({\n name: COMPONENT_NAME,\n props: subMenuProps,\n\n setup(props, { slots, expose }) {\n const instance = getCurrentInstance()!\n const { paddingStyle, indexPath, parentMenu } = useMenu(\n instance,\n computed(() => props.index)\n )\n\n // inject\n const rootMenu = inject<MenuProvider>('rootMenu')\n if (!rootMenu) throwError(COMPONENT_NAME, 'can not inject root menu')\n\n const subMenu = inject<SubMenuProvider>(`subMenu:${parentMenu.value!.uid}`)\n if (!subMenu) throwError(COMPONENT_NAME, 'can not inject sub menu')\n\n const items = ref<MenuProvider['items']>({})\n const subMenus = ref<MenuProvider['subMenus']>({})\n\n let timeout: (() => void) | undefined\n const currentPlacement = ref<Placement | ''>('')\n const mouseInChild = ref(false)\n const verticalTitleRef = ref<HTMLDivElement>()\n const vPopper = ref()\n\n // computed\n const subMenuTitleIcon = computed(() => {\n return (mode.value === 'horizontal' && isFirstLevel.value) ||\n (mode.value === 'vertical' && !rootMenu.props.collapse)\n ? ArrowDown\n : ArrowRight\n })\n const isFirstLevel = computed(() => {\n let isFirstLevel = true\n let parent = instance.parent\n while (parent && parent.type.name !== 'ElMenu') {\n if (['ElSubMenu', 'ElMenuItemGroup'].includes(parent.type.name!)) {\n isFirstLevel = false\n break\n } else {\n parent = parent.parent\n }\n }\n return isFirstLevel\n })\n const appendToBody = computed(() => {\n return props.popperAppendToBody === undefined\n ? isFirstLevel.value\n : Boolean(props.popperAppendToBody)\n })\n const menuTransitionName = computed(() =>\n rootMenu.props.collapse ? 'el-zoom-in-left' : 'el-zoom-in-top'\n )\n const fallbackPlacements = computed<Placement[]>(() =>\n mode.value === 'horizontal' && isFirstLevel.value\n ? [\n 'bottom-start',\n 'bottom-end',\n 'top-start',\n 'top-end',\n 'right-start',\n 'left-start',\n ]\n : [\n 'right-start',\n 'left-start',\n 'bottom-start',\n 'bottom-end',\n 'top-start',\n 'top-end',\n ]\n )\n const opened = computed(() => rootMenu.openedMenus.includes(props.index))\n const active = computed(() => {\n let isActive = false\n\n Object.values(items.value).forEach((item) => {\n if (item.active) {\n isActive = true\n }\n })\n\n Object.values(subMenus.value).forEach((subItem) => {\n if (subItem.active) {\n isActive = true\n }\n })\n\n return isActive\n })\n\n const backgroundColor = computed(() => rootMenu.props.backgroundColor || '')\n const activeTextColor = computed(() => rootMenu.props.activeTextColor || '')\n const textColor = computed(() => rootMenu.props.textColor || '')\n const mode = computed(() => rootMenu.props.mode)\n const item = reactive({\n index: props.index,\n indexPath,\n active,\n })\n\n const titleStyle = computed<CSSProperties>(() => {\n if (mode.value !== 'horizontal') {\n return {\n color: textColor.value,\n }\n }\n return {\n borderBottomColor: active.value\n ? rootMenu.props.activeTextColor\n ? activeTextColor.value\n : ''\n : 'transparent',\n color: active.value ? activeTextColor.value : textColor.value,\n }\n })\n\n // methods\n const doDestroy = () => vPopper.value?.doDestroy()\n\n const handleCollapseToggle = (value: boolean) => {\n if (value) {\n updatePlacement()\n } else {\n doDestroy()\n }\n }\n\n const handleClick = () => {\n if (\n (rootMenu.props.menuTrigger === 'hover' &&\n rootMenu.props.mode === 'horizontal') ||\n (rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n props.disabled\n )\n return\n\n rootMenu.handleSubMenuClick({\n index: props.index,\n indexPath: indexPath.value,\n active: active.value,\n })\n }\n\n const handleMouseenter = (\n event: MouseEvent | FocusEvent,\n showTimeout = props.showTimeout\n ) => {\n if (event.type === 'focus' && !event.relatedTarget) {\n return\n }\n if (\n (rootMenu.props.menuTrigger === 'click' &&\n rootMenu.props.mode === 'horizontal') ||\n (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n props.disabled\n ) {\n return\n }\n mouseInChild.value = true\n\n timeout?.()\n ;({ stop: timeout } = useTimeoutFn(\n () => rootMenu.openMenu(props.index, indexPath.value),\n showTimeout\n ))\n\n if (appendToBody.value) {\n parentMenu.value.vnode.el?.dispatchEvent(new MouseEvent('mouseenter'))\n }\n }\n\n const handleMouseleave = (deepDispatch = false) => {\n if (\n (rootMenu.props.menuTrigger === 'click' &&\n rootMenu.props.mode === 'horizontal') ||\n (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical')\n ) {\n return\n }\n mouseInChild.value = false\n timeout?.()\n ;({ stop: timeout } = useTimeoutFn(\n () =>\n !mouseInChild.value &&\n rootMenu.closeMenu(props.index, indexPath.value),\n props.hideTimeout\n ))\n\n if (appendToBody.value && deepDispatch) {\n if (instance.parent?.type.name === 'ElSubMenu') {\n subMenu.handleMouseleave?.(true)\n }\n }\n }\n\n const updatePlacement = () => {\n currentPlacement.value =\n mode.value === 'horizontal' && isFirstLevel.value\n ? 'bottom-start'\n : 'right-start'\n }\n\n watch(\n () => rootMenu.props.collapse,\n (value) => handleCollapseToggle(Boolean(value))\n )\n\n // provide\n {\n const addSubMenu: SubMenuProvider['addSubMenu'] = (item) => {\n subMenus.value[item.index] = item\n }\n const removeSubMenu: SubMenuProvider['removeSubMenu'] = (item) => {\n delete subMenus.value[item.index]\n }\n provide<SubMenuProvider>(`subMenu:${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n handleMouseleave,\n })\n }\n\n // expose\n expose({\n opened,\n })\n\n // lifecycle\n onMounted(() => {\n rootMenu.addSubMenu(item)\n subMenu.addSubMenu(item)\n updatePlacement()\n })\n\n onBeforeUnmount(() => {\n subMenu.removeSubMenu(item)\n rootMenu.removeSubMenu(item)\n })\n\n return () => {\n const titleTag: VNodeArrayChildren = [\n slots.title?.(),\n h(\n ElIcon,\n {\n class: ['el-sub-menu__icon-arrow'],\n },\n { default: () => h(subMenuTitleIcon.value) }\n ),\n ]\n\n const ulStyle = useMenuCssVar(rootMenu.props)\n\n // this render function is only used for bypass `Vue`'s compiler caused patching issue.\n // temporarily mark ElPopper as any due to type inconsistency.\n const child = rootMenu.isMenuPopup\n ? h(\n // TODO: correct popper's type.\n ElPopper as any,\n {\n ref: vPopper,\n manualMode: true,\n visible: opened.value,\n effect: 'light',\n pure: true,\n offset: 6,\n showArrow: false,\n popperClass: props.popperClass,\n placement: currentPlacement.value,\n appendToBody: appendToBody.value,\n fallbackPlacements: fallbackPlacements.value,\n transition: menuTransitionName.value,\n gpuAcceleration: false,\n },\n {\n default: () =>\n h(\n 'div',\n {\n class: [`el-menu--${mode.value}`, props.popperClass],\n onMouseenter: (evt: MouseEvent) =>\n handleMouseenter(evt, 100),\n onMouseleave: () => handleMouseleave(true),\n onFocus: (evt: FocusEvent) => handleMouseenter(evt, 100),\n },\n [\n h(\n 'ul',\n {\n class: [\n 'el-menu el-menu--popup',\n `el-menu--popup-${currentPlacement.value}`,\n ],\n style: ulStyle.value,\n },\n [slots.default?.()]\n ),\n ]\n ),\n trigger: () =>\n h(\n 'div',\n {\n class: 'el-sub-menu__title',\n style: [\n paddingStyle.value,\n titleStyle.value,\n { backgroundColor: backgroundColor.value },\n ],\n onClick: handleClick,\n },\n titleTag\n ),\n }\n )\n : h(Fragment, {}, [\n h(\n 'div',\n {\n class: 'el-sub-menu__title',\n style: [\n paddingStyle.value,\n titleStyle.value,\n { backgroundColor: backgroundColor.value },\n ],\n ref: verticalTitleRef,\n onClick: handleClick,\n },\n titleTag\n ),\n h(\n ElCollapseTransition,\n {},\n {\n default: () =>\n withDirectives(\n h(\n 'ul',\n {\n role: 'menu',\n class: 'el-menu el-menu--inline',\n style: ulStyle.value,\n },\n [slots.default?.()]\n ),\n [[vShow, opened.value]]\n ),\n }\n ),\n ])\n\n return h(\n 'li',\n {\n class: [\n 'el-sub-menu',\n {\n 'is-active': active.value,\n 'is-opened': opened.value,\n 'is-disabled': props.disabled,\n },\n ],\n role: 'menuitem',\n ariaHaspopup: true,\n ariaExpanded: opened.value,\n onMouseenter: handleMouseenter,\n onMouseleave: () => handleMouseleave(true),\n onFocus: handleMouseenter,\n },\n [child]\n )\n }\n },\n})\n"],"names":["buildProps","defineComponent","getCurrentInstance","useMenu","computed","inject","ref","ArrowDown","ArrowRight","reactive","useTimeoutFn","h","ElIcon","useMenuCssVar","ElPopper","Fragment","ElCollapseTransition","vShow"],"mappings":"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"}
1
+ {"version":3,"file":"sub-menu.js","sources":["../../../../../../packages/components/menu/src/sub-menu.ts"],"sourcesContent":["import {\n defineComponent,\n computed,\n ref,\n provide,\n inject,\n getCurrentInstance,\n watch,\n onMounted,\n onBeforeUnmount,\n withDirectives,\n Fragment,\n vShow,\n h,\n reactive,\n} from 'vue'\nimport { useTimeoutFn } from '@vueuse/core'\nimport ElCollapseTransition from '@element-plus/components/collapse-transition'\nimport ElPopper from '@element-plus/components/popper'\nimport { buildProps } from '@element-plus/utils/props'\nimport { throwError } from '@element-plus/utils/error'\nimport { ArrowDown, ArrowRight } from '@element-plus/icons-vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport useMenu from './use-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\n\nimport type { Placement } from '@element-plus/components/popper'\nimport type { ExtractPropTypes, VNodeArrayChildren, CSSProperties } from 'vue'\nimport type { MenuProvider, SubMenuProvider } from './types'\n\nexport const subMenuProps = buildProps({\n index: {\n type: String,\n required: true,\n },\n showTimeout: {\n type: Number,\n default: 300,\n },\n hideTimeout: {\n type: Number,\n default: 300,\n },\n popperClass: String,\n disabled: Boolean,\n popperAppendToBody: {\n type: Boolean,\n default: undefined,\n },\n} as const)\nexport type SubMenuProps = ExtractPropTypes<typeof subMenuProps>\n\nconst COMPONENT_NAME = 'ElSubMenu'\nexport default defineComponent({\n name: COMPONENT_NAME,\n props: subMenuProps,\n\n setup(props, { slots, expose }) {\n const instance = getCurrentInstance()!\n const { paddingStyle, indexPath, parentMenu } = useMenu(\n instance,\n computed(() => props.index)\n )\n\n // inject\n const rootMenu = inject<MenuProvider>('rootMenu')\n if (!rootMenu) throwError(COMPONENT_NAME, 'can not inject root menu')\n\n const subMenu = inject<SubMenuProvider>(`subMenu:${parentMenu.value!.uid}`)\n if (!subMenu) throwError(COMPONENT_NAME, 'can not inject sub menu')\n\n const items = ref<MenuProvider['items']>({})\n const subMenus = ref<MenuProvider['subMenus']>({})\n\n let timeout: (() => void) | undefined\n const currentPlacement = ref<Placement | ''>('')\n const mouseInChild = ref(false)\n const verticalTitleRef = ref<HTMLDivElement>()\n const vPopper = ref()\n\n // computed\n const subMenuTitleIcon = computed(() => {\n return (mode.value === 'horizontal' && isFirstLevel.value) ||\n (mode.value === 'vertical' && !rootMenu.props.collapse)\n ? ArrowDown\n : ArrowRight\n })\n const isFirstLevel = computed(() => {\n let isFirstLevel = true\n let parent = instance.parent\n while (parent && parent.type.name !== 'ElMenu') {\n if (['ElSubMenu', 'ElMenuItemGroup'].includes(parent.type.name!)) {\n isFirstLevel = false\n break\n } else {\n parent = parent.parent\n }\n }\n return isFirstLevel\n })\n const appendToBody = computed(() => {\n return props.popperAppendToBody === undefined\n ? isFirstLevel.value\n : Boolean(props.popperAppendToBody)\n })\n const menuTransitionName = computed(() =>\n rootMenu.props.collapse ? 'el-zoom-in-left' : 'el-zoom-in-top'\n )\n const fallbackPlacements = computed<Placement[]>(() =>\n mode.value === 'horizontal' && isFirstLevel.value\n ? [\n 'bottom-start',\n 'bottom-end',\n 'top-start',\n 'top-end',\n 'right-start',\n 'left-start',\n ]\n : [\n 'right-start',\n 'left-start',\n 'bottom-start',\n 'bottom-end',\n 'top-start',\n 'top-end',\n ]\n )\n const opened = computed(() => rootMenu.openedMenus.includes(props.index))\n const active = computed(() => {\n let isActive = false\n\n Object.values(items.value).forEach((item) => {\n if (item.active) {\n isActive = true\n }\n })\n\n Object.values(subMenus.value).forEach((subItem) => {\n if (subItem.active) {\n isActive = true\n }\n })\n\n return isActive\n })\n\n const backgroundColor = computed(() => rootMenu.props.backgroundColor || '')\n const activeTextColor = computed(() => rootMenu.props.activeTextColor || '')\n const textColor = computed(() => rootMenu.props.textColor || '')\n const mode = computed(() => rootMenu.props.mode)\n const item = reactive({\n index: props.index,\n indexPath,\n active,\n })\n\n const titleStyle = computed<CSSProperties>(() => {\n if (mode.value !== 'horizontal') {\n return {\n color: textColor.value,\n }\n }\n return {\n borderBottomColor: active.value\n ? rootMenu.props.activeTextColor\n ? activeTextColor.value\n : ''\n : 'transparent',\n color: active.value ? activeTextColor.value : textColor.value,\n }\n })\n\n // methods\n const doDestroy = () => vPopper.value?.doDestroy()\n\n const handleCollapseToggle = (value: boolean) => {\n if (value) {\n updatePlacement()\n } else {\n doDestroy()\n }\n }\n\n const handleClick = () => {\n if (\n (rootMenu.props.menuTrigger === 'hover' &&\n rootMenu.props.mode === 'horizontal') ||\n (rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n props.disabled\n )\n return\n\n rootMenu.handleSubMenuClick({\n index: props.index,\n indexPath: indexPath.value,\n active: active.value,\n })\n }\n\n const handleMouseenter = (\n event: MouseEvent | FocusEvent,\n showTimeout = props.showTimeout\n ) => {\n if (event.type === 'focus' && !event.relatedTarget) {\n return\n }\n if (\n (rootMenu.props.menuTrigger === 'click' &&\n rootMenu.props.mode === 'horizontal') ||\n (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n props.disabled\n ) {\n return\n }\n mouseInChild.value = true\n\n timeout?.()\n ;({ stop: timeout } = useTimeoutFn(\n () => rootMenu.openMenu(props.index, indexPath.value),\n showTimeout\n ))\n\n if (appendToBody.value) {\n parentMenu.value.vnode.el?.dispatchEvent(new MouseEvent('mouseenter'))\n }\n }\n\n const handleMouseleave = (deepDispatch = false) => {\n if (\n (rootMenu.props.menuTrigger === 'click' &&\n rootMenu.props.mode === 'horizontal') ||\n (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical')\n ) {\n return\n }\n mouseInChild.value = false\n timeout?.()\n ;({ stop: timeout } = useTimeoutFn(\n () =>\n !mouseInChild.value &&\n rootMenu.closeMenu(props.index, indexPath.value),\n props.hideTimeout\n ))\n\n if (appendToBody.value && deepDispatch) {\n if (instance.parent?.type.name === 'ElSubMenu') {\n subMenu.handleMouseleave?.(true)\n }\n }\n }\n\n const updatePlacement = () => {\n currentPlacement.value =\n mode.value === 'horizontal' && isFirstLevel.value\n ? 'bottom-start'\n : 'right-start'\n }\n\n watch(\n () => rootMenu.props.collapse,\n (value) => handleCollapseToggle(Boolean(value))\n )\n\n // provide\n {\n const addSubMenu: SubMenuProvider['addSubMenu'] = (item) => {\n subMenus.value[item.index] = item\n }\n const removeSubMenu: SubMenuProvider['removeSubMenu'] = (item) => {\n delete subMenus.value[item.index]\n }\n provide<SubMenuProvider>(`subMenu:${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n handleMouseleave,\n })\n }\n\n // expose\n expose({\n opened,\n })\n\n // lifecycle\n onMounted(() => {\n rootMenu.addSubMenu(item)\n subMenu.addSubMenu(item)\n updatePlacement()\n })\n\n onBeforeUnmount(() => {\n subMenu.removeSubMenu(item)\n rootMenu.removeSubMenu(item)\n })\n\n return () => {\n const titleTag: VNodeArrayChildren = [\n slots.title?.(),\n h(\n ElIcon,\n {\n class: ['el-sub-menu__icon-arrow'],\n },\n { default: () => h(subMenuTitleIcon.value) }\n ),\n ]\n\n const ulStyle = useMenuCssVar(rootMenu.props)\n\n // this render function is only used for bypass `Vue`'s compiler caused patching issue.\n // temporarily mark ElPopper as any due to type inconsistency.\n const child = rootMenu.isMenuPopup\n ? h(\n // TODO: correct popper's type.\n ElPopper as any,\n {\n ref: vPopper,\n manualMode: true,\n visible: opened.value,\n effect: 'light',\n pure: true,\n offset: 6,\n showArrow: false,\n popperClass: props.popperClass,\n placement: currentPlacement.value,\n appendToBody: appendToBody.value,\n fallbackPlacements: fallbackPlacements.value,\n transition: menuTransitionName.value,\n gpuAcceleration: false,\n },\n {\n default: () =>\n h(\n 'div',\n {\n class: [`el-menu--${mode.value}`, props.popperClass],\n onMouseenter: (evt: MouseEvent) =>\n handleMouseenter(evt, 100),\n onMouseleave: () => handleMouseleave(true),\n onFocus: (evt: FocusEvent) => handleMouseenter(evt, 100),\n },\n [\n h(\n 'ul',\n {\n class: [\n 'el-menu el-menu--popup',\n `el-menu--popup-${currentPlacement.value}`,\n ],\n style: ulStyle.value,\n },\n [slots.default?.()]\n ),\n ]\n ),\n trigger: () =>\n h(\n 'div',\n {\n class: 'el-sub-menu__title',\n style: [\n paddingStyle.value,\n titleStyle.value,\n { backgroundColor: backgroundColor.value },\n ],\n onClick: handleClick,\n },\n titleTag\n ),\n }\n )\n : h(Fragment, {}, [\n h(\n 'div',\n {\n class: 'el-sub-menu__title',\n style: [\n paddingStyle.value,\n titleStyle.value,\n { backgroundColor: backgroundColor.value },\n ],\n ref: verticalTitleRef,\n onClick: handleClick,\n },\n titleTag\n ),\n h(\n ElCollapseTransition,\n {},\n {\n default: () =>\n withDirectives(\n h(\n 'ul',\n {\n role: 'menu',\n class: 'el-menu el-menu--inline',\n style: ulStyle.value,\n },\n [slots.default?.()]\n ),\n [[vShow, opened.value]]\n ),\n }\n ),\n ])\n\n return h(\n 'li',\n {\n class: [\n 'el-sub-menu',\n {\n 'is-active': active.value,\n 'is-opened': opened.value,\n 'is-disabled': props.disabled,\n },\n ],\n role: 'menuitem',\n ariaHaspopup: true,\n ariaExpanded: opened.value,\n onMouseenter: handleMouseenter,\n onMouseleave: () => handleMouseleave(true),\n onFocus: handleMouseenter,\n },\n [child]\n )\n }\n },\n})\n"],"names":["buildProps","defineComponent","getCurrentInstance","useMenu","computed","inject","ref","ArrowDown","ArrowRight","reactive","useTimeoutFn","h","ElIcon","useMenuCssVar","ElPopper","Fragment","ElCollapseTransition","vShow"],"mappings":"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"}
@@ -12,7 +12,7 @@ export declare const messageProps: {
12
12
  }>>, "", unknown, unknown, unknown>;
13
13
  readonly onClose: import("element-plus/es/utils/props").BuildPropReturn<import("element-plus/es/utils/props").PropWrapper<() => void>, unknown, false, unknown, unknown>;
14
14
  readonly showClose: import("element-plus/es/utils/props").BuildPropReturn<BooleanConstructor, false, unknown, unknown, unknown>;
15
- readonly type: import("element-plus/es/utils/props").BuildPropReturn<StringConstructor, "info", unknown, "error" | "success" | "warning" | "info", unknown>;
15
+ readonly type: import("element-plus/es/utils/props").BuildPropReturn<StringConstructor, "info", unknown, "success" | "warning" | "info" | "error", unknown>;
16
16
  readonly offset: import("element-plus/es/utils/props").BuildPropReturn<NumberConstructor, 20, unknown, unknown, unknown>;
17
17
  readonly zIndex: import("element-plus/es/utils/props").BuildPropReturn<NumberConstructor, 0, unknown, unknown, unknown>;
18
18
  readonly grouping: import("element-plus/es/utils/props").BuildPropReturn<BooleanConstructor, false, unknown, unknown, unknown>;
@@ -11,7 +11,7 @@ declare const _default: import("vue").DefineComponent<{
11
11
  }>>, "", unknown, unknown, unknown>;
12
12
  readonly onClose: import("../../../utils/props").BuildPropReturn<import("../../../utils/props").PropWrapper<() => void>, unknown, false, unknown, unknown>;
13
13
  readonly showClose: import("../../../utils/props").BuildPropReturn<BooleanConstructor, false, unknown, unknown, unknown>;
14
- readonly type: import("../../../utils/props").BuildPropReturn<StringConstructor, "info", unknown, "error" | "success" | "warning" | "info", unknown>;
14
+ readonly type: import("../../../utils/props").BuildPropReturn<StringConstructor, "info", unknown, "success" | "warning" | "info" | "error", unknown>;
15
15
  readonly offset: import("../../../utils/props").BuildPropReturn<NumberConstructor, 20, unknown, unknown, unknown>;
16
16
  readonly zIndex: import("../../../utils/props").BuildPropReturn<NumberConstructor, 0, unknown, unknown, unknown>;
17
17
  readonly grouping: import("../../../utils/props").BuildPropReturn<BooleanConstructor, false, unknown, unknown, unknown>;
@@ -21,6 +21,7 @@ declare const _default: import("vue").DefineComponent<{
21
21
  iconComponent: import("vue").ComputedRef<import("../../../utils/props").BuildPropType<import("../../../utils/props").PropWrapper<string | import("vue").Component<any, any, any, import("vue").ComputedOptions, import("vue").MethodOptions>>, unknown, unknown>>;
22
22
  customStyle: import("vue").ComputedRef<CSSProperties>;
23
23
  visible: import("vue").Ref<boolean>;
24
+ badgeType: import("vue").Ref<import("../../../utils/props").BuildPropType<StringConstructor, "primary" | "success" | "warning" | "info" | "danger", unknown>>;
24
25
  close: () => void;
25
26
  clearTimer: () => void;
26
27
  startTimer: () => void;
@@ -42,7 +43,7 @@ declare const _default: import("vue").DefineComponent<{
42
43
  readonly grouping?: unknown;
43
44
  readonly repeatNum?: unknown;
44
45
  } & {
45
- type: import("../../../utils/props").BuildPropType<StringConstructor, "error" | "success" | "warning" | "info", unknown>;
46
+ type: import("../../../utils/props").BuildPropType<StringConstructor, "success" | "warning" | "info" | "error", unknown>;
46
47
  icon: import("../../../utils/props").BuildPropType<import("../../../utils/props").PropWrapper<string | import("vue").Component<any, any, any, import("vue").ComputedOptions, import("vue").MethodOptions>>, unknown, unknown>;
47
48
  zIndex: number;
48
49
  message: import("../../../utils/props").BuildPropType<import("../../../utils/props").PropWrapper<string | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
@@ -62,7 +63,7 @@ declare const _default: import("vue").DefineComponent<{
62
63
  }> & {
63
64
  onDestroy?: (() => any) | undefined;
64
65
  }, {
65
- type: import("../../../utils/props").BuildPropType<StringConstructor, "error" | "success" | "warning" | "info", unknown>;
66
+ type: import("../../../utils/props").BuildPropType<StringConstructor, "success" | "warning" | "info" | "error", unknown>;
66
67
  icon: import("../../../utils/props").BuildPropType<import("../../../utils/props").PropWrapper<string | import("vue").Component<any, any, any, import("vue").ComputedOptions, import("vue").MethodOptions>>, unknown, unknown>;
67
68
  zIndex: number;
68
69
  message: import("../../../utils/props").BuildPropType<import("../../../utils/props").PropWrapper<string | import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
@@ -21,6 +21,7 @@ var script = vue.defineComponent({
21
21
  emits: message.messageEmits,
22
22
  setup(props) {
23
23
  const visible = vue.ref(false);
24
+ const badgeType = vue.ref(props.type ? props.type === "error" ? "danger" : props.type : "info");
24
25
  let stopTimer = void 0;
25
26
  const typeClass = vue.computed(() => {
26
27
  const type = props.type;
@@ -71,6 +72,7 @@ var script = vue.defineComponent({
71
72
  iconComponent,
72
73
  customStyle,
73
74
  visible,
75
+ badgeType,
74
76
  close,
75
77
  clearTimer,
76
78
  startTimer
@@ -1 +1 @@
1
- {"version":3,"file":"message.vue_vue_type_script_lang.js","sources":["../../../../../../packages/components/message/src/message.vue"],"sourcesContent":["<template>\n <transition\n name=\"el-message-fade\"\n @before-leave=\"onClose\"\n @after-leave=\"$emit('destroy')\"\n >\n <div\n v-show=\"visible\"\n :id=\"id\"\n :class=\"[\n 'el-message',\n type && !icon ? `el-message--${type}` : '',\n center ? 'is-center' : '',\n showClose ? 'is-closable' : '',\n customClass,\n ]\"\n :style=\"customStyle\"\n role=\"alert\"\n @mouseenter=\"clearTimer\"\n @mouseleave=\"startTimer\"\n >\n <el-badge\n v-if=\"repeatNum > 1\"\n :value=\"repeatNum\"\n :type=\"type ?? 'info'\"\n class=\"el-message__badge\"\n >\n </el-badge>\n <el-icon v-if=\"iconComponent\" class=\"el-message__icon\" :class=\"typeClass\">\n <component :is=\"iconComponent\" />\n </el-icon>\n <slot>\n <p v-if=\"!dangerouslyUseHTMLString\" class=\"el-message__content\">\n {{ message }}\n </p>\n <!-- Caution here, message could've been compromised, never use user's input as message -->\n <p v-else class=\"el-message__content\" v-html=\"message\"></p>\n </slot>\n <el-icon\n v-if=\"showClose\"\n class=\"el-message__closeBtn\"\n @click.stop=\"close\"\n >\n <close />\n </el-icon>\n </div>\n </transition>\n</template>\n<script lang=\"ts\">\nimport { defineComponent, computed, ref, onMounted, watch } from 'vue'\nimport { useEventListener, useTimeoutFn } from '@vueuse/core'\nimport { EVENT_CODE } from '@element-plus/utils/aria'\nimport ElBadge from '@element-plus/components/badge'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { TypeComponents, TypeComponentsMap } from '@element-plus/utils/icon'\n\nimport { messageEmits, messageProps } from './message'\n\nimport type { CSSProperties } from 'vue'\n\nexport default defineComponent({\n name: 'ElMessage',\n\n components: {\n ElBadge,\n ElIcon,\n ...TypeComponents,\n },\n\n props: messageProps,\n emits: messageEmits,\n\n setup(props) {\n const visible = ref(false)\n let stopTimer: (() => void) | undefined = undefined\n\n const typeClass = computed(() => {\n const type = props.type\n return type && TypeComponentsMap[type] ? `el-message-icon--${type}` : ''\n })\n\n const iconComponent = computed(() => {\n return props.icon || TypeComponentsMap[props.type] || ''\n })\n\n const customStyle = computed<CSSProperties>(() => ({\n top: `${props.offset}px`,\n zIndex: props.zIndex,\n }))\n\n function startTimer() {\n if (props.duration > 0) {\n ;({ stop: stopTimer } = useTimeoutFn(() => {\n if (visible.value) close()\n }, props.duration))\n }\n }\n\n function clearTimer() {\n stopTimer?.()\n }\n\n function close() {\n visible.value = false\n }\n\n function keydown({ code }: KeyboardEvent) {\n if (code === EVENT_CODE.esc) {\n // press esc to close the message\n if (visible.value) {\n close()\n }\n } else {\n startTimer() // resume timer\n }\n }\n\n onMounted(() => {\n startTimer()\n visible.value = true\n })\n\n watch(\n () => props.repeatNum,\n () => {\n clearTimer()\n startTimer()\n }\n )\n\n useEventListener(document, 'keydown', keydown)\n\n return {\n typeClass,\n iconComponent,\n customStyle,\n visible,\n\n close,\n clearTimer,\n startTimer,\n }\n },\n})\n</script>\n"],"names":["defineComponent","ElBadge","ElIcon","TypeComponents","messageProps","messageEmits","ref","computed","TypeComponentsMap","useTimeoutFn","EVENT_CODE"],"mappings":";;;;;;;;;;;;AA4DA,aAAeA,oBAAgB;AAAA,EAC7B,MAAM;AAAA,EAEN,YAAY;AAAA,aACVC;AAAA,YACAC;AAAA,OACGC;AAAA;AAAA,EAGL,OAAOC;AAAA,EACP,OAAOC;AAAA,EAEP,MAAM,OAAO;AACX,UAAM,UAAUC,QAAI;AACpB,QAAI,YAAsC;AAE1C,UAAM,YAAYC,aAAS,MAAM;AAC/B,YAAM,OAAO,MAAM;AACnB,aAAO,QAAQC,uBAAkB,QAAQ,oBAAoB,SAAS;AAAA;AAGxE,UAAM,gBAAgBD,aAAS,MAAM;AACnC,aAAO,MAAM,QAAQC,uBAAkB,MAAM,SAAS;AAAA;AAGxD,UAAM,cAAcD,aAAwB;AAAO,MACjD,KAAK,GAAG,MAAM;AAAA,MACd,QAAQ,MAAM;AAAA;AAGhB,0BAAsB;AACpB,UAAI,MAAM,WAAW,GAAG;AACtB;AAAC,QAAC,GAAE,MAAM,cAAcE,kBAAa,MAAM;AACzC,cAAI,QAAQ;AAAO;AAAA,WAClB,MAAM;AAAA;AAAA;AAIb,0BAAsB;AACpB;AAAA;AAGF,qBAAiB;AACf,cAAQ,QAAQ;AAAA;AAGlB,qBAAiB,EAAE,QAAuB;AACxC,UAAI,SAASC,gBAAW,KAAK;AAE3B,YAAI,QAAQ,OAAO;AACjB;AAAA;AAAA,aAEG;AACL;AAAA;AAAA;AAIJ,kBAAU,MAAM;AACd;AACA,cAAQ,QAAQ;AAAA;AAGlB,cACE,MAAM,MAAM,WACZ,MAAM;AACJ;AACA;AAAA;AAIJ,0BAAiB,UAAU,WAAW;AAEtC,WAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MAEA;AAAA,MACA;AAAA,MACA;AAAA;AAAA;AAAA;;;;"}
1
+ {"version":3,"file":"message.vue_vue_type_script_lang.js","sources":["../../../../../../packages/components/message/src/message.vue"],"sourcesContent":["<template>\n <transition\n name=\"el-message-fade\"\n @before-leave=\"onClose\"\n @after-leave=\"$emit('destroy')\"\n >\n <div\n v-show=\"visible\"\n :id=\"id\"\n :class=\"[\n 'el-message',\n type && !icon ? `el-message--${type}` : '',\n center ? 'is-center' : '',\n showClose ? 'is-closable' : '',\n customClass,\n ]\"\n :style=\"customStyle\"\n role=\"alert\"\n @mouseenter=\"clearTimer\"\n @mouseleave=\"startTimer\"\n >\n <el-badge\n v-if=\"repeatNum > 1\"\n :value=\"repeatNum\"\n :type=\"badgeType\"\n class=\"el-message__badge\"\n >\n </el-badge>\n <el-icon v-if=\"iconComponent\" class=\"el-message__icon\" :class=\"typeClass\">\n <component :is=\"iconComponent\" />\n </el-icon>\n <slot>\n <p v-if=\"!dangerouslyUseHTMLString\" class=\"el-message__content\">\n {{ message }}\n </p>\n <!-- Caution here, message could've been compromised, never use user's input as message -->\n <p v-else class=\"el-message__content\" v-html=\"message\"></p>\n </slot>\n <el-icon\n v-if=\"showClose\"\n class=\"el-message__closeBtn\"\n @click.stop=\"close\"\n >\n <close />\n </el-icon>\n </div>\n </transition>\n</template>\n<script lang=\"ts\">\nimport { defineComponent, computed, ref, onMounted, watch } from 'vue'\nimport { useEventListener, useTimeoutFn } from '@vueuse/core'\nimport { EVENT_CODE } from '@element-plus/utils/aria'\nimport ElBadge from '@element-plus/components/badge'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { TypeComponents, TypeComponentsMap } from '@element-plus/utils/icon'\n\nimport { messageEmits, messageProps } from './message'\nimport type { BadgeProps } from '@element-plus/components/badge'\n\nimport type { CSSProperties } from 'vue'\n\nexport default defineComponent({\n name: 'ElMessage',\n\n components: {\n ElBadge,\n ElIcon,\n ...TypeComponents,\n },\n\n props: messageProps,\n emits: messageEmits,\n\n setup(props) {\n const visible = ref(false)\n const badgeType = ref<BadgeProps['type']>(\n props.type ? (props.type === 'error' ? 'danger' : props.type) : 'info'\n )\n let stopTimer: (() => void) | undefined = undefined\n\n const typeClass = computed(() => {\n const type = props.type\n return type && TypeComponentsMap[type] ? `el-message-icon--${type}` : ''\n })\n\n const iconComponent = computed(() => {\n return props.icon || TypeComponentsMap[props.type] || ''\n })\n\n const customStyle = computed<CSSProperties>(() => ({\n top: `${props.offset}px`,\n zIndex: props.zIndex,\n }))\n\n function startTimer() {\n if (props.duration > 0) {\n ;({ stop: stopTimer } = useTimeoutFn(() => {\n if (visible.value) close()\n }, props.duration))\n }\n }\n\n function clearTimer() {\n stopTimer?.()\n }\n\n function close() {\n visible.value = false\n }\n\n function keydown({ code }: KeyboardEvent) {\n if (code === EVENT_CODE.esc) {\n // press esc to close the message\n if (visible.value) {\n close()\n }\n } else {\n startTimer() // resume timer\n }\n }\n\n onMounted(() => {\n startTimer()\n visible.value = true\n })\n\n watch(\n () => props.repeatNum,\n () => {\n clearTimer()\n startTimer()\n }\n )\n\n useEventListener(document, 'keydown', keydown)\n\n return {\n typeClass,\n iconComponent,\n customStyle,\n visible,\n badgeType,\n\n close,\n clearTimer,\n startTimer,\n }\n },\n})\n</script>\n"],"names":["defineComponent","ElBadge","ElIcon","TypeComponents","messageProps","messageEmits","ref","computed","TypeComponentsMap","useTimeoutFn","EVENT_CODE"],"mappings":";;;;;;;;;;;;AA6DA,aAAeA,oBAAgB;AAAA,EAC7B,MAAM;AAAA,EAEN,YAAY;AAAA,aACVC;AAAA,YACAC;AAAA,OACGC;AAAA;AAAA,EAGL,OAAOC;AAAA,EACP,OAAOC;AAAA,EAEP,MAAM,OAAO;AACX,UAAM,UAAUC,QAAI;AACpB,UAAM,YAAYA,QAChB,MAAM,OAAQ,MAAM,SAAS,UAAU,WAAW,MAAM,OAAQ;AAElE,QAAI,YAAsC;AAE1C,UAAM,YAAYC,aAAS,MAAM;AAC/B,YAAM,OAAO,MAAM;AACnB,aAAO,QAAQC,uBAAkB,QAAQ,oBAAoB,SAAS;AAAA;AAGxE,UAAM,gBAAgBD,aAAS,MAAM;AACnC,aAAO,MAAM,QAAQC,uBAAkB,MAAM,SAAS;AAAA;AAGxD,UAAM,cAAcD,aAAwB;AAAO,MACjD,KAAK,GAAG,MAAM;AAAA,MACd,QAAQ,MAAM;AAAA;AAGhB,0BAAsB;AACpB,UAAI,MAAM,WAAW,GAAG;AACtB;AAAC,QAAC,GAAE,MAAM,cAAcE,kBAAa,MAAM;AACzC,cAAI,QAAQ;AAAO;AAAA,WAClB,MAAM;AAAA;AAAA;AAIb,0BAAsB;AACpB;AAAA;AAGF,qBAAiB;AACf,cAAQ,QAAQ;AAAA;AAGlB,qBAAiB,EAAE,QAAuB;AACxC,UAAI,SAASC,gBAAW,KAAK;AAE3B,YAAI,QAAQ,OAAO;AACjB;AAAA;AAAA,aAEG;AACL;AAAA;AAAA;AAIJ,kBAAU,MAAM;AACd;AACA,cAAQ,QAAQ;AAAA;AAGlB,cACE,MAAM,MAAM,WACZ,MAAM;AACJ;AACA;AAAA;AAIJ,0BAAiB,UAAU,WAAW;AAEtC,WAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MAEA;AAAA,MACA;AAAA,MACA;AAAA;AAAA;AAAA;;;;"}
@@ -19,62 +19,59 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
19
19
  onBeforeLeave: _ctx.onClose,
20
20
  onAfterLeave: _cache[2] || (_cache[2] = ($event) => _ctx.$emit("destroy"))
21
21
  }, {
22
- default: vue.withCtx(() => {
23
- var _a;
24
- return [
25
- vue.withDirectives(vue.createElementVNode("div", {
26
- id: _ctx.id,
27
- class: vue.normalizeClass([
28
- "el-message",
29
- _ctx.type && !_ctx.icon ? `el-message--${_ctx.type}` : "",
30
- _ctx.center ? "is-center" : "",
31
- _ctx.showClose ? "is-closable" : "",
32
- _ctx.customClass
22
+ default: vue.withCtx(() => [
23
+ vue.withDirectives(vue.createElementVNode("div", {
24
+ id: _ctx.id,
25
+ class: vue.normalizeClass([
26
+ "el-message",
27
+ _ctx.type && !_ctx.icon ? `el-message--${_ctx.type}` : "",
28
+ _ctx.center ? "is-center" : "",
29
+ _ctx.showClose ? "is-closable" : "",
30
+ _ctx.customClass
31
+ ]),
32
+ style: vue.normalizeStyle(_ctx.customStyle),
33
+ role: "alert",
34
+ onMouseenter: _cache[0] || (_cache[0] = (...args) => _ctx.clearTimer && _ctx.clearTimer(...args)),
35
+ onMouseleave: _cache[1] || (_cache[1] = (...args) => _ctx.startTimer && _ctx.startTimer(...args))
36
+ }, [
37
+ _ctx.repeatNum > 1 ? (vue.openBlock(), vue.createBlock(_component_el_badge, {
38
+ key: 0,
39
+ value: _ctx.repeatNum,
40
+ type: _ctx.badgeType,
41
+ class: "el-message__badge"
42
+ }, null, 8, ["value", "type"])) : vue.createCommentVNode("v-if", true),
43
+ _ctx.iconComponent ? (vue.openBlock(), vue.createBlock(_component_el_icon, {
44
+ key: 1,
45
+ class: vue.normalizeClass(["el-message__icon", _ctx.typeClass])
46
+ }, {
47
+ default: vue.withCtx(() => [
48
+ (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.iconComponent)))
33
49
  ]),
34
- style: vue.normalizeStyle(_ctx.customStyle),
35
- role: "alert",
36
- onMouseenter: _cache[0] || (_cache[0] = (...args) => _ctx.clearTimer && _ctx.clearTimer(...args)),
37
- onMouseleave: _cache[1] || (_cache[1] = (...args) => _ctx.startTimer && _ctx.startTimer(...args))
38
- }, [
39
- _ctx.repeatNum > 1 ? (vue.openBlock(), vue.createBlock(_component_el_badge, {
40
- key: 0,
41
- value: _ctx.repeatNum,
42
- type: (_a = _ctx.type) != null ? _a : "info",
43
- class: "el-message__badge"
44
- }, null, 8, ["value", "type"])) : vue.createCommentVNode("v-if", true),
45
- _ctx.iconComponent ? (vue.openBlock(), vue.createBlock(_component_el_icon, {
46
- key: 1,
47
- class: vue.normalizeClass(["el-message__icon", _ctx.typeClass])
48
- }, {
49
- default: vue.withCtx(() => [
50
- (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.iconComponent)))
51
- ]),
52
- _: 1
53
- }, 8, ["class"])) : vue.createCommentVNode("v-if", true),
54
- vue.renderSlot(_ctx.$slots, "default", {}, () => [
55
- !_ctx.dangerouslyUseHTMLString ? (vue.openBlock(), vue.createElementBlock("p", _hoisted_2, vue.toDisplayString(_ctx.message), 1)) : (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 1 }, [
56
- vue.createCommentVNode(" Caution here, message could've been compromised, never use user's input as message "),
57
- vue.createElementVNode("p", {
58
- class: "el-message__content",
59
- innerHTML: _ctx.message
60
- }, null, 8, _hoisted_3)
61
- ], 2112))
50
+ _: 1
51
+ }, 8, ["class"])) : vue.createCommentVNode("v-if", true),
52
+ vue.renderSlot(_ctx.$slots, "default", {}, () => [
53
+ !_ctx.dangerouslyUseHTMLString ? (vue.openBlock(), vue.createElementBlock("p", _hoisted_2, vue.toDisplayString(_ctx.message), 1)) : (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 1 }, [
54
+ vue.createCommentVNode(" Caution here, message could've been compromised, never use user's input as message "),
55
+ vue.createElementVNode("p", {
56
+ class: "el-message__content",
57
+ innerHTML: _ctx.message
58
+ }, null, 8, _hoisted_3)
59
+ ], 2112))
60
+ ]),
61
+ _ctx.showClose ? (vue.openBlock(), vue.createBlock(_component_el_icon, {
62
+ key: 2,
63
+ class: "el-message__closeBtn",
64
+ onClick: vue.withModifiers(_ctx.close, ["stop"])
65
+ }, {
66
+ default: vue.withCtx(() => [
67
+ vue.createVNode(_component_close)
62
68
  ]),
63
- _ctx.showClose ? (vue.openBlock(), vue.createBlock(_component_el_icon, {
64
- key: 2,
65
- class: "el-message__closeBtn",
66
- onClick: vue.withModifiers(_ctx.close, ["stop"])
67
- }, {
68
- default: vue.withCtx(() => [
69
- vue.createVNode(_component_close)
70
- ]),
71
- _: 1
72
- }, 8, ["onClick"])) : vue.createCommentVNode("v-if", true)
73
- ], 46, _hoisted_1), [
74
- [vue.vShow, _ctx.visible]
75
- ])
76
- ];
77
- }),
69
+ _: 1
70
+ }, 8, ["onClick"])) : vue.createCommentVNode("v-if", true)
71
+ ], 46, _hoisted_1), [
72
+ [vue.vShow, _ctx.visible]
73
+ ])
74
+ ]),
78
75
  _: 3
79
76
  }, 8, ["onBeforeLeave"]);
80
77
  }