@element-plus/nightly 0.0.20241203 → 0.0.20241204

Sign up to get free protection for your applications and to get access to all the features.
Files changed (388) hide show
  1. package/dist/index.full.js +3 -3
  2. package/dist/index.full.min.js +3 -3
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +9 -9
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +3 -3
  7. package/dist/locale/af.js +1 -1
  8. package/dist/locale/af.min.js +1 -1
  9. package/dist/locale/af.min.mjs +1 -1
  10. package/dist/locale/af.mjs +1 -1
  11. package/dist/locale/ar-eg.js +1 -1
  12. package/dist/locale/ar-eg.min.js +1 -1
  13. package/dist/locale/ar-eg.min.mjs +1 -1
  14. package/dist/locale/ar-eg.mjs +1 -1
  15. package/dist/locale/ar.js +1 -1
  16. package/dist/locale/ar.min.js +1 -1
  17. package/dist/locale/ar.min.mjs +1 -1
  18. package/dist/locale/ar.mjs +1 -1
  19. package/dist/locale/az.js +1 -1
  20. package/dist/locale/az.min.js +1 -1
  21. package/dist/locale/az.min.mjs +1 -1
  22. package/dist/locale/az.mjs +1 -1
  23. package/dist/locale/bg.js +1 -1
  24. package/dist/locale/bg.min.js +1 -1
  25. package/dist/locale/bg.min.mjs +1 -1
  26. package/dist/locale/bg.mjs +1 -1
  27. package/dist/locale/bn.js +1 -1
  28. package/dist/locale/bn.min.js +1 -1
  29. package/dist/locale/bn.min.mjs +1 -1
  30. package/dist/locale/bn.mjs +1 -1
  31. package/dist/locale/ca.js +1 -1
  32. package/dist/locale/ca.min.js +1 -1
  33. package/dist/locale/ca.min.mjs +1 -1
  34. package/dist/locale/ca.mjs +1 -1
  35. package/dist/locale/ckb.js +1 -1
  36. package/dist/locale/ckb.min.js +1 -1
  37. package/dist/locale/ckb.min.mjs +1 -1
  38. package/dist/locale/ckb.mjs +1 -1
  39. package/dist/locale/cs.js +1 -1
  40. package/dist/locale/cs.min.js +1 -1
  41. package/dist/locale/cs.min.mjs +1 -1
  42. package/dist/locale/cs.mjs +1 -1
  43. package/dist/locale/da.js +1 -1
  44. package/dist/locale/da.min.js +1 -1
  45. package/dist/locale/da.min.mjs +1 -1
  46. package/dist/locale/da.mjs +1 -1
  47. package/dist/locale/de.js +1 -1
  48. package/dist/locale/de.min.js +1 -1
  49. package/dist/locale/de.min.mjs +1 -1
  50. package/dist/locale/de.mjs +1 -1
  51. package/dist/locale/el.js +1 -1
  52. package/dist/locale/el.min.js +1 -1
  53. package/dist/locale/el.min.mjs +1 -1
  54. package/dist/locale/el.mjs +1 -1
  55. package/dist/locale/en.js +1 -1
  56. package/dist/locale/en.min.js +1 -1
  57. package/dist/locale/en.min.mjs +1 -1
  58. package/dist/locale/en.mjs +1 -1
  59. package/dist/locale/eo.js +1 -1
  60. package/dist/locale/eo.min.js +1 -1
  61. package/dist/locale/eo.min.mjs +1 -1
  62. package/dist/locale/eo.mjs +1 -1
  63. package/dist/locale/es.js +1 -1
  64. package/dist/locale/es.min.js +1 -1
  65. package/dist/locale/es.min.mjs +1 -1
  66. package/dist/locale/es.mjs +1 -1
  67. package/dist/locale/et.js +1 -1
  68. package/dist/locale/et.min.js +1 -1
  69. package/dist/locale/et.min.mjs +1 -1
  70. package/dist/locale/et.mjs +1 -1
  71. package/dist/locale/eu.js +1 -1
  72. package/dist/locale/eu.min.js +1 -1
  73. package/dist/locale/eu.min.mjs +1 -1
  74. package/dist/locale/eu.mjs +1 -1
  75. package/dist/locale/fa.js +1 -1
  76. package/dist/locale/fa.min.js +1 -1
  77. package/dist/locale/fa.min.mjs +1 -1
  78. package/dist/locale/fa.mjs +1 -1
  79. package/dist/locale/fi.js +1 -1
  80. package/dist/locale/fi.min.js +1 -1
  81. package/dist/locale/fi.min.mjs +1 -1
  82. package/dist/locale/fi.mjs +1 -1
  83. package/dist/locale/fr.js +1 -1
  84. package/dist/locale/fr.min.js +1 -1
  85. package/dist/locale/fr.min.mjs +1 -1
  86. package/dist/locale/fr.mjs +1 -1
  87. package/dist/locale/he.js +1 -1
  88. package/dist/locale/he.min.js +1 -1
  89. package/dist/locale/he.min.mjs +1 -1
  90. package/dist/locale/he.mjs +1 -1
  91. package/dist/locale/hr.js +1 -1
  92. package/dist/locale/hr.min.js +1 -1
  93. package/dist/locale/hr.min.mjs +1 -1
  94. package/dist/locale/hr.mjs +1 -1
  95. package/dist/locale/hu.js +1 -1
  96. package/dist/locale/hu.min.js +1 -1
  97. package/dist/locale/hu.min.mjs +1 -1
  98. package/dist/locale/hu.mjs +1 -1
  99. package/dist/locale/hy-am.js +1 -1
  100. package/dist/locale/hy-am.min.js +1 -1
  101. package/dist/locale/hy-am.min.mjs +1 -1
  102. package/dist/locale/hy-am.mjs +1 -1
  103. package/dist/locale/id.js +1 -1
  104. package/dist/locale/id.min.js +1 -1
  105. package/dist/locale/id.min.mjs +1 -1
  106. package/dist/locale/id.mjs +1 -1
  107. package/dist/locale/it.js +1 -1
  108. package/dist/locale/it.min.js +1 -1
  109. package/dist/locale/it.min.mjs +1 -1
  110. package/dist/locale/it.mjs +1 -1
  111. package/dist/locale/ja.js +1 -1
  112. package/dist/locale/ja.min.js +1 -1
  113. package/dist/locale/ja.min.mjs +1 -1
  114. package/dist/locale/ja.mjs +1 -1
  115. package/dist/locale/kk.js +1 -1
  116. package/dist/locale/kk.min.js +1 -1
  117. package/dist/locale/kk.min.mjs +1 -1
  118. package/dist/locale/kk.mjs +1 -1
  119. package/dist/locale/km.js +1 -1
  120. package/dist/locale/km.min.js +1 -1
  121. package/dist/locale/km.min.mjs +1 -1
  122. package/dist/locale/km.mjs +1 -1
  123. package/dist/locale/ko.js +1 -1
  124. package/dist/locale/ko.min.js +1 -1
  125. package/dist/locale/ko.min.mjs +1 -1
  126. package/dist/locale/ko.mjs +1 -1
  127. package/dist/locale/ku.js +1 -1
  128. package/dist/locale/ku.min.js +1 -1
  129. package/dist/locale/ku.min.mjs +1 -1
  130. package/dist/locale/ku.mjs +1 -1
  131. package/dist/locale/ky.js +1 -1
  132. package/dist/locale/ky.min.js +1 -1
  133. package/dist/locale/ky.min.mjs +1 -1
  134. package/dist/locale/ky.mjs +1 -1
  135. package/dist/locale/lt.js +1 -1
  136. package/dist/locale/lt.min.js +1 -1
  137. package/dist/locale/lt.min.mjs +1 -1
  138. package/dist/locale/lt.mjs +1 -1
  139. package/dist/locale/lv.js +1 -1
  140. package/dist/locale/lv.min.js +1 -1
  141. package/dist/locale/lv.min.mjs +1 -1
  142. package/dist/locale/lv.mjs +1 -1
  143. package/dist/locale/mg.js +1 -1
  144. package/dist/locale/mg.min.js +1 -1
  145. package/dist/locale/mg.min.mjs +1 -1
  146. package/dist/locale/mg.mjs +1 -1
  147. package/dist/locale/mn.js +1 -1
  148. package/dist/locale/mn.min.js +1 -1
  149. package/dist/locale/mn.min.mjs +1 -1
  150. package/dist/locale/mn.mjs +1 -1
  151. package/dist/locale/ms.js +1 -1
  152. package/dist/locale/ms.min.js +1 -1
  153. package/dist/locale/ms.min.mjs +1 -1
  154. package/dist/locale/ms.mjs +1 -1
  155. package/dist/locale/my.js +1 -1
  156. package/dist/locale/my.min.js +1 -1
  157. package/dist/locale/my.min.mjs +1 -1
  158. package/dist/locale/my.mjs +1 -1
  159. package/dist/locale/nb-no.js +1 -1
  160. package/dist/locale/nb-no.min.js +1 -1
  161. package/dist/locale/nb-no.min.mjs +1 -1
  162. package/dist/locale/nb-no.mjs +1 -1
  163. package/dist/locale/nl.js +1 -1
  164. package/dist/locale/nl.min.js +1 -1
  165. package/dist/locale/nl.min.mjs +1 -1
  166. package/dist/locale/nl.mjs +1 -1
  167. package/dist/locale/pa.js +1 -1
  168. package/dist/locale/pa.min.js +1 -1
  169. package/dist/locale/pa.min.mjs +1 -1
  170. package/dist/locale/pa.mjs +1 -1
  171. package/dist/locale/pl.js +1 -1
  172. package/dist/locale/pl.min.js +1 -1
  173. package/dist/locale/pl.min.mjs +1 -1
  174. package/dist/locale/pl.mjs +1 -1
  175. package/dist/locale/pt-br.js +1 -1
  176. package/dist/locale/pt-br.min.js +1 -1
  177. package/dist/locale/pt-br.min.mjs +1 -1
  178. package/dist/locale/pt-br.mjs +1 -1
  179. package/dist/locale/pt.js +1 -1
  180. package/dist/locale/pt.min.js +1 -1
  181. package/dist/locale/pt.min.mjs +1 -1
  182. package/dist/locale/pt.mjs +1 -1
  183. package/dist/locale/ro.js +1 -1
  184. package/dist/locale/ro.min.js +1 -1
  185. package/dist/locale/ro.min.mjs +1 -1
  186. package/dist/locale/ro.mjs +1 -1
  187. package/dist/locale/ru.js +1 -1
  188. package/dist/locale/ru.min.js +1 -1
  189. package/dist/locale/ru.min.mjs +1 -1
  190. package/dist/locale/ru.mjs +1 -1
  191. package/dist/locale/sk.js +1 -1
  192. package/dist/locale/sk.min.js +1 -1
  193. package/dist/locale/sk.min.mjs +1 -1
  194. package/dist/locale/sk.mjs +1 -1
  195. package/dist/locale/sl.js +1 -1
  196. package/dist/locale/sl.min.js +1 -1
  197. package/dist/locale/sl.min.mjs +1 -1
  198. package/dist/locale/sl.mjs +1 -1
  199. package/dist/locale/sr.js +1 -1
  200. package/dist/locale/sr.min.js +1 -1
  201. package/dist/locale/sr.min.mjs +1 -1
  202. package/dist/locale/sr.mjs +1 -1
  203. package/dist/locale/sv.js +1 -1
  204. package/dist/locale/sv.min.js +1 -1
  205. package/dist/locale/sv.min.mjs +1 -1
  206. package/dist/locale/sv.mjs +1 -1
  207. package/dist/locale/sw.js +1 -1
  208. package/dist/locale/sw.min.js +1 -1
  209. package/dist/locale/sw.min.mjs +1 -1
  210. package/dist/locale/sw.mjs +1 -1
  211. package/dist/locale/ta.js +1 -1
  212. package/dist/locale/ta.min.js +1 -1
  213. package/dist/locale/ta.min.mjs +1 -1
  214. package/dist/locale/ta.mjs +1 -1
  215. package/dist/locale/th.js +1 -1
  216. package/dist/locale/th.min.js +1 -1
  217. package/dist/locale/th.min.mjs +1 -1
  218. package/dist/locale/th.mjs +1 -1
  219. package/dist/locale/tk.js +1 -1
  220. package/dist/locale/tk.min.js +1 -1
  221. package/dist/locale/tk.min.mjs +1 -1
  222. package/dist/locale/tk.mjs +1 -1
  223. package/dist/locale/tr.js +1 -1
  224. package/dist/locale/tr.min.js +1 -1
  225. package/dist/locale/tr.min.mjs +1 -1
  226. package/dist/locale/tr.mjs +1 -1
  227. package/dist/locale/ug-cn.js +1 -1
  228. package/dist/locale/ug-cn.min.js +1 -1
  229. package/dist/locale/ug-cn.min.mjs +1 -1
  230. package/dist/locale/ug-cn.mjs +1 -1
  231. package/dist/locale/uk.js +1 -1
  232. package/dist/locale/uk.min.js +1 -1
  233. package/dist/locale/uk.min.mjs +1 -1
  234. package/dist/locale/uk.mjs +1 -1
  235. package/dist/locale/uz-uz.js +1 -1
  236. package/dist/locale/uz-uz.min.js +1 -1
  237. package/dist/locale/uz-uz.min.mjs +1 -1
  238. package/dist/locale/uz-uz.mjs +1 -1
  239. package/dist/locale/vi.js +1 -1
  240. package/dist/locale/vi.min.js +1 -1
  241. package/dist/locale/vi.min.mjs +1 -1
  242. package/dist/locale/vi.mjs +1 -1
  243. package/dist/locale/zh-cn.js +1 -1
  244. package/dist/locale/zh-cn.min.js +1 -1
  245. package/dist/locale/zh-cn.min.mjs +1 -1
  246. package/dist/locale/zh-cn.mjs +1 -1
  247. package/dist/locale/zh-tw.js +1 -1
  248. package/dist/locale/zh-tw.min.js +1 -1
  249. package/dist/locale/zh-tw.min.mjs +1 -1
  250. package/dist/locale/zh-tw.mjs +1 -1
  251. package/es/components/col/index.mjs +2 -2
  252. package/es/components/col/src/col.mjs +43 -64
  253. package/es/components/col/src/col.mjs.map +1 -1
  254. package/es/components/col/src/col2.mjs +64 -43
  255. package/es/components/col/src/col2.mjs.map +1 -1
  256. package/es/components/countdown/index.mjs +2 -2
  257. package/es/components/countdown/src/countdown.mjs +22 -79
  258. package/es/components/countdown/src/countdown.mjs.map +1 -1
  259. package/es/components/countdown/src/countdown2.mjs +79 -22
  260. package/es/components/countdown/src/countdown2.mjs.map +1 -1
  261. package/es/components/dropdown/src/dropdown-item-impl.mjs +1 -1
  262. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  263. package/es/components/dropdown/src/dropdown.mjs +1 -1
  264. package/es/components/empty/index.mjs +2 -2
  265. package/es/components/empty/src/empty.mjs +52 -11
  266. package/es/components/empty/src/empty.mjs.map +1 -1
  267. package/es/components/empty/src/empty2.mjs +11 -52
  268. package/es/components/empty/src/empty2.mjs.map +1 -1
  269. package/es/components/index.mjs +7 -7
  270. package/es/components/mention/index.mjs +2 -2
  271. package/es/components/mention/src/mention.mjs +282 -62
  272. package/es/components/mention/src/mention.mjs.map +1 -1
  273. package/es/components/mention/src/mention2.mjs +62 -282
  274. package/es/components/mention/src/mention2.mjs.map +1 -1
  275. package/es/components/message/index.mjs +1 -1
  276. package/es/components/message/src/message.mjs +91 -145
  277. package/es/components/message/src/message.mjs.map +1 -1
  278. package/es/components/message/src/message2.mjs +145 -91
  279. package/es/components/message/src/message2.mjs.map +1 -1
  280. package/es/components/message/src/method.mjs +2 -2
  281. package/es/components/notification/index.mjs +1 -1
  282. package/es/components/notification/src/notification.mjs +68 -142
  283. package/es/components/notification/src/notification.mjs.map +1 -1
  284. package/es/components/notification/src/notification2.mjs +142 -68
  285. package/es/components/notification/src/notification2.mjs.map +1 -1
  286. package/es/components/notification/src/notify.mjs +3 -3
  287. package/es/components/notification/src/notify.mjs.map +1 -1
  288. package/es/components/pagination/src/components/pager.mjs +209 -16
  289. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  290. package/es/components/pagination/src/components/pager2.mjs +16 -209
  291. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  292. package/es/components/pagination/src/pagination.mjs +1 -1
  293. package/es/components/rate/index.mjs +2 -2
  294. package/es/components/rate/src/rate.mjs +258 -83
  295. package/es/components/rate/src/rate.mjs.map +1 -1
  296. package/es/components/rate/src/rate2.mjs +83 -258
  297. package/es/components/rate/src/rate2.mjs.map +1 -1
  298. package/es/components/roving-focus-group/index.mjs +3 -3
  299. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  300. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -27
  301. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  302. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +27 -27
  303. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  304. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  305. package/es/components/tooltip-v2/index.mjs +1 -1
  306. package/es/components/tooltip-v2/src/tooltip.mjs +1 -1
  307. package/es/components/tooltip-v2/src/tooltip2.mjs +2 -2
  308. package/es/components/tooltip-v2/src/trigger.mjs +89 -12
  309. package/es/components/tooltip-v2/src/trigger.mjs.map +1 -1
  310. package/es/components/tooltip-v2/src/trigger2.mjs +12 -89
  311. package/es/components/tooltip-v2/src/trigger2.mjs.map +1 -1
  312. package/es/directives/click-outside/index.mjs +1 -1
  313. package/es/hooks/use-focus-controller/index.mjs +1 -1
  314. package/es/hooks/use-lockscreen/index.mjs +1 -1
  315. package/es/index.mjs +7 -7
  316. package/es/version.d.ts +1 -1
  317. package/es/version.mjs +1 -1
  318. package/es/version.mjs.map +1 -1
  319. package/lib/components/col/index.js +2 -2
  320. package/lib/components/col/src/col.js +43 -64
  321. package/lib/components/col/src/col.js.map +1 -1
  322. package/lib/components/col/src/col2.js +64 -43
  323. package/lib/components/col/src/col2.js.map +1 -1
  324. package/lib/components/countdown/index.js +2 -2
  325. package/lib/components/countdown/src/countdown.js +23 -79
  326. package/lib/components/countdown/src/countdown.js.map +1 -1
  327. package/lib/components/countdown/src/countdown2.js +79 -23
  328. package/lib/components/countdown/src/countdown2.js.map +1 -1
  329. package/lib/components/dropdown/src/dropdown-item-impl.js +1 -1
  330. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  331. package/lib/components/dropdown/src/dropdown.js +1 -1
  332. package/lib/components/empty/index.js +2 -2
  333. package/lib/components/empty/src/empty.js +52 -11
  334. package/lib/components/empty/src/empty.js.map +1 -1
  335. package/lib/components/empty/src/empty2.js +11 -52
  336. package/lib/components/empty/src/empty2.js.map +1 -1
  337. package/lib/components/index.js +7 -7
  338. package/lib/components/mention/index.js +2 -2
  339. package/lib/components/mention/src/mention.js +280 -61
  340. package/lib/components/mention/src/mention.js.map +1 -1
  341. package/lib/components/mention/src/mention2.js +61 -280
  342. package/lib/components/mention/src/mention2.js.map +1 -1
  343. package/lib/components/message/index.js +1 -1
  344. package/lib/components/message/src/message.js +93 -144
  345. package/lib/components/message/src/message.js.map +1 -1
  346. package/lib/components/message/src/message2.js +144 -93
  347. package/lib/components/message/src/message2.js.map +1 -1
  348. package/lib/components/message/src/method.js +2 -2
  349. package/lib/components/notification/index.js +1 -1
  350. package/lib/components/notification/src/notification.js +69 -141
  351. package/lib/components/notification/src/notification.js.map +1 -1
  352. package/lib/components/notification/src/notification2.js +141 -69
  353. package/lib/components/notification/src/notification2.js.map +1 -1
  354. package/lib/components/notification/src/notify.js +3 -3
  355. package/lib/components/notification/src/notify.js.map +1 -1
  356. package/lib/components/pagination/src/components/pager.js +209 -16
  357. package/lib/components/pagination/src/components/pager.js.map +1 -1
  358. package/lib/components/pagination/src/components/pager2.js +16 -209
  359. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  360. package/lib/components/pagination/src/pagination.js +1 -1
  361. package/lib/components/rate/index.js +2 -2
  362. package/lib/components/rate/src/rate.js +257 -83
  363. package/lib/components/rate/src/rate.js.map +1 -1
  364. package/lib/components/rate/src/rate2.js +83 -257
  365. package/lib/components/rate/src/rate2.js.map +1 -1
  366. package/lib/components/roving-focus-group/index.js +2 -2
  367. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  368. package/lib/components/roving-focus-group/src/roving-focus-group.js +27 -31
  369. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  370. package/lib/components/roving-focus-group/src/roving-focus-group2.js +31 -27
  371. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  372. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  373. package/lib/components/tooltip-v2/index.js +1 -1
  374. package/lib/components/tooltip-v2/src/tooltip.js +1 -1
  375. package/lib/components/tooltip-v2/src/tooltip2.js +2 -2
  376. package/lib/components/tooltip-v2/src/trigger.js +89 -12
  377. package/lib/components/tooltip-v2/src/trigger.js.map +1 -1
  378. package/lib/components/tooltip-v2/src/trigger2.js +12 -89
  379. package/lib/components/tooltip-v2/src/trigger2.js.map +1 -1
  380. package/lib/directives/click-outside/index.js +1 -1
  381. package/lib/hooks/use-focus-controller/index.js +1 -1
  382. package/lib/hooks/use-lockscreen/index.js +1 -1
  383. package/lib/index.js +7 -7
  384. package/lib/version.d.ts +1 -1
  385. package/lib/version.js +1 -1
  386. package/lib/version.js.map +1 -1
  387. package/package.json +2 -2
  388. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"pager.mjs","sources":["../../../../../../../packages/components/pagination/src/components/pager.ts"],"sourcesContent":["import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Pager from './pager.vue'\n\nexport const paginationPagerProps = buildProps({\n currentPage: {\n type: Number,\n default: 1,\n },\n pageCount: {\n type: Number,\n required: true,\n },\n pagerCount: {\n type: Number,\n default: 7,\n },\n disabled: Boolean,\n} as const)\n\nexport type PaginationPagerProps = ExtractPropTypes<typeof paginationPagerProps>\n\nexport type PagerInstance = InstanceType<typeof Pager>\n"],"names":[],"mappings":";;AACY,MAAC,oBAAoB,GAAG,UAAU,CAAC;AAC/C,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,QAAQ,EAAE,IAAI;AAClB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,CAAC;;;;"}
