element-ps 2.0.37 → 2.0.38

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 (456) hide show
  1. package/dist/index.full.js +5 -1
  2. package/dist/index.full.min.js +1 -1
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +1 -1
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +5 -1
  7. package/es/components/affix/index.mjs +2 -2
  8. package/es/components/affix/src/affix.mjs +19 -82
  9. package/es/components/affix/src/affix.mjs.map +1 -1
  10. package/es/components/affix/src/affix2.mjs +82 -19
  11. package/es/components/affix/src/affix2.mjs.map +1 -1
  12. package/es/components/alert/index.mjs +2 -2
  13. package/es/components/alert/src/alert.mjs +33 -83
  14. package/es/components/alert/src/alert.mjs.map +1 -1
  15. package/es/components/alert/src/alert2.mjs +83 -33
  16. package/es/components/alert/src/alert2.mjs.map +1 -1
  17. package/es/components/autocomplete/index.d.ts +5 -5
  18. package/es/components/autocomplete/src/autocomplete.vue.d.ts +5 -5
  19. package/es/components/backtop/index.mjs +2 -2
  20. package/es/components/backtop/src/backtop.mjs +59 -18
  21. package/es/components/backtop/src/backtop.mjs.map +1 -1
  22. package/es/components/backtop/src/backtop2.mjs +18 -59
  23. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  24. package/es/components/badge/index.mjs +2 -2
  25. package/es/components/badge/src/badge.mjs +54 -17
  26. package/es/components/badge/src/badge.mjs.map +1 -1
  27. package/es/components/badge/src/badge2.mjs +17 -54
  28. package/es/components/badge/src/badge2.mjs.map +1 -1
  29. package/es/components/breadcrumb/index.mjs +2 -2
  30. package/es/components/breadcrumb/src/breadcrumb.mjs +12 -37
  31. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  32. package/es/components/breadcrumb/src/breadcrumb2.mjs +37 -12
  33. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  34. package/es/components/button/index.mjs +2 -2
  35. package/es/components/button/src/button-group.mjs +1 -1
  36. package/es/components/button/src/button.mjs +48 -96
  37. package/es/components/button/src/button.mjs.map +1 -1
  38. package/es/components/button/src/button2.mjs +96 -48
  39. package/es/components/button/src/button2.mjs.map +1 -1
  40. package/es/components/calendar/index.mjs +2 -2
  41. package/es/components/calendar/src/calendar.mjs +9 -188
  42. package/es/components/calendar/src/calendar.mjs.map +1 -1
  43. package/es/components/calendar/src/calendar2.mjs +188 -9
  44. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  45. package/es/components/carousel/index.mjs +2 -2
  46. package/es/components/carousel/src/carousel.mjs +201 -43
  47. package/es/components/carousel/src/carousel.mjs.map +1 -1
  48. package/es/components/carousel/src/carousel2.mjs +43 -201
  49. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  50. package/es/components/cascader-panel/src/config.mjs +1 -1
  51. package/es/components/cascader-panel/src/index.mjs +1 -1
  52. package/es/components/cascader-panel/src/menu.mjs +1 -1
  53. package/es/components/cascader-panel/src/node.mjs +120 -200
  54. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  55. package/es/components/cascader-panel/src/node2.mjs +200 -120
  56. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  57. package/es/components/cascader-panel/src/store.mjs +1 -1
  58. package/es/components/check-tag/index.mjs +2 -2
  59. package/es/components/check-tag/src/check-tag.mjs +7 -20
  60. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  61. package/es/components/check-tag/src/check-tag2.mjs +20 -7
  62. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  63. package/es/components/collapse/index.mjs +2 -2
  64. package/es/components/collapse/src/collapse.mjs +61 -14
  65. package/es/components/collapse/src/collapse.mjs.map +1 -1
  66. package/es/components/collapse/src/collapse2.mjs +14 -61
  67. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  68. package/es/components/collection/index.mjs +1 -1
  69. package/es/components/collection/src/collection.mjs +10 -30
  70. package/es/components/collection/src/collection.mjs.map +1 -1
  71. package/es/components/collection/src/collection2.mjs +30 -10
  72. package/es/components/collection/src/collection2.mjs.map +1 -1
  73. package/es/components/divider/index.mjs +2 -2
  74. package/es/components/divider/src/divider.mjs +17 -34
  75. package/es/components/divider/src/divider.mjs.map +1 -1
  76. package/es/components/divider/src/divider2.mjs +34 -17
  77. package/es/components/divider/src/divider2.mjs.map +1 -1
  78. package/es/components/drawer/index.mjs +2 -2
  79. package/es/components/drawer/src/drawer.mjs +23 -117
  80. package/es/components/drawer/src/drawer.mjs.map +1 -1
  81. package/es/components/drawer/src/drawer2.mjs +117 -23
  82. package/es/components/drawer/src/drawer2.mjs.map +1 -1
  83. package/es/components/dropdown/index.d.ts +3 -3
  84. package/es/components/dropdown/index.mjs +2 -2
  85. package/es/components/dropdown/src/dropdown-item-impl.mjs +1 -1
  86. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  87. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  88. package/es/components/dropdown/src/dropdown.d.ts +1 -1
  89. package/es/components/dropdown/src/dropdown.mjs +109 -100
  90. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  91. package/es/components/dropdown/src/dropdown.vue.d.ts +3 -3
  92. package/es/components/dropdown/src/dropdown2.mjs +100 -109
  93. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  94. package/es/components/empty/index.mjs +2 -2
  95. package/es/components/empty/src/empty.mjs +56 -11
  96. package/es/components/empty/src/empty.mjs.map +1 -1
  97. package/es/components/empty/src/empty2.mjs +11 -56
  98. package/es/components/empty/src/empty2.mjs.map +1 -1
  99. package/es/components/form/index.mjs +4 -4
  100. package/es/components/form/src/form-item.mjs +46 -171
  101. package/es/components/form/src/form-item.mjs.map +1 -1
  102. package/es/components/form/src/form-item2.mjs +171 -46
  103. package/es/components/form/src/form-item2.mjs.map +1 -1
  104. package/es/components/form/src/form.mjs +40 -45
  105. package/es/components/form/src/form.mjs.map +1 -1
  106. package/es/components/form/src/form2.mjs +45 -40
  107. package/es/components/form/src/form2.mjs.map +1 -1
  108. package/es/components/icon/index.mjs +2 -2
  109. package/es/components/icon/src/icon.mjs +8 -35
  110. package/es/components/icon/src/icon.mjs.map +1 -1
  111. package/es/components/icon/src/icon2.mjs +35 -8
  112. package/es/components/icon/src/icon2.mjs.map +1 -1
  113. package/es/components/image-viewer/index.mjs +2 -2
  114. package/es/components/image-viewer/src/image-viewer.mjs +210 -31
  115. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  116. package/es/components/image-viewer/src/image-viewer2.mjs +31 -210
  117. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  118. package/es/components/index.mjs +33 -33
  119. package/es/components/link/index.mjs +2 -2
  120. package/es/components/link/src/link.mjs +43 -19
  121. package/es/components/link/src/link.mjs.map +1 -1
  122. package/es/components/link/src/link2.mjs +19 -43
  123. package/es/components/link/src/link2.mjs.map +1 -1
  124. package/es/components/menu/index.d.ts +3 -3
  125. package/es/components/menu/index.mjs +4 -4
  126. package/es/components/menu/src/menu-item-group.mjs +4 -35
  127. package/es/components/menu/src/menu-item-group.mjs.map +1 -1
  128. package/es/components/menu/src/menu-item-group2.mjs +35 -4
  129. package/es/components/menu/src/menu-item-group2.mjs.map +1 -1
  130. package/es/components/menu/src/menu-item.mjs +74 -15
  131. package/es/components/menu/src/menu-item.mjs.map +1 -1
  132. package/es/components/menu/src/menu-item2.mjs +15 -74
  133. package/es/components/menu/src/menu-item2.mjs.map +1 -1
  134. package/es/components/menu/src/menu.d.ts +4 -4
  135. package/es/components/popconfirm/src/popconfirm.mjs +1 -1
  136. package/es/components/popover/index.d.ts +6 -6
  137. package/es/components/popover/src/index.vue.d.ts +3 -3
  138. package/es/components/popover/src/popover.d.ts +1 -1
  139. package/es/components/popover/src/popover.mjs +1 -1
  140. package/es/components/popper/index.mjs +4 -4
  141. package/es/components/popper/src/arrow.mjs +7 -31
  142. package/es/components/popper/src/arrow.mjs.map +1 -1
  143. package/es/components/popper/src/arrow2.mjs +31 -7
  144. package/es/components/popper/src/arrow2.mjs.map +1 -1
  145. package/es/components/popper/src/trigger.mjs +28 -17
  146. package/es/components/popper/src/trigger.mjs.map +1 -1
  147. package/es/components/popper/src/trigger2.mjs +17 -28
  148. package/es/components/popper/src/trigger2.mjs.map +1 -1
  149. package/es/components/radio/index.mjs +2 -2
  150. package/es/components/radio/src/radio-button.mjs +1 -1
  151. package/es/components/radio/src/radio-button2.mjs +1 -1
  152. package/es/components/radio/src/radio.mjs +74 -62
  153. package/es/components/radio/src/radio.mjs.map +1 -1
  154. package/es/components/radio/src/radio2.mjs +62 -74
  155. package/es/components/radio/src/radio2.mjs.map +1 -1
  156. package/es/components/result/index.mjs +2 -2
  157. package/es/components/result/src/result.mjs +73 -28
  158. package/es/components/result/src/result.mjs.map +1 -1
  159. package/es/components/result/src/result2.mjs +28 -73
  160. package/es/components/result/src/result2.mjs.map +1 -1
  161. package/es/components/roving-focus-group/index.mjs +3 -3
  162. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  163. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -29
  164. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  165. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +29 -27
  166. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  167. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  168. package/es/components/select/index.d.ts +5 -5
  169. package/es/components/select/src/select.vue.d.ts +5 -5
  170. package/es/components/select/src/useSelect.d.ts +5 -5
  171. package/es/components/select-v2/index.d.ts +10 -10
  172. package/es/components/select-v2/src/option-item.vue.d.ts +1 -1
  173. package/es/components/select-v2/src/select.vue.d.ts +5 -5
  174. package/es/components/select-v2/src/useSelect.d.ts +5 -5
  175. package/es/components/skeleton/index.mjs +4 -4
  176. package/es/components/skeleton/src/skeleton-item.mjs +18 -23
  177. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  178. package/es/components/skeleton/src/skeleton-item2.mjs +23 -18
  179. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  180. package/es/components/skeleton/src/skeleton.mjs +49 -22
  181. package/es/components/skeleton/src/skeleton.mjs.map +1 -1
  182. package/es/components/skeleton/src/skeleton2.mjs +22 -49
  183. package/es/components/skeleton/src/skeleton2.mjs.map +1 -1
  184. package/es/components/table/index.d.ts +1 -1
  185. package/es/components/table/src/filter-panel.vue.d.ts +5 -5
  186. package/es/components/table/src/store/helper.mjs +5 -1
  187. package/es/components/table/src/store/helper.mjs.map +1 -1
  188. package/es/components/table/src/table.vue.d.ts +1 -1
  189. package/es/components/tabs/index.mjs +1 -1
  190. package/es/components/tabs/src/tab-bar.mjs +7 -76
  191. package/es/components/tabs/src/tab-bar.mjs.map +1 -1
  192. package/es/components/tabs/src/tab-bar2.mjs +76 -7
  193. package/es/components/tabs/src/tab-bar2.mjs.map +1 -1
  194. package/es/components/tabs/src/tab-nav.mjs +1 -1
  195. package/es/components/teleport/index.mjs +2 -2
  196. package/es/components/teleport/src/teleport.mjs +18 -43
  197. package/es/components/teleport/src/teleport.mjs.map +1 -1
  198. package/es/components/teleport/src/teleport2.mjs +43 -18
  199. package/es/components/teleport/src/teleport2.mjs.map +1 -1
  200. package/es/components/time-picker/src/common/picker.vue.d.ts +5 -5
  201. package/es/components/timeline/index.mjs +2 -2
  202. package/es/components/timeline/src/timeline-item.mjs +73 -39
  203. package/es/components/timeline/src/timeline-item.mjs.map +1 -1
  204. package/es/components/timeline/src/timeline-item2.mjs +39 -73
  205. package/es/components/timeline/src/timeline-item2.mjs.map +1 -1
  206. package/es/components/tooltip/index.d.ts +3 -3
  207. package/es/components/tooltip/src/tooltip.d.ts +1 -1
  208. package/es/components/tooltip/src/tooltip.mjs +1 -1
  209. package/es/components/tooltip/src/tooltip.vue.d.ts +3 -3
  210. package/es/components/tooltip/src/tooltip2.mjs +1 -1
  211. package/es/components/tooltip/src/trigger.mjs +1 -1
  212. package/es/components/tooltip/src/trigger.vue.d.ts +3 -3
  213. package/es/components/tooltip-v2/index.mjs +1 -1
  214. package/es/components/tooltip-v2/src/tooltip.mjs +1 -1
  215. package/es/components/tooltip-v2/src/tooltip2.mjs +2 -2
  216. package/es/components/tooltip-v2/src/trigger.mjs +89 -11
  217. package/es/components/tooltip-v2/src/trigger.mjs.map +1 -1
  218. package/es/components/tooltip-v2/src/trigger2.mjs +11 -89
  219. package/es/components/tooltip-v2/src/trigger2.mjs.map +1 -1
  220. package/es/components/upload/index.mjs +3 -3
  221. package/es/components/upload/src/upload-content.mjs +15 -46
  222. package/es/components/upload/src/upload-content.mjs.map +1 -1
  223. package/es/components/upload/src/upload-content2.mjs +46 -15
  224. package/es/components/upload/src/upload-content2.mjs.map +1 -1
  225. package/es/components/upload/src/upload-list.mjs +1 -1
  226. package/es/components/upload/src/upload.mjs +99 -106
  227. package/es/components/upload/src/upload.mjs.map +1 -1
  228. package/es/components/upload/src/upload2.mjs +106 -99
  229. package/es/components/upload/src/upload2.mjs.map +1 -1
  230. package/es/index.mjs +33 -33
  231. package/lib/components/affix/index.js +2 -2
  232. package/lib/components/affix/src/affix.js +19 -82
  233. package/lib/components/affix/src/affix.js.map +1 -1
  234. package/lib/components/affix/src/affix2.js +82 -19
  235. package/lib/components/affix/src/affix2.js.map +1 -1
  236. package/lib/components/alert/index.js +2 -2
  237. package/lib/components/alert/src/alert.js +33 -82
  238. package/lib/components/alert/src/alert.js.map +1 -1
  239. package/lib/components/alert/src/alert2.js +82 -33
  240. package/lib/components/alert/src/alert2.js.map +1 -1
  241. package/lib/components/autocomplete/index.d.ts +5 -5
  242. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +5 -5
  243. package/lib/components/backtop/index.js +2 -2
  244. package/lib/components/backtop/src/backtop.js +59 -18
  245. package/lib/components/backtop/src/backtop.js.map +1 -1
  246. package/lib/components/backtop/src/backtop2.js +18 -59
  247. package/lib/components/backtop/src/backtop2.js.map +1 -1
  248. package/lib/components/badge/index.js +2 -2
  249. package/lib/components/badge/src/badge.js +54 -17
  250. package/lib/components/badge/src/badge.js.map +1 -1
  251. package/lib/components/badge/src/badge2.js +17 -54
  252. package/lib/components/badge/src/badge2.js.map +1 -1
  253. package/lib/components/breadcrumb/index.js +2 -2
  254. package/lib/components/breadcrumb/src/breadcrumb.js +12 -37
  255. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  256. package/lib/components/breadcrumb/src/breadcrumb2.js +37 -12
  257. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  258. package/lib/components/button/index.js +2 -2
  259. package/lib/components/button/src/button-group.js +1 -1
  260. package/lib/components/button/src/button.js +50 -96
  261. package/lib/components/button/src/button.js.map +1 -1
  262. package/lib/components/button/src/button2.js +96 -50
  263. package/lib/components/button/src/button2.js.map +1 -1
  264. package/lib/components/calendar/index.js +2 -2
  265. package/lib/components/calendar/src/calendar.js +9 -192
  266. package/lib/components/calendar/src/calendar.js.map +1 -1
  267. package/lib/components/calendar/src/calendar2.js +192 -9
  268. package/lib/components/calendar/src/calendar2.js.map +1 -1
  269. package/lib/components/carousel/index.js +2 -2
  270. package/lib/components/carousel/src/carousel.js +201 -43
  271. package/lib/components/carousel/src/carousel.js.map +1 -1
  272. package/lib/components/carousel/src/carousel2.js +43 -201
  273. package/lib/components/carousel/src/carousel2.js.map +1 -1
  274. package/lib/components/cascader-panel/src/config.js +1 -1
  275. package/lib/components/cascader-panel/src/index.js +1 -1
  276. package/lib/components/cascader-panel/src/menu.js +1 -1
  277. package/lib/components/cascader-panel/src/node.js +121 -200
  278. package/lib/components/cascader-panel/src/node.js.map +1 -1
  279. package/lib/components/cascader-panel/src/node2.js +200 -121
  280. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  281. package/lib/components/cascader-panel/src/store.js +1 -1
  282. package/lib/components/check-tag/index.js +2 -2
  283. package/lib/components/check-tag/src/check-tag.js +7 -20
  284. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  285. package/lib/components/check-tag/src/check-tag2.js +20 -7
  286. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  287. package/lib/components/collapse/index.js +2 -2
  288. package/lib/components/collapse/src/collapse.js +61 -16
  289. package/lib/components/collapse/src/collapse.js.map +1 -1
  290. package/lib/components/collapse/src/collapse2.js +16 -61
  291. package/lib/components/collapse/src/collapse2.js.map +1 -1
  292. package/lib/components/collection/index.js +1 -1
  293. package/lib/components/collection/src/collection.js +9 -30
  294. package/lib/components/collection/src/collection.js.map +1 -1
  295. package/lib/components/collection/src/collection2.js +30 -9
  296. package/lib/components/collection/src/collection2.js.map +1 -1
  297. package/lib/components/divider/index.js +2 -2
  298. package/lib/components/divider/src/divider.js +17 -34
  299. package/lib/components/divider/src/divider.js.map +1 -1
  300. package/lib/components/divider/src/divider2.js +34 -17
  301. package/lib/components/divider/src/divider2.js.map +1 -1
  302. package/lib/components/drawer/index.js +2 -2
  303. package/lib/components/drawer/src/drawer.js +23 -117
  304. package/lib/components/drawer/src/drawer.js.map +1 -1
  305. package/lib/components/drawer/src/drawer2.js +117 -23
  306. package/lib/components/drawer/src/drawer2.js.map +1 -1
  307. package/lib/components/dropdown/index.d.ts +3 -3
  308. package/lib/components/dropdown/index.js +2 -2
  309. package/lib/components/dropdown/src/dropdown-item-impl.js +1 -1
  310. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  311. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  312. package/lib/components/dropdown/src/dropdown.d.ts +1 -1
  313. package/lib/components/dropdown/src/dropdown.js +109 -109
  314. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  315. package/lib/components/dropdown/src/dropdown.vue.d.ts +3 -3
  316. package/lib/components/dropdown/src/dropdown2.js +109 -109
  317. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  318. package/lib/components/empty/index.js +2 -2
  319. package/lib/components/empty/src/empty.js +56 -11
  320. package/lib/components/empty/src/empty.js.map +1 -1
  321. package/lib/components/empty/src/empty2.js +11 -56
  322. package/lib/components/empty/src/empty2.js.map +1 -1
  323. package/lib/components/form/index.js +4 -4
  324. package/lib/components/form/src/form-item.js +47 -171
  325. package/lib/components/form/src/form-item.js.map +1 -1
  326. package/lib/components/form/src/form-item2.js +171 -47
  327. package/lib/components/form/src/form-item2.js.map +1 -1
  328. package/lib/components/form/src/form.js +40 -45
  329. package/lib/components/form/src/form.js.map +1 -1
  330. package/lib/components/form/src/form2.js +45 -40
  331. package/lib/components/form/src/form2.js.map +1 -1
  332. package/lib/components/icon/index.js +2 -2
  333. package/lib/components/icon/src/icon.js +8 -35
  334. package/lib/components/icon/src/icon.js.map +1 -1
  335. package/lib/components/icon/src/icon2.js +35 -8
  336. package/lib/components/icon/src/icon2.js.map +1 -1
  337. package/lib/components/image-viewer/index.js +2 -2
  338. package/lib/components/image-viewer/src/image-viewer.js +210 -31
  339. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  340. package/lib/components/image-viewer/src/image-viewer2.js +31 -210
  341. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  342. package/lib/components/index.js +33 -33
  343. package/lib/components/link/index.js +2 -2
  344. package/lib/components/link/src/link.js +43 -19
  345. package/lib/components/link/src/link.js.map +1 -1
  346. package/lib/components/link/src/link2.js +19 -43
  347. package/lib/components/link/src/link2.js.map +1 -1
  348. package/lib/components/menu/index.d.ts +3 -3
  349. package/lib/components/menu/index.js +4 -4
  350. package/lib/components/menu/src/menu-item-group.js +4 -35
  351. package/lib/components/menu/src/menu-item-group.js.map +1 -1
  352. package/lib/components/menu/src/menu-item-group2.js +35 -4
  353. package/lib/components/menu/src/menu-item-group2.js.map +1 -1
  354. package/lib/components/menu/src/menu-item.js +74 -16
  355. package/lib/components/menu/src/menu-item.js.map +1 -1
  356. package/lib/components/menu/src/menu-item2.js +16 -74
  357. package/lib/components/menu/src/menu-item2.js.map +1 -1
  358. package/lib/components/menu/src/menu.d.ts +4 -4
  359. package/lib/components/popconfirm/src/popconfirm.js +1 -1
  360. package/lib/components/popover/index.d.ts +6 -6
  361. package/lib/components/popover/src/index.vue.d.ts +3 -3
  362. package/lib/components/popover/src/popover.d.ts +1 -1
  363. package/lib/components/popover/src/popover.js +1 -1
  364. package/lib/components/popper/index.js +4 -4
  365. package/lib/components/popper/src/arrow.js +7 -31
  366. package/lib/components/popper/src/arrow.js.map +1 -1
  367. package/lib/components/popper/src/arrow2.js +31 -7
  368. package/lib/components/popper/src/arrow2.js.map +1 -1
  369. package/lib/components/popper/src/trigger.js +28 -17
  370. package/lib/components/popper/src/trigger.js.map +1 -1
  371. package/lib/components/popper/src/trigger2.js +17 -28
  372. package/lib/components/popper/src/trigger2.js.map +1 -1
  373. package/lib/components/radio/index.js +2 -2
  374. package/lib/components/radio/src/radio-button.js +1 -1
  375. package/lib/components/radio/src/radio-button2.js +1 -1
  376. package/lib/components/radio/src/radio.js +73 -64
  377. package/lib/components/radio/src/radio.js.map +1 -1
  378. package/lib/components/radio/src/radio2.js +64 -73
  379. package/lib/components/radio/src/radio2.js.map +1 -1
  380. package/lib/components/result/index.js +2 -2
  381. package/lib/components/result/src/result.js +73 -30
  382. package/lib/components/result/src/result.js.map +1 -1
  383. package/lib/components/result/src/result2.js +30 -73
  384. package/lib/components/result/src/result2.js.map +1 -1
  385. package/lib/components/roving-focus-group/index.js +2 -2
  386. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  387. package/lib/components/roving-focus-group/src/roving-focus-group.js +27 -33
  388. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  389. package/lib/components/roving-focus-group/src/roving-focus-group2.js +33 -27
  390. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  391. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  392. package/lib/components/select/index.d.ts +5 -5
  393. package/lib/components/select/src/select.vue.d.ts +5 -5
  394. package/lib/components/select/src/useSelect.d.ts +5 -5
  395. package/lib/components/select-v2/index.d.ts +10 -10
  396. package/lib/components/select-v2/src/option-item.vue.d.ts +1 -1
  397. package/lib/components/select-v2/src/select.vue.d.ts +5 -5
  398. package/lib/components/select-v2/src/useSelect.d.ts +5 -5
  399. package/lib/components/skeleton/index.js +4 -4
  400. package/lib/components/skeleton/src/skeleton-item.js +18 -23
  401. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  402. package/lib/components/skeleton/src/skeleton-item2.js +23 -18
  403. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  404. package/lib/components/skeleton/src/skeleton.js +49 -22
  405. package/lib/components/skeleton/src/skeleton.js.map +1 -1
  406. package/lib/components/skeleton/src/skeleton2.js +22 -49
  407. package/lib/components/skeleton/src/skeleton2.js.map +1 -1
  408. package/lib/components/table/index.d.ts +1 -1
  409. package/lib/components/table/src/filter-panel.vue.d.ts +5 -5
  410. package/lib/components/table/src/store/helper.js +5 -1
  411. package/lib/components/table/src/store/helper.js.map +1 -1
  412. package/lib/components/table/src/table.vue.d.ts +1 -1
  413. package/lib/components/tabs/index.js +1 -1
  414. package/lib/components/tabs/src/tab-bar.js +7 -76
  415. package/lib/components/tabs/src/tab-bar.js.map +1 -1
  416. package/lib/components/tabs/src/tab-bar2.js +76 -7
  417. package/lib/components/tabs/src/tab-bar2.js.map +1 -1
  418. package/lib/components/tabs/src/tab-nav.js +1 -1
  419. package/lib/components/teleport/index.js +2 -2
  420. package/lib/components/teleport/src/teleport.js +18 -43
  421. package/lib/components/teleport/src/teleport.js.map +1 -1
  422. package/lib/components/teleport/src/teleport2.js +43 -18
  423. package/lib/components/teleport/src/teleport2.js.map +1 -1
  424. package/lib/components/time-picker/src/common/picker.vue.d.ts +5 -5
  425. package/lib/components/timeline/index.js +2 -2
  426. package/lib/components/timeline/src/timeline-item.js +73 -39
  427. package/lib/components/timeline/src/timeline-item.js.map +1 -1
  428. package/lib/components/timeline/src/timeline-item2.js +39 -73
  429. package/lib/components/timeline/src/timeline-item2.js.map +1 -1
  430. package/lib/components/tooltip/index.d.ts +3 -3
  431. package/lib/components/tooltip/src/tooltip.d.ts +1 -1
  432. package/lib/components/tooltip/src/tooltip.js +1 -1
  433. package/lib/components/tooltip/src/tooltip.vue.d.ts +3 -3
  434. package/lib/components/tooltip/src/tooltip2.js +1 -1
  435. package/lib/components/tooltip/src/trigger.js +1 -1
  436. package/lib/components/tooltip/src/trigger.vue.d.ts +3 -3
  437. package/lib/components/tooltip-v2/index.js +1 -1
  438. package/lib/components/tooltip-v2/src/tooltip.js +1 -1
  439. package/lib/components/tooltip-v2/src/tooltip2.js +2 -2
  440. package/lib/components/tooltip-v2/src/trigger.js +89 -11
  441. package/lib/components/tooltip-v2/src/trigger.js.map +1 -1
  442. package/lib/components/tooltip-v2/src/trigger2.js +11 -89
  443. package/lib/components/tooltip-v2/src/trigger2.js.map +1 -1
  444. package/lib/components/upload/index.js +3 -3
  445. package/lib/components/upload/src/upload-content.js +15 -46
  446. package/lib/components/upload/src/upload-content.js.map +1 -1
  447. package/lib/components/upload/src/upload-content2.js +46 -15
  448. package/lib/components/upload/src/upload-content2.js.map +1 -1
  449. package/lib/components/upload/src/upload-list.js +1 -1
  450. package/lib/components/upload/src/upload.js +99 -109
  451. package/lib/components/upload/src/upload.js.map +1 -1
  452. package/lib/components/upload/src/upload2.js +109 -99
  453. package/lib/components/upload/src/upload2.js.map +1 -1
  454. package/lib/index.js +33 -33
  455. package/package.json +1 -1
  456. package/web-types.json +1 -1
