element-plus-secondary 1.2.7 → 1.2.8

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 (490) hide show
  1. package/dist/index.full.js +8 -3
  2. package/dist/index.full.min.js +1 -1
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +1 -1
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +8 -3
  7. package/es/components/affix/index.mjs +2 -2
  8. package/es/components/affix/src/affix.mjs +118 -25
  9. package/es/components/affix/src/affix.mjs.map +1 -1
  10. package/es/components/affix/src/affix2.mjs +25 -118
  11. package/es/components/affix/src/affix2.mjs.map +1 -1
  12. package/es/components/alert/index.mjs +2 -2
  13. package/es/components/alert/src/alert.mjs +36 -89
  14. package/es/components/alert/src/alert.mjs.map +1 -1
  15. package/es/components/alert/src/alert2.mjs +89 -36
  16. package/es/components/alert/src/alert2.mjs.map +1 -1
  17. package/es/components/anchor/index.mjs +2 -2
  18. package/es/components/anchor/src/anchor.mjs +42 -192
  19. package/es/components/anchor/src/anchor.mjs.map +1 -1
  20. package/es/components/anchor/src/anchor2.mjs +192 -42
  21. package/es/components/anchor/src/anchor2.mjs.map +1 -1
  22. package/es/components/autocomplete/index.mjs +2 -2
  23. package/es/components/autocomplete/src/autocomplete.mjs +367 -79
  24. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  25. package/es/components/autocomplete/src/autocomplete2.mjs +79 -367
  26. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  27. package/es/components/avatar/index.mjs +2 -2
  28. package/es/components/avatar/src/avatar.mjs +65 -31
  29. package/es/components/avatar/src/avatar.mjs.map +1 -1
  30. package/es/components/avatar/src/avatar2.mjs +31 -65
  31. package/es/components/avatar/src/avatar2.mjs.map +1 -1
  32. package/es/components/calendar/src/calendar2.mjs +1 -1
  33. package/es/components/calendar/src/date-table.mjs +89 -31
  34. package/es/components/calendar/src/date-table.mjs.map +1 -1
  35. package/es/components/calendar/src/date-table2.mjs +31 -89
  36. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  37. package/es/components/calendar/src/use-date-table.mjs +1 -1
  38. package/es/components/cascader/src/cascader.mjs +1 -1
  39. package/es/components/col/index.mjs +2 -2
  40. package/es/components/col/src/col.mjs +43 -64
  41. package/es/components/col/src/col.mjs.map +1 -1
  42. package/es/components/col/src/col2.mjs +64 -43
  43. package/es/components/col/src/col2.mjs.map +1 -1
  44. package/es/components/color-picker/index.mjs +2 -2
  45. package/es/components/color-picker/src/color-picker.mjs +49 -477
  46. package/es/components/color-picker/src/color-picker.mjs.map +1 -1
  47. package/es/components/color-picker/src/color-picker2.mjs +477 -49
  48. package/es/components/color-picker/src/color-picker2.mjs.map +1 -1
  49. package/es/components/color-picker/src/components/predefine.mjs +1 -1
  50. package/es/components/descriptions/index.mjs +2 -2
  51. package/es/components/descriptions/src/description.mjs +26 -126
  52. package/es/components/descriptions/src/description.mjs.map +1 -1
  53. package/es/components/descriptions/src/description2.mjs +126 -26
  54. package/es/components/descriptions/src/description2.mjs.map +1 -1
  55. package/es/components/descriptions/src/descriptions-row.mjs +6 -63
  56. package/es/components/descriptions/src/descriptions-row.mjs.map +1 -1
  57. package/es/components/descriptions/src/descriptions-row2.mjs +63 -6
  58. package/es/components/descriptions/src/descriptions-row2.mjs.map +1 -1
  59. package/es/components/drawer/index.mjs +2 -2
  60. package/es/components/drawer/src/drawer.mjs +178 -30
  61. package/es/components/drawer/src/drawer.mjs.map +1 -1
  62. package/es/components/drawer/src/drawer2.mjs +30 -178
  63. package/es/components/drawer/src/drawer2.mjs.map +1 -1
  64. package/es/components/dropdown/index.mjs +2 -2
  65. package/es/components/dropdown/src/dropdown-item-impl.mjs +1 -1
  66. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  67. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  68. package/es/components/dropdown/src/dropdown.mjs +301 -108
  69. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  70. package/es/components/dropdown/src/dropdown2.mjs +108 -301
  71. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  72. package/es/components/image/index.mjs +2 -2
  73. package/es/components/image/src/image.mjs +222 -68
  74. package/es/components/image/src/image.mjs.map +1 -1
  75. package/es/components/image/src/image2.mjs +68 -222
  76. package/es/components/image/src/image2.mjs.map +1 -1
  77. package/es/components/image-viewer/index.mjs +2 -2
  78. package/es/components/image-viewer/src/image-viewer.mjs +446 -49
  79. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  80. package/es/components/image-viewer/src/image-viewer2.mjs +49 -446
  81. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  82. package/es/components/index.mjs +35 -35
  83. package/es/components/input/index.mjs +2 -2
  84. package/es/components/input/src/input.mjs +478 -106
  85. package/es/components/input/src/input.mjs.map +1 -1
  86. package/es/components/input/src/input2.mjs +106 -478
  87. package/es/components/input/src/input2.mjs.map +1 -1
  88. package/es/components/input-number/index.mjs +2 -2
  89. package/es/components/input-number/src/input-number.mjs +64 -374
  90. package/es/components/input-number/src/input-number.mjs.map +1 -1
  91. package/es/components/input-number/src/input-number2.mjs +374 -64
  92. package/es/components/input-number/src/input-number2.mjs.map +1 -1
  93. package/es/components/input-tag/index.mjs +2 -2
  94. package/es/components/input-tag/src/input-tag.mjs +65 -215
  95. package/es/components/input-tag/src/input-tag.mjs.map +1 -1
  96. package/es/components/input-tag/src/input-tag2.mjs +215 -65
  97. package/es/components/input-tag/src/input-tag2.mjs.map +1 -1
  98. package/es/components/mention/index.mjs +2 -2
  99. package/es/components/mention/src/mention.mjs +283 -63
  100. package/es/components/mention/src/mention.mjs.map +1 -1
  101. package/es/components/mention/src/mention2.mjs +63 -283
  102. package/es/components/mention/src/mention2.mjs.map +1 -1
  103. package/es/components/menu/index.mjs +4 -4
  104. package/es/components/menu/src/menu-item-group.mjs +33 -4
  105. package/es/components/menu/src/menu-item-group.mjs.map +1 -1
  106. package/es/components/menu/src/menu-item-group2.mjs +4 -33
  107. package/es/components/menu/src/menu-item-group2.mjs.map +1 -1
  108. package/es/components/menu/src/menu-item.mjs +97 -15
  109. package/es/components/menu/src/menu-item.mjs.map +1 -1
  110. package/es/components/menu/src/menu-item2.mjs +15 -97
  111. package/es/components/menu/src/menu-item2.mjs.map +1 -1
  112. package/es/components/notification/index.mjs +1 -1
  113. package/es/components/notification/src/notification.mjs +142 -68
  114. package/es/components/notification/src/notification.mjs.map +1 -1
  115. package/es/components/notification/src/notification2.mjs +68 -142
  116. package/es/components/notification/src/notification2.mjs.map +1 -1
  117. package/es/components/notification/src/notify.mjs +2 -2
  118. package/es/components/pagination/src/components/pager.mjs +16 -243
  119. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  120. package/es/components/pagination/src/components/pager2.mjs +243 -16
  121. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  122. package/es/components/pagination/src/components/prev.mjs +38 -17
  123. package/es/components/pagination/src/components/prev.mjs.map +1 -1
  124. package/es/components/pagination/src/components/prev2.mjs +17 -38
  125. package/es/components/pagination/src/components/prev2.mjs.map +1 -1
  126. package/es/components/pagination/src/components/sizes.mjs +23 -71
  127. package/es/components/pagination/src/components/sizes.mjs.map +1 -1
  128. package/es/components/pagination/src/components/sizes2.mjs +71 -23
  129. package/es/components/pagination/src/components/sizes2.mjs.map +1 -1
  130. package/es/components/pagination/src/pagination.mjs +3 -3
  131. package/es/components/popconfirm/index.mjs +2 -2
  132. package/es/components/popconfirm/src/popconfirm.mjs +114 -45
  133. package/es/components/popconfirm/src/popconfirm.mjs.map +1 -1
  134. package/es/components/popconfirm/src/popconfirm2.mjs +45 -114
  135. package/es/components/popconfirm/src/popconfirm2.mjs.map +1 -1
  136. package/es/components/popover/src/popover.mjs +3 -3
  137. package/es/components/popper/index.mjs +6 -6
  138. package/es/components/popper/src/arrow.mjs +7 -38
  139. package/es/components/popper/src/arrow.mjs.map +1 -1
  140. package/es/components/popper/src/arrow2.mjs +38 -7
  141. package/es/components/popper/src/arrow2.mjs.map +1 -1
  142. package/es/components/popper/src/content.mjs +92 -136
  143. package/es/components/popper/src/content.mjs.map +1 -1
  144. package/es/components/popper/src/content2.mjs +136 -92
  145. package/es/components/popper/src/content2.mjs.map +1 -1
  146. package/es/components/popper/src/popper.mjs +32 -22
  147. package/es/components/popper/src/popper.mjs.map +1 -1
  148. package/es/components/popper/src/popper2.mjs +22 -32
  149. package/es/components/popper/src/popper2.mjs.map +1 -1
  150. package/es/components/radio/index.mjs +2 -2
  151. package/es/components/radio/src/radio-button.mjs +1 -1
  152. package/es/components/radio/src/radio-group.mjs +1 -1
  153. package/es/components/radio/src/radio.mjs +36 -77
  154. package/es/components/radio/src/radio.mjs.map +1 -1
  155. package/es/components/radio/src/radio2.mjs +77 -36
  156. package/es/components/radio/src/radio2.mjs.map +1 -1
  157. package/es/components/scrollbar/index.mjs +3 -3
  158. package/es/components/scrollbar/src/bar2.mjs +1 -1
  159. package/es/components/scrollbar/src/scrollbar.mjs +170 -55
  160. package/es/components/scrollbar/src/scrollbar.mjs.map +1 -1
  161. package/es/components/scrollbar/src/scrollbar2.mjs +55 -170
  162. package/es/components/scrollbar/src/scrollbar2.mjs.map +1 -1
  163. package/es/components/scrollbar/src/thumb.mjs +129 -11
  164. package/es/components/scrollbar/src/thumb.mjs.map +1 -1
  165. package/es/components/scrollbar/src/thumb2.mjs +11 -129
  166. package/es/components/scrollbar/src/thumb2.mjs.map +1 -1
  167. package/es/components/segmented/index.mjs +2 -2
  168. package/es/components/segmented/src/segmented.mjs +167 -33
  169. package/es/components/segmented/src/segmented.mjs.map +1 -1
  170. package/es/components/segmented/src/segmented2.mjs +33 -167
  171. package/es/components/segmented/src/segmented2.mjs.map +1 -1
  172. package/es/components/select/src/select-dropdown.mjs +8 -3
  173. package/es/components/select/src/select-dropdown.mjs.map +1 -1
  174. package/es/components/select/src/select-dropdown.vue.d.ts +1 -0
  175. package/es/components/select/src/select2.mjs +1 -1
  176. package/es/components/select-v2/src/defaults.mjs +1 -1
  177. package/es/components/skeleton/index.mjs +2 -2
  178. package/es/components/skeleton/src/skeleton-item.mjs +22 -17
  179. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  180. package/es/components/skeleton/src/skeleton-item2.mjs +17 -22
  181. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  182. package/es/components/skeleton/src/skeleton2.mjs +1 -1
  183. package/es/components/slider/src/button.mjs +19 -91
  184. package/es/components/slider/src/button.mjs.map +1 -1
  185. package/es/components/slider/src/button2.mjs +91 -19
  186. package/es/components/slider/src/button2.mjs.map +1 -1
  187. package/es/components/slider/src/slider2.mjs +1 -1
  188. package/es/components/steps/index.mjs +2 -2
  189. package/es/components/steps/src/item.mjs +19 -260
  190. package/es/components/steps/src/item.mjs.map +1 -1
  191. package/es/components/steps/src/item2.mjs +260 -19
  192. package/es/components/steps/src/item2.mjs.map +1 -1
  193. package/es/components/teleport/index.mjs +2 -2
  194. package/es/components/teleport/src/teleport.mjs +8 -18
  195. package/es/components/teleport/src/teleport.mjs.map +1 -1
  196. package/es/components/teleport/src/teleport2.mjs +18 -8
  197. package/es/components/teleport/src/teleport2.mjs.map +1 -1
  198. package/es/components/tooltip/index.mjs +2 -2
  199. package/es/components/tooltip/src/content.mjs +28 -192
  200. package/es/components/tooltip/src/content.mjs.map +1 -1
  201. package/es/components/tooltip/src/content2.mjs +192 -28
  202. package/es/components/tooltip/src/content2.mjs.map +1 -1
  203. package/es/components/tooltip/src/tooltip.mjs +3 -3
  204. package/es/components/tooltip/src/tooltip2.mjs +4 -4
  205. package/es/components/tooltip/src/trigger.mjs +72 -14
  206. package/es/components/tooltip/src/trigger.mjs.map +1 -1
  207. package/es/components/tooltip/src/trigger2.mjs +14 -72
  208. package/es/components/tooltip/src/trigger2.mjs.map +1 -1
  209. package/es/components/tooltip-v2/index.mjs +3 -3
  210. package/es/components/tooltip-v2/src/content.mjs +1 -1
  211. package/es/components/tooltip-v2/src/tooltip.mjs +19 -77
  212. package/es/components/tooltip-v2/src/tooltip.mjs.map +1 -1
  213. package/es/components/tooltip-v2/src/tooltip2.mjs +77 -19
  214. package/es/components/tooltip-v2/src/tooltip2.mjs.map +1 -1
  215. package/es/components/tooltip-v2/src/trigger.mjs +89 -12
  216. package/es/components/tooltip-v2/src/trigger.mjs.map +1 -1
  217. package/es/components/tooltip-v2/src/trigger2.mjs +12 -89
  218. package/es/components/tooltip-v2/src/trigger2.mjs.map +1 -1
  219. package/es/components/tour/index.mjs +1 -1
  220. package/es/components/tour/src/content.mjs +67 -43
  221. package/es/components/tour/src/content.mjs.map +1 -1
  222. package/es/components/tour/src/content2.mjs +43 -67
  223. package/es/components/tour/src/content2.mjs.map +1 -1
  224. package/es/components/tour/src/mask.mjs +75 -18
  225. package/es/components/tour/src/mask.mjs.map +1 -1
  226. package/es/components/tour/src/mask2.mjs +18 -75
  227. package/es/components/tour/src/mask2.mjs.map +1 -1
  228. package/es/components/tour/src/step.mjs +1 -1
  229. package/es/components/tour/src/tour.mjs +1 -1
  230. package/es/components/tour/src/tour2.mjs +2 -2
  231. package/es/components/transfer/src/composables/use-check.mjs +1 -1
  232. package/es/components/transfer/src/transfer-panel.mjs +19 -130
  233. package/es/components/transfer/src/transfer-panel.mjs.map +1 -1
  234. package/es/components/transfer/src/transfer-panel2.mjs +130 -19
  235. package/es/components/transfer/src/transfer-panel2.mjs.map +1 -1
  236. package/es/components/transfer/src/transfer.mjs +1 -1
  237. package/es/components/visual-hidden/index.mjs +3 -3
  238. package/es/components/visual-hidden/src/visual-hidden.mjs +6 -35
  239. package/es/components/visual-hidden/src/visual-hidden.mjs.map +1 -1
  240. package/es/components/visual-hidden/src/visual-hidden2.mjs +35 -6
  241. package/es/components/visual-hidden/src/visual-hidden2.mjs.map +1 -1
  242. package/es/components/watermark/index.mjs +2 -2
  243. package/es/components/watermark/src/watermark.mjs +27 -210
  244. package/es/components/watermark/src/watermark.mjs.map +1 -1
  245. package/es/components/watermark/src/watermark2.mjs +210 -27
  246. package/es/components/watermark/src/watermark2.mjs.map +1 -1
  247. package/es/index.mjs +35 -35
  248. package/lib/components/affix/index.js +2 -2
  249. package/lib/components/affix/src/affix.js +118 -26
  250. package/lib/components/affix/src/affix.js.map +1 -1
  251. package/lib/components/affix/src/affix2.js +26 -118
  252. package/lib/components/affix/src/affix2.js.map +1 -1
  253. package/lib/components/alert/index.js +2 -2
  254. package/lib/components/alert/src/alert.js +37 -88
  255. package/lib/components/alert/src/alert.js.map +1 -1
  256. package/lib/components/alert/src/alert2.js +88 -37
  257. package/lib/components/alert/src/alert2.js.map +1 -1
  258. package/lib/components/anchor/index.js +2 -2
  259. package/lib/components/anchor/src/anchor.js +42 -191
  260. package/lib/components/anchor/src/anchor.js.map +1 -1
  261. package/lib/components/anchor/src/anchor2.js +191 -42
  262. package/lib/components/anchor/src/anchor2.js.map +1 -1
  263. package/lib/components/autocomplete/index.js +2 -2
  264. package/lib/components/autocomplete/src/autocomplete.js +366 -79
  265. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  266. package/lib/components/autocomplete/src/autocomplete2.js +79 -366
  267. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  268. package/lib/components/avatar/index.js +2 -2
  269. package/lib/components/avatar/src/avatar.js +65 -32
  270. package/lib/components/avatar/src/avatar.js.map +1 -1
  271. package/lib/components/avatar/src/avatar2.js +32 -65
  272. package/lib/components/avatar/src/avatar2.js.map +1 -1
  273. package/lib/components/calendar/src/calendar2.js +1 -1
  274. package/lib/components/calendar/src/date-table.js +89 -35
  275. package/lib/components/calendar/src/date-table.js.map +1 -1
  276. package/lib/components/calendar/src/date-table2.js +35 -89
  277. package/lib/components/calendar/src/date-table2.js.map +1 -1
  278. package/lib/components/calendar/src/use-date-table.js +1 -1
  279. package/lib/components/cascader/src/cascader.js +1 -1
  280. package/lib/components/col/index.js +2 -2
  281. package/lib/components/col/src/col.js +43 -64
  282. package/lib/components/col/src/col.js.map +1 -1
  283. package/lib/components/col/src/col2.js +64 -43
  284. package/lib/components/col/src/col2.js.map +1 -1
  285. package/lib/components/color-picker/index.js +2 -2
  286. package/lib/components/color-picker/src/color-picker.js +49 -475
  287. package/lib/components/color-picker/src/color-picker.js.map +1 -1
  288. package/lib/components/color-picker/src/color-picker2.js +475 -49
  289. package/lib/components/color-picker/src/color-picker2.js.map +1 -1
  290. package/lib/components/color-picker/src/components/predefine.js +1 -1
  291. package/lib/components/descriptions/index.js +2 -2
  292. package/lib/components/descriptions/src/description.js +26 -126
  293. package/lib/components/descriptions/src/description.js.map +1 -1
  294. package/lib/components/descriptions/src/description2.js +126 -26
  295. package/lib/components/descriptions/src/description2.js.map +1 -1
  296. package/lib/components/descriptions/src/descriptions-row.js +6 -63
  297. package/lib/components/descriptions/src/descriptions-row.js.map +1 -1
  298. package/lib/components/descriptions/src/descriptions-row2.js +63 -6
  299. package/lib/components/descriptions/src/descriptions-row2.js.map +1 -1
  300. package/lib/components/drawer/index.js +2 -2
  301. package/lib/components/drawer/src/drawer.js +178 -31
  302. package/lib/components/drawer/src/drawer.js.map +1 -1
  303. package/lib/components/drawer/src/drawer2.js +31 -178
  304. package/lib/components/drawer/src/drawer2.js.map +1 -1
  305. package/lib/components/dropdown/index.js +2 -2
  306. package/lib/components/dropdown/src/dropdown-item-impl.js +1 -1
  307. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  308. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  309. package/lib/components/dropdown/src/dropdown.js +301 -117
  310. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  311. package/lib/components/dropdown/src/dropdown2.js +117 -301
  312. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  313. package/lib/components/image/index.js +2 -2
  314. package/lib/components/image/src/image.js +221 -68
  315. package/lib/components/image/src/image.js.map +1 -1
  316. package/lib/components/image/src/image2.js +68 -221
  317. package/lib/components/image/src/image2.js.map +1 -1
  318. package/lib/components/image-viewer/index.js +2 -2
  319. package/lib/components/image-viewer/src/image-viewer.js +446 -50
  320. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  321. package/lib/components/image-viewer/src/image-viewer2.js +50 -446
  322. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  323. package/lib/components/index.js +35 -35
  324. package/lib/components/input/index.js +2 -2
  325. package/lib/components/input/src/input.js +477 -106
  326. package/lib/components/input/src/input.js.map +1 -1
  327. package/lib/components/input/src/input2.js +106 -477
  328. package/lib/components/input/src/input2.js.map +1 -1
  329. package/lib/components/input-number/index.js +2 -2
  330. package/lib/components/input-number/src/input-number.js +63 -372
  331. package/lib/components/input-number/src/input-number.js.map +1 -1
  332. package/lib/components/input-number/src/input-number2.js +372 -63
  333. package/lib/components/input-number/src/input-number2.js.map +1 -1
  334. package/lib/components/input-tag/index.js +2 -2
  335. package/lib/components/input-tag/src/input-tag.js +65 -214
  336. package/lib/components/input-tag/src/input-tag.js.map +1 -1
  337. package/lib/components/input-tag/src/input-tag2.js +214 -65
  338. package/lib/components/input-tag/src/input-tag2.js.map +1 -1
  339. package/lib/components/mention/index.js +2 -2
  340. package/lib/components/mention/src/mention.js +281 -62
  341. package/lib/components/mention/src/mention.js.map +1 -1
  342. package/lib/components/mention/src/mention2.js +62 -281
  343. package/lib/components/mention/src/mention2.js.map +1 -1
  344. package/lib/components/menu/index.js +4 -4
  345. package/lib/components/menu/src/menu-item-group.js +33 -4
  346. package/lib/components/menu/src/menu-item-group.js.map +1 -1
  347. package/lib/components/menu/src/menu-item-group2.js +4 -33
  348. package/lib/components/menu/src/menu-item-group2.js.map +1 -1
  349. package/lib/components/menu/src/menu-item.js +97 -16
  350. package/lib/components/menu/src/menu-item.js.map +1 -1
  351. package/lib/components/menu/src/menu-item2.js +16 -97
  352. package/lib/components/menu/src/menu-item2.js.map +1 -1
  353. package/lib/components/notification/index.js +1 -1
  354. package/lib/components/notification/src/notification.js +141 -69
  355. package/lib/components/notification/src/notification.js.map +1 -1
  356. package/lib/components/notification/src/notification2.js +69 -141
  357. package/lib/components/notification/src/notification2.js.map +1 -1
  358. package/lib/components/notification/src/notify.js +2 -2
  359. package/lib/components/pagination/src/components/pager.js +16 -243
  360. package/lib/components/pagination/src/components/pager.js.map +1 -1
  361. package/lib/components/pagination/src/components/pager2.js +243 -16
  362. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  363. package/lib/components/pagination/src/components/prev.js +38 -18
  364. package/lib/components/pagination/src/components/prev.js.map +1 -1
  365. package/lib/components/pagination/src/components/prev2.js +18 -38
  366. package/lib/components/pagination/src/components/prev2.js.map +1 -1
  367. package/lib/components/pagination/src/components/sizes.js +23 -71
  368. package/lib/components/pagination/src/components/sizes.js.map +1 -1
  369. package/lib/components/pagination/src/components/sizes2.js +71 -23
  370. package/lib/components/pagination/src/components/sizes2.js.map +1 -1
  371. package/lib/components/pagination/src/pagination.js +3 -3
  372. package/lib/components/popconfirm/index.js +2 -2
  373. package/lib/components/popconfirm/src/popconfirm.js +114 -46
  374. package/lib/components/popconfirm/src/popconfirm.js.map +1 -1
  375. package/lib/components/popconfirm/src/popconfirm2.js +46 -114
  376. package/lib/components/popconfirm/src/popconfirm2.js.map +1 -1
  377. package/lib/components/popover/src/popover.js +3 -3
  378. package/lib/components/popper/index.js +6 -6
  379. package/lib/components/popper/src/arrow.js +8 -38
  380. package/lib/components/popper/src/arrow.js.map +1 -1
  381. package/lib/components/popper/src/arrow2.js +38 -8
  382. package/lib/components/popper/src/arrow2.js.map +1 -1
  383. package/lib/components/popper/src/content.js +97 -136
  384. package/lib/components/popper/src/content.js.map +1 -1
  385. package/lib/components/popper/src/content2.js +136 -97
  386. package/lib/components/popper/src/content2.js.map +1 -1
  387. package/lib/components/popper/src/popper.js +32 -25
  388. package/lib/components/popper/src/popper.js.map +1 -1
  389. package/lib/components/popper/src/popper2.js +25 -32
  390. package/lib/components/popper/src/popper2.js.map +1 -1
  391. package/lib/components/radio/index.js +2 -2
  392. package/lib/components/radio/src/radio-button.js +1 -1
  393. package/lib/components/radio/src/radio-group.js +1 -1
  394. package/lib/components/radio/src/radio.js +37 -76
  395. package/lib/components/radio/src/radio.js.map +1 -1
  396. package/lib/components/radio/src/radio2.js +76 -37
  397. package/lib/components/radio/src/radio2.js.map +1 -1
  398. package/lib/components/scrollbar/index.js +3 -3
  399. package/lib/components/scrollbar/src/bar2.js +1 -1
  400. package/lib/components/scrollbar/src/scrollbar.js +170 -56
  401. package/lib/components/scrollbar/src/scrollbar.js.map +1 -1
  402. package/lib/components/scrollbar/src/scrollbar2.js +56 -170
  403. package/lib/components/scrollbar/src/scrollbar2.js.map +1 -1
  404. package/lib/components/scrollbar/src/thumb.js +129 -11
  405. package/lib/components/scrollbar/src/thumb.js.map +1 -1
  406. package/lib/components/scrollbar/src/thumb2.js +11 -129
  407. package/lib/components/scrollbar/src/thumb2.js.map +1 -1
  408. package/lib/components/segmented/index.js +2 -2
  409. package/lib/components/segmented/src/segmented.js +167 -34
  410. package/lib/components/segmented/src/segmented.js.map +1 -1
  411. package/lib/components/segmented/src/segmented2.js +34 -167
  412. package/lib/components/segmented/src/segmented2.js.map +1 -1
  413. package/lib/components/select/src/select-dropdown.js +8 -3
  414. package/lib/components/select/src/select-dropdown.js.map +1 -1
  415. package/lib/components/select/src/select-dropdown.vue.d.ts +1 -0
  416. package/lib/components/select/src/select2.js +1 -1
  417. package/lib/components/select-v2/src/defaults.js +1 -1
  418. package/lib/components/skeleton/index.js +2 -2
  419. package/lib/components/skeleton/src/skeleton-item.js +22 -17
  420. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  421. package/lib/components/skeleton/src/skeleton-item2.js +17 -22
  422. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  423. package/lib/components/skeleton/src/skeleton2.js +1 -1
  424. package/lib/components/slider/src/button.js +20 -91
  425. package/lib/components/slider/src/button.js.map +1 -1
  426. package/lib/components/slider/src/button2.js +91 -20
  427. package/lib/components/slider/src/button2.js.map +1 -1
  428. package/lib/components/slider/src/slider2.js +1 -1
  429. package/lib/components/steps/index.js +2 -2
  430. package/lib/components/steps/src/item.js +19 -260
  431. package/lib/components/steps/src/item.js.map +1 -1
  432. package/lib/components/steps/src/item2.js +260 -19
  433. package/lib/components/steps/src/item2.js.map +1 -1
  434. package/lib/components/teleport/index.js +2 -2
  435. package/lib/components/teleport/src/teleport.js +8 -18
  436. package/lib/components/teleport/src/teleport.js.map +1 -1
  437. package/lib/components/teleport/src/teleport2.js +18 -8
  438. package/lib/components/teleport/src/teleport2.js.map +1 -1
  439. package/lib/components/tooltip/index.js +2 -2
  440. package/lib/components/tooltip/src/content.js +28 -192
  441. package/lib/components/tooltip/src/content.js.map +1 -1
  442. package/lib/components/tooltip/src/content2.js +192 -28
  443. package/lib/components/tooltip/src/content2.js.map +1 -1
  444. package/lib/components/tooltip/src/tooltip.js +3 -3
  445. package/lib/components/tooltip/src/tooltip2.js +4 -4
  446. package/lib/components/tooltip/src/trigger.js +72 -14
  447. package/lib/components/tooltip/src/trigger.js.map +1 -1
  448. package/lib/components/tooltip/src/trigger2.js +14 -72
  449. package/lib/components/tooltip/src/trigger2.js.map +1 -1
  450. package/lib/components/tooltip-v2/index.js +3 -3
  451. package/lib/components/tooltip-v2/src/content.js +1 -1
  452. package/lib/components/tooltip-v2/src/tooltip.js +19 -77
  453. package/lib/components/tooltip-v2/src/tooltip.js.map +1 -1
  454. package/lib/components/tooltip-v2/src/tooltip2.js +77 -19
  455. package/lib/components/tooltip-v2/src/tooltip2.js.map +1 -1
  456. package/lib/components/tooltip-v2/src/trigger.js +89 -12
  457. package/lib/components/tooltip-v2/src/trigger.js.map +1 -1
  458. package/lib/components/tooltip-v2/src/trigger2.js +12 -89
  459. package/lib/components/tooltip-v2/src/trigger2.js.map +1 -1
  460. package/lib/components/tour/index.js +1 -1
  461. package/lib/components/tour/src/content.js +67 -46
  462. package/lib/components/tour/src/content.js.map +1 -1
  463. package/lib/components/tour/src/content2.js +46 -67
  464. package/lib/components/tour/src/content2.js.map +1 -1
  465. package/lib/components/tour/src/mask.js +75 -18
  466. package/lib/components/tour/src/mask.js.map +1 -1
  467. package/lib/components/tour/src/mask2.js +18 -75
  468. package/lib/components/tour/src/mask2.js.map +1 -1
  469. package/lib/components/tour/src/step.js +1 -1
  470. package/lib/components/tour/src/tour.js +1 -1
  471. package/lib/components/tour/src/tour2.js +2 -2
  472. package/lib/components/transfer/src/composables/use-check.js +1 -1
  473. package/lib/components/transfer/src/transfer-panel.js +21 -130
  474. package/lib/components/transfer/src/transfer-panel.js.map +1 -1
  475. package/lib/components/transfer/src/transfer-panel2.js +130 -21
  476. package/lib/components/transfer/src/transfer-panel2.js.map +1 -1
  477. package/lib/components/transfer/src/transfer.js +1 -1
  478. package/lib/components/visual-hidden/index.js +2 -2
  479. package/lib/components/visual-hidden/src/visual-hidden.js +6 -35
  480. package/lib/components/visual-hidden/src/visual-hidden.js.map +1 -1
  481. package/lib/components/visual-hidden/src/visual-hidden2.js +35 -6
  482. package/lib/components/visual-hidden/src/visual-hidden2.js.map +1 -1
  483. package/lib/components/watermark/index.js +2 -2
  484. package/lib/components/watermark/src/watermark.js +27 -210
  485. package/lib/components/watermark/src/watermark.js.map +1 -1
  486. package/lib/components/watermark/src/watermark2.js +210 -27
  487. package/lib/components/watermark/src/watermark2.js.map +1 -1
  488. package/lib/index.js +35 -35
  489. package/package.json +1 -1
  490. package/web-types.json +1 -1
