element-pe 2.2.54 → 2.2.56

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 (499) hide show
  1. package/dist/index.full.js +29 -5
  2. package/dist/index.full.min.js +8 -8
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +8 -8
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +29 -5
  7. package/es/components/avatar/index.d.ts +3 -0
  8. package/es/components/avatar/index.mjs +2 -2
  9. package/es/components/avatar/src/avatar.d.ts +1 -0
  10. package/es/components/avatar/src/avatar.mjs +75 -33
  11. package/es/components/avatar/src/avatar.mjs.map +1 -1
  12. package/es/components/avatar/src/avatar.vue.d.ts +3 -0
  13. package/es/components/avatar/src/avatar2.mjs +34 -70
  14. package/es/components/avatar/src/avatar2.mjs.map +1 -1
  15. package/es/components/backtop/index.mjs +2 -2
  16. package/es/components/backtop/src/backtop.mjs +23 -61
  17. package/es/components/backtop/src/backtop.mjs.map +1 -1
  18. package/es/components/backtop/src/backtop2.mjs +61 -23
  19. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  20. package/es/components/breadcrumb/index.mjs +4 -4
  21. package/es/components/breadcrumb/src/breadcrumb-item.mjs +11 -56
  22. package/es/components/breadcrumb/src/breadcrumb-item.mjs.map +1 -1
  23. package/es/components/breadcrumb/src/breadcrumb-item2.mjs +56 -11
  24. package/es/components/breadcrumb/src/breadcrumb-item2.mjs.map +1 -1
  25. package/es/components/breadcrumb/src/breadcrumb.mjs +36 -11
  26. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  27. package/es/components/breadcrumb/src/breadcrumb2.mjs +11 -36
  28. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  29. package/es/components/calendar/src/calendar2.mjs +1 -1
  30. package/es/components/calendar/src/date-table.mjs +33 -87
  31. package/es/components/calendar/src/date-table.mjs.map +1 -1
  32. package/es/components/calendar/src/date-table2.mjs +87 -33
  33. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  34. package/es/components/calendar/src/use-date-table.mjs +1 -1
  35. package/es/components/card/index.mjs +2 -2
  36. package/es/components/card/src/card.mjs +16 -35
  37. package/es/components/card/src/card.mjs.map +1 -1
  38. package/es/components/card/src/card2.mjs +35 -16
  39. package/es/components/card/src/card2.mjs.map +1 -1
  40. package/es/components/carousel/index.mjs +2 -2
  41. package/es/components/carousel/src/carousel.mjs +56 -164
  42. package/es/components/carousel/src/carousel.mjs.map +1 -1
  43. package/es/components/carousel/src/carousel2.mjs +164 -56
  44. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  45. package/es/components/cascader/index.mjs +2 -2
  46. package/es/components/cascader/src/cascader.mjs +63 -622
  47. package/es/components/cascader/src/cascader.mjs.map +1 -1
  48. package/es/components/cascader/src/cascader2.mjs +622 -63
  49. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  50. package/es/components/cascader-panel/src/index.mjs +1 -1
  51. package/es/components/cascader-panel/src/menu.mjs +1 -1
  52. package/es/components/cascader-panel/src/node.mjs +209 -116
  53. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  54. package/es/components/cascader-panel/src/node2.mjs +116 -209
  55. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  56. package/es/components/cascader-panel/src/store.mjs +1 -1
  57. package/es/components/collapse/index.mjs +2 -2
  58. package/es/components/collapse/src/collapse.mjs +17 -30
  59. package/es/components/collapse/src/collapse.mjs.map +1 -1
  60. package/es/components/collapse/src/collapse2.mjs +30 -17
  61. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  62. package/es/components/collection/index.mjs +1 -1
  63. package/es/components/collection/src/collection.mjs +62 -10
  64. package/es/components/collection/src/collection.mjs.map +1 -1
  65. package/es/components/collection/src/collection2.mjs +10 -62
  66. package/es/components/collection/src/collection2.mjs.map +1 -1
  67. package/es/components/drawer/index.mjs +2 -2
  68. package/es/components/drawer/src/drawer.mjs +186 -25
  69. package/es/components/drawer/src/drawer.mjs.map +1 -1
  70. package/es/components/drawer/src/drawer2.mjs +25 -186
  71. package/es/components/drawer/src/drawer2.mjs.map +1 -1
  72. package/es/components/dropdown/index.mjs +2 -2
  73. package/es/components/dropdown/src/dropdown-item-impl.mjs +3 -3
  74. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  75. package/es/components/dropdown/src/dropdown-menu.mjs +2 -2
  76. package/es/components/dropdown/src/dropdown.mjs +310 -105
  77. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  78. package/es/components/dropdown/src/dropdown2.mjs +105 -310
  79. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  80. package/es/components/empty/index.mjs +2 -2
  81. package/es/components/empty/src/empty.mjs +11 -55
  82. package/es/components/empty/src/empty.mjs.map +1 -1
  83. package/es/components/empty/src/empty2.mjs +55 -11
  84. package/es/components/empty/src/empty2.mjs.map +1 -1
  85. package/es/components/form/index.mjs +4 -4
  86. package/es/components/form/src/form-item.mjs +46 -326
  87. package/es/components/form/src/form-item.mjs.map +1 -1
  88. package/es/components/form/src/form-item2.mjs +326 -46
  89. package/es/components/form/src/form-item2.mjs.map +1 -1
  90. package/es/components/form/src/form.mjs +150 -57
  91. package/es/components/form/src/form.mjs.map +1 -1
  92. package/es/components/form/src/form2.mjs +57 -150
  93. package/es/components/form/src/form2.mjs.map +1 -1
  94. package/es/components/image/index.mjs +2 -2
  95. package/es/components/image/src/image.mjs +226 -65
  96. package/es/components/image/src/image.mjs.map +1 -1
  97. package/es/components/image/src/image2.mjs +65 -226
  98. package/es/components/image/src/image2.mjs.map +1 -1
  99. package/es/components/image-viewer/index.mjs +2 -2
  100. package/es/components/image-viewer/src/image-viewer.mjs +401 -38
  101. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  102. package/es/components/image-viewer/src/image-viewer2.mjs +38 -401
  103. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  104. package/es/components/index.mjs +33 -33
  105. package/es/components/link/index.mjs +2 -2
  106. package/es/components/link/src/link.mjs +50 -21
  107. package/es/components/link/src/link.mjs.map +1 -1
  108. package/es/components/link/src/link2.mjs +21 -50
  109. package/es/components/link/src/link2.mjs.map +1 -1
  110. package/es/components/menu/index.mjs +2 -2
  111. package/es/components/menu/src/menu-item.mjs +97 -14
  112. package/es/components/menu/src/menu-item.mjs.map +1 -1
  113. package/es/components/menu/src/menu-item2.mjs +14 -97
  114. package/es/components/menu/src/menu-item2.mjs.map +1 -1
  115. package/es/components/pagination/src/components/jumper.mjs +9 -60
  116. package/es/components/pagination/src/components/jumper.mjs.map +1 -1
  117. package/es/components/pagination/src/components/jumper2.mjs +60 -9
  118. package/es/components/pagination/src/components/jumper2.mjs.map +1 -1
  119. package/es/components/pagination/src/components/pager.mjs +216 -17
  120. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  121. package/es/components/pagination/src/components/pager2.mjs +17 -216
  122. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  123. package/es/components/pagination/src/components/prev.mjs +38 -18
  124. package/es/components/pagination/src/components/prev.mjs.map +1 -1
  125. package/es/components/pagination/src/components/prev2.mjs +18 -38
  126. package/es/components/pagination/src/components/prev2.mjs.map +1 -1
  127. package/es/components/pagination/src/components/total.mjs +28 -7
  128. package/es/components/pagination/src/components/total.mjs.map +1 -1
  129. package/es/components/pagination/src/components/total2.mjs +7 -28
  130. package/es/components/pagination/src/components/total2.mjs.map +1 -1
  131. package/es/components/pagination/src/pagination.mjs +4 -4
  132. package/es/components/popover/index.mjs +2 -2
  133. package/es/components/popover/src/popover.mjs +66 -111
  134. package/es/components/popover/src/popover.mjs.map +1 -1
  135. package/es/components/popover/src/popover2.mjs +111 -66
  136. package/es/components/popover/src/popover2.mjs.map +1 -1
  137. package/es/components/popper/index.mjs +4 -4
  138. package/es/components/popper/src/popper.mjs +25 -32
  139. package/es/components/popper/src/popper.mjs.map +1 -1
  140. package/es/components/popper/src/popper2.mjs +32 -25
  141. package/es/components/popper/src/popper2.mjs.map +1 -1
  142. package/es/components/popper/src/trigger.mjs +31 -121
  143. package/es/components/popper/src/trigger.mjs.map +1 -1
  144. package/es/components/popper/src/trigger2.mjs +121 -31
  145. package/es/components/popper/src/trigger2.mjs.map +1 -1
  146. package/es/components/progress/index.mjs +2 -2
  147. package/es/components/progress/src/progress.mjs +59 -204
  148. package/es/components/progress/src/progress.mjs.map +1 -1
  149. package/es/components/progress/src/progress2.mjs +204 -59
  150. package/es/components/progress/src/progress2.mjs.map +1 -1
  151. package/es/components/radio/index.mjs +4 -4
  152. package/es/components/radio/src/radio-button.mjs +1 -1
  153. package/es/components/radio/src/radio-group.mjs +70 -36
  154. package/es/components/radio/src/radio-group.mjs.map +1 -1
  155. package/es/components/radio/src/radio-group2.mjs +36 -70
  156. package/es/components/radio/src/radio-group2.mjs.map +1 -1
  157. package/es/components/radio/src/radio.mjs +71 -30
  158. package/es/components/radio/src/radio.mjs.map +1 -1
  159. package/es/components/radio/src/radio2.mjs +30 -71
  160. package/es/components/radio/src/radio2.mjs.map +1 -1
  161. package/es/components/result/index.mjs +2 -2
  162. package/es/components/result/src/result.mjs +63 -29
  163. package/es/components/result/src/result.mjs.map +1 -1
  164. package/es/components/result/src/result2.mjs +29 -63
  165. package/es/components/result/src/result2.mjs.map +1 -1
  166. package/es/components/roving-focus-group/index.mjs +3 -3
  167. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  168. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -29
  169. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  170. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +29 -27
  171. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  172. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  173. package/es/components/scrollbar/index.mjs +1 -1
  174. package/es/components/scrollbar/src/bar2.mjs +1 -1
  175. package/es/components/scrollbar/src/thumb.mjs +134 -11
  176. package/es/components/scrollbar/src/thumb.mjs.map +1 -1
  177. package/es/components/scrollbar/src/thumb2.mjs +11 -134
  178. package/es/components/scrollbar/src/thumb2.mjs.map +1 -1
  179. package/es/components/skeleton/index.mjs +2 -2
  180. package/es/components/skeleton/src/skeleton.mjs +22 -49
  181. package/es/components/skeleton/src/skeleton.mjs.map +1 -1
  182. package/es/components/skeleton/src/skeleton2.mjs +49 -22
  183. package/es/components/skeleton/src/skeleton2.mjs.map +1 -1
  184. package/es/components/slider/index.mjs +2 -2
  185. package/es/components/slider/src/slider.mjs +233 -91
  186. package/es/components/slider/src/slider.mjs.map +1 -1
  187. package/es/components/slider/src/slider2.mjs +91 -233
  188. package/es/components/slider/src/slider2.mjs.map +1 -1
  189. package/es/components/statistic/index.mjs +2 -2
  190. package/es/components/statistic/src/statistic.mjs +25 -70
  191. package/es/components/statistic/src/statistic.mjs.map +1 -1
  192. package/es/components/statistic/src/statistic2.mjs +70 -25
  193. package/es/components/statistic/src/statistic2.mjs.map +1 -1
  194. package/es/components/tabs/index.mjs +1 -1
  195. package/es/components/tabs/src/tab-bar.mjs +75 -7
  196. package/es/components/tabs/src/tab-bar.mjs.map +1 -1
  197. package/es/components/tabs/src/tab-bar2.mjs +7 -75
  198. package/es/components/tabs/src/tab-bar2.mjs.map +1 -1
  199. package/es/components/tabs/src/tab-nav.mjs +1 -1
  200. package/es/components/teleport/index.mjs +2 -2
  201. package/es/components/teleport/src/teleport.mjs +44 -18
  202. package/es/components/teleport/src/teleport.mjs.map +1 -1
  203. package/es/components/teleport/src/teleport2.mjs +18 -44
  204. package/es/components/teleport/src/teleport2.mjs.map +1 -1
  205. package/es/components/text/index.mjs +2 -2
  206. package/es/components/text/src/text.mjs +35 -22
  207. package/es/components/text/src/text.mjs.map +1 -1
  208. package/es/components/text/src/text2.mjs +22 -35
  209. package/es/components/text/src/text2.mjs.map +1 -1
  210. package/es/components/tooltip/src/tooltip.mjs +1 -1
  211. package/es/components/tooltip/src/trigger.mjs +1 -1
  212. package/es/components/tooltip/src/trigger2.mjs +1 -1
  213. package/es/components/tooltip-v2/index.mjs +2 -2
  214. package/es/components/tooltip-v2/src/arrow.mjs +37 -22
  215. package/es/components/tooltip-v2/src/arrow.mjs.map +1 -1
  216. package/es/components/tooltip-v2/src/arrow2.mjs +22 -37
  217. package/es/components/tooltip-v2/src/arrow2.mjs.map +1 -1
  218. package/es/components/tooltip-v2/src/content2.mjs +1 -1
  219. package/es/components/tooltip-v2/src/root.mjs +82 -17
  220. package/es/components/tooltip-v2/src/root.mjs.map +1 -1
  221. package/es/components/tooltip-v2/src/root2.mjs +17 -82
  222. package/es/components/tooltip-v2/src/root2.mjs.map +1 -1
  223. package/es/components/tooltip-v2/src/tooltip.mjs +2 -2
  224. package/es/components/tooltip-v2/src/tooltip2.mjs +4 -4
  225. package/es/components/transfer/index.mjs +2 -2
  226. package/es/components/transfer/src/composables/use-check.mjs +1 -1
  227. package/es/components/transfer/src/composables/use-checked-change.mjs +1 -1
  228. package/es/components/transfer/src/transfer-panel.mjs +19 -128
  229. package/es/components/transfer/src/transfer-panel.mjs.map +1 -1
  230. package/es/components/transfer/src/transfer-panel2.mjs +128 -19
  231. package/es/components/transfer/src/transfer-panel2.mjs.map +1 -1
  232. package/es/components/transfer/src/transfer.mjs +162 -69
  233. package/es/components/transfer/src/transfer.mjs.map +1 -1
  234. package/es/components/transfer/src/transfer2.mjs +69 -162
  235. package/es/components/transfer/src/transfer2.mjs.map +1 -1
  236. package/es/components/upload/index.mjs +1 -1
  237. package/es/components/upload/src/upload-list.mjs +177 -26
  238. package/es/components/upload/src/upload-list.mjs.map +1 -1
  239. package/es/components/upload/src/upload-list2.mjs +26 -177
  240. package/es/components/upload/src/upload-list2.mjs.map +1 -1
  241. package/es/components/upload/src/upload2.mjs +1 -1
  242. package/es/components/visual-hidden/index.mjs +3 -3
  243. package/es/components/visual-hidden/src/visual-hidden.mjs +35 -7
  244. package/es/components/visual-hidden/src/visual-hidden.mjs.map +1 -1
  245. package/es/components/visual-hidden/src/visual-hidden2.mjs +7 -35
  246. package/es/components/visual-hidden/src/visual-hidden2.mjs.map +1 -1
  247. package/es/index.mjs +33 -33
  248. package/es/utils/index.mjs +1 -1
  249. package/es/utils/types.d.ts +1 -0
  250. package/es/utils/types.mjs +19 -1
  251. package/es/utils/types.mjs.map +1 -1
  252. package/lib/components/avatar/index.d.ts +3 -0
  253. package/lib/components/avatar/index.js +2 -2
  254. package/lib/components/avatar/src/avatar.d.ts +1 -0
  255. package/lib/components/avatar/src/avatar.js +74 -33
  256. package/lib/components/avatar/src/avatar.js.map +1 -1
  257. package/lib/components/avatar/src/avatar.vue.d.ts +3 -0
  258. package/lib/components/avatar/src/avatar2.js +35 -70
  259. package/lib/components/avatar/src/avatar2.js.map +1 -1
  260. package/lib/components/backtop/index.js +2 -2
  261. package/lib/components/backtop/src/backtop.js +24 -61
  262. package/lib/components/backtop/src/backtop.js.map +1 -1
  263. package/lib/components/backtop/src/backtop2.js +61 -24
  264. package/lib/components/backtop/src/backtop2.js.map +1 -1
  265. package/lib/components/breadcrumb/index.js +4 -4
  266. package/lib/components/breadcrumb/src/breadcrumb-item.js +11 -56
  267. package/lib/components/breadcrumb/src/breadcrumb-item.js.map +1 -1
  268. package/lib/components/breadcrumb/src/breadcrumb-item2.js +56 -11
  269. package/lib/components/breadcrumb/src/breadcrumb-item2.js.map +1 -1
  270. package/lib/components/breadcrumb/src/breadcrumb.js +36 -11
  271. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  272. package/lib/components/breadcrumb/src/breadcrumb2.js +11 -36
  273. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  274. package/lib/components/calendar/src/calendar2.js +1 -1
  275. package/lib/components/calendar/src/date-table.js +37 -87
  276. package/lib/components/calendar/src/date-table.js.map +1 -1
  277. package/lib/components/calendar/src/date-table2.js +87 -37
  278. package/lib/components/calendar/src/date-table2.js.map +1 -1
  279. package/lib/components/calendar/src/use-date-table.js +1 -1
  280. package/lib/components/card/index.js +2 -2
  281. package/lib/components/card/src/card.js +16 -35
  282. package/lib/components/card/src/card.js.map +1 -1
  283. package/lib/components/card/src/card2.js +35 -16
  284. package/lib/components/card/src/card2.js.map +1 -1
  285. package/lib/components/carousel/index.js +2 -2
  286. package/lib/components/carousel/src/carousel.js +57 -164
  287. package/lib/components/carousel/src/carousel.js.map +1 -1
  288. package/lib/components/carousel/src/carousel2.js +164 -57
  289. package/lib/components/carousel/src/carousel2.js.map +1 -1
  290. package/lib/components/cascader/index.js +2 -2
  291. package/lib/components/cascader/src/cascader.js +64 -622
  292. package/lib/components/cascader/src/cascader.js.map +1 -1
  293. package/lib/components/cascader/src/cascader2.js +622 -64
  294. package/lib/components/cascader/src/cascader2.js.map +1 -1
  295. package/lib/components/cascader-panel/src/index.js +1 -1
  296. package/lib/components/cascader-panel/src/menu.js +1 -1
  297. package/lib/components/cascader-panel/src/node.js +209 -116
  298. package/lib/components/cascader-panel/src/node.js.map +1 -1
  299. package/lib/components/cascader-panel/src/node2.js +116 -209
  300. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  301. package/lib/components/cascader-panel/src/store.js +1 -1
  302. package/lib/components/collapse/index.js +2 -2
  303. package/lib/components/collapse/src/collapse.js +19 -30
  304. package/lib/components/collapse/src/collapse.js.map +1 -1
  305. package/lib/components/collapse/src/collapse2.js +30 -19
  306. package/lib/components/collapse/src/collapse2.js.map +1 -1
  307. package/lib/components/collection/index.js +1 -1
  308. package/lib/components/collection/src/collection.js +62 -9
  309. package/lib/components/collection/src/collection.js.map +1 -1
  310. package/lib/components/collection/src/collection2.js +9 -62
  311. package/lib/components/collection/src/collection2.js.map +1 -1
  312. package/lib/components/drawer/index.js +2 -2
  313. package/lib/components/drawer/src/drawer.js +186 -26
  314. package/lib/components/drawer/src/drawer.js.map +1 -1
  315. package/lib/components/drawer/src/drawer2.js +26 -186
  316. package/lib/components/drawer/src/drawer2.js.map +1 -1
  317. package/lib/components/dropdown/index.js +2 -2
  318. package/lib/components/dropdown/src/dropdown-item-impl.js +3 -3
  319. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  320. package/lib/components/dropdown/src/dropdown-menu.js +2 -2
  321. package/lib/components/dropdown/src/dropdown.js +310 -114
  322. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  323. package/lib/components/dropdown/src/dropdown2.js +114 -310
  324. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  325. package/lib/components/empty/index.js +2 -2
  326. package/lib/components/empty/src/empty.js +11 -55
  327. package/lib/components/empty/src/empty.js.map +1 -1
  328. package/lib/components/empty/src/empty2.js +55 -11
  329. package/lib/components/empty/src/empty2.js.map +1 -1
  330. package/lib/components/form/index.js +4 -4
  331. package/lib/components/form/src/form-item.js +47 -330
  332. package/lib/components/form/src/form-item.js.map +1 -1
  333. package/lib/components/form/src/form-item2.js +330 -47
  334. package/lib/components/form/src/form-item2.js.map +1 -1
  335. package/lib/components/form/src/form.js +149 -57
  336. package/lib/components/form/src/form.js.map +1 -1
  337. package/lib/components/form/src/form2.js +57 -149
  338. package/lib/components/form/src/form2.js.map +1 -1
  339. package/lib/components/image/index.js +2 -2
  340. package/lib/components/image/src/image.js +225 -65
  341. package/lib/components/image/src/image.js.map +1 -1
  342. package/lib/components/image/src/image2.js +65 -225
  343. package/lib/components/image/src/image2.js.map +1 -1
  344. package/lib/components/image-viewer/index.js +2 -2
  345. package/lib/components/image-viewer/src/image-viewer.js +401 -39
  346. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  347. package/lib/components/image-viewer/src/image-viewer2.js +39 -401
  348. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  349. package/lib/components/index.js +33 -33
  350. package/lib/components/link/index.js +2 -2
  351. package/lib/components/link/src/link.js +50 -22
  352. package/lib/components/link/src/link.js.map +1 -1
  353. package/lib/components/link/src/link2.js +22 -50
  354. package/lib/components/link/src/link2.js.map +1 -1
  355. package/lib/components/menu/index.js +2 -2
  356. package/lib/components/menu/src/menu-item.js +97 -15
  357. package/lib/components/menu/src/menu-item.js.map +1 -1
  358. package/lib/components/menu/src/menu-item2.js +15 -97
  359. package/lib/components/menu/src/menu-item2.js.map +1 -1
  360. package/lib/components/pagination/src/components/jumper.js +9 -60
  361. package/lib/components/pagination/src/components/jumper.js.map +1 -1
  362. package/lib/components/pagination/src/components/jumper2.js +60 -9
  363. package/lib/components/pagination/src/components/jumper2.js.map +1 -1
  364. package/lib/components/pagination/src/components/pager.js +216 -17
  365. package/lib/components/pagination/src/components/pager.js.map +1 -1
  366. package/lib/components/pagination/src/components/pager2.js +17 -216
  367. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  368. package/lib/components/pagination/src/components/prev.js +38 -19
  369. package/lib/components/pagination/src/components/prev.js.map +1 -1
  370. package/lib/components/pagination/src/components/prev2.js +19 -38
  371. package/lib/components/pagination/src/components/prev2.js.map +1 -1
  372. package/lib/components/pagination/src/components/total.js +28 -7
  373. package/lib/components/pagination/src/components/total.js.map +1 -1
  374. package/lib/components/pagination/src/components/total2.js +7 -28
  375. package/lib/components/pagination/src/components/total2.js.map +1 -1
  376. package/lib/components/pagination/src/pagination.js +4 -4
  377. package/lib/components/popover/index.js +2 -2
  378. package/lib/components/popover/src/popover.js +67 -111
  379. package/lib/components/popover/src/popover.js.map +1 -1
  380. package/lib/components/popover/src/popover2.js +111 -67
  381. package/lib/components/popover/src/popover2.js.map +1 -1
  382. package/lib/components/popper/index.js +4 -4
  383. package/lib/components/popper/src/popper.js +28 -32
  384. package/lib/components/popper/src/popper.js.map +1 -1
  385. package/lib/components/popper/src/popper2.js +32 -28
  386. package/lib/components/popper/src/popper2.js.map +1 -1
  387. package/lib/components/popper/src/trigger.js +32 -121
  388. package/lib/components/popper/src/trigger.js.map +1 -1
  389. package/lib/components/popper/src/trigger2.js +121 -32
  390. package/lib/components/popper/src/trigger2.js.map +1 -1
  391. package/lib/components/progress/index.js +2 -2
  392. package/lib/components/progress/src/progress.js +59 -204
  393. package/lib/components/progress/src/progress.js.map +1 -1
  394. package/lib/components/progress/src/progress2.js +204 -59
  395. package/lib/components/progress/src/progress2.js.map +1 -1
  396. package/lib/components/radio/index.js +4 -4
  397. package/lib/components/radio/src/radio-button.js +1 -1
  398. package/lib/components/radio/src/radio-group.js +70 -37
  399. package/lib/components/radio/src/radio-group.js.map +1 -1
  400. package/lib/components/radio/src/radio-group2.js +37 -70
  401. package/lib/components/radio/src/radio-group2.js.map +1 -1
  402. package/lib/components/radio/src/radio.js +71 -32
  403. package/lib/components/radio/src/radio.js.map +1 -1
  404. package/lib/components/radio/src/radio2.js +32 -71
  405. package/lib/components/radio/src/radio2.js.map +1 -1
  406. package/lib/components/result/index.js +2 -2
  407. package/lib/components/result/src/result.js +63 -31
  408. package/lib/components/result/src/result.js.map +1 -1
  409. package/lib/components/result/src/result2.js +31 -63
  410. package/lib/components/result/src/result2.js.map +1 -1
  411. package/lib/components/roving-focus-group/index.js +2 -2
  412. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  413. package/lib/components/roving-focus-group/src/roving-focus-group.js +27 -33
  414. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  415. package/lib/components/roving-focus-group/src/roving-focus-group2.js +33 -27
  416. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  417. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  418. package/lib/components/scrollbar/index.js +1 -1
  419. package/lib/components/scrollbar/src/bar2.js +1 -1
  420. package/lib/components/scrollbar/src/thumb.js +134 -11
  421. package/lib/components/scrollbar/src/thumb.js.map +1 -1
  422. package/lib/components/scrollbar/src/thumb2.js +11 -134
  423. package/lib/components/scrollbar/src/thumb2.js.map +1 -1
  424. package/lib/components/skeleton/index.js +2 -2
  425. package/lib/components/skeleton/src/skeleton.js +22 -49
  426. package/lib/components/skeleton/src/skeleton.js.map +1 -1
  427. package/lib/components/skeleton/src/skeleton2.js +49 -22
  428. package/lib/components/skeleton/src/skeleton2.js.map +1 -1
  429. package/lib/components/slider/index.js +2 -2
  430. package/lib/components/slider/src/slider.js +233 -92
  431. package/lib/components/slider/src/slider.js.map +1 -1
  432. package/lib/components/slider/src/slider2.js +92 -233
  433. package/lib/components/slider/src/slider2.js.map +1 -1
  434. package/lib/components/statistic/index.js +2 -2
  435. package/lib/components/statistic/src/statistic.js +25 -70
  436. package/lib/components/statistic/src/statistic.js.map +1 -1
  437. package/lib/components/statistic/src/statistic2.js +70 -25
  438. package/lib/components/statistic/src/statistic2.js.map +1 -1
  439. package/lib/components/tabs/index.js +1 -1
  440. package/lib/components/tabs/src/tab-bar.js +75 -7
  441. package/lib/components/tabs/src/tab-bar.js.map +1 -1
  442. package/lib/components/tabs/src/tab-bar2.js +7 -75
  443. package/lib/components/tabs/src/tab-bar2.js.map +1 -1
  444. package/lib/components/tabs/src/tab-nav.js +1 -1
  445. package/lib/components/teleport/index.js +2 -2
  446. package/lib/components/teleport/src/teleport.js +44 -18
  447. package/lib/components/teleport/src/teleport.js.map +1 -1
  448. package/lib/components/teleport/src/teleport2.js +18 -44
  449. package/lib/components/teleport/src/teleport2.js.map +1 -1
  450. package/lib/components/text/index.js +2 -2
  451. package/lib/components/text/src/text.js +35 -22
  452. package/lib/components/text/src/text.js.map +1 -1
  453. package/lib/components/text/src/text2.js +22 -35
  454. package/lib/components/text/src/text2.js.map +1 -1
  455. package/lib/components/tooltip/src/tooltip.js +1 -1
  456. package/lib/components/tooltip/src/trigger.js +1 -1
  457. package/lib/components/tooltip/src/trigger2.js +1 -1
  458. package/lib/components/tooltip-v2/index.js +2 -2
  459. package/lib/components/tooltip-v2/src/arrow.js +37 -23
  460. package/lib/components/tooltip-v2/src/arrow.js.map +1 -1
  461. package/lib/components/tooltip-v2/src/arrow2.js +23 -37
  462. package/lib/components/tooltip-v2/src/arrow2.js.map +1 -1
  463. package/lib/components/tooltip-v2/src/content2.js +1 -1
  464. package/lib/components/tooltip-v2/src/root.js +82 -17
  465. package/lib/components/tooltip-v2/src/root.js.map +1 -1
  466. package/lib/components/tooltip-v2/src/root2.js +17 -82
  467. package/lib/components/tooltip-v2/src/root2.js.map +1 -1
  468. package/lib/components/tooltip-v2/src/tooltip.js +2 -2
  469. package/lib/components/tooltip-v2/src/tooltip2.js +4 -4
  470. package/lib/components/transfer/index.js +2 -2
  471. package/lib/components/transfer/src/composables/use-check.js +1 -1
  472. package/lib/components/transfer/src/composables/use-checked-change.js +1 -1
  473. package/lib/components/transfer/src/transfer-panel.js +21 -128
  474. package/lib/components/transfer/src/transfer-panel.js.map +1 -1
  475. package/lib/components/transfer/src/transfer-panel2.js +128 -21
  476. package/lib/components/transfer/src/transfer-panel2.js.map +1 -1
  477. package/lib/components/transfer/src/transfer.js +162 -73
  478. package/lib/components/transfer/src/transfer.js.map +1 -1
  479. package/lib/components/transfer/src/transfer2.js +73 -162
  480. package/lib/components/transfer/src/transfer2.js.map +1 -1
  481. package/lib/components/upload/index.js +1 -1
  482. package/lib/components/upload/src/upload-list.js +177 -27
  483. package/lib/components/upload/src/upload-list.js.map +1 -1
  484. package/lib/components/upload/src/upload-list2.js +27 -177
  485. package/lib/components/upload/src/upload-list2.js.map +1 -1
  486. package/lib/components/upload/src/upload2.js +1 -1
  487. package/lib/components/visual-hidden/index.js +2 -2
  488. package/lib/components/visual-hidden/src/visual-hidden.js +35 -7
  489. package/lib/components/visual-hidden/src/visual-hidden.js.map +1 -1
  490. package/lib/components/visual-hidden/src/visual-hidden2.js +7 -35
  491. package/lib/components/visual-hidden/src/visual-hidden2.js.map +1 -1
  492. package/lib/index.js +33 -33
  493. package/lib/utils/index.js +1 -0
  494. package/lib/utils/index.js.map +1 -1
  495. package/lib/utils/types.d.ts +1 -0
  496. package/lib/utils/types.js +19 -0
  497. package/lib/utils/types.js.map +1 -1
  498. package/package.json +1 -1
  499. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"form.mjs","sources":["../../../../../../packages/components/form/src/form.ts"],"sourcesContent":["import { componentSizes } from '@element-plus/constants'\nimport {\n buildProps,\n definePropType,\n isArray,\n isBoolean,\n isString,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { FormItemProp } from './form-item'\nimport type { FormRules } from './types'\n\nconst formMetaProps = buildProps({\n /**\n * @description Control the size of components in this form.\n */\n size: {\n type: String,\n values: componentSizes,\n },\n /**\n * @description Whether to disable all components in this form. If set to `true`, it will override the `disabled` prop of the inner component.\n */\n disabled: Boolean,\n} as const)\n\nexport const formProps = buildProps({\n ...formMetaProps,\n /**\n * @description Data of form component.\n */\n model: Object,\n /**\n * @description Validation rules of form.\n */\n rules: {\n type: definePropType<FormRules>(Object),\n },\n /**\n * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required.\n */\n labelPosition: {\n type: String,\n values: ['left', 'right', 'top'],\n default: 'right',\n },\n /**\n * @description Position of asterisk.\n */\n requireAsteriskPosition: {\n type: String,\n values: ['left', 'right'],\n default: 'left',\n },\n /**\n * @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported.\n */\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description Suffix of the label.\n */\n labelSuffix: {\n type: String,\n default: '',\n },\n /**\n * @description Whether the form is inline.\n */\n inline: Boolean,\n /**\n * @description Whether to display the error message inline with the form item.\n */\n inlineMessage: Boolean,\n /**\n * @description Whether to display an icon indicating the validation result.\n */\n statusIcon: Boolean,\n /**\n * @description Whether to show the error message.\n */\n showMessage: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to trigger validation when the `rules` prop is changed.\n */\n validateOnRuleChange: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to hide required fields should have a red asterisk (star) beside their labels.\n */\n hideRequiredAsterisk: {\n type: Boolean,\n default: false,\n },\n /**\n * @description When validation fails, scroll to the first error form entry.\n */\n scrollToError: Boolean,\n /**\n * @description When validation fails, it scrolls to the first error item based on the scrollIntoView option.\n */\n scrollIntoViewOptions: {\n type: [Object, Boolean],\n },\n} as const)\nexport type FormProps = ExtractPropTypes<typeof formProps>\nexport type FormMetaProps = ExtractPropTypes<typeof formMetaProps>\n\nexport const formEmits = {\n validate: (prop: FormItemProp, isValid: boolean, message: string) =>\n (isArray(prop) || isString(prop)) &&\n isBoolean(isValid) &&\n isString(message),\n}\nexport type FormEmits = typeof formEmits\n"],"names":[],"mappings":";;;;;;;AAQA,MAAM,aAAa,GAAG,UAAU,CAAC;AACjC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,cAAc;AAC1B,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,CAAC,CAAC,CAAC;AACS,MAAC,SAAS,GAAG,UAAU,CAAC;AACpC,EAAE,GAAG,aAAa;AAClB,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC;AACpC,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,uBAAuB,EAAE;AAC3B,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC7B,IAAI,OAAO,EAAE,MAAM;AACnB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,MAAM,EAAE,OAAO;AACjB,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,UAAU,EAAE,OAAO;AACrB,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,qBAAqB,EAAE;AACzB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC3B,GAAG;AACH,CAAC,EAAE;AACS,MAAC,SAAS,GAAG;AACzB,EAAE,QAAQ,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,OAAO,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC;AACpH;;;;"}