@@ -2,18 +2,201 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ var vue = require('vue');
6
+ var dayjs = require('dayjs');
7
+ var index$2 = require('../../button/index.js');
8
+ require('../../../hooks/index.js');
5
9
  require('../../../utils/index.js');
6
- var props = require('../../../utils/vue/props.js');
10
+ var dateTable = require('./date-table2.js');
11
+ var calendar = require('./calendar.js');
12
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
13
+ var index = require('../../../hooks/use-namespace/index.js');
14
+ var index$1 = require('../../../hooks/use-locale/index.js');
15
+ var error = require('../../../utils/error.js');
7
16
 
8
- const calendarProps = props.buildProps({
9
- modelValue: {
10
- type: Date
11
- },
12
- range: {
13
- type: props.definePropType(Array),
14
- validator: (range) => Array.isArray(range) && range.length === 2 && range.every((item) => item instanceof Date)
17
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
18
+
19
+ var dayjs__default = /*#__PURE__*/_interopDefaultLegacy(dayjs);
20
+
21
+ const __default__ = {
22
+ name: "PsCalendar"
23
+ };
24
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
25
+ ...__default__,
26
+ props: calendar.calendarProps,
27
+ setup(__props, { expose }) {
28
+ const props = __props;
29
+ const COMPONENT_NAME = "PsCalendar";
30
+ const ns = index.useNamespace("calendar");
31
+ const { t, lang } = index$1.useLocale();
32
+ const selectedDay = vue.ref();
33
+ const now = dayjs__default["default"]().locale(lang.value);
34
+ const i18nDate = vue.computed(() => {
35
+ const pickedMonth = `el.datepicker.month${date.value.format("M")}`;
36
+ return `${date.value.year()} ${t("el.datepicker.year")} ${t(pickedMonth)}`;
37
+ });
38
+ const realSelectedDay = vue.computed({
39
+ get() {
40
+ if (!props.modelValue)
41
+ return selectedDay.value;
42
+ return date.value;
43
+ },
44
+ set(val) {
45
+ if (!val)
46
+ return;
47
+ selectedDay.value = val;
48
+ }
49
+ });
50
+ const date = vue.computed(() => {
51
+ if (!props.modelValue) {
52
+ if (realSelectedDay.value) {
53
+ return realSelectedDay.value;
54
+ } else if (validatedRange.value.length) {
55
+ return validatedRange.value[0][0];
56
+ }
57
+ return now;
58
+ } else {
59
+ return dayjs__default["default"](props.modelValue).locale(lang.value);
60
+ }
61
+ });
62
+ const calculateValidatedDateRange = (startDayjs, endDayjs) => {
63
+ const firstDay = startDayjs.startOf("week");
64
+ const lastDay = endDayjs.endOf("week");
65
+ const firstMonth = firstDay.get("month");
66
+ const lastMonth = lastDay.get("month");
67
+ if (firstMonth === lastMonth) {
68
+ return [[firstDay, lastDay]];
69
+ } else if (firstMonth + 1 === lastMonth) {
70
+ const firstMonthLastDay = firstDay.endOf("month");
71
+ const lastMonthFirstDay = lastDay.startOf("month");
72
+ const isSameWeek = firstMonthLastDay.isSame(lastMonthFirstDay, "week");
73
+ const lastMonthStartDay = isSameWeek ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
74
+ return [
75
+ [firstDay, firstMonthLastDay],
76
+ [lastMonthStartDay.startOf("week"), lastDay]
77
+ ];
78
+ } else if (firstMonth + 2 === lastMonth || (firstMonth + 1) % 11 === lastMonth) {
79
+ const firstMonthLastDay = firstDay.endOf("month");
80
+ const secondMonthFirstDay = firstDay.add(1, "month").startOf("month");
81
+ const secondMonthStartDay = firstMonthLastDay.isSame(secondMonthFirstDay, "week") ? secondMonthFirstDay.add(1, "week") : secondMonthFirstDay;
82
+ const secondMonthLastDay = secondMonthStartDay.endOf("month");
83
+ const lastMonthFirstDay = lastDay.startOf("month");
84
+ const lastMonthStartDay = secondMonthLastDay.isSame(lastMonthFirstDay, "week") ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
85
+ return [
86
+ [firstDay, firstMonthLastDay],
87
+ [secondMonthStartDay.startOf("week"), secondMonthLastDay],
88
+ [lastMonthStartDay.startOf("week"), lastDay]
89
+ ];
90
+ } else {
91
+ error.debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
92
+ return [];
93
+ }
94
+ };
95
+ const validatedRange = vue.computed(() => {
96
+ if (!props.range)
97
+ return [];
98
+ const rangeArrDayjs = props.range.map((_) => dayjs__default["default"](_).locale(lang.value));
99
+ const [startDayjs, endDayjs] = rangeArrDayjs;
100
+ if (startDayjs.isAfter(endDayjs)) {
101
+ error.debugWarn(COMPONENT_NAME, "end time should be greater than start time");
102
+ return [];
103
+ }
104
+ if (startDayjs.isSame(endDayjs, "month")) {
105
+ return calculateValidatedDateRange(startDayjs, endDayjs);
106
+ } else {
107
+ if (startDayjs.add(1, "month").month() !== endDayjs.month()) {
108
+ error.debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
109
+ return [];
110
+ }
111
+ return calculateValidatedDateRange(startDayjs, endDayjs);
112
+ }
113
+ });
114
+ expose({
115
+ selectedDay: realSelectedDay,
116
+ calculateValidatedDateRange
117
+ });
118
+ return (_ctx, _cache) => {
119
+ return vue.openBlock(), vue.createElementBlock("div", {
120
+ class: vue.normalizeClass(vue.unref(ns).b())
121
+ }, [
122
+ vue.createElementVNode("div", {
123
+ class: vue.normalizeClass(vue.unref(ns).e("header"))
124
+ }, [
125
+ vue.renderSlot(_ctx.$slots, "header", { date: vue.unref(i18nDate) }, () => [
126
+ vue.createElementVNode("div", {
127
+ class: vue.normalizeClass(vue.unref(ns).e("title"))
128
+ }, vue.toDisplayString(vue.unref(i18nDate)), 3),
129
+ vue.unref(validatedRange).length === 0 ? (vue.openBlock(), vue.createElementBlock("div", {
130
+ key: 0,
131
+ class: vue.normalizeClass(vue.unref(ns).e("button-group"))
132
+ }, [
133
+ vue.createVNode(vue.unref(index$2.PsButtonGroup), null, {
134
+ default: vue.withCtx(() => [
135
+ vue.createVNode(vue.unref(index$2.PsButton), { size: "small" }, {
136
+ default: vue.withCtx(() => [
137
+ vue.createTextVNode(vue.toDisplayString(vue.unref(t)("el.datepicker.prevMonth")), 1)
138
+ ]),
139
+ _: 1
140
+ }),
141
+ vue.createVNode(vue.unref(index$2.PsButton), { size: "small" }, {
142
+ default: vue.withCtx(() => [
143
+ vue.createTextVNode(vue.toDisplayString(vue.unref(t)("el.datepicker.today")), 1)
144
+ ]),
145
+ _: 1
146
+ }),
147
+ vue.createVNode(vue.unref(index$2.PsButton), { size: "small" }, {
148
+ default: vue.withCtx(() => [
149
+ vue.createTextVNode(vue.toDisplayString(vue.unref(t)("el.datepicker.nextMonth")), 1)
150
+ ]),
151
+ _: 1
152
+ })
153
+ ]),
154
+ _: 1
155
+ })
156
+ ], 2)) : vue.createCommentVNode("v-if", true)
157
+ ])
158
+ ], 2),
159
+ vue.unref(validatedRange).length === 0 ? (vue.openBlock(), vue.createElementBlock("div", {
160
+ key: 0,
161
+ class: vue.normalizeClass(vue.unref(ns).e("body"))
162
+ }, [
163
+ vue.createVNode(dateTable["default"], {
164
+ date: vue.unref(date),
165
+ "selected-day": vue.unref(realSelectedDay)
166
+ }, vue.createSlots({ _: 2 }, [
167
+ _ctx.$slots.dateCell ? {
168
+ name: "dateCell",
169
+ fn: vue.withCtx((data) => [
170
+ vue.renderSlot(_ctx.$slots, "dateCell", vue.normalizeProps(vue.guardReactiveProps(data)))
171
+ ])
172
+ } : void 0
173
+ ]), 1032, ["date", "selected-day"])
174
+ ], 2)) : (vue.openBlock(), vue.createElementBlock("div", {
175
+ key: 1,
176
+ class: vue.normalizeClass(vue.unref(ns).e("body"))
177
+ }, [
178
+ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(validatedRange), (range_, index) => {
179
+ return vue.openBlock(), vue.createBlock(dateTable["default"], {
180
+ key: index,
181
+ date: range_[0],
182
+ "selected-day": vue.unref(realSelectedDay),
183
+ range: range_,
184
+ "hide-header": index !== 0
185
+ }, vue.createSlots({ _: 2 }, [
186
+ _ctx.$slots.dateCell ? {
187
+ name: "dateCell",
188
+ fn: vue.withCtx((data) => [
189
+ vue.renderSlot(_ctx.$slots, "dateCell", vue.normalizeProps(vue.guardReactiveProps(data)))
190
+ ])
191
+ } : void 0
192
+ ]), 1032, ["date", "selected-day", "range", "hide-header"]);
193
+ }), 128))
194
+ ], 2))
195
+ ], 2);
196
+ };
15
197
  }