@@ -1,289 +1,69 @@
1
- import { defineComponent, computed, ref, openBlock, createElementBlock, normalizeClass, unref, createVNode, mergeProps, createSlots, renderList, withCtx, renderSlot, normalizeProps, guardReactiveProps, createElementVNode, normalizeStyle, withModifiers, nextTick } from 'vue';
2
- import { pick } from 'lodash-unified';
3
- import { ElInput } from '../../input/index.mjs';
4
- import { ElTooltip } from '../../tooltip/index.mjs';
5
- import { mentionProps, mentionEmits } from './mention.mjs';
6
- import { getCursorPosition, getMentionCtx } from './helper.mjs';
7
- import ElMentionDropdown from './mention-dropdown2.mjs';
8
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
- import { inputProps } from '../../input/src/input.mjs';
10
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
11
- import { useFormDisabled } from '../../form/src/hooks/use-form-common-props.mjs';
12
- import { useId } from '../../../hooks/use-id/index.mjs';
13
- import { useFocusController } from '../../../hooks/use-focus-controller/index.mjs';
14
- import { EVENT_CODE } from '../../../constants/aria.mjs';
15
- import { isFunction } from '@vue/shared';
1
+ import { filterOption } from './helper.mjs';
2
+ import { inputProps } from '../../input/src/input2.mjs';
3
+ import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
4
+ import { isString, isFunction } from '@vue/shared';
16
5
  import { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';
17
6
 
18
- const __default__ = defineComponent({
19
- name: "ElMention",
20
- inheritAttrs: false
21
- });
22
- const _sfc_main = /* @__PURE__ */ defineComponent({
23
- ...__default__,
24
- props: mentionProps,
25
- emits: mentionEmits,
26
- setup(__props, { expose, emit }) {
27
- const props = __props;
28
- const passInputProps = computed(() => pick(props, Object.keys(inputProps)));
29
- const ns = useNamespace("mention");
30
- const disabled = useFormDisabled();
31
- const contentId = useId();
32
- const elInputRef = ref();
33
- const tooltipRef = ref();
34
- const dropdownRef = ref();
35
- const visible = ref(false);
36
- const cursorStyle = ref();
37
- const mentionCtx = ref();
38
- const computedPlacement = computed(() => props.showArrow ? props.placement : `${props.placement}-start`);
39
- const computedFallbackPlacements = computed(() => props.showArrow ? ["bottom", "top"] : ["bottom-start", "top-start"]);
40
- const filteredOptions = computed(() => {
41
- const { filterOption, options } = props;
42
- if (!mentionCtx.value || !filterOption)
43
- return options;
44
- return options.filter((option) => filterOption(mentionCtx.value.pattern, option));
45
- });
46
- const dropdownVisible = computed(() => {
47
- return visible.value && (!!filteredOptions.value.length || props.loading);
48
- });
49
- const hoveringId = computed(() => {
50
- var _a;
51
- return `${contentId.value}-${(_a = dropdownRef.value) == null ? void 0 : _a.hoveringIndex}`;
52
- });
53
- const handleInputChange = (value) => {
54
- emit("update:modelValue", value);
55
- syncAfterCursorMove();
56
- };
57
- const handleInputKeyDown = (event) => {
58
- var _a, _b, _c, _d;
59
- if (!("code" in event) || ((_a = elInputRef.value) == null ? void 0 : _a.isComposing))
60
- return;
61
- switch (event.code) {
62
- case EVENT_CODE.left:
63
- case EVENT_CODE.right:
64
- syncAfterCursorMove();
65
- break;
66
- case EVENT_CODE.up:
67
- case EVENT_CODE.down:
68
- if (!visible.value)
69
- return;
70
- event.preventDefault();
71
- (_b = dropdownRef.value) == null ? void 0 : _b.navigateOptions(event.code === EVENT_CODE.up ? "prev" : "next");
72
- break;
73
- case EVENT_CODE.enter:
74
- case EVENT_CODE.numpadEnter:
75
- if (!visible.value)
76
- return;
77
- event.preventDefault();
78
- if ((_c = dropdownRef.value) == null ? void 0 : _c.hoverOption) {
79
- (_d = dropdownRef.value) == null ? void 0 : _d.selectHoverOption();
80
- } else {
81
- visible.value = false;
82
- }
83
- break;
84
- case EVENT_CODE.esc:
85
- if (!visible.value)
86
- return;
87
- event.preventDefault();
88
- visible.value = false;
89
- break;
90
- case EVENT_CODE.backspace:
91
- if (props.whole && mentionCtx.value) {
92
- const { splitIndex, selectionEnd, pattern, prefixIndex, prefix } = mentionCtx.value;
93
- const inputEl = getInputEl();
94
- if (!inputEl)
95
- return;
96
- const inputValue = inputEl.value;
97
- const matchOption = props.options.find((item) => item.value === pattern);
98
- const isWhole = isFunction(props.checkIsWhole) ? props.checkIsWhole(pattern, prefix) : matchOption;
99
- if (isWhole && splitIndex !== -1 && splitIndex + 1 === selectionEnd) {
100
- event.preventDefault();
101
- const newValue = inputValue.slice(0, prefixIndex) + inputValue.slice(splitIndex + 1);
102
- emit(UPDATE_MODEL_EVENT, newValue);
103
- const newSelectionEnd = prefixIndex;
104
- nextTick(() => {
105
- inputEl.selectionStart = newSelectionEnd;
106
- inputEl.selectionEnd = newSelectionEnd;
107
- syncDropdownVisible();
108
- });
109
- }
110
- }
111
- }
112
- };
113
- const { wrapperRef } = useFocusController(elInputRef, {
114
- beforeFocus() {
115
- return disabled.value;
116
- },
117
- afterFocus() {
118
- syncAfterCursorMove();
119
- },
120
- beforeBlur(event) {
121
- var _a;
122
- return (_a = tooltipRef.value) == null ? void 0 : _a.isFocusInsideContent(event);
123
- },
124
- afterBlur() {
125
- visible.value = false;
126
- }
127
- });
128
- const handleInputMouseDown = () => {
129
- syncAfterCursorMove();
130
- };
131
- const handleSelect = (item) => {
132
- if (!mentionCtx.value)
133
- return;
134
- const inputEl = getInputEl();
135
- if (!inputEl)
136
- return;
137
- const inputValue = inputEl.value;
138
- const { split } = props;
139
- const newEndPart = inputValue.slice(mentionCtx.value.end);
140
- const alreadySeparated = newEndPart.startsWith(split);
141
- const newMiddlePart = `${item.value}${alreadySeparated ? "" : split}`;
142
- const newValue = inputValue.slice(0, mentionCtx.value.start) + newMiddlePart + newEndPart;
143
- emit(UPDATE_MODEL_EVENT, newValue);
144
- emit("select", item, mentionCtx.value.prefix);
145
- const newSelectionEnd = mentionCtx.value.start + newMiddlePart.length + (alreadySeparated ? 1 : 0);
146
- nextTick(() => {
147
- inputEl.selectionStart = newSelectionEnd;
148
- inputEl.selectionEnd = newSelectionEnd;
149
- inputEl.focus();
150
- syncDropdownVisible();
151
- });
152
- };
153
- const getInputEl = () => {
154
- var _a, _b;
155
- return props.type === "textarea" ? (_a = elInputRef.value) == null ? void 0 : _a.textarea : (_b = elInputRef.value) == null ? void 0 : _b.input;
156
- };
157
- const syncAfterCursorMove = () => {
158
- setTimeout(() => {
159
- syncCursor();
160
- syncDropdownVisible();
161
- nextTick(() => {
162
- var _a;
163
- return (_a = tooltipRef.value) == null ? void 0 : _a.updatePopper();
164
- });
165
- }, 0);
166
- };
167
- const syncCursor = () => {
168
- const inputEl = getInputEl();
169
- if (!inputEl)
170
- return;
171
- const caretPosition = getCursorPosition(inputEl);
172
- const inputRect = inputEl.getBoundingClientRect();
173
- const elInputRect = elInputRef.value.$el.getBoundingClientRect();
174
- cursorStyle.value = {
175
- position: "absolute",
176
- width: 0,
177
- height: `${caretPosition.height}px`,
178
- left: `${caretPosition.left + inputRect.left - elInputRect.left}px`,
179
- top: `${caretPosition.top + inputRect.top - elInputRect.top}px`
180
- };
181
- };
182
- const syncDropdownVisible = () => {
183
- const inputEl = getInputEl();
184
- if (document.activeElement !== inputEl) {
185
- visible.value = false;
186
- return;
187
- }
188
- const { prefix, split } = props;
189
- mentionCtx.value = getMentionCtx(inputEl, prefix, split);
190
- if (mentionCtx.value && mentionCtx.value.splitIndex === -1) {
191
- visible.value = true;
192
- emit("search", mentionCtx.value.pattern, mentionCtx.value.prefix);
193
- return;
194
- }
195
- visible.value = false;
196
- };
197
- expose({
198
- input: elInputRef,
199
- tooltip: tooltipRef,
200
- dropdownVisible
201
- });
202
- return (_ctx, _cache) => {
203
- return openBlock(), createElementBlock("div", {
204
- ref_key: "wrapperRef",
205
- ref: wrapperRef,
206
- class: normalizeClass([unref(ns).b(), unref(ns).is("disabled", unref(disabled))])
207
- }, [
208
- createVNode(unref(ElInput), mergeProps(mergeProps(unref(passInputProps), _ctx.$attrs), {
209
- ref_key: "elInputRef",
210
- ref: elInputRef,
211
- "model-value": _ctx.modelValue,
212
- disabled: unref(disabled),
213
- role: unref(dropdownVisible) ? "combobox" : void 0,
214
- "aria-activedescendant": unref(dropdownVisible) ? unref(hoveringId) || "" : void 0,
215
- "aria-controls": unref(dropdownVisible) ? unref(contentId) : void 0,
216
- "aria-expanded": unref(dropdownVisible) || void 0,
217
- "aria-label": _ctx.ariaLabel,
218
- "aria-autocomplete": unref(dropdownVisible) ? "none" : void 0,
219
- "aria-haspopup": unref(dropdownVisible) ? "listbox" : void 0,
220
- onInput: handleInputChange,
221
- onKeydown: handleInputKeyDown,
222
- onMousedown: handleInputMouseDown
223
- }), createSlots({
224
- _: 2
225
- }, [
226
- renderList(_ctx.$slots, (_, name) => {
227
- return {
228
- name,
229
- fn: withCtx((slotProps) => [
230
- renderSlot(_ctx.$slots, name, normalizeProps(guardReactiveProps(slotProps)))
231
- ])
232
- };
233
- })
234
- ]), 1040, ["model-value", "disabled", "role", "aria-activedescendant", "aria-controls", "aria-expanded", "aria-label", "aria-autocomplete", "aria-haspopup"]),
235
- createVNode(unref(ElTooltip), {
236
- ref_key: "tooltipRef",
237
- ref: tooltipRef,
238
- visible: unref(dropdownVisible),
239
- "popper-class": [unref(ns).e("popper"), _ctx.popperClass],
240
- "popper-options": _ctx.popperOptions,
241
- placement: unref(computedPlacement),
242
- "fallback-placements": unref(computedFallbackPlacements),
243
- effect: "light",
244
- pure: "",
245
- offset: _ctx.offset,
246
- "show-arrow": _ctx.showArrow
247
- }, {
248
- default: withCtx(() => [
249
- createElementVNode("div", {
250
- style: normalizeStyle(cursorStyle.value)
251
- }, null, 4)
252
- ]),
253
- content: withCtx(() => {
254
- var _a;
255
- return [
256
- createVNode(ElMentionDropdown, {
257
- ref_key: "dropdownRef",
258
- ref: dropdownRef,
259
- options: unref(filteredOptions),
260
- disabled: unref(disabled),
261
- loading: _ctx.loading,
262
- "content-id": unref(contentId),
263
- "aria-label": _ctx.ariaLabel,
264
- onSelect: handleSelect,
265
- onClick: withModifiers((_a = elInputRef.value) == null ? void 0 : _a.focus, ["stop"])
266
- }, createSlots({
267
- _: 2
268
- }, [
269
- renderList(_ctx.$slots, (_, name) => {
270
- return {
271
- name,
272
- fn: withCtx((slotProps) => [
273
- renderSlot(_ctx.$slots, name, normalizeProps(guardReactiveProps(slotProps)))
274
- ])
275
- };
276
- })
277
- ]), 1032, ["options", "disabled", "loading", "content-id", "aria-label", "onClick"])
278
- ];
279
- }),
280
- _: 3
281
- }, 8, ["visible", "popper-class", "popper-options", "placement", "fallback-placements", "offset", "show-arrow"])
282
- ], 2);
283
- };
7
+ const mentionProps = buildProps({
8
+ ...inputProps,
9
+ options: {
10
+ type: definePropType(Array),
11
+ default: () => []
12
+ },
13
+ prefix: {
14
+ type: definePropType([String, Array]),
15
+ default: "@",
16
+ validator: (val) => {
17
+ if (isString(val))
18
+ return val.length === 1;
19
+ return val.every((v) => isString(v) && v.length === 1);
20
+ }
21
+ },
22
+ split: {
23
+ type: String,
24
+ default: " ",
25
+ validator: (val) => val.length === 1
26
+ },
27
+ filterOption: {
28
+ type: definePropType([Boolean, Function]),
29
+ default: () => filterOption,
30
+ validator: (val) => {
31
+ if (val === false)
32
+ return true;
33
+ return isFunction(val);
34
+ }
35
+ },
36
+ placement: {
37
+ type: definePropType(String),
38
+ default: "bottom"
39
+ },
40
+ showArrow: Boolean,
41
+ offset: {
42
+ type: Number,
43
+ default: 0
44
+ },
45
+ whole: Boolean,
46
+ checkIsWhole: {
47
+ type: definePropType(Function)
48
+ },
49
+ modelValue: String,
50
+ loading: Boolean,
51
+ popperClass: {
52
+ type: String,
53
+ default: ""
54
+ },
55
+ popperOptions: {
56
+ type: definePropType(Object),
57
+ default: () => ({})
284
58
  }
285
59
  });
286
- var Mention = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "mention.vue"]]);
60
+ const mentionEmits = {
61
+ [UPDATE_MODEL_EVENT]: (value) => isString(value),
62
+ search: (pattern, prefix) => isString(pattern) && isString(prefix),
63
+ select: (option, prefix) => isString(option.value) && isString(prefix),
64
+ focus: (evt) => evt instanceof FocusEvent,
65
+ blur: (evt) => evt instanceof FocusEvent
66
+ };
287
67
 
288
- export { Mention as default };
68
+ export { mentionEmits, mentionProps };
289
69
  //# sourceMappingURL=mention2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"mention2.mjs","sources":["../../../../../../packages/components/mention/src/mention.vue"],"sourcesContent":["<template>\n <div ref=\"wrapperRef\" :class=\"[ns.b(), ns.is('disabled', disabled)]\">\n <el-input\n v-bind=\"mergeProps(passInputProps, $attrs)\"\n ref=\"elInputRef\"\n :model-value=\"modelValue\"\n :disabled=\"disabled\"\n :role=\"dropdownVisible ? 'combobox' : undefined\"\n :aria-activedescendant=\"dropdownVisible ? hoveringId || '' : undefined\"\n :aria-controls=\"dropdownVisible ? contentId : undefined\"\n :aria-expanded=\"dropdownVisible || undefined\"\n :aria-label=\"ariaLabel\"\n :aria-autocomplete=\"dropdownVisible ? 'none' : undefined\"\n :aria-haspopup=\"dropdownVisible ? 'listbox' : undefined\"\n @input=\"handleInputChange\"\n @keydown=\"handleInputKeyDown\"\n @mousedown=\"handleInputMouseDown\"\n >\n <template v-for=\"(_, name) in $slots\" #[name]=\"slotProps\">\n <slot :name=\"name\" v-bind=\"slotProps\" />\n </template>\n </el-input>\n <el-tooltip\n ref=\"tooltipRef\"\n :visible=\"dropdownVisible\"\n :popper-class=\"[ns.e('popper'), popperClass]\"\n :popper-options=\"popperOptions\"\n :placement=\"computedPlacement\"\n :fallback-placements=\"computedFallbackPlacements\"\n effect=\"light\"\n pure\n :offset=\"offset\"\n :show-arrow=\"showArrow\"\n >\n <template #default>\n <div :style=\"cursorStyle\" />\n </template>\n <template #content>\n <el-mention-dropdown\n ref=\"dropdownRef\"\n :options=\"filteredOptions\"\n :disabled=\"disabled\"\n :loading=\"loading\"\n :content-id=\"contentId\"\n :aria-label=\"ariaLabel\"\n @select=\"handleSelect\"\n @click.stop=\"elInputRef?.focus\"\n >\n <template v-for=\"(_, name) in $slots\" #[name]=\"slotProps\">\n <slot :name=\"name\" v-bind=\"slotProps\" />\n </template>\n </el-mention-dropdown>\n </template>\n </el-tooltip>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, mergeProps, nextTick, ref } from 'vue'\nimport { pick } from 'lodash-unified'\nimport { useFocusController, useId, useNamespace } from '@element-plus/hooks'\nimport ElInput, { inputProps } from '@element-plus/components/input'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport { EVENT_CODE, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { isFunction } from '@element-plus/utils'\nimport { mentionEmits, mentionProps } from './mention'\nimport { getCursorPosition, getMentionCtx } from './helper'\nimport ElMentionDropdown from './mention-dropdown.vue'\n\nimport type { Placement } from '@popperjs/core'\nimport type { CSSProperties, ComputedRef, Ref } from 'vue'\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { MentionCtx, MentionOption } from './types'\n\ndefineOptions({\n name: 'ElMention',\n inheritAttrs: false,\n})\n\nconst props = defineProps(mentionProps)\nconst emit = defineEmits(mentionEmits)\n\nconst passInputProps = computed(() => pick(props, Object.keys(inputProps)))\n\nconst ns = useNamespace('mention')\nconst disabled = useFormDisabled()\nconst contentId = useId()\n\nconst elInputRef = ref<InputInstance>()\nconst tooltipRef = ref<TooltipInstance>()\nconst dropdownRef = ref<InstanceType<typeof ElMentionDropdown>>()\n\nconst visible = ref(false)\nconst cursorStyle = ref<CSSProperties>()\nconst mentionCtx = ref<MentionCtx>()\n\nconst computedPlacement = computed<Placement>(() =>\n props.showArrow ? props.placement : `${props.placement}-start`\n)\n\nconst computedFallbackPlacements = computed<Placement[]>(() =>\n props.showArrow ? ['bottom', 'top'] : ['bottom-start', 'top-start']\n)\n\nconst filteredOptions = computed(() => {\n const { filterOption, options } = props\n if (!mentionCtx.value || !filterOption) return options\n return options.filter((option) =>\n filterOption(mentionCtx.value!.pattern, option)\n )\n})\n\nconst dropdownVisible = computed(() => {\n return visible.value && (!!filteredOptions.value.length || props.loading)\n})\n\nconst hoveringId = computed(() => {\n return `${contentId.value}-${dropdownRef.value?.hoveringIndex}`\n})\n\nconst handleInputChange = (value: string) => {\n emit('update:modelValue', value)\n syncAfterCursorMove()\n}\n\nconst handleInputKeyDown = (event: KeyboardEvent | Event) => {\n if (!('code' in event) || elInputRef.value?.isComposing) return\n\n switch (event.code) {\n case EVENT_CODE.left:\n case EVENT_CODE.right:\n syncAfterCursorMove()\n break\n case EVENT_CODE.up:\n case EVENT_CODE.down:\n if (!visible.value) return\n event.preventDefault()\n dropdownRef.value?.navigateOptions(\n event.code === EVENT_CODE.up ? 'prev' : 'next'\n )\n break\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n if (!visible.value) return\n event.preventDefault()\n if (dropdownRef.value?.hoverOption) {\n dropdownRef.value?.selectHoverOption()\n } else {\n visible.value = false\n }\n break\n case EVENT_CODE.esc:\n if (!visible.value) return\n event.preventDefault()\n visible.value = false\n break\n case EVENT_CODE.backspace:\n if (props.whole && mentionCtx.value) {\n const { splitIndex, selectionEnd, pattern, prefixIndex, prefix } =\n mentionCtx.value\n const inputEl = getInputEl()\n if (!inputEl) return\n const inputValue = inputEl.value\n const matchOption = props.options.find((item) => item.value === pattern)\n const isWhole = isFunction(props.checkIsWhole)\n ? props.checkIsWhole(pattern, prefix)\n : matchOption\n if (isWhole && splitIndex !== -1 && splitIndex + 1 === selectionEnd) {\n event.preventDefault()\n const newValue =\n inputValue.slice(0, prefixIndex) + inputValue.slice(splitIndex + 1)\n emit(UPDATE_MODEL_EVENT, newValue)\n\n const newSelectionEnd = prefixIndex\n nextTick(() => {\n // input value is updated\n inputEl.selectionStart = newSelectionEnd\n inputEl.selectionEnd = newSelectionEnd\n syncDropdownVisible()\n })\n }\n }\n }\n}\n\nconst { wrapperRef } = useFocusController(elInputRef, {\n beforeFocus() {\n return disabled.value\n },\n afterFocus() {\n syncAfterCursorMove()\n },\n beforeBlur(event) {\n return tooltipRef.value?.isFocusInsideContent(event)\n },\n afterBlur() {\n visible.value = false\n },\n})\n\nconst handleInputMouseDown = () => {\n syncAfterCursorMove()\n}\n\nconst handleSelect = (item: MentionOption) => {\n if (!mentionCtx.value) return\n const inputEl = getInputEl()\n if (!inputEl) return\n const inputValue = inputEl.value\n const { split } = props\n\n const newEndPart = inputValue.slice(mentionCtx.value.end)\n const alreadySeparated = newEndPart.startsWith(split)\n const newMiddlePart = `${item.value}${alreadySeparated ? '' : split}`\n\n const newValue =\n inputValue.slice(0, mentionCtx.value.start) + newMiddlePart + newEndPart\n\n emit(UPDATE_MODEL_EVENT, newValue)\n emit('select', item, mentionCtx.value.prefix)\n\n const newSelectionEnd =\n mentionCtx.value.start + newMiddlePart.length + (alreadySeparated ? 1 : 0)\n\n nextTick(() => {\n // input value is updated\n inputEl.selectionStart = newSelectionEnd\n inputEl.selectionEnd = newSelectionEnd\n inputEl.focus()\n syncDropdownVisible()\n })\n}\n\nconst getInputEl = () =>\n props.type === 'textarea'\n ? elInputRef.value?.textarea\n : elInputRef.value?.input\n\nconst syncAfterCursorMove = () => {\n // can't use nextTick(), get cursor position will be wrong\n setTimeout(() => {\n syncCursor()\n syncDropdownVisible()\n nextTick(() => tooltipRef.value?.updatePopper())\n }, 0)\n}\n\nconst syncCursor = () => {\n const inputEl = getInputEl()\n if (!inputEl) return\n\n const caretPosition = getCursorPosition(inputEl)\n const inputRect = inputEl.getBoundingClientRect()\n const elInputRect = elInputRef.value!.$el.getBoundingClientRect()\n\n cursorStyle.value = {\n position: 'absolute',\n width: 0,\n height: `${caretPosition.height}px`,\n left: `${caretPosition.left + inputRect.left - elInputRect.left}px`,\n top: `${caretPosition.top + inputRect.top - elInputRect.top}px`,\n }\n}\n\nconst syncDropdownVisible = () => {\n const inputEl = getInputEl()\n if (document.activeElement !== inputEl) {\n visible.value = false\n return\n }\n const { prefix, split } = props\n mentionCtx.value = getMentionCtx(inputEl, prefix, split)\n if (mentionCtx.value && mentionCtx.value.splitIndex === -1) {\n visible.value = true\n emit('search', mentionCtx.value.pattern, mentionCtx.value.prefix)\n return\n }\n visible.value = false\n}\n\ndefineExpose<{\n input: Ref<InputInstance | undefined>\n tooltip: Ref<TooltipInstance | undefined>\n dropdownVisible: ComputedRef<boolean>\n}>({\n input: elInputRef,\n tooltip: tooltipRef,\n dropdownVisible,\n})\n</script>\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"mention2.mjs","sources":["../../../../../../packages/components/mention/src/mention.ts"],"sourcesContent":["import {\n buildProps,\n definePropType,\n isFunction,\n isString,\n} from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { inputProps } from '@element-plus/components/input'\nimport { filterOption } from './helper'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Mention from './mention.vue'\nimport type { MentionOption } from './types'\nimport type { Options } from '@element-plus/components/popper'\n\nexport const mentionProps = buildProps({\n ...inputProps,\n /**\n * @description mention options list\n */\n options: {\n type: definePropType<MentionOption[]>(Array),\n default: () => [],\n },\n /**\n * @description prefix character to trigger mentions. The string length must be exactly 1.\n */\n prefix: {\n type: definePropType<string | string[]>([String, Array]),\n default: '@',\n validator: (val: string | string[]) => {\n if (isString(val)) return val.length === 1\n return val.every((v) => isString(v) && v.length === 1)\n },\n },\n /**\n * @description character to split mentions. The string length must be exactly 1.\n */\n split: {\n type: String,\n default: ' ',\n validator: (val: string) => val.length === 1,\n },\n /**\n * @description customize filter option logic.\n */\n filterOption: {\n type: definePropType<false | typeof filterOption>([Boolean, Function]),\n default: () => filterOption,\n validator: (val) => {\n if (val === false) return true\n return isFunction(val)\n },\n },\n /**\n * @description set popup placement\n */\n placement: {\n type: definePropType<'bottom' | 'top'>(String),\n default: 'bottom',\n },\n /**\n * @description whether the dropdown panel has an arrow\n */\n showArrow: Boolean,\n /**\n * @description offset of the dropdown panel\n */\n offset: {\n type: Number,\n default: 0,\n },\n /**\n * @description when backspace is pressed to delete, whether the mention content is deleted as a whole\n */\n whole: Boolean,\n /**\n * @description when backspace is pressed to delete, check if the mention is a whole\n */\n checkIsWhole: {\n type: definePropType<(pattern: string, prefix: string) => boolean>(\n Function\n ),\n },\n /**\n * @description input value\n */\n modelValue: String,\n /**\n * @description whether the dropdown panel of mentions is in a loading state.\n */\n loading: Boolean,\n /**\n * @description custom class name for dropdown panel\n */\n popperClass: {\n type: String,\n default: '',\n },\n /**\n * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n */\n popperOptions: {\n type: definePropType<Partial<Options>>(Object),\n default: () => ({} as Partial<Options>),\n },\n})\n\nexport const mentionEmits = {\n [UPDATE_MODEL_EVENT]: (value: string) => isString(value),\n search: (pattern: string, prefix: string) =>\n isString(pattern) && isString(prefix),\n select: (option: MentionOption, prefix: string) =>\n isString(option.value) && isString(prefix),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n}\n\nexport type MentionEmits = typeof mentionEmits\nexport type MentionProps = ExtractPropTypes<typeof mentionProps>\nexport type MentionInstance = InstanceType<typeof Mention>\n\nexport type { MentionOption } from './types'\n"],"names":[],"mappings":";;;;;;AASY,MAAC,YAAY,GAAG,UAAU,CAAC;AACvC,EAAE,GAAG,UAAU;AACf,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACzC,IAAI,OAAO,EAAE,GAAG;AAChB,IAAI,SAAS,EAAE,CAAC,GAAG,KAAK;AACxB,MAAM,IAAI,QAAQ,CAAC,GAAG,CAAC;AACvB,QAAQ,OAAO,GAAG,CAAC,MAAM,KAAK,CAAC,CAAC;AAChC,MAAM,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;AAC7D,KAAK;AACL,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,IAAI,SAAS,EAAE,CAAC,GAAG,KAAK,GAAG,CAAC,MAAM,KAAK,CAAC;AACxC,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;AAC7C,IAAI,OAAO,EAAE,MAAM,YAAY;AAC/B,IAAI,SAAS,EAAE,CAAC,GAAG,KAAK;AACxB,MAAM,IAAI,GAAG,KAAK,KAAK;AACvB,QAAQ,OAAO,IAAI,CAAC;AACpB,MAAM,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC;AAC7B,KAAK;AACL,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,IAAI,OAAO,EAAE,QAAQ;AACrB,GAAG;AACH,EAAE,SAAS,EAAE,OAAO;AACpB,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,KAAK,EAAE,OAAO;AAChB,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,cAAc,CAAC,QAAQ,CAAC;AAClC,GAAG;AACH,EAAE,UAAU,EAAE,MAAM;AACpB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,IAAI,OAAO,EAAE,OAAO,EAAE,CAAC;AACvB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,YAAY,GAAG;AAC5B,EAAE,CAAC,kBAAkB,GAAG,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,QAAQ,CAAC,OAAO,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC;AACpE,EAAE,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC;AACxE,EAAE,KAAK,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC3C,EAAE,IAAI,EAAE,CAAC,GAAG,KAAK,GAAG,YAAY,UAAU;AAC1C;;;;"}
@@ -1,11 +1,11 @@
1
1
  import Menu from './src/menu.mjs';
2
2
  export { menuEmits, menuProps } from './src/menu.mjs';
3
- import MenuItem from './src/menu-item2.mjs';
4
- import MenuItemGroup from './src/menu-item-group2.mjs';
3
+ import MenuItem from './src/menu-item.mjs';
4
+ import MenuItemGroup from './src/menu-item-group.mjs';
5
5
  import SubMenu from './src/sub-menu.mjs';
6
6
  export { subMenuProps } from './src/sub-menu.mjs';
7
- export { menuItemEmits, menuItemProps } from './src/menu-item.mjs';
8
- export { menuItemGroupProps } from './src/menu-item-group.mjs';
7
+ export { menuItemEmits, menuItemProps } from './src/menu-item2.mjs';
8
+ export { menuItemGroupProps } from './src/menu-item-group2.mjs';
9
9
  import { withInstall, withNoopInstall } from '../../utils/vue/install.mjs';
10
10
 
11
11
  const ElMenu = withInstall(Menu, {
@@ -1,6 +1,35 @@
1
- const menuItemGroupProps = {
2
- title: String
3
- };
1
+ import { defineComponent, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, Fragment, createTextVNode, toDisplayString, renderSlot } from 'vue';
2
+ import { menuItemGroupProps } from './menu-item-group2.mjs';
3
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
4
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
4
5
 
5
- export { menuItemGroupProps };
6
+ const __default__ = defineComponent({
7
+ name: "ElMenuItemGroup"
8
+ });
9
+ const _sfc_main = /* @__PURE__ */ defineComponent({
10
+ ...__default__,
11
+ props: menuItemGroupProps,
12
+ setup(__props) {
13
+ const ns = useNamespace("menu-item-group");
14
+ return (_ctx, _cache) => {
15
+ return openBlock(), createElementBlock("li", {
16
+ class: normalizeClass(unref(ns).b())
17
+ }, [
18
+ createElementVNode("div", {
19
+ class: normalizeClass(unref(ns).e("title"))
20
+ }, [
21
+ !_ctx.$slots.title ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
22
+ createTextVNode(toDisplayString(_ctx.title), 1)
23
+ ], 64)) : renderSlot(_ctx.$slots, "title", { key: 1 })
24
+ ], 2),
25
+ createElementVNode("ul", null, [
26
+ renderSlot(_ctx.$slots, "default")
27
+ ])
28
+ ], 2);
29
+ };
30
+ }
31
+ });
32
+ var MenuItemGroup = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "menu-item-group.vue"]]);
33
+
34
+ export { MenuItemGroup as default };
6
35
  //# sourceMappingURL=menu-item-group.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"menu-item-group.mjs","sources":["../../../../../../packages/components/menu/src/menu-item-group.ts"],"sourcesContent":["import type { ExtractPropTypes } from 'vue'\n\nexport const menuItemGroupProps = {\n /**\n * @description group title\n */\n title: String,\n} as const\nexport type MenuItemGroupProps = ExtractPropTypes<typeof menuItemGroupProps>\n"],"names":[],"mappings":"AAAY,MAAC,kBAAkB,GAAG;AAClC,EAAE,KAAK,EAAE,MAAM;AACf;;;;"}