1
+ {"version":3,"file":"form.mjs","sources":["../../../../../../packages/components/form/src/form.vue"],"sourcesContent":["<template>\n <form :class=\"formClasses\">\n <slot />\n </form>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, reactive, toRefs } from 'vue'\nimport { watch } from '../../config-provider'\nimport { debugWarn, isFunction } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from './hooks'\nimport { formContextKey } from './constants'\nimport { formEmits, formProps } from './form'\nimport { filterFields, useFormLabelWidth } from './utils'\n\nimport type { ValidateFieldsError } from 'async-validator'\nimport type { Arrayable } from '@element-plus/utils'\nimport type {\n FormContext,\n FormItemContext,\n FormValidateCallback,\n FormValidationResult,\n} from './types'\nimport type { FormItemProp } from './form-item'\n\nconst COMPONENT_NAME = 'ElForm'\ndefineOptions({\n name: COMPONENT_NAME,\n})\nconst props = defineProps(formProps)\nconst emit = defineEmits(formEmits)\n\nconst fields: FormItemContext[] = []\n\nconst formSize = useFormSize()\nconst ns = useNamespace('form')\nconst formClasses = computed(() => {\n const { labelPosition, inline } = props\n return [\n ns.b(),\n // todo: in v2.2.0, we can remove default\n // in fact, remove it doesn't affect the final style\n ns.m(formSize.value || 'default'),\n {\n [ns.m(`label-${labelPosition}`)]: labelPosition,\n [ns.m('inline')]: inline,\n },\n ]\n})\n\nconst addField: FormContext['addField'] = (field) => {\n fields.push(field)\n}\n\nconst removeField: FormContext['removeField'] = (field) => {\n if (field.prop) {\n fields.splice(fields.indexOf(field), 1)\n }\n}\n\nconst resetFields: FormContext['resetFields'] = (properties = []) => {\n if (!props.model) {\n debugWarn(COMPONENT_NAME, 'model is required for resetFields to work.')\n return\n }\n filterFields(fields, properties).forEach((field) => field.resetField())\n}\n\nconst clearValidate: FormContext['clearValidate'] = (props = []) => {\n filterFields(fields, props).forEach((field) => field.clearValidate())\n}\n\nconst isValidatable = computed(() => {\n const hasModel = !!props.model\n if (!hasModel) {\n debugWarn(COMPONENT_NAME, 'model is required for validate to work.')\n }\n return hasModel\n})\n\nconst obtainValidateFields = (props: Arrayable<FormItemProp>) => {\n if (fields.length === 0) return []\n\n const filteredFields = filterFields(fields, props)\n if (!filteredFields.length) {\n debugWarn(COMPONENT_NAME, 'please pass correct props!')\n return []\n }\n return filteredFields\n}\n\nconst validate = async (\n callback?: FormValidateCallback\n): FormValidationResult => validateField(undefined, callback)\n\nconst doValidateField = async (\n props: Arrayable<FormItemProp> = []\n): Promise<boolean> => {\n if (!isValidatable.value) return false\n\n const fields = obtainValidateFields(props)\n if (fields.length === 0) return true\n\n let validationErrors: ValidateFieldsError = {}\n for (const field of fields) {\n try {\n await field.validate('')\n } catch (fields) {\n validationErrors = {\n ...validationErrors,\n ...(fields as ValidateFieldsError),\n }\n }\n }\n\n if (Object.keys(validationErrors).length === 0) return true\n return Promise.reject(validationErrors)\n}\n\nconst validateField: FormContext['validateField'] = async (\n modelProps = [],\n callback\n) => {\n const shouldThrow = !isFunction(callback)\n try {\n const result = await doValidateField(modelProps)\n // When result is false meaning that the fields are not validatable\n if (result === true) {\n callback?.(result)\n }\n return result\n } catch (e) {\n if (e instanceof Error) throw e\n\n const invalidFields = e as ValidateFieldsError\n\n if (props.scrollToError) {\n scrollToField(Object.keys(invalidFields)[0])\n }\n callback?.(false, invalidFields)\n return shouldThrow && Promise.reject(invalidFields)\n }\n}\n\nconst scrollToField = (prop: FormItemProp) => {\n const field = filterFields(fields, prop)[0]\n if (field) {\n field.$el?.scrollIntoView(props.scrollIntoViewOptions)\n }\n}\n\nwatch(\n () => props.rules,\n () => {\n if (props.validateOnRuleChange) {\n validate().catch((err) => debugWarn(err))\n }\n },\n { deep: true }\n)\n\nprovide(\n formContextKey,\n reactive({\n ...toRefs(props),\n emit,\n\n resetFields,\n clearValidate,\n validateField,\n addField,\n removeField,\n\n ...useFormLabelWidth(),\n })\n)\n\ndefineExpose({\n /**\n * @description Validate the whole form. Receives a callback or returns `Promise`.\n */\n validate,\n /**\n * @description Validate specified fields.\n */\n validateField,\n /**\n * @description Reset specified fields and remove validation result.\n */\n resetFields,\n /**\n * @description Clear validation message for specified fields.\n */\n clearValidate,\n /**\n * @description Scroll to the specified fields.\n */\n scrollToField,\n})\n</script>\n"],"names":[],"mappings":"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"}
@@ -1,157 +1,64 @@
1
- import { defineComponent, computed, provide, reactive, toRefs, openBlock, createElementBlock, normalizeClass, unref, renderSlot } from 'vue';
2
- import '../../config-provider/index.mjs';
1
+ import '../../../constants/index.mjs';
3
2
  import '../../../utils/index.mjs';