1
+ {"version":3,"file":"pager.mjs","sources":["../../../../../../../packages/components/pagination/src/components/pager.vue"],"sourcesContent":["<template>\n <ul :class=\"nsPager.b()\" @click=\"onPagerClick\" @keyup.enter=\"onEnter\">\n <li\n v-if=\"pageCount > 0\"\n :class=\"[\n nsPager.is('active', currentPage === 1),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === 1\"\n :aria-label=\"t('el.pagination.currentPage', { pager: 1 })\"\n :tabindex=\"tabindex\"\n >\n 1\n </li>\n <li\n v-if=\"showPrevMore\"\n :class=\"prevMoreKls\"\n :tabindex=\"tabindex\"\n :aria-label=\"t('el.pagination.prevPages', { pager: pagerCount - 2 })\"\n @mouseenter=\"onMouseEnter(true)\"\n @mouseleave=\"quickPrevHover = false\"\n @focus=\"onFocus(true)\"\n @blur=\"quickPrevFocus = false\"\n >\n <d-arrow-left v-if=\"(quickPrevHover || quickPrevFocus) && !disabled\" />\n <more-filled v-else />\n </li>\n <li\n v-for=\"pager in pagers\"\n :key=\"pager\"\n :class=\"[\n nsPager.is('active', currentPage === pager),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === pager\"\n :aria-label=\"t('el.pagination.currentPage', { pager })\"\n :tabindex=\"tabindex\"\n >\n {{ pager }}\n </li>\n <li\n v-if=\"showNextMore\"\n :class=\"nextMoreKls\"\n :tabindex=\"tabindex\"\n :aria-label=\"t('el.pagination.nextPages', { pager: pagerCount - 2 })\"\n @mouseenter=\"onMouseEnter()\"\n @mouseleave=\"quickNextHover = false\"\n @focus=\"onFocus()\"\n @blur=\"quickNextFocus = false\"\n >\n <d-arrow-right v-if=\"(quickNextHover || quickNextFocus) && !disabled\" />\n <more-filled v-else />\n </li>\n <li\n v-if=\"pageCount > 1\"\n :class=\"[\n nsPager.is('active', currentPage === pageCount),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === pageCount\"\n :aria-label=\"t('el.pagination.currentPage', { pager: pageCount })\"\n :tabindex=\"tabindex\"\n >\n {{ pageCount }}\n </li>\n </ul>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref, watchEffect } from 'vue'\nimport { DArrowLeft, DArrowRight, MoreFilled } from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { paginationPagerProps } from './pager'\ndefineOptions({\n name: 'ElPaginationPager',\n})\nconst props = defineProps(paginationPagerProps)\nconst emit = defineEmits(['change'])\nconst nsPager = useNamespace('pager')\nconst nsIcon = useNamespace('icon')\nconst { t } = useLocale()\n\nconst showPrevMore = ref(false)\nconst showNextMore = ref(false)\nconst quickPrevHover = ref(false)\nconst quickNextHover = ref(false)\nconst quickPrevFocus = ref(false)\nconst quickNextFocus = ref(false)\nconst pagers = computed(() => {\n const pagerCount = props.pagerCount\n const halfPagerCount = (pagerCount - 1) / 2\n const currentPage = Number(props.currentPage)\n const pageCount = Number(props.pageCount)\n let showPrevMore = false\n let showNextMore = false\n if (pageCount > pagerCount) {\n if (currentPage > pagerCount - halfPagerCount) {\n showPrevMore = true\n }\n if (currentPage < pageCount - halfPagerCount) {\n showNextMore = true\n }\n }\n const array: number[] = []\n if (showPrevMore && !showNextMore) {\n const startPage = pageCount - (pagerCount - 2)\n for (let i = startPage; i < pageCount; i++) {\n array.push(i)\n }\n } else if (!showPrevMore && showNextMore) {\n for (let i = 2; i < pagerCount; i++) {\n array.push(i)\n }\n } else if (showPrevMore && showNextMore) {\n const offset = Math.floor(pagerCount / 2) - 1\n for (let i = currentPage - offset; i <= currentPage + offset; i++) {\n array.push(i)\n }\n } else {\n for (let i = 2; i < pageCount; i++) {\n array.push(i)\n }\n }\n return array\n})\n\nconst prevMoreKls = computed(() => [\n 'more',\n 'btn-quickprev',\n nsIcon.b(),\n nsPager.is('disabled', props.disabled),\n])\nconst nextMoreKls = computed(() => [\n 'more',\n 'btn-quicknext',\n nsIcon.b(),\n nsPager.is('disabled', props.disabled),\n])\n\nconst tabindex = computed(() => (props.disabled ? -1 : 0))\nwatchEffect(() => {\n const halfPagerCount = (props.pagerCount - 1) / 2\n showPrevMore.value = false\n showNextMore.value = false\n if (props.pageCount! > props.pagerCount) {\n if (props.currentPage > props.pagerCount - halfPagerCount) {\n showPrevMore.value = true\n }\n if (props.currentPage < props.pageCount! - halfPagerCount) {\n showNextMore.value = true\n }\n }\n})\nfunction onMouseEnter(forward = false) {\n if (props.disabled) return\n if (forward) {\n quickPrevHover.value = true\n } else {\n quickNextHover.value = true\n }\n}\nfunction onFocus(forward = false) {\n if (forward) {\n quickPrevFocus.value = true\n } else {\n quickNextFocus.value = true\n }\n}\nfunction onEnter(e: UIEvent) {\n const target = e.target as HTMLElement\n if (\n target.tagName.toLowerCase() === 'li' &&\n Array.from(target.classList).includes('number')\n ) {\n const newPage = Number(target.textContent)\n if (newPage !== props.currentPage) {\n emit('change', newPage)\n }\n } else if (\n target.tagName.toLowerCase() === 'li' &&\n Array.from(target.classList).includes('more')\n ) {\n onPagerClick(e)\n }\n}\nfunction onPagerClick(event: UIEvent) {\n const target = event.target as HTMLElement\n if (target.tagName.toLowerCase() === 'ul' || props.disabled) {\n return\n }\n let newPage = Number(target.textContent)\n const pageCount = props.pageCount!\n const currentPage = props.currentPage\n const pagerCountOffset = props.pagerCount - 2\n if (target.className.includes('more')) {\n if (target.className.includes('quickprev')) {\n newPage = currentPage - pagerCountOffset\n } else if (target.className.includes('quicknext')) {\n newPage = currentPage + pagerCountOffset\n }\n }\n if (!Number.isNaN(+newPage)) {\n if (newPage < 1) {\n newPage = 1\n }\n if (newPage > pageCount) {\n newPage = pageCount\n }\n }\n if (newPage !== currentPage) {\n emit('change', newPage)\n }\n}\n</script>\n"],"names":["showPrevMore","showNextMore"],"mappings":"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"}
@@ -1,213 +1,20 @@
1
- import { defineComponent, ref, computed, watchEffect, openBlock, createElementBlock, normalizeClass, unref, withKeys, createCommentVNode, createBlock, Fragment, renderList, toDisplayString } from 'vue';
2
- import { DArrowLeft, MoreFilled, DArrowRight } from '@element-plus/icons-vue';
3
- import { paginationPagerProps } from './pager.mjs';
4
- import _export_sfc from '../../../../_virtual/plugin-vue_export-helper.mjs';
5
- import { useNamespace } from '../../../../hooks/use-namespace/index.mjs';
6
- import { useLocale } from '../../../../hooks/use-locale/index.mjs';
1
+ import { buildProps } from '../../../../utils/vue/props/runtime.mjs';
7
2
 
