@element-plus/nightly 0.0.20240930 → 0.0.20241001

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 (535) hide show
  1. package/attributes.json +1 -1
  2. package/dist/index.full.js +2 -2
  3. package/dist/index.full.min.js +2 -2
  4. package/dist/index.full.min.js.map +1 -1
  5. package/dist/index.full.min.mjs +2 -2
  6. package/dist/index.full.min.mjs.map +1 -1
  7. package/dist/index.full.mjs +2 -2
  8. package/dist/locale/af.js +1 -1
  9. package/dist/locale/af.min.js +1 -1
  10. package/dist/locale/af.min.mjs +1 -1
  11. package/dist/locale/af.mjs +1 -1
  12. package/dist/locale/ar-eg.js +1 -1
  13. package/dist/locale/ar-eg.min.js +1 -1
  14. package/dist/locale/ar-eg.min.mjs +1 -1
  15. package/dist/locale/ar-eg.mjs +1 -1
  16. package/dist/locale/ar.js +1 -1
  17. package/dist/locale/ar.min.js +1 -1
  18. package/dist/locale/ar.min.mjs +1 -1
  19. package/dist/locale/ar.mjs +1 -1
  20. package/dist/locale/az.js +1 -1
  21. package/dist/locale/az.min.js +1 -1
  22. package/dist/locale/az.min.mjs +1 -1
  23. package/dist/locale/az.mjs +1 -1
  24. package/dist/locale/bg.js +1 -1
  25. package/dist/locale/bg.min.js +1 -1
  26. package/dist/locale/bg.min.mjs +1 -1
  27. package/dist/locale/bg.mjs +1 -1
  28. package/dist/locale/bn.js +1 -1
  29. package/dist/locale/bn.min.js +1 -1
  30. package/dist/locale/bn.min.mjs +1 -1
  31. package/dist/locale/bn.mjs +1 -1
  32. package/dist/locale/ca.js +1 -1
  33. package/dist/locale/ca.min.js +1 -1
  34. package/dist/locale/ca.min.mjs +1 -1
  35. package/dist/locale/ca.mjs +1 -1
  36. package/dist/locale/ckb.js +1 -1
  37. package/dist/locale/ckb.min.js +1 -1
  38. package/dist/locale/ckb.min.mjs +1 -1
  39. package/dist/locale/ckb.mjs +1 -1
  40. package/dist/locale/cs.js +1 -1
  41. package/dist/locale/cs.min.js +1 -1
  42. package/dist/locale/cs.min.mjs +1 -1
  43. package/dist/locale/cs.mjs +1 -1
  44. package/dist/locale/da.js +1 -1
  45. package/dist/locale/da.min.js +1 -1
  46. package/dist/locale/da.min.mjs +1 -1
  47. package/dist/locale/da.mjs +1 -1
  48. package/dist/locale/de.js +1 -1
  49. package/dist/locale/de.min.js +1 -1
  50. package/dist/locale/de.min.mjs +1 -1
  51. package/dist/locale/de.mjs +1 -1
  52. package/dist/locale/el.js +1 -1
  53. package/dist/locale/el.min.js +1 -1
  54. package/dist/locale/el.min.mjs +1 -1
  55. package/dist/locale/el.mjs +1 -1
  56. package/dist/locale/en.js +1 -1
  57. package/dist/locale/en.min.js +1 -1
  58. package/dist/locale/en.min.mjs +1 -1
  59. package/dist/locale/en.mjs +1 -1
  60. package/dist/locale/eo.js +1 -1
  61. package/dist/locale/eo.min.js +1 -1
  62. package/dist/locale/eo.min.mjs +1 -1
  63. package/dist/locale/eo.mjs +1 -1
  64. package/dist/locale/es.js +1 -1
  65. package/dist/locale/es.min.js +1 -1
  66. package/dist/locale/es.min.mjs +1 -1
  67. package/dist/locale/es.mjs +1 -1
  68. package/dist/locale/et.js +1 -1
  69. package/dist/locale/et.min.js +1 -1
  70. package/dist/locale/et.min.mjs +1 -1
  71. package/dist/locale/et.mjs +1 -1
  72. package/dist/locale/eu.js +1 -1
  73. package/dist/locale/eu.min.js +1 -1
  74. package/dist/locale/eu.min.mjs +1 -1
  75. package/dist/locale/eu.mjs +1 -1
  76. package/dist/locale/fa.js +1 -1
  77. package/dist/locale/fa.min.js +1 -1
  78. package/dist/locale/fa.min.mjs +1 -1
  79. package/dist/locale/fa.mjs +1 -1
  80. package/dist/locale/fi.js +1 -1
  81. package/dist/locale/fi.min.js +1 -1
  82. package/dist/locale/fi.min.mjs +1 -1
  83. package/dist/locale/fi.mjs +1 -1
  84. package/dist/locale/fr.js +1 -1
  85. package/dist/locale/fr.min.js +1 -1
  86. package/dist/locale/fr.min.mjs +1 -1
  87. package/dist/locale/fr.mjs +1 -1
  88. package/dist/locale/he.js +1 -1
  89. package/dist/locale/he.min.js +1 -1
  90. package/dist/locale/he.min.mjs +1 -1
  91. package/dist/locale/he.mjs +1 -1
  92. package/dist/locale/hr.js +1 -1
  93. package/dist/locale/hr.min.js +1 -1
  94. package/dist/locale/hr.min.mjs +1 -1
  95. package/dist/locale/hr.mjs +1 -1
  96. package/dist/locale/hu.js +1 -1
  97. package/dist/locale/hu.min.js +1 -1
  98. package/dist/locale/hu.min.mjs +1 -1
  99. package/dist/locale/hu.mjs +1 -1
  100. package/dist/locale/hy-am.js +1 -1
  101. package/dist/locale/hy-am.min.js +1 -1
  102. package/dist/locale/hy-am.min.mjs +1 -1
  103. package/dist/locale/hy-am.mjs +1 -1
  104. package/dist/locale/id.js +1 -1
  105. package/dist/locale/id.min.js +1 -1
  106. package/dist/locale/id.min.mjs +1 -1
  107. package/dist/locale/id.mjs +1 -1
  108. package/dist/locale/it.js +1 -1
  109. package/dist/locale/it.min.js +1 -1
  110. package/dist/locale/it.min.mjs +1 -1
  111. package/dist/locale/it.mjs +1 -1
  112. package/dist/locale/ja.js +1 -1
  113. package/dist/locale/ja.min.js +1 -1
  114. package/dist/locale/ja.min.mjs +1 -1
  115. package/dist/locale/ja.mjs +1 -1
  116. package/dist/locale/kk.js +1 -1
  117. package/dist/locale/kk.min.js +1 -1
  118. package/dist/locale/kk.min.mjs +1 -1
  119. package/dist/locale/kk.mjs +1 -1
  120. package/dist/locale/km.js +1 -1
  121. package/dist/locale/km.min.js +1 -1
  122. package/dist/locale/km.min.mjs +1 -1
  123. package/dist/locale/km.mjs +1 -1
  124. package/dist/locale/ko.js +1 -1
  125. package/dist/locale/ko.min.js +1 -1
  126. package/dist/locale/ko.min.mjs +1 -1
  127. package/dist/locale/ko.mjs +1 -1
  128. package/dist/locale/ku.js +1 -1
  129. package/dist/locale/ku.min.js +1 -1
  130. package/dist/locale/ku.min.mjs +1 -1
  131. package/dist/locale/ku.mjs +1 -1
  132. package/dist/locale/ky.js +1 -1
  133. package/dist/locale/ky.min.js +1 -1
  134. package/dist/locale/ky.min.mjs +1 -1
  135. package/dist/locale/ky.mjs +1 -1
  136. package/dist/locale/lt.js +1 -1
  137. package/dist/locale/lt.min.js +1 -1
  138. package/dist/locale/lt.min.mjs +1 -1
  139. package/dist/locale/lt.mjs +1 -1
  140. package/dist/locale/lv.js +1 -1
  141. package/dist/locale/lv.min.js +1 -1
  142. package/dist/locale/lv.min.mjs +1 -1
  143. package/dist/locale/lv.mjs +1 -1
  144. package/dist/locale/mg.js +1 -1
  145. package/dist/locale/mg.min.js +1 -1
  146. package/dist/locale/mg.min.mjs +1 -1
  147. package/dist/locale/mg.mjs +1 -1
  148. package/dist/locale/mn.js +1 -1
  149. package/dist/locale/mn.min.js +1 -1
  150. package/dist/locale/mn.min.mjs +1 -1
  151. package/dist/locale/mn.mjs +1 -1
  152. package/dist/locale/my.js +1 -1
  153. package/dist/locale/my.min.js +1 -1
  154. package/dist/locale/my.min.mjs +1 -1
  155. package/dist/locale/my.mjs +1 -1
  156. package/dist/locale/nb-no.js +1 -1
  157. package/dist/locale/nb-no.min.js +1 -1
  158. package/dist/locale/nb-no.min.mjs +1 -1
  159. package/dist/locale/nb-no.mjs +1 -1
  160. package/dist/locale/nl.js +1 -1
  161. package/dist/locale/nl.min.js +1 -1
  162. package/dist/locale/nl.min.mjs +1 -1
  163. package/dist/locale/nl.mjs +1 -1
  164. package/dist/locale/pa.js +1 -1
  165. package/dist/locale/pa.min.js +1 -1
  166. package/dist/locale/pa.min.mjs +1 -1
  167. package/dist/locale/pa.mjs +1 -1
  168. package/dist/locale/pl.js +1 -1
  169. package/dist/locale/pl.min.js +1 -1
  170. package/dist/locale/pl.min.mjs +1 -1
  171. package/dist/locale/pl.mjs +1 -1
  172. package/dist/locale/pt-br.js +1 -1
  173. package/dist/locale/pt-br.min.js +1 -1
  174. package/dist/locale/pt-br.min.mjs +1 -1
  175. package/dist/locale/pt-br.mjs +1 -1
  176. package/dist/locale/pt.js +1 -1
  177. package/dist/locale/pt.min.js +1 -1
  178. package/dist/locale/pt.min.mjs +1 -1
  179. package/dist/locale/pt.mjs +1 -1
  180. package/dist/locale/ro.js +1 -1
  181. package/dist/locale/ro.min.js +1 -1
  182. package/dist/locale/ro.min.mjs +1 -1
  183. package/dist/locale/ro.mjs +1 -1
  184. package/dist/locale/ru.js +1 -1
  185. package/dist/locale/ru.min.js +1 -1
  186. package/dist/locale/ru.min.mjs +1 -1
  187. package/dist/locale/ru.mjs +1 -1
  188. package/dist/locale/sk.js +1 -1
  189. package/dist/locale/sk.min.js +1 -1
  190. package/dist/locale/sk.min.mjs +1 -1
  191. package/dist/locale/sk.mjs +1 -1
  192. package/dist/locale/sl.js +1 -1
  193. package/dist/locale/sl.min.js +1 -1
  194. package/dist/locale/sl.min.mjs +1 -1
  195. package/dist/locale/sl.mjs +1 -1
  196. package/dist/locale/sr.js +1 -1
  197. package/dist/locale/sr.min.js +1 -1
  198. package/dist/locale/sr.min.mjs +1 -1
  199. package/dist/locale/sr.mjs +1 -1
  200. package/dist/locale/sv.js +1 -1
  201. package/dist/locale/sv.min.js +1 -1
  202. package/dist/locale/sv.min.mjs +1 -1
  203. package/dist/locale/sv.mjs +1 -1
  204. package/dist/locale/sw.js +1 -1
  205. package/dist/locale/sw.min.js +1 -1
  206. package/dist/locale/sw.min.mjs +1 -1
  207. package/dist/locale/sw.mjs +1 -1
  208. package/dist/locale/ta.js +1 -1
  209. package/dist/locale/ta.min.js +1 -1
  210. package/dist/locale/ta.min.mjs +1 -1
  211. package/dist/locale/ta.mjs +1 -1
  212. package/dist/locale/th.js +1 -1
  213. package/dist/locale/th.min.js +1 -1
  214. package/dist/locale/th.min.mjs +1 -1
  215. package/dist/locale/th.mjs +1 -1
  216. package/dist/locale/tk.js +1 -1
  217. package/dist/locale/tk.min.js +1 -1
  218. package/dist/locale/tk.min.mjs +1 -1
  219. package/dist/locale/tk.mjs +1 -1
  220. package/dist/locale/tr.js +1 -1
  221. package/dist/locale/tr.min.js +1 -1
  222. package/dist/locale/tr.min.mjs +1 -1
  223. package/dist/locale/tr.mjs +1 -1
  224. package/dist/locale/ug-cn.js +1 -1
  225. package/dist/locale/ug-cn.min.js +1 -1
  226. package/dist/locale/ug-cn.min.mjs +1 -1
  227. package/dist/locale/ug-cn.mjs +1 -1
  228. package/dist/locale/uk.js +1 -1
  229. package/dist/locale/uk.min.js +1 -1
  230. package/dist/locale/uk.min.mjs +1 -1
  231. package/dist/locale/uk.mjs +1 -1
  232. package/dist/locale/uz-uz.js +1 -1
  233. package/dist/locale/uz-uz.min.js +1 -1
  234. package/dist/locale/uz-uz.min.mjs +1 -1
  235. package/dist/locale/uz-uz.mjs +1 -1
  236. package/dist/locale/vi.js +1 -1
  237. package/dist/locale/vi.min.js +1 -1
  238. package/dist/locale/vi.min.mjs +1 -1
  239. package/dist/locale/vi.mjs +1 -1
  240. package/dist/locale/zh-cn.js +1 -1
  241. package/dist/locale/zh-cn.min.js +1 -1
  242. package/dist/locale/zh-cn.min.mjs +1 -1
  243. package/dist/locale/zh-cn.mjs +1 -1
  244. package/dist/locale/zh-tw.js +1 -1
  245. package/dist/locale/zh-tw.min.js +1 -1
  246. package/dist/locale/zh-tw.min.mjs +1 -1
  247. package/dist/locale/zh-tw.mjs +1 -1
  248. package/es/components/autocomplete/index.mjs +2 -2
  249. package/es/components/autocomplete/src/autocomplete.mjs +367 -81
  250. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  251. package/es/components/autocomplete/src/autocomplete2.mjs +81 -367
  252. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  253. package/es/components/backtop/index.mjs +2 -2
  254. package/es/components/backtop/src/backtop.mjs +21 -54
  255. package/es/components/backtop/src/backtop.mjs.map +1 -1
  256. package/es/components/backtop/src/backtop2.mjs +54 -21
  257. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  258. package/es/components/cascader/src/cascader.mjs +1 -1
  259. package/es/components/collapse/index.mjs +2 -2
  260. package/es/components/collapse/src/collapse-item.mjs +90 -19
  261. package/es/components/collapse/src/collapse-item.mjs.map +1 -1
  262. package/es/components/collapse/src/collapse-item2.mjs +19 -90
  263. package/es/components/collapse/src/collapse-item2.mjs.map +1 -1
  264. package/es/components/color-picker/src/color-picker.mjs +1 -1
  265. package/es/components/dropdown/index.mjs +2 -2
  266. package/es/components/dropdown/src/dropdown-item-impl.mjs +1 -1
  267. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  268. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  269. package/es/components/dropdown/src/dropdown.mjs +304 -94
  270. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  271. package/es/components/dropdown/src/dropdown2.mjs +94 -304
  272. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  273. package/es/components/image-viewer/index.mjs +2 -2
  274. package/es/components/image-viewer/src/image-viewer.mjs +392 -45
  275. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  276. package/es/components/image-viewer/src/image-viewer2.mjs +45 -392
  277. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  278. package/es/components/index.mjs +20 -20
  279. package/es/components/input/index.mjs +2 -2
  280. package/es/components/input/src/input.mjs +445 -103
  281. package/es/components/input/src/input.mjs.map +1 -1
  282. package/es/components/input/src/input2.mjs +103 -445
  283. package/es/components/input/src/input2.mjs.map +1 -1
  284. package/es/components/mention/index.mjs +2 -2
  285. package/es/components/mention/src/mention.mjs +65 -278
  286. package/es/components/mention/src/mention.mjs.map +1 -1
  287. package/es/components/mention/src/mention2.mjs +278 -65
  288. package/es/components/mention/src/mention2.mjs.map +1 -1
  289. package/es/components/message/index.mjs +1 -1
  290. package/es/components/message/src/message.mjs +147 -91
  291. package/es/components/message/src/message.mjs.map +1 -1
  292. package/es/components/message/src/message2.mjs +91 -147
  293. package/es/components/message/src/message2.mjs.map +1 -1
  294. package/es/components/message/src/method.mjs +2 -2
  295. package/es/components/pagination/src/components/jumper.mjs +59 -9
  296. package/es/components/pagination/src/components/jumper.mjs.map +1 -1
  297. package/es/components/pagination/src/components/jumper2.mjs +9 -59
  298. package/es/components/pagination/src/components/jumper2.mjs.map +1 -1
  299. package/es/components/pagination/src/components/next.mjs +19 -36
  300. package/es/components/pagination/src/components/next.mjs.map +1 -1
  301. package/es/components/pagination/src/components/next2.mjs +36 -19
  302. package/es/components/pagination/src/components/next2.mjs.map +1 -1
  303. package/es/components/pagination/src/components/pager.mjs +210 -17
  304. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  305. package/es/components/pagination/src/components/pager2.mjs +17 -210
  306. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  307. package/es/components/pagination/src/components/sizes.mjs +71 -25
  308. package/es/components/pagination/src/components/sizes.mjs.map +1 -1
  309. package/es/components/pagination/src/components/sizes2.mjs +25 -71
  310. package/es/components/pagination/src/components/sizes2.mjs.map +1 -1
  311. package/es/components/pagination/src/pagination.mjs +4 -4
  312. package/es/components/popconfirm/src/popconfirm.mjs +1 -1
  313. package/es/components/popover/src/popover.mjs +3 -3
  314. package/es/components/radio/index.mjs +4 -4
  315. package/es/components/radio/src/radio-button.mjs +66 -6
  316. package/es/components/radio/src/radio-button.mjs.map +1 -1
  317. package/es/components/radio/src/radio-button2.mjs +6 -66
  318. package/es/components/radio/src/radio-button2.mjs.map +1 -1
  319. package/es/components/radio/src/radio-group.mjs +35 -68
  320. package/es/components/radio/src/radio-group.mjs.map +1 -1
  321. package/es/components/radio/src/radio-group2.mjs +68 -35
  322. package/es/components/radio/src/radio-group2.mjs.map +1 -1
  323. package/es/components/result/index.mjs +2 -2
  324. package/es/components/result/src/result.mjs +63 -29
  325. package/es/components/result/src/result.mjs.map +1 -1
  326. package/es/components/result/src/result2.mjs +29 -63
  327. package/es/components/result/src/result2.mjs.map +1 -1
  328. package/es/components/select/index.mjs +1 -1
  329. package/es/components/select/src/select.mjs +104 -412
  330. package/es/components/select/src/select.mjs.map +1 -1
  331. package/es/components/select/src/select2.mjs +412 -104
  332. package/es/components/select/src/select2.mjs.map +1 -1
  333. package/es/components/select-v2/src/defaults.mjs +1 -1
  334. package/es/components/statistic/index.mjs +2 -2
  335. package/es/components/statistic/src/statistic.mjs +25 -70
  336. package/es/components/statistic/src/statistic.mjs.map +1 -1
  337. package/es/components/statistic/src/statistic2.mjs +70 -25
  338. package/es/components/statistic/src/statistic2.mjs.map +1 -1
  339. package/es/components/steps/index.mjs +2 -2
  340. package/es/components/steps/src/item.mjs +191 -19
  341. package/es/components/steps/src/item.mjs.map +1 -1
  342. package/es/components/steps/src/item2.mjs +19 -191
  343. package/es/components/steps/src/item2.mjs.map +1 -1
  344. package/es/components/text/index.mjs +2 -2
  345. package/es/components/text/src/text.mjs +22 -38
  346. package/es/components/text/src/text.mjs.map +1 -1
  347. package/es/components/text/src/text2.mjs +38 -22
  348. package/es/components/text/src/text2.mjs.map +1 -1
  349. package/es/components/tooltip/index.mjs +4 -4
  350. package/es/components/tooltip/src/content.mjs +183 -29
  351. package/es/components/tooltip/src/content.mjs.map +1 -1
  352. package/es/components/tooltip/src/content2.mjs +29 -183
  353. package/es/components/tooltip/src/content2.mjs.map +1 -1
  354. package/es/components/tooltip/src/tooltip.mjs +168 -31
  355. package/es/components/tooltip/src/tooltip.mjs.map +1 -1
  356. package/es/components/tooltip/src/tooltip2.mjs +31 -168
  357. package/es/components/tooltip/src/tooltip2.mjs.map +1 -1
  358. package/es/components/tooltip/src/trigger.mjs +73 -16
  359. package/es/components/tooltip/src/trigger.mjs.map +1 -1
  360. package/es/components/tooltip/src/trigger2.mjs +16 -73
  361. package/es/components/tooltip/src/trigger2.mjs.map +1 -1
  362. package/es/components/tour/index.mjs +1 -1
  363. package/es/components/tour/src/content.mjs +44 -68
  364. package/es/components/tour/src/content.mjs.map +1 -1
  365. package/es/components/tour/src/content2.mjs +68 -44
  366. package/es/components/tour/src/content2.mjs.map +1 -1
  367. package/es/components/tour/src/mask.mjs +19 -76
  368. package/es/components/tour/src/mask.mjs.map +1 -1
  369. package/es/components/tour/src/mask2.mjs +76 -19
  370. package/es/components/tour/src/mask2.mjs.map +1 -1
  371. package/es/components/tour/src/step.mjs +1 -1
  372. package/es/components/tour/src/tour.mjs +1 -1
  373. package/es/components/tour/src/tour2.mjs +2 -2
  374. package/es/components/transfer/index.mjs +2 -2
  375. package/es/components/transfer/src/composables/use-checked-change.mjs +1 -1
  376. package/es/components/transfer/src/transfer-panel.mjs +1 -1
  377. package/es/components/transfer/src/transfer.mjs +158 -69
  378. package/es/components/transfer/src/transfer.mjs.map +1 -1
  379. package/es/components/transfer/src/transfer.vue.d.ts +9 -9
  380. package/es/components/transfer/src/transfer2.mjs +69 -158
  381. package/es/components/transfer/src/transfer2.mjs.map +1 -1
  382. package/es/components/watermark/index.mjs +2 -2
  383. package/es/components/watermark/src/watermark.mjs +209 -28
  384. package/es/components/watermark/src/watermark.mjs.map +1 -1
  385. package/es/components/watermark/src/watermark2.mjs +28 -209
  386. package/es/components/watermark/src/watermark2.mjs.map +1 -1
  387. package/es/index.mjs +20 -20
  388. package/es/version.d.ts +1 -1
  389. package/es/version.mjs +1 -1
  390. package/es/version.mjs.map +1 -1
  391. package/lib/components/autocomplete/index.js +2 -2
  392. package/lib/components/autocomplete/src/autocomplete.js +365 -80
  393. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  394. package/lib/components/autocomplete/src/autocomplete2.js +80 -365
  395. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  396. package/lib/components/backtop/index.js +2 -2
  397. package/lib/components/backtop/src/backtop.js +22 -54
  398. package/lib/components/backtop/src/backtop.js.map +1 -1
  399. package/lib/components/backtop/src/backtop2.js +54 -22
  400. package/lib/components/backtop/src/backtop2.js.map +1 -1
  401. package/lib/components/cascader/src/cascader.js +1 -1
  402. package/lib/components/collapse/index.js +2 -2
  403. package/lib/components/collapse/src/collapse-item.js +90 -19
  404. package/lib/components/collapse/src/collapse-item.js.map +1 -1
  405. package/lib/components/collapse/src/collapse-item2.js +19 -90
  406. package/lib/components/collapse/src/collapse-item2.js.map +1 -1
  407. package/lib/components/color-picker/src/color-picker.js +1 -1
  408. package/lib/components/dropdown/index.js +2 -2
  409. package/lib/components/dropdown/src/dropdown-item-impl.js +1 -1
  410. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  411. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  412. package/lib/components/dropdown/src/dropdown.js +304 -103
  413. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  414. package/lib/components/dropdown/src/dropdown2.js +103 -304
  415. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  416. package/lib/components/image-viewer/index.js +2 -2
  417. package/lib/components/image-viewer/src/image-viewer.js +392 -46
  418. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  419. package/lib/components/image-viewer/src/image-viewer2.js +46 -392
  420. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  421. package/lib/components/index.js +20 -20
  422. package/lib/components/input/index.js +2 -2
  423. package/lib/components/input/src/input.js +444 -103
  424. package/lib/components/input/src/input.js.map +1 -1
  425. package/lib/components/input/src/input2.js +103 -444
  426. package/lib/components/input/src/input2.js.map +1 -1
  427. package/lib/components/mention/index.js +2 -2
  428. package/lib/components/mention/src/mention.js +64 -276
  429. package/lib/components/mention/src/mention.js.map +1 -1
  430. package/lib/components/mention/src/mention2.js +276 -64
  431. package/lib/components/mention/src/mention2.js.map +1 -1
  432. package/lib/components/message/index.js +1 -1
  433. package/lib/components/message/src/message.js +146 -93
  434. package/lib/components/message/src/message.js.map +1 -1
  435. package/lib/components/message/src/message2.js +93 -146
  436. package/lib/components/message/src/message2.js.map +1 -1
  437. package/lib/components/message/src/method.js +2 -2
  438. package/lib/components/pagination/src/components/jumper.js +59 -9
  439. package/lib/components/pagination/src/components/jumper.js.map +1 -1
  440. package/lib/components/pagination/src/components/jumper2.js +9 -59
  441. package/lib/components/pagination/src/components/jumper2.js.map +1 -1
  442. package/lib/components/pagination/src/components/next.js +19 -36
  443. package/lib/components/pagination/src/components/next.js.map +1 -1
  444. package/lib/components/pagination/src/components/next2.js +36 -19
  445. package/lib/components/pagination/src/components/next2.js.map +1 -1
  446. package/lib/components/pagination/src/components/pager.js +210 -17
  447. package/lib/components/pagination/src/components/pager.js.map +1 -1
  448. package/lib/components/pagination/src/components/pager2.js +17 -210
  449. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  450. package/lib/components/pagination/src/components/sizes.js +71 -25
  451. package/lib/components/pagination/src/components/sizes.js.map +1 -1
  452. package/lib/components/pagination/src/components/sizes2.js +25 -71
  453. package/lib/components/pagination/src/components/sizes2.js.map +1 -1
  454. package/lib/components/pagination/src/pagination.js +4 -4
  455. package/lib/components/popconfirm/src/popconfirm.js +1 -1
  456. package/lib/components/popover/src/popover.js +3 -3
  457. package/lib/components/radio/index.js +4 -4
  458. package/lib/components/radio/src/radio-button.js +66 -6
  459. package/lib/components/radio/src/radio-button.js.map +1 -1
  460. package/lib/components/radio/src/radio-button2.js +6 -66
  461. package/lib/components/radio/src/radio-button2.js.map +1 -1
  462. package/lib/components/radio/src/radio-group.js +36 -68
  463. package/lib/components/radio/src/radio-group.js.map +1 -1
  464. package/lib/components/radio/src/radio-group2.js +68 -36
  465. package/lib/components/radio/src/radio-group2.js.map +1 -1
  466. package/lib/components/result/index.js +2 -2
  467. package/lib/components/result/src/result.js +63 -31
  468. package/lib/components/result/src/result.js.map +1 -1
  469. package/lib/components/result/src/result2.js +31 -63
  470. package/lib/components/result/src/result2.js.map +1 -1
  471. package/lib/components/select/index.js +1 -1
  472. package/lib/components/select/src/select.js +104 -412
  473. package/lib/components/select/src/select.js.map +1 -1
  474. package/lib/components/select/src/select2.js +412 -104
  475. package/lib/components/select/src/select2.js.map +1 -1
  476. package/lib/components/select-v2/src/defaults.js +1 -1
  477. package/lib/components/statistic/index.js +2 -2
  478. package/lib/components/statistic/src/statistic.js +25 -70
  479. package/lib/components/statistic/src/statistic.js.map +1 -1
  480. package/lib/components/statistic/src/statistic2.js +70 -25
  481. package/lib/components/statistic/src/statistic2.js.map +1 -1
  482. package/lib/components/steps/index.js +2 -2
  483. package/lib/components/steps/src/item.js +191 -19
  484. package/lib/components/steps/src/item.js.map +1 -1
  485. package/lib/components/steps/src/item2.js +19 -191
  486. package/lib/components/steps/src/item2.js.map +1 -1
  487. package/lib/components/text/index.js +2 -2
  488. package/lib/components/text/src/text.js +22 -38
  489. package/lib/components/text/src/text.js.map +1 -1
  490. package/lib/components/text/src/text2.js +38 -22
  491. package/lib/components/text/src/text2.js.map +1 -1
  492. package/lib/components/tooltip/index.js +4 -4
  493. package/lib/components/tooltip/src/content.js +183 -29
  494. package/lib/components/tooltip/src/content.js.map +1 -1
  495. package/lib/components/tooltip/src/content2.js +29 -183
  496. package/lib/components/tooltip/src/content2.js.map +1 -1
  497. package/lib/components/tooltip/src/tooltip.js +167 -34
  498. package/lib/components/tooltip/src/tooltip.js.map +1 -1
  499. package/lib/components/tooltip/src/tooltip2.js +34 -167
  500. package/lib/components/tooltip/src/tooltip2.js.map +1 -1
  501. package/lib/components/tooltip/src/trigger.js +73 -16
  502. package/lib/components/tooltip/src/trigger.js.map +1 -1
  503. package/lib/components/tooltip/src/trigger2.js +16 -73
  504. package/lib/components/tooltip/src/trigger2.js.map +1 -1
  505. package/lib/components/tour/index.js +1 -1
  506. package/lib/components/tour/src/content.js +47 -68
  507. package/lib/components/tour/src/content.js.map +1 -1
  508. package/lib/components/tour/src/content2.js +68 -47
  509. package/lib/components/tour/src/content2.js.map +1 -1
  510. package/lib/components/tour/src/mask.js +19 -76
  511. package/lib/components/tour/src/mask.js.map +1 -1
  512. package/lib/components/tour/src/mask2.js +76 -19
  513. package/lib/components/tour/src/mask2.js.map +1 -1
  514. package/lib/components/tour/src/step.js +1 -1
  515. package/lib/components/tour/src/tour.js +1 -1
  516. package/lib/components/tour/src/tour2.js +2 -2
  517. package/lib/components/transfer/index.js +2 -2
  518. package/lib/components/transfer/src/composables/use-checked-change.js +1 -1
  519. package/lib/components/transfer/src/transfer-panel.js +1 -1
  520. package/lib/components/transfer/src/transfer.js +158 -73
  521. package/lib/components/transfer/src/transfer.js.map +1 -1
  522. package/lib/components/transfer/src/transfer.vue.d.ts +9 -9
  523. package/lib/components/transfer/src/transfer2.js +73 -158
  524. package/lib/components/transfer/src/transfer2.js.map +1 -1
  525. package/lib/components/watermark/index.js +2 -2
  526. package/lib/components/watermark/src/watermark.js +209 -28
  527. package/lib/components/watermark/src/watermark.js.map +1 -1
  528. package/lib/components/watermark/src/watermark2.js +28 -209
  529. package/lib/components/watermark/src/watermark2.js.map +1 -1
  530. package/lib/index.js +20 -20
  531. package/lib/version.d.ts +1 -1
  532. package/lib/version.js +1 -1
  533. package/lib/version.js.map +1 -1
  534. package/package.json +2 -2
  535. package/web-types.json +1 -1