4
- import '../../../hooks/index.mjs';
5
- import './hooks/index.mjs';
6
- import { formContextKey } from './constants.mjs';
7
- import { formProps, formEmits } from './form.mjs';
8
- import { filterFields, useFormLabelWidth } from './utils.mjs';
9
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
10
- import { useFormSize } from './hooks/use-form-common-props.mjs';
11
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
12
- import { debugWarn } from '../../../utils/error.mjs';
13
- import { isFunction } from '@vue/shared';
14
- import { watch } from '../../config-provider/src/for-editor.mjs';
3
+ import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
4
+ import { componentSizes } from '../../../constants/size.mjs';
5
+ import { isArray, isString } from '@vue/shared';
6
+ import { isBoolean } from '../../../utils/types.mjs';
15
7
 
16
- const COMPONENT_NAME = "ElForm";
17
- const __default__ = defineComponent({
18
- name: COMPONENT_NAME
8
+ const formMetaProps = buildProps({
9
+ size: {
10
+ type: String,
11
+ values: componentSizes
12
+ },
13
+ disabled: Boolean
19
14
  });
20
- const _sfc_main = /* @__PURE__ */ defineComponent({
21
- ...__default__,
22
- props: formProps,
23
- emits: formEmits,
24
- setup(__props, { expose, emit }) {
25
- const props = __props;
26
- const fields = [];
27
- const formSize = useFormSize();
28
- const ns = useNamespace("form");
29
- const formClasses = computed(() => {
30
- const { labelPosition, inline } = props;
31
- return [
32
- ns.b(),
33
- ns.m(formSize.value || "default"),
34
- {
35
- [ns.m(`label-${labelPosition}`)]: labelPosition,
36
- [ns.m("inline")]: inline
37
- }
38
- ];
39
- });
40
- const addField = (field) => {
41
- fields.push(field);
42
- };
43
- const removeField = (field) => {
44
- if (field.prop) {
45
- fields.splice(fields.indexOf(field), 1);
46
- }
47
- };
48
- const resetFields = (properties = []) => {
49
- if (!props.model) {
50
- debugWarn(COMPONENT_NAME, "model is required for resetFields to work.");
51
- return;
52
- }
53
- filterFields(fields, properties).forEach((field) => field.resetField());
54
- };
55
- const clearValidate = (props2 = []) => {
56
- filterFields(fields, props2).forEach((field) => field.clearValidate());
57
- };
58
- const isValidatable = computed(() => {
59
- const hasModel = !!props.model;
60
- if (!hasModel) {
61
- debugWarn(COMPONENT_NAME, "model is required for validate to work.");
62
- }
63
- return hasModel;
64
- });
65
- const obtainValidateFields = (props2) => {
66
- if (fields.length === 0)
67
- return [];
68
- const filteredFields = filterFields(fields, props2);
69
- if (!filteredFields.length) {
70
- debugWarn(COMPONENT_NAME, "please pass correct props!");
71
- return [];
72
- }
73
- return filteredFields;
74
- };
75
- const validate = async (callback) => validateField(void 0, callback);
76
- const doValidateField = async (props2 = []) => {
77
- if (!isValidatable.value)
78
- return false;
79
- const fields2 = obtainValidateFields(props2);
80
- if (fields2.length === 0)
81
- return true;
82
- let validationErrors = {};
83
- for (const field of fields2) {
84
- try {
85
- await field.validate("");
86
- } catch (fields3) {
87
- validationErrors = {
88
- ...validationErrors,
89
- ...fields3
90
- };
91
- }
92
- }
93
- if (Object.keys(validationErrors).length === 0)
94
- return true;
95
- return Promise.reject(validationErrors);
96
- };
97
- const validateField = async (modelProps = [], callback) => {
98
- const shouldThrow = !isFunction(callback);
99
- try {
100
- const result = await doValidateField(modelProps);
101
- if (result === true) {
102
- callback == null ? void 0 : callback(result);
103
- }
104
- return result;
105
- } catch (e) {
106
- if (e instanceof Error)
107
- throw e;
108
- const invalidFields = e;
109
- if (props.scrollToError) {
110
- scrollToField(Object.keys(invalidFields)[0]);
111
- }
112
- callback == null ? void 0 : callback(false, invalidFields);
113
- return shouldThrow && Promise.reject(invalidFields);
114
- }
115
- };
116
- const scrollToField = (prop) => {
117
- var _a;
118
- const field = filterFields(fields, prop)[0];
119
- if (field) {
120
- (_a = field.$el) == null ? void 0 : _a.scrollIntoView(props.scrollIntoViewOptions);
121
- }
122
- };
123
- watch(() => props.rules, () => {
124
- if (props.validateOnRuleChange) {
125
- validate().catch((err) => debugWarn(err));
126
- }
127
- }, { deep: true });
128
- provide(formContextKey, reactive({
129
- ...toRefs(props),
130
- emit,
131
- resetFields,
132
- clearValidate,
133
- validateField,
134
- addField,
135
- removeField,
136
- ...useFormLabelWidth()
137
- }));
138
- expose({
139
- validate,
140
- validateField,
141
- resetFields,
142
- clearValidate,
143
- scrollToField
144
- });
145
- return (_ctx, _cache) => {
146
- return openBlock(), createElementBlock("form", {
147
- class: normalizeClass(unref(formClasses))
148
- }, [
149
- renderSlot(_ctx.$slots, "default")
150
- ], 2);
151
- };
15
+ const formProps = buildProps({
16
+ ...formMetaProps,
17
+ model: Object,
18
+ rules: {
19
+ type: definePropType(Object)
20
+ },
21
+ labelPosition: {
22
+ type: String,
23
+ values: ["left", "right", "top"],
24
+ default: "right"
25
+ },
26
+ requireAsteriskPosition: {
27
+ type: String,
28
+ values: ["left", "right"],
29
+ default: "left"
30
+ },
31
+ labelWidth: {
32
+ type: [String, Number],
33
+ default: ""
34
+ },
35
+ labelSuffix: {
36
+ type: String,
37
+ default: ""
38
+ },
39
+ inline: Boolean,
40
+ inlineMessage: Boolean,
41
+ statusIcon: Boolean,
42
+ showMessage: {
43
+ type: Boolean,
44
+ default: true
45
+ },
46
+ validateOnRuleChange: {
47
+ type: Boolean,
48
+ default: true
49
+ },
50
+ hideRequiredAsterisk: {
51
+ type: Boolean,
52
+ default: false
53
+ },
54
+ scrollToError: Boolean,
55
+ scrollIntoViewOptions: {
56
+ type: [Object, Boolean]
152
57
  }
153
58
  });
154
- var Form = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "D:\\workspace\\element-pe\\packages\\components\\form\\src\\form.vue"]]);
59
+ const formEmits = {
60
+ validate: (prop, isValid, message) => (isArray(prop) || isString(prop)) && isBoolean(isValid) && isString(message)
61
+ };
155
62
 
156
- export { Form as default };
63
+ export { formEmits, formProps };
157
64
  //# sourceMappingURL=form2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form2.mjs","sources":["../../../../../../packages/components/form/src/form.vue"],"sourcesContent":["<template>\n <form :class=\"formClasses\">\n <slot />\n </form>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, reactive, toRefs } from 'vue'\nimport { watch } from '../../config-provider'\nimport { debugWarn, isFunction } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from './hooks'\nimport { formContextKey } from './constants'\nimport { formEmits, formProps } from './form'\nimport { filterFields, useFormLabelWidth } from './utils'\n\nimport type { ValidateFieldsError } from 'async-validator'\nimport type { Arrayable } from '@element-plus/utils'\nimport type {\n FormContext,\n FormItemContext,\n FormValidateCallback,\n FormValidationResult,\n} from './types'\nimport type { FormItemProp } from './form-item'\n\nconst COMPONENT_NAME = 'ElForm'\ndefineOptions({\n name: COMPONENT_NAME,\n})\nconst props = defineProps(formProps)\nconst emit = defineEmits(formEmits)\n\nconst fields: FormItemContext[] = []\n\nconst formSize = useFormSize()\nconst ns = useNamespace('form')\nconst formClasses = computed(() => {\n const { labelPosition, inline } = props\n return [\n ns.b(),\n // todo: in v2.2.0, we can remove default\n // in fact, remove it doesn't affect the final style\n ns.m(formSize.value || 'default'),\n {\n [ns.m(`label-${labelPosition}`)]: labelPosition,\n [ns.m('inline')]: inline,\n },\n ]\n})\n\nconst addField: FormContext['addField'] = (field) => {\n fields.push(field)\n}\n\nconst removeField: FormContext['removeField'] = (field) => {\n if (field.prop) {\n fields.splice(fields.indexOf(field), 1)\n }\n}\n\nconst resetFields: FormContext['resetFields'] = (properties = []) => {\n if (!props.model) {\n debugWarn(COMPONENT_NAME, 'model is required for resetFields to work.')\n return\n }\n filterFields(fields, properties).forEach((field) => field.resetField())\n}\n\nconst clearValidate: FormContext['clearValidate'] = (props = []) => {\n filterFields(fields, props).forEach((field) => field.clearValidate())\n}\n\nconst isValidatable = computed(() => {\n const hasModel = !!props.model\n if (!hasModel) {\n debugWarn(COMPONENT_NAME, 'model is required for validate to work.')\n }\n return hasModel\n})\n\nconst obtainValidateFields = (props: Arrayable<FormItemProp>) => {\n if (fields.length === 0) return []\n\n const filteredFields = filterFields(fields, props)\n if (!filteredFields.length) {\n debugWarn(COMPONENT_NAME, 'please pass correct props!')\n return []\n }\n return filteredFields\n}\n\nconst validate = async (\n callback?: FormValidateCallback\n): FormValidationResult => validateField(undefined, callback)\n\nconst doValidateField = async (\n props: Arrayable<FormItemProp> = []\n): Promise<boolean> => {\n if (!isValidatable.value) return false\n\n const fields = obtainValidateFields(props)\n if (fields.length === 0) return true\n\n let validationErrors: ValidateFieldsError = {}\n for (const field of fields) {\n try {\n await field.validate('')\n } catch (fields) {\n validationErrors = {\n ...validationErrors,\n ...(fields as ValidateFieldsError),\n }\n }\n }\n\n if (Object.keys(validationErrors).length === 0) return true\n return Promise.reject(validationErrors)\n}\n\nconst validateField: FormContext['validateField'] = async (\n modelProps = [],\n callback\n) => {\n const shouldThrow = !isFunction(callback)\n try {\n const result = await doValidateField(modelProps)\n // When result is false meaning that the fields are not validatable\n if (result === true) {\n callback?.(result)\n }\n return result\n } catch (e) {\n if (e instanceof Error) throw e\n\n const invalidFields = e as ValidateFieldsError\n\n if (props.scrollToError) {\n scrollToField(Object.keys(invalidFields)[0])\n }\n callback?.(false, invalidFields)\n return shouldThrow && Promise.reject(invalidFields)\n }\n}\n\nconst scrollToField = (prop: FormItemProp) => {\n const field = filterFields(fields, prop)[0]\n if (field) {\n field.$el?.scrollIntoView(props.scrollIntoViewOptions)\n }\n}\n\nwatch(\n () => props.rules,\n () => {\n if (props.validateOnRuleChange) {\n validate().catch((err) => debugWarn(err))\n }\n },\n { deep: true }\n)\n\nprovide(\n formContextKey,\n reactive({\n ...toRefs(props),\n emit,\n\n resetFields,\n clearValidate,\n validateField,\n addField,\n removeField,\n\n ...useFormLabelWidth(),\n })\n)\n\ndefineExpose({\n /**\n * @description Validate the whole form. Receives a callback or returns `Promise`.\n */\n validate,\n /**\n * @description Validate specified fields.\n */\n validateField,\n /**\n * @description Reset specified fields and remove validation result.\n */\n resetFields,\n /**\n * @description Clear validation message for specified fields.\n */\n clearValidate,\n /**\n * @description Scroll to the specified fields.\n */\n scrollToField,\n})\n</script>\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"form2.mjs","sources":["../../../../../../packages/components/form/src/form.ts"],"sourcesContent":["import { componentSizes } from '@element-plus/constants'\nimport {\n buildProps,\n definePropType,\n isArray,\n isBoolean,\n isString,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { FormItemProp } from './form-item'\nimport type { FormRules } from './types'\n\nconst formMetaProps = buildProps({\n /**\n * @description Control the size of components in this form.\n */\n size: {\n type: String,\n values: componentSizes,\n },\n /**\n * @description Whether to disable all components in this form. If set to `true`, it will override the `disabled` prop of the inner component.\n */\n disabled: Boolean,\n} as const)\n\nexport const formProps = buildProps({\n ...formMetaProps,\n /**\n * @description Data of form component.\n */\n model: Object,\n /**\n * @description Validation rules of form.\n */\n rules: {\n type: definePropType<FormRules>(Object),\n },\n /**\n * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required.\n */\n labelPosition: {\n type: String,\n values: ['left', 'right', 'top'],\n default: 'right',\n },\n /**\n * @description Position of asterisk.\n */\n requireAsteriskPosition: {\n type: String,\n values: ['left', 'right'],\n default: 'left',\n },\n /**\n * @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported.\n */\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description Suffix of the label.\n */\n labelSuffix: {\n type: String,\n default: '',\n },\n /**\n * @description Whether the form is inline.\n */\n inline: Boolean,\n /**\n * @description Whether to display the error message inline with the form item.\n */\n inlineMessage: Boolean,\n /**\n * @description Whether to display an icon indicating the validation result.\n */\n statusIcon: Boolean,\n /**\n * @description Whether to show the error message.\n */\n showMessage: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to trigger validation when the `rules` prop is changed.\n */\n validateOnRuleChange: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to hide required fields should have a red asterisk (star) beside their labels.\n */\n hideRequiredAsterisk: {\n type: Boolean,\n default: false,\n },\n /**\n * @description When validation fails, scroll to the first error form entry.\n */\n scrollToError: Boolean,\n /**\n * @description When validation fails, it scrolls to the first error item based on the scrollIntoView option.\n */\n scrollIntoViewOptions: {\n type: [Object, Boolean],\n },\n} as const)\nexport type FormProps = ExtractPropTypes<typeof formProps>\nexport type FormMetaProps = ExtractPropTypes<typeof formMetaProps>\n\nexport const formEmits = {\n validate: (prop: FormItemProp, isValid: boolean, message: string) =>\n (isArray(prop) || isString(prop)) &&\n isBoolean(isValid) &&\n isString(message),\n}\nexport type FormEmits = typeof formEmits\n"],"names":[],"mappings":";;;;;;;AAQA,MAAM,aAAa,GAAG,UAAU,CAAC;AACjC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,cAAc;AAC1B,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,CAAC,CAAC,CAAC;AACS,MAAC,SAAS,GAAG,UAAU,CAAC;AACpC,EAAE,GAAG,aAAa;AAClB,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC;AACpC,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,uBAAuB,EAAE;AAC3B,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC7B,IAAI,OAAO,EAAE,MAAM;AACnB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,MAAM,EAAE,OAAO;AACjB,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,UAAU,EAAE,OAAO;AACrB,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,qBAAqB,EAAE;AACzB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC3B,GAAG;AACH,CAAC,EAAE;AACS,MAAC,SAAS,GAAG;AACzB,EAAE,QAAQ,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,OAAO,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC;AACpH;;;;"}
@@ -1,6 +1,6 @@
1
1
  import '../../utils/index.mjs';
2
- import Image from './src/image2.mjs';
3
- export { imageEmits, imageProps } from './src/image.mjs';
2
+ import Image from './src/image.mjs';
3
+ export { imageEmits, imageProps } from './src/image2.mjs';
4
4
  import { withInstall } from '../../utils/vue/install.mjs';
5
5
 
6
6
  const ElImage = withInstall(Image);
@@ -1,71 +1,232 @@
1
+ import { defineComponent, useAttrs, ref, computed, nextTick, onMounted, openBlock, createElementBlock, normalizeClass, unref, normalizeStyle, renderSlot, createElementVNode, toDisplayString, Fragment, mergeProps, createCommentVNode, createBlock, withCtx } from 'vue';
2
+ import '../../config-provider/index.mjs';
3
+ import { isClient, useThrottleFn, useEventListener } from '@vueuse/core';
4
+ import '../../../hooks/index.mjs';
5
+ import { ElImageViewer } from '../../image-viewer/index.mjs';
1
6
  import '../../../utils/index.mjs';
2
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
3
- import { mutable } from '../../../utils/typescript.mjs';
4
- import { isNumber } from '../../../utils/types.mjs';
7
+ import { imageProps, imageEmits } from './image2.mjs';
8
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
+ import { useLocale } from '../../../hooks/use-locale/index.mjs';
10
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
11
+ import { useAttrs as useAttrs$1 } from '../../../hooks/use-attrs/index.mjs';
12
+ import { isInContainer } from '../../../utils/dom/position.mjs';
13
+ import { isElement } from '../../../utils/types.mjs';
14
+ import { isString } from '@vue/shared';
15
+ import { getScrollContainer } from '../../../utils/dom/scroll.mjs';
16
+ import { watch } from '../../config-provider/src/for-editor.mjs';
5
17
 
6
- const imageProps = buildProps({
7
- hideOnClickModal: {
8
- type: Boolean,
9
- default: false
10
- },
11
- src: {
12
- type: String,
13
- default: ""
14
- },
15
- fit: {
16
- type: String,
17
- values: ["", "contain", "cover", "fill", "none", "scale-down"],
18
- default: ""
19
- },
20
- loading: {
21
- type: String,
22
- values: ["eager", "lazy"]
23
- },
24
- lazy: {
25
- type: Boolean,
26
- default: false
27
- },
28
- scrollContainer: {
29
- type: definePropType([String, Object])
30
- },
31
- previewSrcList: {
32
- type: definePropType(Array),
33
- default: () => mutable([])
34
- },
35
- previewTeleported: {
36
- type: Boolean,
37
- default: false
38
- },
39
- zIndex: {
40
- type: Number
41
- },
42
- initialIndex: {
43
- type: Number,
44
- default: 0
45
- },
46
- infinite: {
47
- type: Boolean,
48
- default: true
49
- },
50
- closeOnPressEscape: {
51
- type: Boolean,
52
- default: true
53
- },
54
- zoomRate: {
55
- type: Number,
56
- default: 1.2
57
- },
58
- widget: {
59
- type: String
18
+ const _hoisted_1 = ["widget"];
19
+ const _hoisted_2 = ["src", "loading"];
20
+ const _hoisted_3 = { key: 0 };
21
+ const __default__ = defineComponent({
22
+ name: "ElImage",
23
+ inheritAttrs: false
24
+ });
25
+ const _sfc_main = /* @__PURE__ */ defineComponent({
26
+ ...__default__,
27
+ props: imageProps,
28
+ emits: imageEmits,
29
+ setup(__props, { emit }) {
30
+ const props = __props;
31
+ let prevOverflow = "";
32
+ const { t } = useLocale();
33
+ const ns = useNamespace("image");
34
+ const rawAttrs = useAttrs();
35
+ const attrs = useAttrs$1();
36
+ const imageSrc = ref();
37
+ const hasLoadError = ref(false);
38
+ const isLoading = ref(true);
39
+ const showViewer = ref(false);
40
+ const container = ref();
41
+ const _scrollContainer = ref();
42
+ const supportLoading = isClient && "loading" in HTMLImageElement.prototype;
43
+ let stopScrollListener;
44
+ let stopWheelListener;
45
+ const containerStyle = computed(() => rawAttrs.style);
46
+ const imageStyle = computed(() => {
47
+ const { fit } = props;
48
+ if (isClient && fit) {
49
+ return { objectFit: fit };
50
+ }
51
+ return {};
52
+ });
53
+ const preview = computed(() => {
54
+ const { previewSrcList } = props;
55
+ return Array.isArray(previewSrcList) && previewSrcList.length > 0;
56
+ });
57
+ const imageIndex = computed(() => {
58
+ const { previewSrcList, initialIndex } = props;
59
+ let previewIndex = initialIndex;
60
+ if (initialIndex > previewSrcList.length - 1) {
61
+ previewIndex = 0;
62
+ }
63
+ return previewIndex;
64
+ });
65
+ const isManual = computed(() => {
66
+ if (props.loading === "eager")
67
+ return false;
68
+ return !supportLoading && props.loading === "lazy" || props.lazy;
69
+ });
70
+ const loadImage = () => {
71
+ if (!isClient)
72
+ return;
73
+ isLoading.value = true;
74
+ hasLoadError.value = false;
75
+ imageSrc.value = props.src;
76
+ };
77
+ function handleLoad(event) {
78
+ isLoading.value = false;
79
+ hasLoadError.value = false;
80
+ emit("load", event);
81
+ }
82
+ function handleError(event) {
83
+ isLoading.value = false;
84
+ hasLoadError.value = true;
85
+ emit("error", event);
86
+ }
87
+ function handleLazyLoad() {
88
+ if (isInContainer(container.value, _scrollContainer.value)) {
89
+ loadImage();
90
+ removeLazyLoadListener();
91
+ }
92
+ }
93
+ const lazyLoadHandler = useThrottleFn(handleLazyLoad, 200);
94
+ async function addLazyLoadListener() {
95
+ var _a;
96
+ if (!isClient)
97
+ return;
98
+ await nextTick();
99
+ const { scrollContainer } = props;
100
+ if (isElement(scrollContainer)) {
101
+ _scrollContainer.value = scrollContainer;
102
+ } else if (isString(scrollContainer) && scrollContainer !== "") {
103
+ _scrollContainer.value = (_a = document.querySelector(scrollContainer)) != null ? _a : void 0;
104
+ } else if (container.value) {
105
+ _scrollContainer.value = getScrollContainer(container.value);
106
+ }
107
+ if (_scrollContainer.value) {
108
+ stopScrollListener = useEventListener(_scrollContainer, "scroll", lazyLoadHandler);
109
+ setTimeout(() => handleLazyLoad(), 100);
110
+ }
111
+ }
112
+ function removeLazyLoadListener() {
113
+ if (!isClient || !_scrollContainer.value || !lazyLoadHandler)
114
+ return;
115
+ stopScrollListener == null ? void 0 : stopScrollListener();
116
+ _scrollContainer.value = void 0;
117
+ }
118
+ function wheelHandler(e) {
119
+ if (!e.ctrlKey)
120
+ return;
121
+ if (e.deltaY < 0) {
122
+ e.preventDefault();
123
+ return false;
124
+ } else if (e.deltaY > 0) {
125
+ e.preventDefault();
126
+ return false;
127
+ }
128
+ }
129
+ function clickHandler() {
130
+ if (!preview.value)
131
+ return;
132
+ stopWheelListener = useEventListener("wheel", wheelHandler, {
133
+ passive: false
134
+ });
135
+ prevOverflow = document.body.style.overflow;
136
+ document.body.style.overflow = "hidden";
137
+ showViewer.value = true;
138
+ emit("show");
139
+ }
140
+ function closeViewer() {
141
+ stopWheelListener == null ? void 0 : stopWheelListener();
142
+ document.body.style.overflow = prevOverflow;
143
+ showViewer.value = false;
144
+ emit("close");
145
+ }
146
+ function switchViewer(val) {
147
+ emit("switch", val);
148
+ }
149
+ watch(() => props.src, () => {
150
+ if (isManual.value) {
151
+ isLoading.value = true;
152
+ hasLoadError.value = false;
153
+ removeLazyLoadListener();
154
+ addLazyLoadListener();
155
+ } else {
156
+ loadImage();
157
+ }
158
+ });
159
+ onMounted(() => {
160
+ if (isManual.value) {
161
+ addLazyLoadListener();
162
+ } else {
163
+ loadImage();
164
+ }
165
+ });
166
+ return (_ctx, _cache) => {
167
+ return openBlock(), createElementBlock("div", {
168
+ ref_key: "container",
169
+ ref: container,
170
+ class: normalizeClass([unref(ns).b(), _ctx.$attrs.class]),
171
+ style: normalizeStyle(unref(containerStyle)),
172
+ widget: _ctx.widget
173
+ }, [
174
+ hasLoadError.value ? renderSlot(_ctx.$slots, "error", { key: 0 }, () => [
175
+ createElementVNode("div", {
176
+ class: normalizeClass(unref(ns).e("error"))
177
+ }, toDisplayString(unref(t)("el.image.error")), 3)
178
+ ]) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
179
+ imageSrc.value !== void 0 ? (openBlock(), createElementBlock("img", mergeProps({ key: 0 }, unref(attrs), {
180
+ src: imageSrc.value,
181
+ loading: _ctx.loading,
182
+ style: unref(imageStyle),
183
+ class: [
184
+ unref(ns).e("inner"),
185
+ unref(preview) && unref(ns).e("preview"),
186
+ isLoading.value && unref(ns).is("loading")
187
+ ],
188
+ onClick: clickHandler,
189
+ onLoad: handleLoad,
190
+ onError: handleError
191
+ }), null, 16, _hoisted_2)) : createCommentVNode("v-if", true),
192
+ isLoading.value ? (openBlock(), createElementBlock("div", {
193
+ key: 1,
194
+ class: normalizeClass(unref(ns).e("wrapper"))
195
+ }, [
196
+ renderSlot(_ctx.$slots, "placeholder", {}, () => [
197
+ createElementVNode("div", {
198
+ class: normalizeClass(unref(ns).e("placeholder"))
199
+ }, null, 2)
200
+ ])
201
+ ], 2)) : createCommentVNode("v-if", true)
202
+ ], 64)),
203
+ unref(preview) ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [
204
+ showViewer.value ? (openBlock(), createBlock(unref(ElImageViewer), {
205
+ key: 0,
206
+ "z-index": _ctx.zIndex,
207
+ "initial-index": unref(imageIndex),
208
+ infinite: _ctx.infinite,
209
+ "zoom-rate": _ctx.zoomRate,
210
+ "url-list": _ctx.previewSrcList,
211
+ "hide-on-click-modal": _ctx.hideOnClickModal,
212
+ teleported: _ctx.previewTeleported,
213
+ "close-on-press-escape": _ctx.closeOnPressEscape,
214
+ onClose: closeViewer,
215
+ onSwitch: switchViewer
216
+ }, {
217
+ default: withCtx(() => [
218
+ _ctx.$slots.viewer ? (openBlock(), createElementBlock("div", _hoisted_3, [
219
+ renderSlot(_ctx.$slots, "viewer")
220
+ ])) : createCommentVNode("v-if", true)
221
+ ]),
222
+ _: 3
223
+ }, 8, ["z-index", "initial-index", "infinite", "zoom-rate", "url-list", "hide-on-click-modal", "teleported", "close-on-press-escape"])) : createCommentVNode("v-if", true)
224
+ ], 64)) : createCommentVNode("v-if", true)
225
+ ], 14, _hoisted_1);
226
+ };
60
227
  }
61
228
  });
62
- const imageEmits = {
63
- load: (evt) => evt instanceof Event,
64
- error: (evt) => evt instanceof Event,
65
- switch: (val) => isNumber(val),
66
- close: () => true,
67
- show: () => true
68
- };
229
+ var Image = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "D:\\workspace\\element-pe\\packages\\components\\image\\src\\image.vue"]]);
69
230
 
70
- export { imageEmits, imageProps };
231
+ export { Image as default };
71
232
  //# sourceMappingURL=image.mjs.map