16
198
  });
199
+ var Calendar = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/calendar/src/calendar.vue"]]);
17
200
 
18
- exports.calendarProps = calendarProps;
201
+ exports["default"] = Calendar;
19
202
  //# sourceMappingURL=calendar2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"calendar2.js","sources":["../../../../../../packages/components/calendar/src/calendar.ts"],"sourcesContent":["import { buildProps, definePropType } from '@element-ps/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-ps/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type Calendar from './calendar.vue'\n\nexport type CalendarDateType =\n | 'prev-month'\n | 'next-month'\n | 'prev-year'\n | 'next-year'\n | 'today'\n\nexport const calendarProps = buildProps({\n modelValue: {\n type: Date,\n },\n range: {\n type: definePropType<[Date, Date]>(Array),\n validator: (range: unknown): range is [Date, Date] =>\n Array.isArray(range) &&\n range.length === 2 &&\n range.every((item) => item instanceof Date),\n },\n} as const)\nexport type CalendarProps = ExtractPropTypes<typeof calendarProps>\n\nexport type CalendarInstance = InstanceType<typeof Calendar>\n"],"names":["buildProps","definePropType"],"mappings":";;;;;;;AACY,MAAC,aAAa,GAAGA,gBAAU,CAAC;AACxC,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,IAAI;AACd,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAEC,oBAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,SAAS,EAAE,CAAC,KAAK,KAAK,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,IAAI,YAAY,IAAI,CAAC;AACnH,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"calendar2.js","sources":["../../../../../../packages/components/calendar/src/calendar.vue"],"sourcesContent":["<template>\n <div :class=\"ns.b()\">\n <div :class=\"ns.e('header')\">\n <slot name=\"header\" :date=\"i18nDate\">\n <div :class=\"ns.e('title')\">{{ i18nDate }}</div>\n <div v-if=\"validatedRange.length === 0\" :class=\"ns.e('button-group')\">\n <ps-button-group>\n <ps-button size=\"small\">\n {{ t('el.datepicker.prevMonth') }}\n </ps-button>\n <ps-button size=\"small\">\n {{ t('el.datepicker.today') }}\n </ps-button>\n <ps-button size=\"small\">\n {{ t('el.datepicker.nextMonth') }}\n </ps-button>\n </ps-button-group>\n </div>\n </slot>\n </div>\n <div v-if=\"validatedRange.length === 0\" :class=\"ns.e('body')\">\n <date-table :date=\"date\" :selected-day=\"realSelectedDay\">\n <template v-if=\"$slots.dateCell\" #dateCell=\"data\">\n <slot name=\"dateCell\" v-bind=\"data\" />\n </template>\n </date-table>\n </div>\n <div v-else :class=\"ns.e('body')\">\n <date-table\n v-for=\"(range_, index) in validatedRange\"\n :key=\"index\"\n :date=\"range_[0]\"\n :selected-day=\"realSelectedDay\"\n :range=\"range_\"\n :hide-header=\"index !== 0\"\n >\n <template v-if=\"$slots.dateCell\" #dateCell=\"data\">\n <slot name=\"dateCell\" v-bind=\"data\" />\n </template>\n </date-table>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, ref } from 'vue'\nimport dayjs from 'dayjs'\nimport { PsButton, PsButtonGroup } from '@element-ps/components/button'\nimport { useLocale, useNamespace } from '@element-ps/hooks'\nimport { debugWarn } from '@element-ps/utils'\nimport DateTable from './date-table.vue'\nimport { calendarProps } from './calendar'\n\nimport type { ComputedRef } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nconst COMPONENT_NAME = 'PsCalendar'\n\ndefineOptions({\n name: 'PsCalendar',\n})\n\nconst props = defineProps(calendarProps)\n\nconst ns = useNamespace('calendar')\n\nconst { t, lang } = useLocale()\nconst selectedDay = ref<Dayjs>()\nconst now = dayjs().locale(lang.value)\n\nconst i18nDate = computed(() => {\n const pickedMonth = `el.datepicker.month${date.value.format('M')}`\n return `${date.value.year()} ${t('el.datepicker.year')} ${t(pickedMonth)}`\n})\n\nconst realSelectedDay = computed<Dayjs | undefined>({\n get() {\n if (!props.modelValue) return selectedDay.value\n return date.value\n },\n set(val) {\n if (!val) return\n selectedDay.value = val\n },\n})\n\nconst date: ComputedRef<Dayjs> = computed(() => {\n if (!props.modelValue) {\n if (realSelectedDay.value) {\n return realSelectedDay.value\n } else if (validatedRange.value.length) {\n return validatedRange.value[0][0]\n }\n return now\n } else {\n return dayjs(props.modelValue).locale(lang.value)\n }\n})\n\n// https://github.com/element-ps/element-ps/issues/3155\n// Calculate the validate date range according to the start and end dates\nconst calculateValidatedDateRange = (\n startDayjs: Dayjs,\n endDayjs: Dayjs\n): [Dayjs, Dayjs][] => {\n const firstDay = startDayjs.startOf('week')\n const lastDay = endDayjs.endOf('week')\n const firstMonth = firstDay.get('month')\n const lastMonth = lastDay.get('month')\n\n // Current mouth\n if (firstMonth === lastMonth) {\n return [[firstDay, lastDay]]\n }\n // Two adjacent months\n else if (firstMonth + 1 === lastMonth) {\n const firstMonthLastDay = firstDay.endOf('month')\n const lastMonthFirstDay = lastDay.startOf('month')\n\n // Whether the last day of the first month and the first day of the last month is in the same week\n const isSameWeek = firstMonthLastDay.isSame(lastMonthFirstDay, 'week')\n const lastMonthStartDay = isSameWeek\n ? lastMonthFirstDay.add(1, 'week')\n : lastMonthFirstDay\n\n return [\n [firstDay, firstMonthLastDay],\n [lastMonthStartDay.startOf('week'), lastDay],\n ]\n }\n // Three consecutive months (compatible: 2021-01-30 to 2021-02-28)\n else if (\n firstMonth + 2 === lastMonth ||\n (firstMonth + 1) % 11 === lastMonth\n ) {\n const firstMonthLastDay = firstDay.endOf('month')\n const secondMonthFirstDay = firstDay.add(1, 'month').startOf('month')\n\n // Whether the last day of the first month and the second month is in the same week\n const secondMonthStartDay = firstMonthLastDay.isSame(\n secondMonthFirstDay,\n 'week'\n )\n ? secondMonthFirstDay.add(1, 'week')\n : secondMonthFirstDay\n\n const secondMonthLastDay = secondMonthStartDay.endOf('month')\n const lastMonthFirstDay = lastDay.startOf('month')\n\n // Whether the last day of the second month and the last day of the last month is in the same week\n const lastMonthStartDay = secondMonthLastDay.isSame(\n lastMonthFirstDay,\n 'week'\n )\n ? lastMonthFirstDay.add(1, 'week')\n : lastMonthFirstDay\n\n return [\n [firstDay, firstMonthLastDay],\n [secondMonthStartDay.startOf('week'), secondMonthLastDay],\n [lastMonthStartDay.startOf('week'), lastDay],\n ]\n }\n // Other cases\n else {\n debugWarn(\n COMPONENT_NAME,\n 'start time and end time interval must not exceed two months'\n )\n return []\n }\n}\n\n// if range is valid, we get a two-digit array\nconst validatedRange = computed(() => {\n if (!props.range) return []\n const rangeArrDayjs = props.range.map((_) => dayjs(_).locale(lang.value))\n const [startDayjs, endDayjs] = rangeArrDayjs\n if (startDayjs.isAfter(endDayjs)) {\n debugWarn(COMPONENT_NAME, 'end time should be greater than start time')\n return []\n }\n if (startDayjs.isSame(endDayjs, 'month')) {\n // same month\n return calculateValidatedDateRange(startDayjs, endDayjs)\n } else {\n // two months\n if (startDayjs.add(1, 'month').month() !== endDayjs.month()) {\n debugWarn(\n COMPONENT_NAME,\n 'start time and end time interval must not exceed two months'\n )\n return []\n }\n return calculateValidatedDateRange(startDayjs, endDayjs)\n }\n})\n\ndefineExpose({\n /** @description currently selected date */\n selectedDay: realSelectedDay,\n /** @description Calculate the validate date range according to the start and end dates */\n calculateValidatedDateRange,\n})\n</script>\n"],"names":["useNamespace","useLocale","ref","dayjs","computed","debugWarn"],"mappings":"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"}