@@ -1,72 +1,285 @@
1
- import '../../../utils/index.mjs';
1
+ import { defineComponent, computed, ref, nextTick, openBlock, createElementBlock, normalizeClass, unref, createVNode, mergeProps, createSlots, renderList, withCtx, renderSlot, normalizeProps, guardReactiveProps, createElementVNode, normalizeStyle, withModifiers } from 'vue';
2
+ import { pick } from 'lodash-unified';
3
+ import '../../../hooks/index.mjs';
4
+ import { ElInput } from '../../input/index.mjs';
5
+ import { ElTooltip } from '../../tooltip/index.mjs';
2
6
  import '../../../constants/index.mjs';
3
- import '../../input/index.mjs';
4
- import { filterOption } from './helper.mjs';
5
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
6
- import { inputProps } from '../../input/src/input.mjs';
7
- import { isString, isFunction } from '@vue/shared';
7
+ import '../../form/index.mjs';
8
+ import '../../../utils/index.mjs';
9
+ import { mentionProps, mentionEmits } from './mention.mjs';
10
+ import { getCursorPosition, getMentionCtx } from './helper.mjs';
11
+ import ElMentionDropdown from './mention-dropdown2.mjs';
12
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
13
+ import { inputProps } from '../../input/src/input2.mjs';
14
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
15
+ import { useFormDisabled } from '../../form/src/hooks/use-form-common-props.mjs';
16
+ import { useId } from '../../../hooks/use-id/index.mjs';
17
+ import { isFunction } from '@vue/shared';
8
18
  import { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';
19
+ import { useFocusController } from '../../../hooks/use-focus-controller/index.mjs';
9
20
 
10
- const mentionProps = buildProps({
11
- ...inputProps,
12
- options: {
13
- type: definePropType(Array),
14
- default: () => []
15
- },
16
- prefix: {
17
- type: definePropType([String, Array]),
18
- default: "@",
19
- validator: (val) => {
20
- if (isString(val))
21
- return val.length === 1;
22
- return val.every((v) => isString(v) && v.length === 1);
23
- }
24
- },
25
- split: {
26
- type: String,
27
- default: " ",
28
- validator: (val) => val.length === 1
29
- },
30
- filterOption: {
31
- type: definePropType([Boolean, Function]),
32
- default: () => filterOption,
33
- validator: (val) => {
34
- if (val === false)
35
- return true;
36
- return isFunction(val);
37
- }
38
- },
39
- placement: {
40
- type: definePropType(String),
41
- default: "bottom"
42
- },
43
- showArrow: Boolean,
44
- offset: {
45
- type: Number,
46
- default: 0
47
- },
48
- whole: Boolean,
49
- checkIsWhole: {
50
- type: definePropType(Function)
51
- },
52
- modelValue: String,
53
- loading: Boolean,
54
- popperClass: {
55
- type: String,
56
- default: ""
57
- },
58
- popperOptions: {
59
- type: definePropType(Object),
60
- default: () => ({})
21
+ const __default__ = defineComponent({
22
+ name: "ElMention"
23
+ });
24
+ const _sfc_main = /* @__PURE__ */ defineComponent({
25
+ ...__default__,
26
+ props: mentionProps,
27
+ emits: mentionEmits,
28
+ setup(__props, { expose, emit }) {
29
+ const props = __props;
30
+ const passInputProps = computed(() => pick(props, Object.keys(inputProps)));
31
+ const ns = useNamespace("mention");
32
+ const disabled = useFormDisabled();
33
+ const contentId = useId();
34
+ const elInputRef = ref();
35
+ const tooltipRef = ref();
36
+ const dropdownRef = ref();
37
+ const visible = ref(false);
38
+ const cursorStyle = ref();
39
+ const mentionCtx = ref();
40
+ const computedPlacement = computed(() => props.showArrow ? props.placement : `${props.placement}-start`);
41
+ const computedFallbackPlacements = computed(() => props.showArrow ? ["bottom", "top"] : ["bottom-start", "top-start"]);
42
+ const filteredOptions = computed(() => {
43
+ const { filterOption, options } = props;
44
+ if (!mentionCtx.value || !filterOption)
45
+ return options;
46
+ return options.filter((option) => filterOption(mentionCtx.value.pattern, option));
47
+ });
48
+ const dropdownVisible = computed(() => {
49
+ return visible.value && (!!filteredOptions.value.length || props.loading);
50
+ });
51
+ const hoveringId = computed(() => {
52
+ var _a;
53
+ return `${contentId.value}-${(_a = dropdownRef.value) == null ? void 0 : _a.hoveringIndex}`;
54
+ });
55
+ const handleInputChange = (value) => {
56
+ emit("update:modelValue", value);
57
+ syncAfterCursorMove();
58
+ };
59
+ const handleInputKeyDown = (e) => {
60
+ var _a, _b, _c, _d;
61
+ if (!("key" in e))
62
+ return;
63
+ if ((_a = elInputRef.value) == null ? void 0 : _a.isComposing)
64
+ return;
65
+ if (["ArrowLeft", "ArrowRight"].includes(e.key)) {
66
+ syncAfterCursorMove();
67
+ } else if (["ArrowUp", "ArrowDown"].includes(e.key)) {
68
+ if (!visible.value)
69
+ return;
70
+ e.preventDefault();
71
+ const direction = e.key === "ArrowUp" ? "prev" : "next";
72
+ (_b = dropdownRef.value) == null ? void 0 : _b.navigateOptions(direction);
73
+ } else if (["Enter"].includes(e.key)) {
74
+ if (!visible.value)
75
+ return;
76
+ e.preventDefault();
77
+ if ((_c = dropdownRef.value) == null ? void 0 : _c.hoverOption) {
78
+ (_d = dropdownRef.value) == null ? void 0 : _d.selectHoverOption();
79
+ } else {
80
+ visible.value = false;
81
+ }
82
+ } else if (["Escape"].includes(e.key)) {
83
+ if (!visible.value)
84
+ return;
85
+ e.preventDefault();
86
+ visible.value = false;
87
+ } else if (["Backspace"].includes(e.key)) {
88
+ if (props.whole && mentionCtx.value) {
89
+ const { splitIndex, selectionEnd, pattern, prefixIndex, prefix } = mentionCtx.value;
90
+ const inputEl = getInputEl();
91
+ if (!inputEl)
92
+ return;
93
+ const inputValue = inputEl.value;
94
+ const matchOption = props.options.find((item) => item.value === pattern);
95
+ const isWhole = isFunction(props.checkIsWhole) ? props.checkIsWhole(pattern, prefix) : matchOption;
96
+ if (isWhole && splitIndex !== -1 && splitIndex + 1 === selectionEnd) {
97
+ e.preventDefault();
98
+ const newValue = inputValue.slice(0, prefixIndex) + inputValue.slice(splitIndex + 1);
99
+ emit(UPDATE_MODEL_EVENT, newValue);
100
+ const newSelectionEnd = prefixIndex;
101
+ nextTick(() => {
102
+ inputEl.selectionStart = newSelectionEnd;
103
+ inputEl.selectionEnd = newSelectionEnd;
104
+ syncDropdownVisible();
105
+ });
106
+ }
107
+ }
108
+ }
109
+ };
110
+ const { wrapperRef } = useFocusController(elInputRef, {
111
+ beforeFocus() {
112
+ return disabled.value;
113
+ },
114
+ afterFocus() {
115
+ syncAfterCursorMove();
116
+ },
117
+ beforeBlur(event) {
118
+ var _a;
119
+ return (_a = tooltipRef.value) == null ? void 0 : _a.isFocusInsideContent(event);
120
+ },
121
+ afterBlur() {
122
+ visible.value = false;
123
+ }
124
+ });
125
+ const handleInputMouseDown = () => {
126
+ syncAfterCursorMove();
127
+ };
128
+ const handleSelect = (item) => {
129
+ if (!mentionCtx.value)
130
+ return;
131
+ const inputEl = getInputEl();
132
+ if (!inputEl)
133
+ return;
134
+ const inputValue = inputEl.value;
135
+ const { split } = props;
136
+ const newEndPart = inputValue.slice(mentionCtx.value.end);
137
+ const alreadySeparated = newEndPart.startsWith(split);
138
+ const newMiddlePart = `${item.value}${alreadySeparated ? "" : split}`;
139
+ const newValue = inputValue.slice(0, mentionCtx.value.start) + newMiddlePart + newEndPart;
140
+ emit(UPDATE_MODEL_EVENT, newValue);
141
+ emit("select", item, mentionCtx.value.prefix);
142
+ const newSelectionEnd = mentionCtx.value.start + newMiddlePart.length + (alreadySeparated ? 1 : 0);
143
+ nextTick(() => {
144
+ inputEl.selectionStart = newSelectionEnd;
145
+ inputEl.selectionEnd = newSelectionEnd;
146
+ inputEl.focus();
147
+ syncDropdownVisible();
148
+ });
149
+ };
150
+ const getInputEl = () => {
151
+ var _a, _b;
152
+ return props.type === "textarea" ? (_a = elInputRef.value) == null ? void 0 : _a.textarea : (_b = elInputRef.value) == null ? void 0 : _b.input;
153
+ };
154
+ const syncAfterCursorMove = () => {
155
+ setTimeout(() => {
156
+ syncCursor();
157
+ syncDropdownVisible();
158
+ nextTick(() => {
159
+ var _a;
160
+ return (_a = tooltipRef.value) == null ? void 0 : _a.updatePopper();
161
+ });
162
+ }, 0);
163
+ };
164
+ const syncCursor = () => {
165
+ const inputEl = getInputEl();
166
+ if (!inputEl)
167
+ return;
168
+ const caretPosition = getCursorPosition(inputEl);
169
+ const inputRect = inputEl.getBoundingClientRect();
170
+ const elInputRect = elInputRef.value.$el.getBoundingClientRect();
171
+ cursorStyle.value = {
172
+ position: "absolute",
173
+ width: 0,
174
+ height: `${caretPosition.height}px`,
175
+ left: `${caretPosition.left + inputRect.left - elInputRect.left}px`,
176
+ top: `${caretPosition.top + inputRect.top - elInputRect.top}px`
177
+ };
178
+ };
179
+ const syncDropdownVisible = () => {
180
+ const inputEl = getInputEl();
181
+ if (document.activeElement !== inputEl) {
182
+ visible.value = false;
183
+ return;
184
+ }
185
+ const { prefix, split } = props;
186
+ mentionCtx.value = getMentionCtx(inputEl, prefix, split);
187
+ if (mentionCtx.value && mentionCtx.value.splitIndex === -1) {
188
+ visible.value = true;
189
+ emit("search", mentionCtx.value.pattern, mentionCtx.value.prefix);
190
+ return;
191
+ }
192
+ visible.value = false;
193
+ };
194
+ expose({
195
+ input: elInputRef,
196
+ tooltip: tooltipRef
197
+ });
198
+ return (_ctx, _cache) => {
199
+ return openBlock(), createElementBlock("div", {
200
+ ref_key: "wrapperRef",
201
+ ref: wrapperRef,
202
+ class: normalizeClass(unref(ns).b())
203
+ }, [
204
+ createVNode(unref(ElInput), mergeProps(mergeProps(unref(passInputProps), _ctx.$attrs), {
205
+ ref_key: "elInputRef",
206
+ ref: elInputRef,
207
+ "model-value": _ctx.modelValue,
208
+ disabled: unref(disabled),
209
+ role: unref(dropdownVisible) ? "combobox" : void 0,
210
+ "aria-activedescendant": unref(dropdownVisible) ? unref(hoveringId) || "" : void 0,
211
+ "aria-controls": unref(dropdownVisible) ? unref(contentId) : void 0,
212
+ "aria-expanded": unref(dropdownVisible) || void 0,
213
+ "aria-label": _ctx.ariaLabel,
214
+ "aria-autocomplete": unref(dropdownVisible) ? "none" : void 0,
215
+ "aria-haspopup": unref(dropdownVisible) ? "listbox" : void 0,
216
+ onInput: handleInputChange,
217
+ onKeydown: handleInputKeyDown,
218
+ onMousedown: handleInputMouseDown
219
+ }), createSlots({
220
+ _: 2
221
+ }, [
222
+ renderList(_ctx.$slots, (_, name) => {
223
+ return {
224
+ name,
225
+ fn: withCtx((slotProps) => [
226
+ renderSlot(_ctx.$slots, name, normalizeProps(guardReactiveProps(slotProps)))
227
+ ])
228
+ };
229
+ })
230
+ ]), 1040, ["model-value", "disabled", "role", "aria-activedescendant", "aria-controls", "aria-expanded", "aria-label", "aria-autocomplete", "aria-haspopup"]),
231
+ createVNode(unref(ElTooltip), {
232
+ ref_key: "tooltipRef",
233
+ ref: tooltipRef,
234
+ visible: unref(dropdownVisible),
235
+ "popper-class": [unref(ns).e("popper"), _ctx.popperClass],
236
+ "popper-options": _ctx.popperOptions,
237
+ placement: unref(computedPlacement),
238
+ "fallback-placements": unref(computedFallbackPlacements),
239
+ effect: "light",
240
+ pure: "",
241
+ offset: _ctx.offset,
242
+ "show-arrow": _ctx.showArrow
243
+ }, {
244
+ default: withCtx(() => [
245
+ createElementVNode("div", {
246
+ style: normalizeStyle(cursorStyle.value)
247
+ }, null, 4)
248
+ ]),
249
+ content: withCtx(() => {
250
+ var _a;
251
+ return [
252
+ createVNode(ElMentionDropdown, {
253
+ ref_key: "dropdownRef",
254
+ ref: dropdownRef,
255
+ options: unref(filteredOptions),
256
+ disabled: unref(disabled),
257
+ loading: _ctx.loading,
258
+ "content-id": unref(contentId),
259
+ "aria-label": _ctx.ariaLabel,
260
+ onSelect: handleSelect,
261
+ onClick: withModifiers((_a = elInputRef.value) == null ? void 0 : _a.focus, ["stop"])
262
+ }, createSlots({
263
+ _: 2
264
+ }, [
265
+ renderList(_ctx.$slots, (_, name) => {
266
+ return {
267
+ name,
268
+ fn: withCtx((slotProps) => [
269
+ renderSlot(_ctx.$slots, name, normalizeProps(guardReactiveProps(slotProps)))
270
+ ])
271
+ };
272
+ })
273
+ ]), 1032, ["options", "disabled", "loading", "content-id", "aria-label", "onClick"])
274
+ ];
275
+ }),
276
+ _: 3
277
+ }, 8, ["visible", "popper-class", "popper-options", "placement", "fallback-placements", "offset", "show-arrow"])
278
+ ], 2);
279
+ };
61
280
  }
62
281
  });
63
- const mentionEmits = {
64
- [UPDATE_MODEL_EVENT]: (value) => isString(value),
65
- search: (pattern, prefix) => isString(pattern) && isString(prefix),
66
- select: (option, prefix) => isString(option.value) && isString(prefix),
67
- focus: (evt) => evt instanceof FocusEvent,
68
- blur: (evt) => evt instanceof FocusEvent
69
- };
282
+ var Mention = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "mention.vue"]]);
70
283
 
71
- export { mentionEmits, mentionProps };
284
+ export { Mention as default };
72
285
  //# sourceMappingURL=mention2.mjs.map
@@ -1 +1 @@
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
+ {"version":3,"file":"mention2.mjs","sources":["../../../../../../packages/components/mention/src/mention.vue"],"sourcesContent":["<template>\n <div ref=\"wrapperRef\" :class=\"ns.b()\">\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 { 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 } 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})\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 = (e: KeyboardEvent | Event) => {\n if (!('key' in e)) return\n if (elInputRef.value?.isComposing) return\n if (['ArrowLeft', 'ArrowRight'].includes(e.key)) {\n syncAfterCursorMove()\n } else if (['ArrowUp', 'ArrowDown'].includes(e.key)) {\n if (!visible.value) return\n e.preventDefault()\n const direction = e.key === 'ArrowUp' ? 'prev' : 'next'\n dropdownRef.value?.navigateOptions(direction)\n } else if (['Enter'].includes(e.key)) {\n if (!visible.value) return\n e.preventDefault()\n if (dropdownRef.value?.hoverOption) {\n dropdownRef.value?.selectHoverOption()\n } else {\n visible.value = false\n }\n } else if (['Escape'].includes(e.key)) {\n if (!visible.value) return\n e.preventDefault()\n visible.value = false\n } else if (['Backspace'].includes(e.key)) {\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 e.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: elInputRef,\n tooltip: tooltipRef,\n})\n</script>\n"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import '../../utils/index.mjs';
2
2
  import message from './src/method.mjs';
3
- export { messageDefaults, messageEmits, messageProps, messageTypes } from './src/message.mjs';
3
+ export { messageDefaults, messageEmits, messageProps, messageTypes } from './src/message2.mjs';
4
4
  import { withInstallFunction } from '../../utils/vue/install.mjs';
5
5
 
6
6
  const ElMessage = withInstallFunction(message, "$message");
@@ -1,98 +1,154 @@
1
+ import { defineComponent, ref, computed, onMounted, watch, openBlock, createBlock, Transition, unref, withCtx, withDirectives, createElementVNode, normalizeClass, normalizeStyle, createCommentVNode, resolveDynamicComponent, renderSlot, createElementBlock, toDisplayString, Fragment, withModifiers, createVNode, vShow } from 'vue';
2
+ import { useTimeoutFn, useEventListener, useResizeObserver } from '@vueuse/core';
1
3
  import '../../../utils/index.mjs';
2
- import { mutable } from '../../../utils/typescript.mjs';
3
- import { isClient } from '@vueuse/core';
4
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
5
- import { iconPropType } from '../../../utils/vue/icon.mjs';
4
+ import '../../../constants/index.mjs';
5
+ import { ElBadge } from '../../badge/index.mjs';
6
+ import '../../config-provider/index.mjs';
7
+ import { ElIcon } from '../../icon/index.mjs';
8
+ import { messageProps, messageEmits } from './message2.mjs';
9
+ import { getLastOffset, getOffsetOrSpace } from './instance.mjs';
10
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
11
+ import { TypeComponents, TypeComponentsMap } from '../../../utils/vue/icon.mjs';
12
+ import { useGlobalComponentSettings } from '../../config-provider/src/hooks/use-global-config.mjs';
13
+ import { EVENT_CODE } from '../../../constants/aria.mjs';
6
14
 
7
- const messageTypes = ["success", "info", "warning", "error"];
8
- const messageDefaults = mutable({
9
- customClass: "",
10
- center: false,
11
- dangerouslyUseHTMLString: false,
12
- duration: 3e3,
13
- icon: void 0,
14
- id: "",
15
- message: "",
16
- onClose: void 0,
17
- showClose: false,
18
- type: "info",
19
- plain: false,
20
- offset: 16,
21
- zIndex: 0,
22
- grouping: false,
23
- repeatNum: 1,
24
- appendTo: isClient ? document.body : void 0
15
+ const __default__ = defineComponent({
16
+ name: "ElMessage"
25
17
  });
26
- const messageProps = buildProps({
27
- customClass: {
28
- type: String,
29
- default: messageDefaults.customClass
30
- },
31
- center: {
32
- type: Boolean,
33
- default: messageDefaults.center
34
- },
35
- dangerouslyUseHTMLString: {
36
- type: Boolean,
37
- default: messageDefaults.dangerouslyUseHTMLString
38
- },
39
- duration: {
40
- type: Number,
41
- default: messageDefaults.duration
42
- },
43
- icon: {
44
- type: iconPropType,
45
- default: messageDefaults.icon
46
- },
47
- id: {
48
- type: String,
49
- default: messageDefaults.id
50
- },
51
- message: {
52
- type: definePropType([
53
- String,
54
- Object,
55
- Function
56
- ]),
57
- default: messageDefaults.message
58
- },
59
- onClose: {
60
- type: definePropType(Function),
61
- default: messageDefaults.onClose
62
- },
63
- showClose: {
64
- type: Boolean,
65
- default: messageDefaults.showClose
66
- },
67
- type: {
68
- type: String,
69
- values: messageTypes,
70
- default: messageDefaults.type
71
- },
72
- plain: {
73
- type: Boolean,
74
- default: messageDefaults.plain
75
- },
76
- offset: {
77
- type: Number,
78
- default: messageDefaults.offset
79
- },
80
- zIndex: {
81
- type: Number,
82
- default: messageDefaults.zIndex
83
- },
84
- grouping: {
85
- type: Boolean,
86
- default: messageDefaults.grouping
87
- },
88
- repeatNum: {
89
- type: Number,
90
- default: messageDefaults.repeatNum
18
+ const _sfc_main = /* @__PURE__ */ defineComponent({
19
+ ...__default__,
20
+ props: messageProps,
21
+ emits: messageEmits,
22
+ setup(__props, { expose }) {
23
+ const props = __props;
24
+ const { Close } = TypeComponents;
25
+ const { ns, zIndex } = useGlobalComponentSettings("message");
26
+ const { currentZIndex, nextZIndex } = zIndex;
27
+ const messageRef = ref();
28
+ const visible = ref(false);
29
+ const height = ref(0);
30
+ let stopTimer = void 0;
31
+ const badgeType = computed(() => props.type ? props.type === "error" ? "danger" : props.type : "info");
32
+ const typeClass = computed(() => {
33
+ const type = props.type;
34
+ return { [ns.bm("icon", type)]: type && TypeComponentsMap[type] };
35
+ });
36
+ const iconComponent = computed(() => props.icon || TypeComponentsMap[props.type] || "");
37
+ const lastOffset = computed(() => getLastOffset(props.id));
38
+ const offset = computed(() => getOffsetOrSpace(props.id, props.offset) + lastOffset.value);
39
+ const bottom = computed(() => height.value + offset.value);
40
+ const customStyle = computed(() => ({
41
+ top: `${offset.value}px`,
42
+ zIndex: currentZIndex.value
43
+ }));
44
+ function startTimer() {
45
+ if (props.duration === 0)
46
+ return;
47
+ ({ stop: stopTimer } = useTimeoutFn(() => {
48
+ close();
49
+ }, props.duration));
50
+ }
51
+ function clearTimer() {
52
+ stopTimer == null ? void 0 : stopTimer();
53
+ }
54
+ function close() {
55
+ visible.value = false;
56
+ }
57
+ function keydown({ code }) {
58
+ if (code === EVENT_CODE.esc) {
59
+ close();
60
+ }
61
+ }
62
+ onMounted(() => {
63
+ startTimer();
64
+ nextZIndex();
65
+ visible.value = true;
66
+ });
67
+ watch(() => props.repeatNum, () => {
68
+ clearTimer();
69
+ startTimer();
70
+ });
71
+ useEventListener(document, "keydown", keydown);
72
+ useResizeObserver(messageRef, () => {
73
+ height.value = messageRef.value.getBoundingClientRect().height;
74
+ });
75
+ expose({
76
+ visible,
77
+ bottom,
78
+ close
79
+ });
80
+ return (_ctx, _cache) => {
81
+ return openBlock(), createBlock(Transition, {
82
+ name: unref(ns).b("fade"),
83
+ onBeforeLeave: _ctx.onClose,
84
+ onAfterLeave: ($event) => _ctx.$emit("destroy"),
85
+ persisted: ""
86
+ }, {
87
+ default: withCtx(() => [
88
+ withDirectives(createElementVNode("div", {
89
+ id: _ctx.id,
90
+ ref_key: "messageRef",
91
+ ref: messageRef,
92
+ class: normalizeClass([
93
+ unref(ns).b(),
94
+ { [unref(ns).m(_ctx.type)]: _ctx.type },
95
+ unref(ns).is("center", _ctx.center),
96
+ unref(ns).is("closable", _ctx.showClose),
97
+ unref(ns).is("plain", _ctx.plain),
98
+ _ctx.customClass
99
+ ]),
100
+ style: normalizeStyle(unref(customStyle)),
101
+ role: "alert",
102
+ onMouseenter: clearTimer,
103
+ onMouseleave: startTimer
104
+ }, [
105
+ _ctx.repeatNum > 1 ? (openBlock(), createBlock(unref(ElBadge), {
106
+ key: 0,
107
+ value: _ctx.repeatNum,
108
+ type: unref(badgeType),
109
+ class: normalizeClass(unref(ns).e("badge"))
110
+ }, null, 8, ["value", "type", "class"])) : createCommentVNode("v-if", true),
111
+ unref(iconComponent) ? (openBlock(), createBlock(unref(ElIcon), {
112
+ key: 1,
113
+ class: normalizeClass([unref(ns).e("icon"), unref(typeClass)])
114
+ }, {
115
+ default: withCtx(() => [
116
+ (openBlock(), createBlock(resolveDynamicComponent(unref(iconComponent))))
117
+ ]),
118
+ _: 1
119
+ }, 8, ["class"])) : createCommentVNode("v-if", true),
120
+ renderSlot(_ctx.$slots, "default", {}, () => [
121
+ !_ctx.dangerouslyUseHTMLString ? (openBlock(), createElementBlock("p", {
122
+ key: 0,
123
+ class: normalizeClass(unref(ns).e("content"))
124
+ }, toDisplayString(_ctx.message), 3)) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
125
+ createCommentVNode(" Caution here, message could've been compromised, never use user's input as message "),
126
+ createElementVNode("p", {
127
+ class: normalizeClass(unref(ns).e("content")),
128
+ innerHTML: _ctx.message
129
+ }, null, 10, ["innerHTML"])
130
+ ], 2112))
131
+ ]),
132
+ _ctx.showClose ? (openBlock(), createBlock(unref(ElIcon), {
133
+ key: 2,
134
+ class: normalizeClass(unref(ns).e("closeBtn")),
135
+ onClick: withModifiers(close, ["stop"])
136
+ }, {
137
+ default: withCtx(() => [
138
+ createVNode(unref(Close))
139
+ ]),
140
+ _: 1
141
+ }, 8, ["class", "onClick"])) : createCommentVNode("v-if", true)
142
+ ], 46, ["id"]), [
143
+ [vShow, visible.value]
144
+ ])
145
+ ]),
146
+ _: 3
147
+ }, 8, ["name", "onBeforeLeave", "onAfterLeave"]);
148
+ };
91
149
  }
92
150
  });
93
- const messageEmits = {
94
- destroy: () => true
95
- };
151
+ var MessageConstructor = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "message.vue"]]);
96
152
 
97
- export { messageDefaults, messageEmits, messageProps, messageTypes };
153
+ export { MessageConstructor as default };
98
154
  //# sourceMappingURL=message.mjs.map