8
- const __default__ = defineComponent({
9
- name: "ElPaginationPager"
3
+ const paginationPagerProps = buildProps({
4
+ currentPage: {
5
+ type: Number,
6
+ default: 1
7
+ },
8
+ pageCount: {
9
+ type: Number,
10
+ required: true
11
+ },
12
+ pagerCount: {
13
+ type: Number,
14
+ default: 7
15
+ },
16
+ disabled: Boolean
10
17
  });
11
- const _sfc_main = /* @__PURE__ */ defineComponent({
12
- ...__default__,
13
- props: paginationPagerProps,
14
- emits: ["change"],
15
- setup(__props, { emit }) {
16
- const props = __props;
17
- const nsPager = useNamespace("pager");
18
- const nsIcon = useNamespace("icon");
19
- const { t } = useLocale();
20
- const showPrevMore = ref(false);
21
- const showNextMore = ref(false);
22
- const quickPrevHover = ref(false);
23
- const quickNextHover = ref(false);
24
- const quickPrevFocus = ref(false);
25
- const quickNextFocus = ref(false);
26
- const pagers = computed(() => {
27
- const pagerCount = props.pagerCount;
28
- const halfPagerCount = (pagerCount - 1) / 2;
29
- const currentPage = Number(props.currentPage);
30
- const pageCount = Number(props.pageCount);
31
- let showPrevMore2 = false;
32
- let showNextMore2 = false;
33
- if (pageCount > pagerCount) {
34
- if (currentPage > pagerCount - halfPagerCount) {
35
- showPrevMore2 = true;
36
- }
37
- if (currentPage < pageCount - halfPagerCount) {
38
- showNextMore2 = true;
39
- }
40
- }
41
- const array = [];
42
- if (showPrevMore2 && !showNextMore2) {
43
- const startPage = pageCount - (pagerCount - 2);
44
- for (let i = startPage; i < pageCount; i++) {
45
- array.push(i);
46
- }
47
- } else if (!showPrevMore2 && showNextMore2) {
48
- for (let i = 2; i < pagerCount; i++) {
49
- array.push(i);
50
- }
51
- } else if (showPrevMore2 && showNextMore2) {
52
- const offset = Math.floor(pagerCount / 2) - 1;
53
- for (let i = currentPage - offset; i <= currentPage + offset; i++) {
54
- array.push(i);
55
- }
56
- } else {
57
- for (let i = 2; i < pageCount; i++) {
58
- array.push(i);
59
- }
60
- }
61
- return array;
62
- });
63
- const prevMoreKls = computed(() => [
64
- "more",
65
- "btn-quickprev",
66
- nsIcon.b(),
67
- nsPager.is("disabled", props.disabled)
68
- ]);
69
- const nextMoreKls = computed(() => [
70
- "more",
71
- "btn-quicknext",
72
- nsIcon.b(),
73
- nsPager.is("disabled", props.disabled)
74
- ]);
75
- const tabindex = computed(() => props.disabled ? -1 : 0);
76
- watchEffect(() => {
77
- const halfPagerCount = (props.pagerCount - 1) / 2;
78
- showPrevMore.value = false;
79
- showNextMore.value = false;
80
- if (props.pageCount > props.pagerCount) {
81
- if (props.currentPage > props.pagerCount - halfPagerCount) {
82
- showPrevMore.value = true;
83
- }
84
- if (props.currentPage < props.pageCount - halfPagerCount) {
85
- showNextMore.value = true;
86
- }
87
- }
88
- });
89
- function onMouseEnter(forward = false) {
90
- if (props.disabled)
91
- return;
92
- if (forward) {
93
- quickPrevHover.value = true;
94
- } else {
95
- quickNextHover.value = true;
96
- }
97
- }
98
- function onFocus(forward = false) {
99
- if (forward) {
100
- quickPrevFocus.value = true;
101
- } else {
102
- quickNextFocus.value = true;
103
- }
104
- }
105
- function onEnter(e) {
106
- const target = e.target;
107
- if (target.tagName.toLowerCase() === "li" && Array.from(target.classList).includes("number")) {
108
- const newPage = Number(target.textContent);
109
- if (newPage !== props.currentPage) {
110
- emit("change", newPage);
111
- }
112
- } else if (target.tagName.toLowerCase() === "li" && Array.from(target.classList).includes("more")) {
113
- onPagerClick(e);
114
- }
115
- }
116
- function onPagerClick(event) {
117
- const target = event.target;
118
- if (target.tagName.toLowerCase() === "ul" || props.disabled) {
119
- return;
120
- }
121
- let newPage = Number(target.textContent);
122
- const pageCount = props.pageCount;
123
- const currentPage = props.currentPage;
124
- const pagerCountOffset = props.pagerCount - 2;
125
- if (target.className.includes("more")) {
126
- if (target.className.includes("quickprev")) {
127
- newPage = currentPage - pagerCountOffset;
128
- } else if (target.className.includes("quicknext")) {
129
- newPage = currentPage + pagerCountOffset;
130
- }
131
- }
132
- if (!Number.isNaN(+newPage)) {
133
- if (newPage < 1) {
134
- newPage = 1;
135
- }
136
- if (newPage > pageCount) {
137
- newPage = pageCount;
138
- }
139
- }
140
- if (newPage !== currentPage) {
141
- emit("change", newPage);
142
- }
143
- }
144
- return (_ctx, _cache) => {
145
- return openBlock(), createElementBlock("ul", {
146
- class: normalizeClass(unref(nsPager).b()),
147
- onClick: onPagerClick,
148
- onKeyup: withKeys(onEnter, ["enter"])
149
- }, [
150
- _ctx.pageCount > 0 ? (openBlock(), createElementBlock("li", {
151
- key: 0,
152
- class: normalizeClass([[
153
- unref(nsPager).is("active", _ctx.currentPage === 1),
154
- unref(nsPager).is("disabled", _ctx.disabled)
155
- ], "number"]),
156
- "aria-current": _ctx.currentPage === 1,
157
- "aria-label": unref(t)("el.pagination.currentPage", { pager: 1 }),
158
- tabindex: unref(tabindex)
159
- }, " 1 ", 10, ["aria-current", "aria-label", "tabindex"])) : createCommentVNode("v-if", true),
160
- showPrevMore.value ? (openBlock(), createElementBlock("li", {
161
- key: 1,
162
- class: normalizeClass(unref(prevMoreKls)),
163
- tabindex: unref(tabindex),
164
- "aria-label": unref(t)("el.pagination.prevPages", { pager: _ctx.pagerCount - 2 }),
165
- onMouseenter: ($event) => onMouseEnter(true),
166
- onMouseleave: ($event) => quickPrevHover.value = false,
167
- onFocus: ($event) => onFocus(true),
168
- onBlur: ($event) => quickPrevFocus.value = false
169
- }, [
170
- (quickPrevHover.value || quickPrevFocus.value) && !_ctx.disabled ? (openBlock(), createBlock(unref(DArrowLeft), { key: 0 })) : (openBlock(), createBlock(unref(MoreFilled), { key: 1 }))
171
- ], 42, ["tabindex", "aria-label", "onMouseenter", "onMouseleave", "onFocus", "onBlur"])) : createCommentVNode("v-if", true),
172
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(pagers), (pager) => {
173
- return openBlock(), createElementBlock("li", {
174
- key: pager,
175
- class: normalizeClass([[
176
- unref(nsPager).is("active", _ctx.currentPage === pager),
177
- unref(nsPager).is("disabled", _ctx.disabled)
178
- ], "number"]),
179
- "aria-current": _ctx.currentPage === pager,
180
- "aria-label": unref(t)("el.pagination.currentPage", { pager }),
181
- tabindex: unref(tabindex)
182
- }, toDisplayString(pager), 11, ["aria-current", "aria-label", "tabindex"]);
183
- }), 128)),
184
- showNextMore.value ? (openBlock(), createElementBlock("li", {
185
- key: 2,
186
- class: normalizeClass(unref(nextMoreKls)),
187
- tabindex: unref(tabindex),
188
- "aria-label": unref(t)("el.pagination.nextPages", { pager: _ctx.pagerCount - 2 }),
189
- onMouseenter: ($event) => onMouseEnter(),
190
- onMouseleave: ($event) => quickNextHover.value = false,
191
- onFocus: ($event) => onFocus(),
192
- onBlur: ($event) => quickNextFocus.value = false
193
- }, [
194
- (quickNextHover.value || quickNextFocus.value) && !_ctx.disabled ? (openBlock(), createBlock(unref(DArrowRight), { key: 0 })) : (openBlock(), createBlock(unref(MoreFilled), { key: 1 }))
195
- ], 42, ["tabindex", "aria-label", "onMouseenter", "onMouseleave", "onFocus", "onBlur"])) : createCommentVNode("v-if", true),
196
- _ctx.pageCount > 1 ? (openBlock(), createElementBlock("li", {
197
- key: 3,
198
- class: normalizeClass([[
199
- unref(nsPager).is("active", _ctx.currentPage === _ctx.pageCount),
200
- unref(nsPager).is("disabled", _ctx.disabled)
201
- ], "number"]),
202
- "aria-current": _ctx.currentPage === _ctx.pageCount,
203
- "aria-label": unref(t)("el.pagination.currentPage", { pager: _ctx.pageCount }),
204
- tabindex: unref(tabindex)
205
- }, toDisplayString(_ctx.pageCount), 11, ["aria-current", "aria-label", "tabindex"])) : createCommentVNode("v-if", true)
206
- ], 42, ["onKeyup"]);
207
- };
208
- }
209
- });
210
- var Pager = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "pager.vue"]]);
211
18
 