@@ -3,9 +3,9 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  require('../../utils/index.js');
6
- var carousel$1 = require('./src/carousel2.js');
6
+ var carousel$1 = require('./src/carousel.js');
7
7
  var carouselItem$1 = require('./src/carousel-item2.js');
8
- var carousel = require('./src/carousel.js');
8
+ var carousel = require('./src/carousel2.js');
9
9
  var carouselItem = require('./src/carousel-item.js');
10
10
  var install = require('../../utils/vue/install.js');
11
11
 
@@ -2,53 +2,211 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ var vue = require('vue');
6
+ var core = require('@vueuse/core');
5
7
  require('../../../utils/index.js');
6
- var props = require('../../../utils/vue/props.js');
8
+ var index$1 = require('../../icon/index.js');
9
+ var iconsVue = require('@element-plus/icons-vue');
10
+ require('../../../hooks/index.js');
11
+ require('../../../tokens/index.js');
12
+ var carousel = require('./carousel2.js');
13
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
14
+ var index = require('../../../hooks/use-namespace/index.js');
15
+ var shared = require('@vue/shared');
16
+ var error = require('../../../utils/error.js');
17
+ var carousel$1 = require('../../../tokens/carousel.js');
7
18
 
8
- const carouselProps = props.buildProps({
9
- initialIndex: {
10
- type: Number,
11
- default: 0
12
- },
13
- height: { type: String, default: "" },
14
- trigger: {
15
- type: String,
16
- default: "hover"
17
- },
18
- autoplay: {
19
- type: Boolean,
20
- default: true
21
- },
22
- interval: {
23
- type: Number,
24
- default: 3e3
25
- },
26
- indicatorPosition: { type: String, default: "" },
27
- indicator: {
28
- type: Boolean,
29
- default: true
30
- },
31
- arrow: {
32
- type: String,
33
- default: "hover"
34
- },
35
- type: { type: String, default: "" },
36
- loop: {
37
- type: Boolean,
38
- default: true
39
- },
40
- direction: {
41
- type: String,
42
- default: "horizontal",
43
- validator(val) {
44
- return ["horizontal", "vertical"].includes(val);
19
+ const _hoisted_1 = { key: 0 };
20
+ const __default__ = {
21
+ name: "PsCarousel"
22
+ };
23
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
24
+ ...__default__,
25
+ props: carousel.carouselProps,
26
+ setup(__props, { expose }) {
27
+ const props = __props;
28
+ const ns = index.useNamespace("carousel");
29
+ const COMPONENT_NAME = "PsCarousel";
30
+ const THROTTLE_TIME = 300;
31
+ const activeIndex = vue.ref(-1);
32
+ const timer = vue.ref(null);
33
+ const hover = vue.ref(false);
34
+ const root = vue.ref();
35
+ const items = vue.ref([]);
36
+ const arrowDisplay = vue.computed(() => props.arrow !== "never" && !vue.unref(isVertical));
37
+ const hasLabel = vue.computed(() => {
38
+ return items.value.some((item) => item.props.label.toString().length > 0);
39
+ });
40
+ const carouselClasses = vue.computed(() => {
41
+ const classes = [ns.b(), ns.m(props.direction)];
42
+ if (vue.unref(isCardType)) {
43
+ classes.push(ns.m("card"));
44
+ }
45
+ return classes;
46
+ });
47
+ const indicatorsClasses = vue.computed(() => {
48
+ const classes = [ns.e("indicators"), ns.em("indicators", props.direction)];
49
+ if (hasLabel.value) {
50
+ classes.push(ns.em("indicators", "labels"));
51
+ }
52
+ if (props.indicatorPosition === "outside" || vue.unref(isCardType)) {
53
+ classes.push(ns.em("indicators", "outside"));
54
+ }
55
+ return classes;
56
+ });
57
+ const isCardType = vue.computed(() => props.type === "card");
58
+ const isVertical = vue.computed(() => props.direction === "vertical");
59
+ function pauseTimer() {
60
+ if (timer.value) {
61
+ clearInterval(timer.value);
62
+ timer.value = null;
63
+ }
45
64
  }
46
- },
47
- pauseOnHover: {
48
- type: Boolean,
49
- default: true
65
+ function startTimer() {
66
+ if (props.interval <= 0 || !props.autoplay || timer.value)
67
+ return;
68
+ timer.value = setInterval(() => playSlides(), props.interval);
69
+ }
70
+ const playSlides = () => {
71
+ if (activeIndex.value < items.value.length - 1) {
72
+ activeIndex.value = activeIndex.value + 1;
73
+ } else if (props.loop) {
74
+ activeIndex.value = 0;
75
+ }
76
+ };
77
+ function setActiveItem(index) {
78
+ if (shared.isString(index)) {
79
+ const filteredItems = items.value.filter((item) => item.props.name === index);
80
+ if (filteredItems.length > 0) {
81
+ index = items.value.indexOf(filteredItems[0]);
82
+ }
83
+ }
84
+ index = Number(index);
85
+ if (Number.isNaN(index) || index !== Math.floor(index)) {
86
+ error.debugWarn(COMPONENT_NAME, "index must be integer.");
87
+ return;
88
+ }
89
+ const itemCount = items.value.length;
90
+ const oldIndex = activeIndex.value;
91
+ if (index < 0) {
92
+ activeIndex.value = props.loop ? itemCount - 1 : 0;
93
+ } else if (index >= itemCount) {
94
+ activeIndex.value = props.loop ? 0 : itemCount - 1;
95
+ } else {
96
+ activeIndex.value = index;
97
+ }
98
+ if (oldIndex === activeIndex.value) {
99
+ resetItemPosition(oldIndex);
100
+ }
101
+ }
102
+ function resetItemPosition(oldIndex) {
103
+ items.value.forEach((item, index) => {
104
+ item.translateItem(index, activeIndex.value, oldIndex);
105
+ });
106
+ }
107
+ function addItem(item) {
108
+ items.value.push(item);
109
+ }
110
+ function removeItem(uid) {
111
+ const index = items.value.findIndex((item) => item.uid === uid);
112
+ if (index !== -1) {
113
+ items.value.splice(index, 1);
114
+ if (activeIndex.value === index)
115
+ next();
116
+ }
117
+ }
118
+ function next() {
119
+ setActiveItem(activeIndex.value + 1);
120
+ }
121
+ const resizeObserver = vue.shallowRef();
122
+ vue.onMounted(async () => {
123
+ await vue.nextTick();
124
+ resizeObserver.value = core.useResizeObserver(root.value, () => {
125
+ resetItemPosition();
126
+ });
127
+ if (props.initialIndex < items.value.length && props.initialIndex >= 0) {
128
+ activeIndex.value = props.initialIndex;
129
+ }
130
+ startTimer();
131
+ });
132
+ vue.onBeforeUnmount(() => {
133
+ pauseTimer();
134
+ if (root.value && resizeObserver.value)
135
+ resizeObserver.value.stop();
136
+ });
137
+ vue.provide(carousel$1.carouselContextKey, {
138
+ root,
139
+ isCardType,
140
+ isVertical,
141
+ items,
142
+ loop: props.loop,
143
+ addItem,
144
+ removeItem,
145
+ setActiveItem
146
+ });
147
+ expose({
148
+ setActiveItem
149
+ });
150
+ return (_ctx, _cache) => {
151
+ return vue.openBlock(), vue.createElementBlock("div", {
152
+ ref_key: "root",
153
+ ref: root,
154
+ class: vue.normalizeClass(vue.unref(carouselClasses))
155
+ }, [
156
+ vue.createElementVNode("div", {
157
+ class: vue.normalizeClass(vue.unref(ns).e("container")),
158
+ style: vue.normalizeStyle({ height: _ctx.height })
159
+ }, [
160
+ vue.createElementVNode("button", {
161
+ type: "button",
162
+ class: vue.normalizeClass([vue.unref(ns).e("arrow"), vue.unref(ns).em("arrow", "left")])
163
+ }, [
164
+ vue.createVNode(vue.unref(index$1.PsIcon), null, {
165
+ default: vue.withCtx(() => [
166
+ vue.createVNode(vue.unref(iconsVue.ArrowLeft))
167
+ ]),
168
+ _: 1
169
+ })
170
+ ], 2),
171
+ vue.createElementVNode("button", {
172
+ type: "button",
173
+ class: vue.normalizeClass([vue.unref(ns).e("arrow"), vue.unref(ns).em("arrow", "right")])
174
+ }, [
175
+ vue.createVNode(vue.unref(index$1.PsIcon), null, {
176
+ default: vue.withCtx(() => [
177
+ vue.createVNode(vue.unref(iconsVue.ArrowRight))
178
+ ]),
179
+ _: 1
180
+ })
181
+ ], 2),
182
+ vue.renderSlot(_ctx.$slots, "default")
183
+ ], 6),
184
+ _ctx.indicatorPosition !== "none" ? (vue.openBlock(), vue.createElementBlock("ul", {
185
+ key: 0,
186
+ class: vue.normalizeClass(vue.unref(indicatorsClasses))
187
+ }, [
188
+ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(items.value, (item, index) => {
189
+ return vue.openBlock(), vue.createElementBlock("li", {
190
+ key: index,
191
+ class: vue.normalizeClass([
192
+ vue.unref(ns).e("indicator"),
193
+ vue.unref(ns).em("indicator", _ctx.direction),
194
+ vue.unref(ns).is("active", index === activeIndex.value)
195
+ ])
196
+ }, [
197
+ vue.createElementVNode("button", {
198
+ class: vue.normalizeClass(vue.unref(ns).e("button"))
199
+ }, [
200
+ vue.unref(hasLabel) ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_1, vue.toDisplayString(item.props.label), 1)) : vue.createCommentVNode("v-if", true)
201
+ ], 2)
202
+ ], 2);
203
+ }), 128))
204
+ ], 2)) : vue.createCommentVNode("v-if", true)
205
+ ], 2);
206
+ };
50
207
  }