1
+ {"version":3,"file":"menu-item-group.mjs","sources":["../../../../../../packages/components/menu/src/menu-item-group.vue"],"sourcesContent":["<template>\n <li :class=\"ns.b()\">\n <div :class=\"ns.e('title')\">\n <template v-if=\"!$slots.title\">{{ title }}</template>\n <slot v-else name=\"title\" />\n </div>\n <ul>\n <slot />\n </ul>\n </li>\n</template>\n\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-plus/hooks'\nimport { menuItemGroupProps } from './menu-item-group'\n\ndefineOptions({\n name: 'ElMenuItemGroup',\n})\ndefineProps(menuItemGroupProps)\nconst ns = useNamespace('menu-item-group')\n</script>\n"],"names":[],"mappings":";;;;;mCAgBc,CAAA;AAAA,EACZ,IAAM,EAAA,iBAAA;AACR,CAAA,CAAA,CAAA;;;;;AAEA,IAAM,MAAA,EAAA,GAAK,aAAa,iBAAiB,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,35 +1,6 @@
1
- import { defineComponent, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, Fragment, createTextVNode, toDisplayString, renderSlot } from 'vue';
2
- import { menuItemGroupProps } from './menu-item-group.mjs';
3
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
4
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
1
+ const menuItemGroupProps = {
2
+ title: String
3
+ };
5
4
 
6
- const __default__ = defineComponent({
7
- name: "ElMenuItemGroup"
8
- });
9
- const _sfc_main = /* @__PURE__ */ defineComponent({
10
- ...__default__,
11
- props: menuItemGroupProps,
12
- setup(__props) {
13
- const ns = useNamespace("menu-item-group");
14
- return (_ctx, _cache) => {
15
- return openBlock(), createElementBlock("li", {
16
- class: normalizeClass(unref(ns).b())
17
- }, [
18
- createElementVNode("div", {
19
- class: normalizeClass(unref(ns).e("title"))
20
- }, [
21
- !_ctx.$slots.title ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
22
- createTextVNode(toDisplayString(_ctx.title), 1)
23
- ], 64)) : renderSlot(_ctx.$slots, "title", { key: 1 })
24
- ], 2),
25
- createElementVNode("ul", null, [
26
- renderSlot(_ctx.$slots, "default")
27
- ])
28
- ], 2);
29
- };
30
- }
31
- });
32
- var MenuItemGroup = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "menu-item-group.vue"]]);
33
-
34
- export { MenuItemGroup as default };
5
+ export { menuItemGroupProps };
35
6
  //# sourceMappingURL=menu-item-group2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"menu-item-group2.mjs","sources":["../../../../../../packages/components/menu/src/menu-item-group.vue"],"sourcesContent":["<template>\n <li :class=\"ns.b()\">\n <div :class=\"ns.e('title')\">\n <template v-if=\"!$slots.title\">{{ title }}</template>\n <slot v-else name=\"title\" />\n </div>\n <ul>\n <slot />\n </ul>\n </li>\n</template>\n\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-plus/hooks'\nimport { menuItemGroupProps } from './menu-item-group'\n\ndefineOptions({\n name: 'ElMenuItemGroup',\n})\ndefineProps(menuItemGroupProps)\nconst ns = useNamespace('menu-item-group')\n</script>\n"],"names":[],"mappings":";;;;;mCAgBc,CAAA;AAAA,EACZ,IAAM,EAAA,iBAAA;AACR,CAAA,CAAA,CAAA;;;;;AAEA,IAAM,MAAA,EAAA,GAAK,aAAa,iBAAiB,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"menu-item-group2.mjs","sources":["../../../../../../packages/components/menu/src/menu-item-group.ts"],"sourcesContent":["import type { ExtractPropTypes } from 'vue'\n\nexport const menuItemGroupProps = {\n /**\n * @description group title\n */\n title: String,\n} as const\nexport type MenuItemGroupProps = ExtractPropTypes<typeof menuItemGroupProps>\n"],"names":[],"mappings":"AAAY,MAAC,kBAAkB,GAAG;AAClC,EAAE,KAAK,EAAE,MAAM;AACf;;;;"}