212
- export { Pager as default };
19
+ export { paginationPagerProps };
213
20
  //# sourceMappingURL=pager2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"pager2.mjs","sources":["../../../../../../../packages/components/pagination/src/components/pager.vue"],"sourcesContent":["<template>\n <ul :class=\"nsPager.b()\" @click=\"onPagerClick\" @keyup.enter=\"onEnter\">\n <li\n v-if=\"pageCount > 0\"\n :class=\"[\n nsPager.is('active', currentPage === 1),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === 1\"\n :aria-label=\"t('el.pagination.currentPage', { pager: 1 })\"\n :tabindex=\"tabindex\"\n >\n 1\n </li>\n <li\n v-if=\"showPrevMore\"\n :class=\"prevMoreKls\"\n :tabindex=\"tabindex\"\n :aria-label=\"t('el.pagination.prevPages', { pager: pagerCount - 2 })\"\n @mouseenter=\"onMouseEnter(true)\"\n @mouseleave=\"quickPrevHover = false\"\n @focus=\"onFocus(true)\"\n @blur=\"quickPrevFocus = false\"\n >\n <d-arrow-left v-if=\"(quickPrevHover || quickPrevFocus) && !disabled\" />\n <more-filled v-else />\n </li>\n <li\n v-for=\"pager in pagers\"\n :key=\"pager\"\n :class=\"[\n nsPager.is('active', currentPage === pager),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === pager\"\n :aria-label=\"t('el.pagination.currentPage', { pager })\"\n :tabindex=\"tabindex\"\n >\n {{ pager }}\n </li>\n <li\n v-if=\"showNextMore\"\n :class=\"nextMoreKls\"\n :tabindex=\"tabindex\"\n :aria-label=\"t('el.pagination.nextPages', { pager: pagerCount - 2 })\"\n @mouseenter=\"onMouseEnter()\"\n @mouseleave=\"quickNextHover = false\"\n @focus=\"onFocus()\"\n @blur=\"quickNextFocus = false\"\n >\n <d-arrow-right v-if=\"(quickNextHover || quickNextFocus) && !disabled\" />\n <more-filled v-else />\n </li>\n <li\n v-if=\"pageCount > 1\"\n :class=\"[\n nsPager.is('active', currentPage === pageCount),\n nsPager.is('disabled', disabled),\n ]\"\n class=\"number\"\n :aria-current=\"currentPage === pageCount\"\n :aria-label=\"t('el.pagination.currentPage', { pager: pageCount })\"\n :tabindex=\"tabindex\"\n >\n {{ pageCount }}\n </li>\n </ul>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref, watchEffect } from 'vue'\nimport { DArrowLeft, DArrowRight, MoreFilled } from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { paginationPagerProps } from './pager'\ndefineOptions({\n name: 'ElPaginationPager',\n})\nconst props = defineProps(paginationPagerProps)\nconst emit = defineEmits(['change'])\nconst nsPager = useNamespace('pager')\nconst nsIcon = useNamespace('icon')\nconst { t } = useLocale()\n\nconst showPrevMore = ref(false)\nconst showNextMore = ref(false)\nconst quickPrevHover = ref(false)\nconst quickNextHover = ref(false)\nconst quickPrevFocus = ref(false)\nconst quickNextFocus = ref(false)\nconst pagers = computed(() => {\n const pagerCount = props.pagerCount\n const halfPagerCount = (pagerCount - 1) / 2\n const currentPage = Number(props.currentPage)\n const pageCount = Number(props.pageCount)\n let showPrevMore = false\n let showNextMore = false\n if (pageCount > pagerCount) {\n if (currentPage > pagerCount - halfPagerCount) {\n showPrevMore = true\n }\n if (currentPage < pageCount - halfPagerCount) {\n showNextMore = true\n }\n }\n const array: number[] = []\n if (showPrevMore && !showNextMore) {\n const startPage = pageCount - (pagerCount - 2)\n for (let i = startPage; i < pageCount; i++) {\n array.push(i)\n }\n } else if (!showPrevMore && showNextMore) {\n for (let i = 2; i < pagerCount; i++) {\n array.push(i)\n }\n } else if (showPrevMore && showNextMore) {\n const offset = Math.floor(pagerCount / 2) - 1\n for (let i = currentPage - offset; i <= currentPage + offset; i++) {\n array.push(i)\n }\n } else {\n for (let i = 2; i < pageCount; i++) {\n array.push(i)\n }\n }\n return array\n})\n\nconst prevMoreKls = computed(() => [\n 'more',\n 'btn-quickprev',\n nsIcon.b(),\n nsPager.is('disabled', props.disabled),\n])\nconst nextMoreKls = computed(() => [\n 'more',\n 'btn-quicknext',\n nsIcon.b(),\n nsPager.is('disabled', props.disabled),\n])\n\nconst tabindex = computed(() => (props.disabled ? -1 : 0))\nwatchEffect(() => {\n const halfPagerCount = (props.pagerCount - 1) / 2\n showPrevMore.value = false\n showNextMore.value = false\n if (props.pageCount! > props.pagerCount) {\n if (props.currentPage > props.pagerCount - halfPagerCount) {\n showPrevMore.value = true\n }\n if (props.currentPage < props.pageCount! - halfPagerCount) {\n showNextMore.value = true\n }\n }\n})\nfunction onMouseEnter(forward = false) {\n if (props.disabled) return\n if (forward) {\n quickPrevHover.value = true\n } else {\n quickNextHover.value = true\n }\n}\nfunction onFocus(forward = false) {\n if (forward) {\n quickPrevFocus.value = true\n } else {\n quickNextFocus.value = true\n }\n}\nfunction onEnter(e: UIEvent) {\n const target = e.target as HTMLElement\n if (\n target.tagName.toLowerCase() === 'li' &&\n Array.from(target.classList).includes('number')\n ) {\n const newPage = Number(target.textContent)\n if (newPage !== props.currentPage) {\n emit('change', newPage)\n }\n } else if (\n target.tagName.toLowerCase() === 'li' &&\n Array.from(target.classList).includes('more')\n ) {\n onPagerClick(e)\n }\n}\nfunction onPagerClick(event: UIEvent) {\n const target = event.target as HTMLElement\n if (target.tagName.toLowerCase() === 'ul' || props.disabled) {\n return\n }\n let newPage = Number(target.textContent)\n const pageCount = props.pageCount!\n const currentPage = props.currentPage\n const pagerCountOffset = props.pagerCount - 2\n if (target.className.includes('more')) {\n if (target.className.includes('quickprev')) {\n newPage = currentPage - pagerCountOffset\n } else if (target.className.includes('quicknext')) {\n newPage = currentPage + pagerCountOffset\n }\n }\n if (!Number.isNaN(+newPage)) {\n if (newPage < 1) {\n newPage = 1\n }\n if (newPage > pageCount) {\n newPage = pageCount\n }\n }\n if (newPage !== currentPage) {\n emit('change', newPage)\n }\n}\n</script>\n"],"names":["showPrevMore","showNextMore"],"mappings":"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"}