51
208
  });
209
+ var Carousel = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/carousel/src/carousel.vue"]]);
52
210
 
53
- exports.carouselProps = carouselProps;
211
+ exports["default"] = Carousel;
54
212
  //# sourceMappingURL=carousel.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"carousel.js","sources":["../../../../../../packages/components/carousel/src/carousel.ts"],"sourcesContent":["import { buildProps } from '@element-ps/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Carousel from './carousel.vue'\n\nexport const carouselProps = buildProps({\n initialIndex: {\n type: Number,\n default: 0,\n },\n height: { type: String, default: '' },\n trigger: {\n type: String,\n default: 'hover',\n },\n autoplay: {\n type: Boolean,\n default: true,\n },\n interval: {\n type: Number,\n default: 3000,\n },\n indicatorPosition: { type: String, default: '' },\n indicator: {\n type: Boolean,\n default: true,\n },\n arrow: {\n type: String,\n default: 'hover',\n },\n type: { type: String, default: '' },\n loop: {\n type: Boolean,\n default: true,\n },\n direction: {\n type: String,\n default: 'horizontal',\n validator(val: string) {\n return ['horizontal', 'vertical'].includes(val)\n },\n },\n pauseOnHover: {\n type: Boolean,\n default: true,\n },\n} as const)\n\nexport type CarouselProps = ExtractPropTypes<typeof carouselProps>\n\nexport type CarouselInstance = InstanceType<typeof Carousel>\n"],"names":["buildProps"],"mappings":";;;;;;;AACY,MAAC,aAAa,GAAGA,gBAAU,CAAC;AACxC,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AACvC,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,iBAAiB,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AAClD,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AACrC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,YAAY;AACzB,IAAI,SAAS,CAAC,GAAG,EAAE;AACnB,MAAM,OAAO,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AACtD,KAAK;AACL,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"carousel.js","sources":["../../../../../../packages/components/carousel/src/carousel.vue"],"sourcesContent":["<template>\n <div\n ref=\"root\"\n :class=\"carouselClasses\"\n >\n <div :class=\"ns.e('container')\" :style=\"{ height: height }\">\n <button\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'left')]\"\n >\n <PsIcon>\n <ArrowLeft />\n </PsIcon>\n </button>\n <button\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'right')]\"\n >\n <PsIcon>\n <ArrowRight />\n </PsIcon>\n </button>\n <slot />\n </div>\n <ul v-if=\"indicatorPosition !== 'none'\" :class=\"indicatorsClasses\">\n <li\n v-for=\"(item, index) in items\"\n :key=\"index\"\n :class=\"[\n ns.e('indicator'),\n ns.em('indicator', direction),\n ns.is('active', index === activeIndex),\n ]\"\n >\n <button :class=\"ns.e('button')\">\n <span v-if=\"hasLabel\">{{ item.props.label }}</span>\n </button>\n </li>\n </ul>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n nextTick,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n shallowRef,\n unref,\n} from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { debugWarn, isString } from '@element-ps/utils'\nimport { PsIcon } from '@element-ps/components/icon'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-ps/hooks'\nimport { carouselContextKey } from '@element-ps/tokens'\nimport { carouselProps } from './carousel'\nimport type { CarouselItemContext } from '@element-ps/tokens'\n\ndefineOptions({\n name: 'PsCarousel',\n})\n\nconst props = defineProps(carouselProps)\nconst ns = useNamespace('carousel')\nconst COMPONENT_NAME = 'PsCarousel'\nconst THROTTLE_TIME = 300\n\n// refs\nconst activeIndex = ref(-1)\nconst timer = ref<ReturnType<typeof setInterval> | null>(null)\nconst hover = ref(false)\nconst root = ref<HTMLDivElement>()\nconst items = ref<Array<CarouselItemContext>>([])\n\n// computed\nconst arrowDisplay = computed(\n () => props.arrow !== 'never' && !unref(isVertical)\n)\n\nconst hasLabel = computed(() => {\n return items.value.some((item) => item.props.label.toString().length > 0)\n})\n\nconst carouselClasses = computed(() => {\n const classes = [ns.b(), ns.m(props.direction)]\n if (unref(isCardType)) {\n classes.push(ns.m('card'))\n }\n return classes\n})\n\nconst indicatorsClasses = computed(() => {\n const classes = [ns.e('indicators'), ns.em('indicators', props.direction)]\n if (hasLabel.value) {\n classes.push(ns.em('indicators', 'labels'))\n }\n if (props.indicatorPosition === 'outside' || unref(isCardType)) {\n classes.push(ns.em('indicators', 'outside'))\n }\n return classes\n})\n\nconst isCardType = computed(() => props.type === 'card')\nconst isVertical = computed(() => props.direction === 'vertical')\n\nfunction pauseTimer() {\n if (timer.value) {\n clearInterval(timer.value)\n timer.value = null\n }\n}\n\nfunction startTimer() {\n if (props.interval <= 0 || !props.autoplay || timer.value) return\n timer.value = setInterval(() => playSlides(), props.interval)\n}\n\nconst playSlides = () => {\n if (activeIndex.value < items.value.length - 1) {\n activeIndex.value = activeIndex.value + 1\n } else if (props.loop) {\n activeIndex.value = 0\n }\n}\n\nfunction setActiveItem(index: number | string) {\n if (isString(index)) {\n const filteredItems = items.value.filter(\n (item) => item.props.name === index\n )\n if (filteredItems.length > 0) {\n index = items.value.indexOf(filteredItems[0])\n }\n }\n index = Number(index)\n if (Number.isNaN(index) || index !== Math.floor(index)) {\n debugWarn(COMPONENT_NAME, 'index must be integer.')\n return\n }\n const itemCount = items.value.length\n const oldIndex = activeIndex.value\n if (index < 0) {\n activeIndex.value = props.loop ? itemCount - 1 : 0\n } else if (index >= itemCount) {\n activeIndex.value = props.loop ? 0 : itemCount - 1\n } else {\n activeIndex.value = index\n }\n if (oldIndex === activeIndex.value) {\n resetItemPosition(oldIndex)\n }\n}\n\nfunction resetItemPosition(oldIndex?: number) {\n items.value.forEach((item, index) => {\n item.translateItem(index, activeIndex.value, oldIndex)\n })\n}\n\nfunction addItem(item: CarouselItemContext) {\n items.value.push(item)\n}\n\nfunction removeItem(uid?: number) {\n const index = items.value.findIndex((item) => item.uid === uid)\n if (index !== -1) {\n items.value.splice(index, 1)\n if (activeIndex.value === index) next()\n }\n}\n\nfunction next() {\n setActiveItem(activeIndex.value + 1)\n}\n\nconst resizeObserver = shallowRef<ReturnType<typeof useResizeObserver>>()\n// lifecycle\nonMounted(async () => {\n await nextTick()\n\n resizeObserver.value = useResizeObserver(root.value, () => {\n resetItemPosition()\n })\n if (props.initialIndex < items.value.length && props.initialIndex >= 0) {\n activeIndex.value = props.initialIndex\n }\n startTimer()\n})\n\nonBeforeUnmount(() => {\n pauseTimer()\n if (root.value && resizeObserver.value) resizeObserver.value.stop()\n})\n\n// provide\nprovide(carouselContextKey, {\n root,\n isCardType,\n isVertical,\n items,\n loop: props.loop,\n addItem,\n removeItem,\n setActiveItem,\n})\n\ndefineExpose({\n /** @description manually switch slide */\n setActiveItem,\n})\n</script>\n"],"names":["useNamespace","ref","computed","unref","isString","debugWarn","shallowRef","onMounted","nextTick","useResizeObserver","onBeforeUnmount","provide","carouselContextKey"],"mappings":"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"}