@@ -1,19 +1,101 @@
1
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
2
- import { isString, isArray } from '@vue/shared';
1
+ import { defineComponent, getCurrentInstance, inject, toRef, computed, reactive, onMounted, onBeforeUnmount, openBlock, createElementBlock, normalizeClass, unref, createBlock, withCtx, renderSlot, createElementVNode, Fragment } from 'vue';
2
+ import { ElTooltip } from '../../tooltip/index.mjs';
3
+ import useMenu from './use-menu.mjs';
4
+ import { menuItemProps, menuItemEmits } from './menu-item2.mjs';
5
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
6
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
7
+ import { throwError } from '../../../utils/error.mjs';
3
8
 
4
- const menuItemProps = buildProps({
5
- index: {
6
- type: definePropType([String, null]),
7
- default: null
8
- },
9
- route: {
10
- type: definePropType([String, Object])
11
- },
12
- disabled: Boolean
9
+ const COMPONENT_NAME = "ElMenuItem";
10
+ const __default__ = defineComponent({
11
+ name: COMPONENT_NAME
13
12
  });
14
- const menuItemEmits = {
15
- click: (item) => isString(item.index) && isArray(item.indexPath)
16
- };
13
+ const _sfc_main = /* @__PURE__ */ defineComponent({
14
+ ...__default__,
15
+ props: menuItemProps,
16
+ emits: menuItemEmits,
17
+ setup(__props, { expose, emit }) {
18
+ const props = __props;
19
+ const instance = getCurrentInstance();
20
+ const rootMenu = inject("rootMenu");
21
+ const nsMenu = useNamespace("menu");
22
+ const nsMenuItem = useNamespace("menu-item");
23
+ if (!rootMenu)
24
+ throwError(COMPONENT_NAME, "can not inject root menu");
25
+ const { parentMenu, indexPath } = useMenu(instance, toRef(props, "index"));
26
+ const subMenu = inject(`subMenu:${parentMenu.value.uid}`);
27
+ if (!subMenu)
28
+ throwError(COMPONENT_NAME, "can not inject sub menu");
29
+ const active = computed(() => props.index === rootMenu.activeIndex);
30
+ const item = reactive({
31
+ index: props.index,
32
+ indexPath,
33
+ active
34
+ });
35
+ const handleClick = () => {
36
+ if (!props.disabled) {
37
+ rootMenu.handleMenuItemClick({
38
+ index: props.index,
39
+ indexPath: indexPath.value,
40
+ route: props.route
41
+ });
42
+ emit("click", item);
43
+ }
44
+ };
45
+ onMounted(() => {
46
+ subMenu.addSubMenu(item);
47
+ rootMenu.addMenuItem(item);
48
+ });
49
+ onBeforeUnmount(() => {
50
+ subMenu.removeSubMenu(item);
51
+ rootMenu.removeMenuItem(item);
52
+ });
53
+ expose({
54
+ parentMenu,
55
+ rootMenu,
56
+ active,
57
+ nsMenu,
58
+ nsMenuItem,
59
+ handleClick
60
+ });
61
+ return (_ctx, _cache) => {
62
+ return openBlock(), createElementBlock("li", {
63
+ class: normalizeClass([
64
+ unref(nsMenuItem).b(),
65
+ unref(nsMenuItem).is("active", unref(active)),
66
+ unref(nsMenuItem).is("disabled", _ctx.disabled)
67
+ ]),
68
+ role: "menuitem",
69
+ tabindex: "-1",
70
+ onClick: handleClick
71
+ }, [
72
+ unref(parentMenu).type.name === "ElMenu" && unref(rootMenu).props.collapse && _ctx.$slots.title ? (openBlock(), createBlock(unref(ElTooltip), {
73
+ key: 0,
74
+ effect: unref(rootMenu).props.popperEffect,
75
+ placement: "right",
76
+ "fallback-placements": ["left"],
77
+ persistent: unref(rootMenu).props.persistent
78
+ }, {
79
+ content: withCtx(() => [
80
+ renderSlot(_ctx.$slots, "title")
81
+ ]),
82
+ default: withCtx(() => [
83
+ createElementVNode("div", {
84
+ class: normalizeClass(unref(nsMenu).be("tooltip", "trigger"))
85
+ }, [
86
+ renderSlot(_ctx.$slots, "default")
87
+ ], 2)
88
+ ]),
89
+ _: 3
90
+ }, 8, ["effect", "persistent"])) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
91
+ renderSlot(_ctx.$slots, "default"),
92
+ renderSlot(_ctx.$slots, "title")
93
+ ], 64))
94
+ ], 2);
95
+ };
96
+ }
97
+ });
98
+ var MenuItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "menu-item.vue"]]);
17
99
 
18
- export { menuItemEmits, menuItemProps };
100
+ export { MenuItem as default };
19
101
  //# sourceMappingURL=menu-item.mjs.map