1
+ {"version":3,"file":"pager2.mjs","sources":["../../../../../../../packages/components/pagination/src/components/pager.ts"],"sourcesContent":["import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Pager from './pager.vue'\n\nexport const paginationPagerProps = buildProps({\n currentPage: {\n type: Number,\n default: 1,\n },\n pageCount: {\n type: Number,\n required: true,\n },\n pagerCount: {\n type: Number,\n default: 7,\n },\n disabled: Boolean,\n} as const)\n\nexport type PaginationPagerProps = ExtractPropTypes<typeof paginationPagerProps>\n\nexport type PagerInstance = InstanceType<typeof Pager>\n"],"names":[],"mappings":";;AACY,MAAC,oBAAoB,GAAG,UAAU,CAAC;AAC/C,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,QAAQ,EAAE,IAAI;AAClB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,CAAC;;;;"}
@@ -6,7 +6,7 @@ import Next from './components/next2.mjs';
6
6
  import Sizes from './components/sizes2.mjs';
7
7
  import Jumper from './components/jumper2.mjs';
8
8
  import Total from './components/total2.mjs';
9
- import Pager from './components/pager2.mjs';
9
+ import Pager from './components/pager.mjs';
10
10
  import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
11
11
  import { isNumber } from '../../../utils/types.mjs';
12
12
  import { mutable } from '../../../utils/typescript.mjs';
@@ -1,5 +1,5 @@
1
- import Rate from './src/rate2.mjs';
2
- export { rateEmits, rateProps } from './src/rate.mjs';
1
+ import Rate from './src/rate.mjs';
2
+ export { rateEmits, rateProps } from './src/rate2.mjs';
3
3
  import { withInstall } from '../../utils/vue/install.mjs';
4
4
 
5
5
  const ElRate = withInstall(Rate);
@@ -1,87 +1,262 @@
1
- import { StarFilled, Star } from '@element-plus/icons-vue';
2
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
3
- import { mutable } from '../../../utils/typescript.mjs';
4
- import { iconPropType } from '../../../utils/vue/icon.mjs';
5
- import { useSizeProp } from '../../../hooks/use-size/index.mjs';
6
- import { useAriaProps } from '../../../hooks/use-aria/index.mjs';
7
- import { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';
8
- import { isNumber } from '../../../utils/types.mjs';
1
+ import { defineComponent, inject, ref, computed, markRaw, watch, openBlock, createElementBlock, unref, normalizeClass, normalizeStyle, Fragment, renderList, createVNode, withCtx, withDirectives, createBlock, resolveDynamicComponent, vShow, createCommentVNode, toDisplayString } from 'vue';
2
+ import { ElIcon } from '../../icon/index.mjs';
3
+ import { rateProps, rateEmits } from './rate2.mjs';
4
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
5
+ import { formContextKey, formItemContextKey } from '../../form/src/constants.mjs';
6
+ import { useFormSize } from '../../form/src/hooks/use-form-common-props.mjs';
7
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
8
+ import { useFormItemInputId } from '../../form/src/hooks/use-form-item.mjs';
9
+ import { isArray, isObject, isString } from '@vue/shared';
10
+ import { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';
11
+ import { EVENT_CODE } from '../../../constants/aria.mjs';
12
+ import { hasClass } from '../../../utils/dom/style.mjs';
9
13
 
10
- const rateProps = buildProps({
11
- modelValue: {
12
- type: Number,
13
- default: 0
14
- },
15
- id: {
16
- type: String,
17
- default: void 0
18
- },
19
- lowThreshold: {
20
- type: Number,
21
- default: 2
22
- },
23
- highThreshold: {
24
- type: Number,
25
- default: 4
26
- },
27
- max: {
28
- type: Number,
29
- default: 5
30
- },
31
- colors: {
32
- type: definePropType([Array, Object]),
33
- default: () => mutable(["", "", ""])
34
- },
35
- voidColor: {
36
- type: String,
37
- default: ""
38
- },
39
- disabledVoidColor: {
40
- type: String,
41
- default: ""
42
- },
43
- icons: {
44
- type: definePropType([Array, Object]),
45
- default: () => [StarFilled, StarFilled, StarFilled]
46
- },
47
- voidIcon: {
48
- type: iconPropType,
49
- default: () => Star
50
- },
51
- disabledVoidIcon: {
52
- type: iconPropType,
53
- default: () => StarFilled
54
- },
55
- disabled: Boolean,
56
- allowHalf: Boolean,
57
- showText: Boolean,
58
- showScore: Boolean,
59
- textColor: {
60
- type: String,
61
- default: ""
62
- },
63
- texts: {
64
- type: definePropType(Array),
65
- default: () => mutable([
66
- "Extremely bad",
67
- "Disappointed",
68
- "Fair",
69
- "Satisfied",
70
- "Surprise"
71
- ])
72
- },
73
- scoreTemplate: {
74
- type: String,
75
- default: "{value}"
76
- },
77
- size: useSizeProp,
78
- clearable: Boolean,
79
- ...useAriaProps(["ariaLabel"])
14
+ const __default__ = defineComponent({
15
+ name: "ElRate"
80
16
  });
81
- const rateEmits = {
82
- [CHANGE_EVENT]: (value) => isNumber(value),
83
- [UPDATE_MODEL_EVENT]: (value) => isNumber(value)
84
- };
17
+ const _sfc_main = /* @__PURE__ */ defineComponent({
18
+ ...__default__,
19
+ props: rateProps,
20
+ emits: rateEmits,
21
+ setup(__props, { expose, emit }) {
22
+ const props = __props;
23
+ function getValueFromMap(value, map) {
24
+ const isExcludedObject = (val) => isObject(val);
25
+ const matchedKeys = Object.keys(map).map((key) => +key).filter((key) => {
26
+ const val = map[key];
27
+ const excluded = isExcludedObject(val) ? val.excluded : false;
28
+ return excluded ? value < key : value <= key;
29
+ }).sort((a, b) => a - b);
30
+ const matchedValue = map[matchedKeys[0]];
31
+ return isExcludedObject(matchedValue) && matchedValue.value || matchedValue;
32
+ }
33
+ const formContext = inject(formContextKey, void 0);
34
+ const formItemContext = inject(formItemContextKey, void 0);
35
+ const rateSize = useFormSize();
36
+ const ns = useNamespace("rate");
37
+ const { inputId, isLabeledByFormItem } = useFormItemInputId(props, {
38
+ formItemContext
39
+ });
40
+ const currentValue = ref(props.modelValue);
41
+ const hoverIndex = ref(-1);
42
+ const pointerAtLeftHalf = ref(true);
43
+ const rateClasses = computed(() => [ns.b(), ns.m(rateSize.value)]);
44
+ const rateDisabled = computed(() => props.disabled || (formContext == null ? void 0 : formContext.disabled));
45
+ const rateStyles = computed(() => {
46
+ return ns.cssVarBlock({
47
+ "void-color": props.voidColor,
48
+ "disabled-void-color": props.disabledVoidColor,
49
+ "fill-color": activeColor.value
50
+ });
51
+ });
52
+ const text = computed(() => {
53
+ let result = "";
54
+ if (props.showScore) {
55
+ result = props.scoreTemplate.replace(/\{\s*value\s*\}/, rateDisabled.value ? `${props.modelValue}` : `${currentValue.value}`);
56
+ } else if (props.showText) {
57
+ result = props.texts[Math.ceil(currentValue.value) - 1];
58
+ }
59
+ return result;
60
+ });
61
+ const valueDecimal = computed(() => props.modelValue * 100 - Math.floor(props.modelValue) * 100);
62
+ const colorMap = computed(() => isArray(props.colors) ? {
63
+ [props.lowThreshold]: props.colors[0],
64
+ [props.highThreshold]: { value: props.colors[1], excluded: true },
65
+ [props.max]: props.colors[2]
66
+ } : props.colors);
67
+ const activeColor = computed(() => {
68
+ const color = getValueFromMap(currentValue.value, colorMap.value);
69
+ return isObject(color) ? "" : color;
70
+ });
71
+ const decimalStyle = computed(() => {
72
+ let width = "";
73
+ if (rateDisabled.value) {
74
+ width = `${valueDecimal.value}%`;
75
+ } else if (props.allowHalf) {
76
+ width = "50%";
77
+ }
78
+ return {
79
+ color: activeColor.value,
80
+ width
81
+ };
82
+ });
83
+ const componentMap = computed(() => {
84
+ let icons = isArray(props.icons) ? [...props.icons] : { ...props.icons };
85
+ icons = markRaw(icons);
86
+ return isArray(icons) ? {
87
+ [props.lowThreshold]: icons[0],
88
+ [props.highThreshold]: {
89
+ value: icons[1],
90
+ excluded: true
91
+ },
92
+ [props.max]: icons[2]
93
+ } : icons;
94
+ });
95
+ const decimalIconComponent = computed(() => getValueFromMap(props.modelValue, componentMap.value));
96
+ const voidComponent = computed(() => rateDisabled.value ? isString(props.disabledVoidIcon) ? props.disabledVoidIcon : markRaw(props.disabledVoidIcon) : isString(props.voidIcon) ? props.voidIcon : markRaw(props.voidIcon));
97
+ const activeComponent = computed(() => getValueFromMap(currentValue.value, componentMap.value));
98
+ function showDecimalIcon(item) {
99
+ const showWhenDisabled = rateDisabled.value && valueDecimal.value > 0 && item - 1 < props.modelValue && item > props.modelValue;
100
+ const showWhenAllowHalf = props.allowHalf && pointerAtLeftHalf.value && item - 0.5 <= currentValue.value && item > currentValue.value;
101
+ return showWhenDisabled || showWhenAllowHalf;
102
+ }
103
+ function emitValue(value) {
104
+ if (props.clearable && value === props.modelValue) {
105
+ value = 0;
106
+ }
107
+ emit(UPDATE_MODEL_EVENT, value);
108
+ if (props.modelValue !== value) {
109
+ emit("change", value);
110
+ }
111
+ }
112
+ function selectValue(value) {
113
+ if (rateDisabled.value) {
114
+ return;
115
+ }
116
+ if (props.allowHalf && pointerAtLeftHalf.value) {
117
+ emitValue(currentValue.value);
118
+ } else {
119
+ emitValue(value);
120
+ }
121
+ }
122
+ function handleKey(e) {
123
+ if (rateDisabled.value) {
124
+ return;
125
+ }
126
+ let _currentValue = currentValue.value;
127
+ const code = e.code;
128
+ if (code === EVENT_CODE.up || code === EVENT_CODE.right) {
129
+ if (props.allowHalf) {
130
+ _currentValue += 0.5;
131
+ } else {
132
+ _currentValue += 1;
133
+ }
134
+ e.stopPropagation();
135
+ e.preventDefault();
136
+ } else if (code === EVENT_CODE.left || code === EVENT_CODE.down) {
137
+ if (props.allowHalf) {
138
+ _currentValue -= 0.5;
139
+ } else {
140
+ _currentValue -= 1;
141
+ }
142
+ e.stopPropagation();
143
+ e.preventDefault();
144
+ }
145
+ _currentValue = _currentValue < 0 ? 0 : _currentValue;
146
+ _currentValue = _currentValue > props.max ? props.max : _currentValue;
147
+ emit(UPDATE_MODEL_EVENT, _currentValue);
148
+ emit("change", _currentValue);
149
+ return _currentValue;
150
+ }
151
+ function setCurrentValue(value, event) {
152
+ if (rateDisabled.value) {
153
+ return;
154
+ }
155
+ if (props.allowHalf && event) {
156
+ let target = event.target;
157
+ if (hasClass(target, ns.e("item"))) {
158
+ target = target.querySelector(`.${ns.e("icon")}`);
159
+ }
160
+ if (target.clientWidth === 0 || hasClass(target, ns.e("decimal"))) {
161
+ target = target.parentNode;
162
+ }
163
+ pointerAtLeftHalf.value = event.offsetX * 2 <= target.clientWidth;
164
+ currentValue.value = pointerAtLeftHalf.value ? value - 0.5 : value;
165
+ } else {
166
+ currentValue.value = value;
167
+ }
168
+ hoverIndex.value = value;
169
+ }
170
+ function resetCurrentValue() {
171
+ if (rateDisabled.value) {
172
+ return;
173
+ }
174
+ if (props.allowHalf) {
175
+ pointerAtLeftHalf.value = props.modelValue !== Math.floor(props.modelValue);
176
+ }
177
+ currentValue.value = props.modelValue;
178
+ hoverIndex.value = -1;
179
+ }
180
+ watch(() => props.modelValue, (val) => {
181
+ currentValue.value = val;
182
+ pointerAtLeftHalf.value = props.modelValue !== Math.floor(props.modelValue);
183
+ });
184
+ if (!props.modelValue) {
185
+ emit(UPDATE_MODEL_EVENT, 0);
186
+ }
187
+ expose({
188
+ setCurrentValue,
189
+ resetCurrentValue
190
+ });
191
+ return (_ctx, _cache) => {
192
+ var _a;
193
+ return openBlock(), createElementBlock("div", {
194
+ id: unref(inputId),
195
+ class: normalizeClass([unref(rateClasses), unref(ns).is("disabled", unref(rateDisabled))]),
196
+ role: "slider",
197
+ "aria-label": !unref(isLabeledByFormItem) ? _ctx.ariaLabel || "rating" : void 0,
198
+ "aria-labelledby": unref(isLabeledByFormItem) ? (_a = unref(formItemContext)) == null ? void 0 : _a.labelId : void 0,
199
+ "aria-valuenow": currentValue.value,
200
+ "aria-valuetext": unref(text) || void 0,
201
+ "aria-valuemin": "0",
202
+ "aria-valuemax": _ctx.max,
203
+ tabindex: "0",
204
+ style: normalizeStyle(unref(rateStyles)),
205
+ onKeydown: handleKey
206
+ }, [
207
+ (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.max, (item, key) => {
208
+ return openBlock(), createElementBlock("span", {
209
+ key,
210
+ class: normalizeClass(unref(ns).e("item")),
211
+ onMousemove: ($event) => setCurrentValue(item, $event),
212
+ onMouseleave: resetCurrentValue,
213
+ onClick: ($event) => selectValue(item)
214
+ }, [
215
+ createVNode(unref(ElIcon), {
216
+ class: normalizeClass([
217
+ unref(ns).e("icon"),
218
+ { hover: hoverIndex.value === item },
219
+ unref(ns).is("active", item <= currentValue.value)
220
+ ])
221
+ }, {
222
+ default: withCtx(() => [
223
+ !showDecimalIcon(item) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
224
+ withDirectives((openBlock(), createBlock(resolveDynamicComponent(unref(activeComponent)), null, null, 512)), [
225
+ [vShow, item <= currentValue.value]
226
+ ]),
227
+ withDirectives((openBlock(), createBlock(resolveDynamicComponent(unref(voidComponent)), null, null, 512)), [
228
+ [vShow, !(item <= currentValue.value)]
229
+ ])
230
+ ], 64)) : createCommentVNode("v-if", true),
231
+ showDecimalIcon(item) ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [
232
+ (openBlock(), createBlock(resolveDynamicComponent(unref(voidComponent)), {
233
+ class: normalizeClass([unref(ns).em("decimal", "box")])
234
+ }, null, 8, ["class"])),
235
+ createVNode(unref(ElIcon), {
236
+ style: normalizeStyle(unref(decimalStyle)),
237
+ class: normalizeClass([unref(ns).e("icon"), unref(ns).e("decimal")])
238
+ }, {
239
+ default: withCtx(() => [
240
+ (openBlock(), createBlock(resolveDynamicComponent(unref(decimalIconComponent))))
241
+ ]),
242
+ _: 1
243
+ }, 8, ["style", "class"])
244
+ ], 64)) : createCommentVNode("v-if", true)
245
+ ]),
246
+ _: 2
247
+ }, 1032, ["class"])
248
+ ], 42, ["onMousemove", "onClick"]);
249
+ }), 128)),
250
+ _ctx.showText || _ctx.showScore ? (openBlock(), createElementBlock("span", {
251
+ key: 0,
252
+ class: normalizeClass(unref(ns).e("text")),
253
+ style: normalizeStyle({ color: _ctx.textColor })
254
+ }, toDisplayString(unref(text)), 7)) : createCommentVNode("v-if", true)
255
+ ], 46, ["id", "aria-label", "aria-labelledby", "aria-valuenow", "aria-valuetext", "aria-valuemax"]);
256
+ };
257
+ }
258
+ });
259
+ var Rate = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "rate.vue"]]);
85
260
 
86
- export { rateEmits, rateProps };
261
+ export { Rate as default };
87
262
  //# sourceMappingURL=rate.mjs.map