element-ps 2.0.10 → 2.0.13

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 (522) hide show
  1. package/dist/index.full.js +441 -412
  2. package/dist/index.full.min.js +5 -5
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +5 -5
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +441 -412
  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.d.ts +2 -2
  13. package/es/components/alert/index.mjs +2 -2
  14. package/es/components/alert/src/alert.mjs +33 -83
  15. package/es/components/alert/src/alert.mjs.map +1 -1
  16. package/es/components/alert/src/alert.vue.d.ts +2 -2
  17. package/es/components/alert/src/alert2.mjs +83 -33
  18. package/es/components/alert/src/alert2.mjs.map +1 -1
  19. package/es/components/autocomplete/index.d.ts +186 -95
  20. package/es/components/autocomplete/index.mjs +2 -2
  21. package/es/components/autocomplete/src/autocomplete.mjs +96 -58
  22. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  23. package/es/components/autocomplete/src/autocomplete.vue.d.ts +186 -95
  24. package/es/components/autocomplete/src/autocomplete2.mjs +58 -96
  25. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  26. package/es/components/avatar/index.mjs +2 -2
  27. package/es/components/avatar/src/avatar.mjs +29 -61
  28. package/es/components/avatar/src/avatar.mjs.map +1 -1
  29. package/es/components/avatar/src/avatar2.mjs +61 -29
  30. package/es/components/avatar/src/avatar2.mjs.map +1 -1
  31. package/es/components/breadcrumb/index.mjs +2 -2
  32. package/es/components/breadcrumb/src/breadcrumb.mjs +37 -12
  33. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  34. package/es/components/breadcrumb/src/breadcrumb2.mjs +12 -37
  35. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  36. package/es/components/calendar/index.mjs +2 -2
  37. package/es/components/calendar/src/calendar.mjs +188 -9
  38. package/es/components/calendar/src/calendar.mjs.map +1 -1
  39. package/es/components/calendar/src/calendar2.mjs +9 -188
  40. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  41. package/es/components/carousel/index.mjs +2 -2
  42. package/es/components/carousel/src/carousel-item.mjs +7 -148
  43. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  44. package/es/components/carousel/src/carousel-item2.mjs +148 -7
  45. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  46. package/es/components/cascader/index.d.ts +364 -170
  47. package/es/components/cascader/src/index.mjs +15 -10
  48. package/es/components/cascader/src/index.mjs.map +1 -1
  49. package/es/components/cascader/src/index.vue.d.ts +182 -85
  50. package/es/components/check-tag/index.mjs +2 -2
  51. package/es/components/check-tag/src/check-tag.mjs +20 -7
  52. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  53. package/es/components/check-tag/src/check-tag2.mjs +7 -20
  54. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  55. package/es/components/collapse/index.mjs +2 -2
  56. package/es/components/collapse/src/collapse.mjs +14 -61
  57. package/es/components/collapse/src/collapse.mjs.map +1 -1
  58. package/es/components/collapse/src/collapse2.mjs +61 -14
  59. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  60. package/es/components/date-picker/index.d.ts +8 -8
  61. package/es/components/date-picker/src/date-picker.d.ts +4 -4
  62. package/es/components/descriptions/index.d.ts +14 -2
  63. package/es/components/descriptions/src/description-item.d.ts +6 -0
  64. package/es/components/descriptions/src/description-item.mjs +3 -0
  65. package/es/components/descriptions/src/description-item.mjs.map +1 -1
  66. package/es/components/descriptions/src/descriptions.type.d.ts +1 -0
  67. package/es/components/descriptions/src/index.vue.d.ts +2 -2
  68. package/es/components/dialog/index.d.ts +5 -1
  69. package/es/components/dialog/index.mjs +2 -2
  70. package/es/components/dialog/src/dialog-content.d.ts +1 -0
  71. package/es/components/dialog/src/dialog-content.mjs +3 -0
  72. package/es/components/dialog/src/dialog-content.mjs.map +1 -1
  73. package/es/components/dialog/src/dialog-content.vue.d.ts +4 -1
  74. package/es/components/dialog/src/dialog-content2.mjs +11 -6
  75. package/es/components/dialog/src/dialog-content2.mjs.map +1 -1
  76. package/es/components/dialog/src/dialog.d.ts +1 -0
  77. package/es/components/dialog/src/dialog.mjs +97 -58
  78. package/es/components/dialog/src/dialog.mjs.map +1 -1
  79. package/es/components/dialog/src/dialog.vue.d.ts +5 -1
  80. package/es/components/dialog/src/dialog2.mjs +61 -96
  81. package/es/components/dialog/src/dialog2.mjs.map +1 -1
  82. package/es/components/divider/index.mjs +2 -2
  83. package/es/components/divider/src/divider.mjs +34 -17
  84. package/es/components/divider/src/divider.mjs.map +1 -1
  85. package/es/components/divider/src/divider2.mjs +17 -34
  86. package/es/components/divider/src/divider2.mjs.map +1 -1
  87. package/es/components/drawer/index.d.ts +4 -1
  88. package/es/components/drawer/src/drawer.d.ts +1 -0
  89. package/es/components/drawer/src/drawer.mjs +4 -1
  90. package/es/components/drawer/src/drawer.mjs.map +1 -1
  91. package/es/components/drawer/src/drawer.vue.d.ts +4 -1
  92. package/es/components/drawer/src/drawer2.mjs +64 -65
  93. package/es/components/drawer/src/drawer2.mjs.map +1 -1
  94. package/es/components/dropdown/index.d.ts +5 -5
  95. package/es/components/dropdown/src/dropdown.d.ts +1 -1
  96. package/es/components/dropdown/src/dropdown.vue.d.ts +5 -5
  97. package/es/components/form/index.d.ts +8 -0
  98. package/es/components/form/index.mjs +2 -2
  99. package/es/components/form/src/form-item.d.ts +1 -0
  100. package/es/components/form/src/form-item.mjs +3 -0
  101. package/es/components/form/src/form-item.mjs.map +1 -1
  102. package/es/components/form/src/form-item.vue.d.ts +4 -0
  103. package/es/components/form/src/form-item2.mjs +12 -7
  104. package/es/components/form/src/form-item2.mjs.map +1 -1
  105. package/es/components/form/src/form.mjs +45 -40
  106. package/es/components/form/src/form.mjs.map +1 -1
  107. package/es/components/form/src/form2.mjs +40 -45
  108. package/es/components/form/src/form2.mjs.map +1 -1
  109. package/es/components/image/index.d.ts +1 -1
  110. package/es/components/image/index.mjs +2 -2
  111. package/es/components/image/src/image.mjs +50 -158
  112. package/es/components/image/src/image.mjs.map +1 -1
  113. package/es/components/image/src/image.vue.d.ts +1 -1
  114. package/es/components/image/src/image2.mjs +158 -50
  115. package/es/components/image/src/image2.mjs.map +1 -1
  116. package/es/components/image-viewer/index.mjs +2 -2
  117. package/es/components/image-viewer/src/image-viewer.mjs +31 -210
  118. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  119. package/es/components/image-viewer/src/image-viewer2.mjs +210 -31
  120. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  121. package/es/components/index.mjs +28 -28
  122. package/es/components/input/index.d.ts +99 -42
  123. package/es/components/input/src/input.d.ts +1 -0
  124. package/es/components/input/src/input.mjs +3 -0
  125. package/es/components/input/src/input.mjs.map +1 -1
  126. package/es/components/input/src/input.vue.d.ts +99 -42
  127. package/es/components/input/src/input2.mjs +19 -15
  128. package/es/components/input/src/input2.mjs.map +1 -1
  129. package/es/components/input-number/index.d.ts +198 -84
  130. package/es/components/input-number/index.mjs +2 -2
  131. package/es/components/input-number/src/input-number.mjs +46 -171
  132. package/es/components/input-number/src/input-number.mjs.map +1 -1
  133. package/es/components/input-number/src/input-number.vue.d.ts +198 -84
  134. package/es/components/input-number/src/input-number2.mjs +171 -46
  135. package/es/components/input-number/src/input-number2.mjs.map +1 -1
  136. package/es/components/link/index.mjs +2 -2
  137. package/es/components/link/src/link.mjs +40 -19
  138. package/es/components/link/src/link.mjs.map +1 -1
  139. package/es/components/link/src/link2.mjs +19 -40
  140. package/es/components/link/src/link2.mjs.map +1 -1
  141. package/es/components/menu/src/menu-item2.mjs +1 -1
  142. package/es/components/popconfirm/index.d.ts +1 -1
  143. package/es/components/popconfirm/index.mjs +2 -2
  144. package/es/components/popconfirm/src/popconfirm.mjs +53 -20
  145. package/es/components/popconfirm/src/popconfirm.mjs.map +1 -1
  146. package/es/components/popconfirm/src/popconfirm.vue.d.ts +1 -1
  147. package/es/components/popconfirm/src/popconfirm2.mjs +20 -53
  148. package/es/components/popconfirm/src/popconfirm2.mjs.map +1 -1
  149. package/es/components/popover/index.d.ts +10 -10
  150. package/es/components/popover/src/index.vue.d.ts +5 -5
  151. package/es/components/popover/src/popover.d.ts +1 -1
  152. package/es/components/popper/index.mjs +2 -2
  153. package/es/components/popper/src/content.vue.d.ts +2 -2
  154. package/es/components/popper/src/popper.mjs +27 -20
  155. package/es/components/popper/src/popper.mjs.map +1 -1
  156. package/es/components/popper/src/popper2.mjs +20 -27
  157. package/es/components/popper/src/popper2.mjs.map +1 -1
  158. package/es/components/progress/index.d.ts +3 -3
  159. package/es/components/progress/src/progress.d.ts +1 -1
  160. package/es/components/progress/src/progress.vue.d.ts +3 -3
  161. package/es/components/radio/index.mjs +4 -4
  162. package/es/components/radio/src/radio-button.mjs +9 -80
  163. package/es/components/radio/src/radio-button.mjs.map +1 -1
  164. package/es/components/radio/src/radio-button2.mjs +80 -9
  165. package/es/components/radio/src/radio-button2.mjs.map +1 -1
  166. package/es/components/radio/src/radio.mjs +74 -67
  167. package/es/components/radio/src/radio.mjs.map +1 -1
  168. package/es/components/radio/src/radio2.mjs +67 -74
  169. package/es/components/radio/src/radio2.mjs.map +1 -1
  170. package/es/components/rate/index.mjs +2 -2
  171. package/es/components/rate/src/rate.mjs +84 -169
  172. package/es/components/rate/src/rate.mjs.map +1 -1
  173. package/es/components/rate/src/rate2.mjs +169 -84
  174. package/es/components/rate/src/rate2.mjs.map +1 -1
  175. package/es/components/row/index.d.ts +3 -3
  176. package/es/components/row/src/row.d.ts +4 -4
  177. package/es/components/scrollbar/src/thumb.vue.d.ts +1 -1
  178. package/es/components/select/index.d.ts +12 -12
  179. package/es/components/select/src/select.mjs +1 -1
  180. package/es/components/select/src/select.vue.d.ts +12 -12
  181. package/es/components/select/src/useSelect.d.ts +10 -10
  182. package/es/components/select-v2/index.d.ts +24 -24
  183. package/es/components/select-v2/src/select.vue.d.ts +12 -12
  184. package/es/components/select-v2/src/useSelect.d.ts +10 -10
  185. package/es/components/skeleton/index.mjs +4 -4
  186. package/es/components/skeleton/src/skeleton-item.mjs +18 -23
  187. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  188. package/es/components/skeleton/src/skeleton-item2.mjs +23 -18
  189. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  190. package/es/components/skeleton/src/skeleton.mjs +49 -22
  191. package/es/components/skeleton/src/skeleton.mjs.map +1 -1
  192. package/es/components/skeleton/src/skeleton2.mjs +22 -49
  193. package/es/components/skeleton/src/skeleton2.mjs.map +1 -1
  194. package/es/components/space/index.d.ts +1 -1
  195. package/es/components/space/src/space.d.ts +1 -1
  196. package/es/components/switch/index.d.ts +2 -2
  197. package/es/components/switch/src/switch.vue.d.ts +2 -2
  198. package/es/components/switch/src/switch2.mjs +0 -1
  199. package/es/components/switch/src/switch2.mjs.map +1 -1
  200. package/es/components/table/index.d.ts +14 -2
  201. package/es/components/table/src/filter-panel.vue.d.ts +10 -10
  202. package/es/components/table/src/table-body/render-helper.mjs +2 -1
  203. package/es/components/table/src/table-body/render-helper.mjs.map +1 -1
  204. package/es/components/table/src/table-column/defaults.d.ts +4 -0
  205. package/es/components/table/src/table-column/defaults.mjs +3 -0
  206. package/es/components/table/src/table-column/defaults.mjs.map +1 -1
  207. package/es/components/table/src/table-column/index.d.ts +6 -0
  208. package/es/components/table/src/table-column/index.mjs +2 -1
  209. package/es/components/table/src/table-column/index.mjs.map +1 -1
  210. package/es/components/table/src/table-header/index.mjs +1 -8
  211. package/es/components/table/src/table-header/index.mjs.map +1 -1
  212. package/es/components/table/src/table.vue.d.ts +2 -2
  213. package/es/components/tabs/index.mjs +2 -2
  214. package/es/components/tabs/src/tab-pane.mjs +60 -14
  215. package/es/components/tabs/src/tab-pane.mjs.map +1 -1
  216. package/es/components/tabs/src/tab-pane2.mjs +14 -60
  217. package/es/components/tabs/src/tab-pane2.mjs.map +1 -1
  218. package/es/components/tag/index.mjs +2 -2
  219. package/es/components/tag/src/tag.mjs +81 -33
  220. package/es/components/tag/src/tag.mjs.map +1 -1
  221. package/es/components/tag/src/tag2.mjs +33 -81
  222. package/es/components/tag/src/tag2.mjs.map +1 -1
  223. package/es/components/time-picker/index.d.ts +8 -8
  224. package/es/components/time-picker/src/common/picker.vue.d.ts +14 -14
  225. package/es/components/time-picker/src/time-picker.d.ts +4 -4
  226. package/es/components/time-select/index.d.ts +6 -6
  227. package/es/components/time-select/src/time-select.vue.d.ts +3 -3
  228. package/es/components/timeline/index.mjs +2 -2
  229. package/es/components/timeline/src/timeline-item.mjs +73 -39
  230. package/es/components/timeline/src/timeline-item.mjs.map +1 -1
  231. package/es/components/timeline/src/timeline-item2.mjs +39 -73
  232. package/es/components/timeline/src/timeline-item2.mjs.map +1 -1
  233. package/es/components/tooltip/index.d.ts +5 -5
  234. package/es/components/tooltip/src/tooltip.d.ts +1 -1
  235. package/es/components/tooltip/src/tooltip.vue.d.ts +5 -5
  236. package/es/components/tooltip/src/trigger.vue.d.ts +3 -3
  237. package/es/components/tooltip-v2/index.d.ts +6 -6
  238. package/es/components/tooltip-v2/index.mjs +3 -3
  239. package/es/components/tooltip-v2/src/arrow.mjs +38 -22
  240. package/es/components/tooltip-v2/src/arrow.mjs.map +1 -1
  241. package/es/components/tooltip-v2/src/arrow2.mjs +22 -38
  242. package/es/components/tooltip-v2/src/arrow2.mjs.map +1 -1
  243. package/es/components/tooltip-v2/src/content.vue.d.ts +1 -1
  244. package/es/components/tooltip-v2/src/tooltip.mjs +20 -73
  245. package/es/components/tooltip-v2/src/tooltip.mjs.map +1 -1
  246. package/es/components/tooltip-v2/src/tooltip.vue.d.ts +6 -6
  247. package/es/components/tooltip-v2/src/tooltip2.mjs +73 -20
  248. package/es/components/tooltip-v2/src/tooltip2.mjs.map +1 -1
  249. package/es/components/upload/index.mjs +3 -3
  250. package/es/components/upload/src/upload-content.mjs +15 -46
  251. package/es/components/upload/src/upload-content.mjs.map +1 -1
  252. package/es/components/upload/src/upload-content2.mjs +46 -15
  253. package/es/components/upload/src/upload-content2.mjs.map +1 -1
  254. package/es/components/upload/src/upload-list.vue.d.ts +3 -3
  255. package/es/components/upload/src/upload-list2.mjs +1 -1
  256. package/es/components/upload/src/upload.mjs +99 -106
  257. package/es/components/upload/src/upload.mjs.map +1 -1
  258. package/es/components/upload/src/upload2.mjs +106 -99
  259. package/es/components/upload/src/upload2.mjs.map +1 -1
  260. package/es/components/virtual-list/src/builders/build-list.d.ts +1 -1
  261. package/es/components/virtual-list/src/components/dynamic-size-list.d.ts +1 -1
  262. package/es/components/virtual-list/src/components/fixed-size-list.d.ts +1 -1
  263. package/es/index.mjs +28 -28
  264. package/lib/components/affix/index.js +2 -2
  265. package/lib/components/affix/src/affix.js +19 -82
  266. package/lib/components/affix/src/affix.js.map +1 -1
  267. package/lib/components/affix/src/affix2.js +82 -19
  268. package/lib/components/affix/src/affix2.js.map +1 -1
  269. package/lib/components/alert/index.d.ts +2 -2
  270. package/lib/components/alert/index.js +2 -2
  271. package/lib/components/alert/src/alert.js +33 -82
  272. package/lib/components/alert/src/alert.js.map +1 -1
  273. package/lib/components/alert/src/alert.vue.d.ts +2 -2
  274. package/lib/components/alert/src/alert2.js +82 -33
  275. package/lib/components/alert/src/alert2.js.map +1 -1
  276. package/lib/components/autocomplete/index.d.ts +186 -95
  277. package/lib/components/autocomplete/index.js +2 -2
  278. package/lib/components/autocomplete/src/autocomplete.js +96 -58
  279. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  280. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +186 -95
  281. package/lib/components/autocomplete/src/autocomplete2.js +58 -96
  282. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  283. package/lib/components/avatar/index.js +2 -2
  284. package/lib/components/avatar/src/avatar.js +29 -61
  285. package/lib/components/avatar/src/avatar.js.map +1 -1
  286. package/lib/components/avatar/src/avatar2.js +61 -29
  287. package/lib/components/avatar/src/avatar2.js.map +1 -1
  288. package/lib/components/breadcrumb/index.js +2 -2
  289. package/lib/components/breadcrumb/src/breadcrumb.js +37 -12
  290. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  291. package/lib/components/breadcrumb/src/breadcrumb2.js +12 -37
  292. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  293. package/lib/components/calendar/index.js +2 -2
  294. package/lib/components/calendar/src/calendar.js +192 -9
  295. package/lib/components/calendar/src/calendar.js.map +1 -1
  296. package/lib/components/calendar/src/calendar2.js +9 -192
  297. package/lib/components/calendar/src/calendar2.js.map +1 -1
  298. package/lib/components/carousel/index.js +2 -2
  299. package/lib/components/carousel/src/carousel-item.js +7 -148
  300. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  301. package/lib/components/carousel/src/carousel-item2.js +148 -7
  302. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  303. package/lib/components/cascader/index.d.ts +364 -170
  304. package/lib/components/cascader/src/index.js +15 -10
  305. package/lib/components/cascader/src/index.js.map +1 -1
  306. package/lib/components/cascader/src/index.vue.d.ts +182 -85
  307. package/lib/components/check-tag/index.js +2 -2
  308. package/lib/components/check-tag/src/check-tag.js +20 -7
  309. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  310. package/lib/components/check-tag/src/check-tag2.js +7 -20
  311. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  312. package/lib/components/collapse/index.js +2 -2
  313. package/lib/components/collapse/src/collapse.js +16 -61
  314. package/lib/components/collapse/src/collapse.js.map +1 -1
  315. package/lib/components/collapse/src/collapse2.js +61 -16
  316. package/lib/components/collapse/src/collapse2.js.map +1 -1
  317. package/lib/components/date-picker/index.d.ts +8 -8
  318. package/lib/components/date-picker/src/date-picker.d.ts +4 -4
  319. package/lib/components/descriptions/index.d.ts +14 -2
  320. package/lib/components/descriptions/src/description-item.d.ts +6 -0
  321. package/lib/components/descriptions/src/description-item.js +3 -0
  322. package/lib/components/descriptions/src/description-item.js.map +1 -1
  323. package/lib/components/descriptions/src/descriptions.type.d.ts +1 -0
  324. package/lib/components/descriptions/src/index.vue.d.ts +2 -2
  325. package/lib/components/dialog/index.d.ts +5 -1
  326. package/lib/components/dialog/index.js +2 -2
  327. package/lib/components/dialog/src/dialog-content.d.ts +1 -0
  328. package/lib/components/dialog/src/dialog-content.js +3 -0
  329. package/lib/components/dialog/src/dialog-content.js.map +1 -1
  330. package/lib/components/dialog/src/dialog-content.vue.d.ts +4 -1
  331. package/lib/components/dialog/src/dialog-content2.js +11 -6
  332. package/lib/components/dialog/src/dialog-content2.js.map +1 -1
  333. package/lib/components/dialog/src/dialog.d.ts +1 -0
  334. package/lib/components/dialog/src/dialog.js +97 -58
  335. package/lib/components/dialog/src/dialog.js.map +1 -1
  336. package/lib/components/dialog/src/dialog.vue.d.ts +5 -1
  337. package/lib/components/dialog/src/dialog2.js +61 -96
  338. package/lib/components/dialog/src/dialog2.js.map +1 -1
  339. package/lib/components/divider/index.js +2 -2
  340. package/lib/components/divider/src/divider.js +34 -17
  341. package/lib/components/divider/src/divider.js.map +1 -1
  342. package/lib/components/divider/src/divider2.js +17 -34
  343. package/lib/components/divider/src/divider2.js.map +1 -1
  344. package/lib/components/drawer/index.d.ts +4 -1
  345. package/lib/components/drawer/src/drawer.d.ts +1 -0
  346. package/lib/components/drawer/src/drawer.js +4 -1
  347. package/lib/components/drawer/src/drawer.js.map +1 -1
  348. package/lib/components/drawer/src/drawer.vue.d.ts +4 -1
  349. package/lib/components/drawer/src/drawer2.js +63 -64
  350. package/lib/components/drawer/src/drawer2.js.map +1 -1
  351. package/lib/components/dropdown/index.d.ts +5 -5
  352. package/lib/components/dropdown/src/dropdown.d.ts +1 -1
  353. package/lib/components/dropdown/src/dropdown.vue.d.ts +5 -5
  354. package/lib/components/form/index.d.ts +8 -0
  355. package/lib/components/form/index.js +2 -2
  356. package/lib/components/form/src/form-item.d.ts +1 -0
  357. package/lib/components/form/src/form-item.js +3 -0
  358. package/lib/components/form/src/form-item.js.map +1 -1
  359. package/lib/components/form/src/form-item.vue.d.ts +4 -0
  360. package/lib/components/form/src/form-item2.js +12 -7
  361. package/lib/components/form/src/form-item2.js.map +1 -1
  362. package/lib/components/form/src/form.js +45 -40
  363. package/lib/components/form/src/form.js.map +1 -1
  364. package/lib/components/form/src/form2.js +40 -45
  365. package/lib/components/form/src/form2.js.map +1 -1
  366. package/lib/components/image/index.d.ts +1 -1
  367. package/lib/components/image/index.js +2 -2
  368. package/lib/components/image/src/image.js +50 -158
  369. package/lib/components/image/src/image.js.map +1 -1
  370. package/lib/components/image/src/image.vue.d.ts +1 -1
  371. package/lib/components/image/src/image2.js +158 -50
  372. package/lib/components/image/src/image2.js.map +1 -1
  373. package/lib/components/image-viewer/index.js +2 -2
  374. package/lib/components/image-viewer/src/image-viewer.js +31 -210
  375. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  376. package/lib/components/image-viewer/src/image-viewer2.js +210 -31
  377. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  378. package/lib/components/index.js +28 -28
  379. package/lib/components/input/index.d.ts +99 -42
  380. package/lib/components/input/src/input.d.ts +1 -0
  381. package/lib/components/input/src/input.js +3 -0
  382. package/lib/components/input/src/input.js.map +1 -1
  383. package/lib/components/input/src/input.vue.d.ts +99 -42
  384. package/lib/components/input/src/input2.js +18 -14
  385. package/lib/components/input/src/input2.js.map +1 -1
  386. package/lib/components/input-number/index.d.ts +198 -84
  387. package/lib/components/input-number/index.js +2 -2
  388. package/lib/components/input-number/src/input-number.js +46 -171
  389. package/lib/components/input-number/src/input-number.js.map +1 -1
  390. package/lib/components/input-number/src/input-number.vue.d.ts +198 -84
  391. package/lib/components/input-number/src/input-number2.js +171 -46
  392. package/lib/components/input-number/src/input-number2.js.map +1 -1
  393. package/lib/components/link/index.js +2 -2
  394. package/lib/components/link/src/link.js +40 -19
  395. package/lib/components/link/src/link.js.map +1 -1
  396. package/lib/components/link/src/link2.js +19 -40
  397. package/lib/components/link/src/link2.js.map +1 -1
  398. package/lib/components/menu/src/menu-item2.js +1 -1
  399. package/lib/components/popconfirm/index.d.ts +1 -1
  400. package/lib/components/popconfirm/index.js +2 -2
  401. package/lib/components/popconfirm/src/popconfirm.js +53 -20
  402. package/lib/components/popconfirm/src/popconfirm.js.map +1 -1
  403. package/lib/components/popconfirm/src/popconfirm.vue.d.ts +1 -1
  404. package/lib/components/popconfirm/src/popconfirm2.js +20 -53
  405. package/lib/components/popconfirm/src/popconfirm2.js.map +1 -1
  406. package/lib/components/popover/index.d.ts +10 -10
  407. package/lib/components/popover/src/index.vue.d.ts +5 -5
  408. package/lib/components/popover/src/popover.d.ts +1 -1
  409. package/lib/components/popper/index.js +2 -2
  410. package/lib/components/popper/src/content.vue.d.ts +2 -2
  411. package/lib/components/popper/src/popper.js +27 -21
  412. package/lib/components/popper/src/popper.js.map +1 -1
  413. package/lib/components/popper/src/popper2.js +21 -27
  414. package/lib/components/popper/src/popper2.js.map +1 -1
  415. package/lib/components/progress/index.d.ts +3 -3
  416. package/lib/components/progress/src/progress.d.ts +1 -1
  417. package/lib/components/progress/src/progress.vue.d.ts +3 -3
  418. package/lib/components/radio/index.js +4 -4
  419. package/lib/components/radio/src/radio-button.js +9 -80
  420. package/lib/components/radio/src/radio-button.js.map +1 -1
  421. package/lib/components/radio/src/radio-button2.js +80 -9
  422. package/lib/components/radio/src/radio-button2.js.map +1 -1
  423. package/lib/components/radio/src/radio.js +73 -69
  424. package/lib/components/radio/src/radio.js.map +1 -1
  425. package/lib/components/radio/src/radio2.js +69 -73
  426. package/lib/components/radio/src/radio2.js.map +1 -1
  427. package/lib/components/rate/index.js +2 -2
  428. package/lib/components/rate/src/rate.js +84 -169
  429. package/lib/components/rate/src/rate.js.map +1 -1
  430. package/lib/components/rate/src/rate2.js +169 -84
  431. package/lib/components/rate/src/rate2.js.map +1 -1
  432. package/lib/components/row/index.d.ts +3 -3
  433. package/lib/components/row/src/row.d.ts +4 -4
  434. package/lib/components/scrollbar/src/thumb.vue.d.ts +1 -1
  435. package/lib/components/select/index.d.ts +12 -12
  436. package/lib/components/select/src/select.js +1 -1
  437. package/lib/components/select/src/select.vue.d.ts +12 -12
  438. package/lib/components/select/src/useSelect.d.ts +10 -10
  439. package/lib/components/select-v2/index.d.ts +24 -24
  440. package/lib/components/select-v2/src/select.vue.d.ts +12 -12
  441. package/lib/components/select-v2/src/useSelect.d.ts +10 -10
  442. package/lib/components/skeleton/index.js +4 -4
  443. package/lib/components/skeleton/src/skeleton-item.js +18 -23
  444. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  445. package/lib/components/skeleton/src/skeleton-item2.js +23 -18
  446. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  447. package/lib/components/skeleton/src/skeleton.js +49 -22
  448. package/lib/components/skeleton/src/skeleton.js.map +1 -1
  449. package/lib/components/skeleton/src/skeleton2.js +22 -49
  450. package/lib/components/skeleton/src/skeleton2.js.map +1 -1
  451. package/lib/components/space/index.d.ts +1 -1
  452. package/lib/components/space/src/space.d.ts +1 -1
  453. package/lib/components/switch/index.d.ts +2 -2
  454. package/lib/components/switch/src/switch.vue.d.ts +2 -2
  455. package/lib/components/switch/src/switch2.js +0 -1
  456. package/lib/components/switch/src/switch2.js.map +1 -1
  457. package/lib/components/table/index.d.ts +14 -2
  458. package/lib/components/table/src/filter-panel.vue.d.ts +10 -10
  459. package/lib/components/table/src/table-body/render-helper.js +2 -1
  460. package/lib/components/table/src/table-body/render-helper.js.map +1 -1
  461. package/lib/components/table/src/table-column/defaults.d.ts +4 -0
  462. package/lib/components/table/src/table-column/defaults.js +3 -0
  463. package/lib/components/table/src/table-column/defaults.js.map +1 -1
  464. package/lib/components/table/src/table-column/index.d.ts +6 -0
  465. package/lib/components/table/src/table-column/index.js +2 -1
  466. package/lib/components/table/src/table-column/index.js.map +1 -1
  467. package/lib/components/table/src/table-header/index.js +1 -8
  468. package/lib/components/table/src/table-header/index.js.map +1 -1
  469. package/lib/components/table/src/table.vue.d.ts +2 -2
  470. package/lib/components/tabs/index.js +2 -2
  471. package/lib/components/tabs/src/tab-pane.js +60 -14
  472. package/lib/components/tabs/src/tab-pane.js.map +1 -1
  473. package/lib/components/tabs/src/tab-pane2.js +14 -60
  474. package/lib/components/tabs/src/tab-pane2.js.map +1 -1
  475. package/lib/components/tag/index.js +2 -2
  476. package/lib/components/tag/src/tag.js +81 -34
  477. package/lib/components/tag/src/tag.js.map +1 -1
  478. package/lib/components/tag/src/tag2.js +34 -81
  479. package/lib/components/tag/src/tag2.js.map +1 -1
  480. package/lib/components/time-picker/index.d.ts +8 -8
  481. package/lib/components/time-picker/src/common/picker.vue.d.ts +14 -14
  482. package/lib/components/time-picker/src/time-picker.d.ts +4 -4
  483. package/lib/components/time-select/index.d.ts +6 -6
  484. package/lib/components/time-select/src/time-select.vue.d.ts +3 -3
  485. package/lib/components/timeline/index.js +2 -2
  486. package/lib/components/timeline/src/timeline-item.js +73 -39
  487. package/lib/components/timeline/src/timeline-item.js.map +1 -1
  488. package/lib/components/timeline/src/timeline-item2.js +39 -73
  489. package/lib/components/timeline/src/timeline-item2.js.map +1 -1
  490. package/lib/components/tooltip/index.d.ts +5 -5
  491. package/lib/components/tooltip/src/tooltip.d.ts +1 -1
  492. package/lib/components/tooltip/src/tooltip.vue.d.ts +5 -5
  493. package/lib/components/tooltip/src/trigger.vue.d.ts +3 -3
  494. package/lib/components/tooltip-v2/index.d.ts +6 -6
  495. package/lib/components/tooltip-v2/index.js +3 -3
  496. package/lib/components/tooltip-v2/src/arrow.js +38 -23
  497. package/lib/components/tooltip-v2/src/arrow.js.map +1 -1
  498. package/lib/components/tooltip-v2/src/arrow2.js +23 -38
  499. package/lib/components/tooltip-v2/src/arrow2.js.map +1 -1
  500. package/lib/components/tooltip-v2/src/content.vue.d.ts +1 -1
  501. package/lib/components/tooltip-v2/src/tooltip.js +20 -73
  502. package/lib/components/tooltip-v2/src/tooltip.js.map +1 -1
  503. package/lib/components/tooltip-v2/src/tooltip.vue.d.ts +6 -6
  504. package/lib/components/tooltip-v2/src/tooltip2.js +73 -20
  505. package/lib/components/tooltip-v2/src/tooltip2.js.map +1 -1
  506. package/lib/components/upload/index.js +3 -3
  507. package/lib/components/upload/src/upload-content.js +15 -46
  508. package/lib/components/upload/src/upload-content.js.map +1 -1
  509. package/lib/components/upload/src/upload-content2.js +46 -15
  510. package/lib/components/upload/src/upload-content2.js.map +1 -1
  511. package/lib/components/upload/src/upload-list.vue.d.ts +3 -3
  512. package/lib/components/upload/src/upload-list2.js +1 -1
  513. package/lib/components/upload/src/upload.js +99 -109
  514. package/lib/components/upload/src/upload.js.map +1 -1
  515. package/lib/components/upload/src/upload2.js +109 -99
  516. package/lib/components/upload/src/upload2.js.map +1 -1
  517. package/lib/components/virtual-list/src/builders/build-list.d.ts +1 -1
  518. package/lib/components/virtual-list/src/components/dynamic-size-list.d.ts +1 -1
  519. package/lib/components/virtual-list/src/components/fixed-size-list.d.ts +1 -1
  520. package/lib/index.js +28 -28
  521. package/package.json +1 -1
  522. package/web-types.json +1 -1
@@ -1,15 +1,194 @@
1
+ import { defineComponent, ref, computed, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, renderSlot, toDisplayString, createVNode, withCtx, createTextVNode, createCommentVNode, createSlots, normalizeProps, guardReactiveProps, Fragment, renderList, createBlock } from 'vue';
2
+ import dayjs from 'dayjs';
3
+ import { PsButtonGroup, PsButton } from '../../button/index.mjs';
4
+ import '../../../hooks/index.mjs';
1
5
  import '../../../utils/index.mjs';
2
- import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
6
+ import DateTable from './date-table2.mjs';
7
+ import { calendarProps } from './calendar2.mjs';
8
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
10
+ import { useLocale } from '../../../hooks/use-locale/index.mjs';
11
+ import { debugWarn } from '../../../utils/error.mjs';
3
12
 
4
- const calendarProps = buildProps({
5
- modelValue: {
6
- type: Date
7
- },
8
- range: {
9
- type: definePropType(Array),
10
- validator: (range) => Array.isArray(range) && range.length === 2 && range.every((item) => item instanceof Date)
13
+ const __default__ = {
14
+ name: "PsCalendar"
15
+ };
16
+ const _sfc_main = /* @__PURE__ */ defineComponent({
17
+ ...__default__,
18
+ props: calendarProps,
19
+ setup(__props, { expose }) {
20
+ const props = __props;
21
+ const COMPONENT_NAME = "PsCalendar";
22
+ const ns = useNamespace("calendar");
23
+ const { t, lang } = useLocale();
24
+ const selectedDay = ref();
25
+ const now = dayjs().locale(lang.value);
26
+ const i18nDate = computed(() => {
27
+ const pickedMonth = `el.datepicker.month${date.value.format("M")}`;
28
+ return `${date.value.year()} ${t("el.datepicker.year")} ${t(pickedMonth)}`;
29
+ });
30
+ const realSelectedDay = computed({
31
+ get() {
32
+ if (!props.modelValue)
33
+ return selectedDay.value;
34
+ return date.value;
35
+ },
36
+ set(val) {
37
+ if (!val)
38
+ return;
39
+ selectedDay.value = val;
40
+ }
41
+ });
42
+ const date = computed(() => {
43
+ if (!props.modelValue) {
44
+ if (realSelectedDay.value) {
45
+ return realSelectedDay.value;
46
+ } else if (validatedRange.value.length) {
47
+ return validatedRange.value[0][0];
48
+ }
49
+ return now;
50
+ } else {
51
+ return dayjs(props.modelValue).locale(lang.value);
52
+ }
53
+ });
54
+ const calculateValidatedDateRange = (startDayjs, endDayjs) => {
55
+ const firstDay = startDayjs.startOf("week");
56
+ const lastDay = endDayjs.endOf("week");
57
+ const firstMonth = firstDay.get("month");
58
+ const lastMonth = lastDay.get("month");
59
+ if (firstMonth === lastMonth) {
60
+ return [[firstDay, lastDay]];
61
+ } else if (firstMonth + 1 === lastMonth) {
62
+ const firstMonthLastDay = firstDay.endOf("month");
63
+ const lastMonthFirstDay = lastDay.startOf("month");
64
+ const isSameWeek = firstMonthLastDay.isSame(lastMonthFirstDay, "week");
65
+ const lastMonthStartDay = isSameWeek ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
66
+ return [
67
+ [firstDay, firstMonthLastDay],
68
+ [lastMonthStartDay.startOf("week"), lastDay]
69
+ ];
70
+ } else if (firstMonth + 2 === lastMonth || (firstMonth + 1) % 11 === lastMonth) {
71
+ const firstMonthLastDay = firstDay.endOf("month");
72
+ const secondMonthFirstDay = firstDay.add(1, "month").startOf("month");
73
+ const secondMonthStartDay = firstMonthLastDay.isSame(secondMonthFirstDay, "week") ? secondMonthFirstDay.add(1, "week") : secondMonthFirstDay;
74
+ const secondMonthLastDay = secondMonthStartDay.endOf("month");
75
+ const lastMonthFirstDay = lastDay.startOf("month");
76
+ const lastMonthStartDay = secondMonthLastDay.isSame(lastMonthFirstDay, "week") ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
77
+ return [
78
+ [firstDay, firstMonthLastDay],
79
+ [secondMonthStartDay.startOf("week"), secondMonthLastDay],
80
+ [lastMonthStartDay.startOf("week"), lastDay]
81
+ ];
82
+ } else {
83
+ debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
84
+ return [];
85
+ }
86
+ };
87
+ const validatedRange = computed(() => {
88
+ if (!props.range)
89
+ return [];
90
+ const rangeArrDayjs = props.range.map((_) => dayjs(_).locale(lang.value));
91
+ const [startDayjs, endDayjs] = rangeArrDayjs;
92
+ if (startDayjs.isAfter(endDayjs)) {
93
+ debugWarn(COMPONENT_NAME, "end time should be greater than start time");
94
+ return [];
95
+ }
96
+ if (startDayjs.isSame(endDayjs, "month")) {
97
+ return calculateValidatedDateRange(startDayjs, endDayjs);
98
+ } else {
99
+ if (startDayjs.add(1, "month").month() !== endDayjs.month()) {
100
+ debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
101
+ return [];
102
+ }
103
+ return calculateValidatedDateRange(startDayjs, endDayjs);
104
+ }
105
+ });
106
+ expose({
107
+ selectedDay: realSelectedDay,
108
+ calculateValidatedDateRange
109
+ });
110
+ return (_ctx, _cache) => {
111
+ return openBlock(), createElementBlock("div", {
112
+ class: normalizeClass(unref(ns).b())
113
+ }, [
114
+ createElementVNode("div", {
115
+ class: normalizeClass(unref(ns).e("header"))
116
+ }, [
117
+ renderSlot(_ctx.$slots, "header", { date: unref(i18nDate) }, () => [
118
+ createElementVNode("div", {
119
+ class: normalizeClass(unref(ns).e("title"))
120
+ }, toDisplayString(unref(i18nDate)), 3),
121
+ unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", {
122
+ key: 0,
123
+ class: normalizeClass(unref(ns).e("button-group"))
124
+ }, [
125
+ createVNode(unref(PsButtonGroup), null, {
126
+ default: withCtx(() => [
127
+ createVNode(unref(PsButton), { size: "small" }, {
128
+ default: withCtx(() => [
129
+ createTextVNode(toDisplayString(unref(t)("el.datepicker.prevMonth")), 1)
130
+ ]),
131
+ _: 1
132
+ }),
133
+ createVNode(unref(PsButton), { size: "small" }, {
134
+ default: withCtx(() => [
135
+ createTextVNode(toDisplayString(unref(t)("el.datepicker.today")), 1)
136
+ ]),
137
+ _: 1
138
+ }),
139
+ createVNode(unref(PsButton), { size: "small" }, {
140
+ default: withCtx(() => [
141
+ createTextVNode(toDisplayString(unref(t)("el.datepicker.nextMonth")), 1)
142
+ ]),
143
+ _: 1
144
+ })
145
+ ]),
146
+ _: 1
147
+ })
148
+ ], 2)) : createCommentVNode("v-if", true)
149
+ ])
150
+ ], 2),
151
+ unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", {
152
+ key: 0,
153
+ class: normalizeClass(unref(ns).e("body"))
154
+ }, [
155
+ createVNode(DateTable, {
156
+ date: unref(date),
157
+ "selected-day": unref(realSelectedDay)
158
+ }, createSlots({ _: 2 }, [
159
+ _ctx.$slots.dateCell ? {
160
+ name: "dateCell",
161
+ fn: withCtx((data) => [
162
+ renderSlot(_ctx.$slots, "dateCell", normalizeProps(guardReactiveProps(data)))
163
+ ])
164
+ } : void 0
165
+ ]), 1032, ["date", "selected-day"])
166
+ ], 2)) : (openBlock(), createElementBlock("div", {
167
+ key: 1,
168
+ class: normalizeClass(unref(ns).e("body"))
169
+ }, [
170
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(validatedRange), (range_, index) => {
171
+ return openBlock(), createBlock(DateTable, {
172
+ key: index,
173
+ date: range_[0],
174
+ "selected-day": unref(realSelectedDay),
175
+ range: range_,
176
+ "hide-header": index !== 0
177
+ }, createSlots({ _: 2 }, [
178
+ _ctx.$slots.dateCell ? {
179
+ name: "dateCell",
180
+ fn: withCtx((data) => [
181
+ renderSlot(_ctx.$slots, "dateCell", normalizeProps(guardReactiveProps(data)))
182
+ ])
183
+ } : void 0
184
+ ]), 1032, ["date", "selected-day", "range", "hide-header"]);
185
+ }), 128))
186
+ ], 2))
187
+ ], 2);
188
+ };
11
189
  }
12
190
  });
191
+ var Calendar = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/calendar/src/calendar.vue"]]);
13
192
 
14
- export { calendarProps };
193
+ export { Calendar as default };
15
194
  //# sourceMappingURL=calendar.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"calendar.mjs","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":[],"mappings":";;;AACY,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,IAAI;AACd,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,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":"calendar.mjs","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":[],"mappings":"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"}
@@ -1,194 +1,15 @@
1
- import { defineComponent, ref, computed, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, renderSlot, toDisplayString, createVNode, withCtx, createTextVNode, createCommentVNode, createSlots, normalizeProps, guardReactiveProps, Fragment, renderList, createBlock } from 'vue';
2
- import dayjs from 'dayjs';
3
- import { PsButtonGroup, PsButton } from '../../button/index.mjs';
4
- import '../../../hooks/index.mjs';
5
1
  import '../../../utils/index.mjs';
6
- import DateTable from './date-table2.mjs';
7
- import { calendarProps } from './calendar.mjs';
8
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
10
- import { useLocale } from '../../../hooks/use-locale/index.mjs';
11
- import { debugWarn } from '../../../utils/error.mjs';
2
+ import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
12
3
 
13
- const __default__ = {
14
- name: "PsCalendar"
15
- };
16
- const _sfc_main = /* @__PURE__ */ defineComponent({
17
- ...__default__,
18
- props: calendarProps,
19
- setup(__props, { expose }) {
20
- const props = __props;
21
- const COMPONENT_NAME = "PsCalendar";
22
- const ns = useNamespace("calendar");
23
- const { t, lang } = useLocale();
24
- const selectedDay = ref();
25
- const now = dayjs().locale(lang.value);
26
- const i18nDate = computed(() => {
27
- const pickedMonth = `el.datepicker.month${date.value.format("M")}`;
28
- return `${date.value.year()} ${t("el.datepicker.year")} ${t(pickedMonth)}`;
29
- });
30
- const realSelectedDay = computed({
31
- get() {
32
- if (!props.modelValue)
33
- return selectedDay.value;
34
- return date.value;
35
- },
36
- set(val) {
37
- if (!val)
38
- return;
39
- selectedDay.value = val;
40
- }
41
- });
42
- const date = computed(() => {
43
- if (!props.modelValue) {
44
- if (realSelectedDay.value) {
45
- return realSelectedDay.value;
46
- } else if (validatedRange.value.length) {
47
- return validatedRange.value[0][0];
48
- }
49
- return now;
50
- } else {
51
- return dayjs(props.modelValue).locale(lang.value);
52
- }
53
- });
54
- const calculateValidatedDateRange = (startDayjs, endDayjs) => {
55
- const firstDay = startDayjs.startOf("week");
56
- const lastDay = endDayjs.endOf("week");
57
- const firstMonth = firstDay.get("month");
58
- const lastMonth = lastDay.get("month");
59
- if (firstMonth === lastMonth) {
60
- return [[firstDay, lastDay]];
61
- } else if (firstMonth + 1 === lastMonth) {
62
- const firstMonthLastDay = firstDay.endOf("month");
63
- const lastMonthFirstDay = lastDay.startOf("month");
64
- const isSameWeek = firstMonthLastDay.isSame(lastMonthFirstDay, "week");
65
- const lastMonthStartDay = isSameWeek ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
66
- return [
67
- [firstDay, firstMonthLastDay],
68
- [lastMonthStartDay.startOf("week"), lastDay]
69
- ];
70
- } else if (firstMonth + 2 === lastMonth || (firstMonth + 1) % 11 === lastMonth) {
71
- const firstMonthLastDay = firstDay.endOf("month");
72
- const secondMonthFirstDay = firstDay.add(1, "month").startOf("month");
73
- const secondMonthStartDay = firstMonthLastDay.isSame(secondMonthFirstDay, "week") ? secondMonthFirstDay.add(1, "week") : secondMonthFirstDay;
74
- const secondMonthLastDay = secondMonthStartDay.endOf("month");
75
- const lastMonthFirstDay = lastDay.startOf("month");
76
- const lastMonthStartDay = secondMonthLastDay.isSame(lastMonthFirstDay, "week") ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
77
- return [
78
- [firstDay, firstMonthLastDay],
79
- [secondMonthStartDay.startOf("week"), secondMonthLastDay],
80
- [lastMonthStartDay.startOf("week"), lastDay]
81
- ];
82
- } else {
83
- debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
84
- return [];
85
- }
86
- };
87
- const validatedRange = computed(() => {
88
- if (!props.range)
89
- return [];
90
- const rangeArrDayjs = props.range.map((_) => dayjs(_).locale(lang.value));
91
- const [startDayjs, endDayjs] = rangeArrDayjs;
92
- if (startDayjs.isAfter(endDayjs)) {
93
- debugWarn(COMPONENT_NAME, "end time should be greater than start time");
94
- return [];
95
- }
96
- if (startDayjs.isSame(endDayjs, "month")) {
97
- return calculateValidatedDateRange(startDayjs, endDayjs);
98
- } else {
99
- if (startDayjs.add(1, "month").month() !== endDayjs.month()) {
100
- debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
101
- return [];
102
- }
103
- return calculateValidatedDateRange(startDayjs, endDayjs);
104
- }
105
- });
106
- expose({
107
- selectedDay: realSelectedDay,
108
- calculateValidatedDateRange
109
- });
110
- return (_ctx, _cache) => {
111
- return openBlock(), createElementBlock("div", {
112
- class: normalizeClass(unref(ns).b())
113
- }, [
114
- createElementVNode("div", {
115
- class: normalizeClass(unref(ns).e("header"))
116
- }, [
117
- renderSlot(_ctx.$slots, "header", { date: unref(i18nDate) }, () => [
118
- createElementVNode("div", {
119
- class: normalizeClass(unref(ns).e("title"))
120
- }, toDisplayString(unref(i18nDate)), 3),
121
- unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", {
122
- key: 0,
123
- class: normalizeClass(unref(ns).e("button-group"))
124
- }, [
125
- createVNode(unref(PsButtonGroup), null, {
126
- default: withCtx(() => [
127
- createVNode(unref(PsButton), { size: "small" }, {
128
- default: withCtx(() => [
129
- createTextVNode(toDisplayString(unref(t)("el.datepicker.prevMonth")), 1)
130
- ]),
131
- _: 1
132
- }),
133
- createVNode(unref(PsButton), { size: "small" }, {
134
- default: withCtx(() => [
135
- createTextVNode(toDisplayString(unref(t)("el.datepicker.today")), 1)
136
- ]),
137
- _: 1
138
- }),
139
- createVNode(unref(PsButton), { size: "small" }, {
140
- default: withCtx(() => [
141
- createTextVNode(toDisplayString(unref(t)("el.datepicker.nextMonth")), 1)
142
- ]),
143
- _: 1
144
- })
145
- ]),
146
- _: 1
147
- })
148
- ], 2)) : createCommentVNode("v-if", true)
149
- ])
150
- ], 2),
151
- unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", {
152
- key: 0,
153
- class: normalizeClass(unref(ns).e("body"))
154
- }, [
155
- createVNode(DateTable, {
156
- date: unref(date),
157
- "selected-day": unref(realSelectedDay)
158
- }, createSlots({ _: 2 }, [
159
- _ctx.$slots.dateCell ? {
160
- name: "dateCell",
161
- fn: withCtx((data) => [
162
- renderSlot(_ctx.$slots, "dateCell", normalizeProps(guardReactiveProps(data)))
163
- ])
164
- } : void 0
165
- ]), 1032, ["date", "selected-day"])
166
- ], 2)) : (openBlock(), createElementBlock("div", {
167
- key: 1,
168
- class: normalizeClass(unref(ns).e("body"))
169
- }, [
170
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(validatedRange), (range_, index) => {
171
- return openBlock(), createBlock(DateTable, {
172
- key: index,
173
- date: range_[0],
174
- "selected-day": unref(realSelectedDay),
175
- range: range_,
176
- "hide-header": index !== 0
177
- }, createSlots({ _: 2 }, [
178
- _ctx.$slots.dateCell ? {
179
- name: "dateCell",
180
- fn: withCtx((data) => [
181
- renderSlot(_ctx.$slots, "dateCell", normalizeProps(guardReactiveProps(data)))
182
- ])
183
- } : void 0
184
- ]), 1032, ["date", "selected-day", "range", "hide-header"]);
185
- }), 128))
186
- ], 2))
187
- ], 2);
188
- };
4
+ const calendarProps = buildProps({
5
+ modelValue: {
6
+ type: Date
7
+ },
8
+ range: {
9
+ type: definePropType(Array),
10
+ validator: (range) => Array.isArray(range) && range.length === 2 && range.every((item) => item instanceof Date)
189
11
  }
190
12
  });
191
- var Calendar = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/calendar/src/calendar.vue"]]);
192
13
 
193
- export { Calendar as default };
14
+ export { calendarProps };
194
15
  //# sourceMappingURL=calendar2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"calendar2.mjs","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":[],"mappings":"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"}
1
+ {"version":3,"file":"calendar2.mjs","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":[],"mappings":";;;AACY,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,IAAI;AACd,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,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,8 +1,8 @@
1
1
  import '../../utils/index.mjs';
2
2
  import Carousel from './src/carousel2.mjs';
3
- import CarouselItem from './src/carousel-item.mjs';
3
+ import CarouselItem from './src/carousel-item2.mjs';
4
4
  export { carouselProps } from './src/carousel.mjs';
5
- export { carouselItemProps } from './src/carousel-item2.mjs';
5
+ export { carouselItemProps } from './src/carousel-item.mjs';
6
6
  import { withInstall, withNoopInstall } from '../../utils/vue/install.mjs';
7
7
 
8
8
  const PsCarousel = withInstall(Carousel, {
@@ -1,154 +1,13 @@
1
- import { defineComponent, inject, getCurrentInstance, ref, computed, unref, onMounted, reactive, onUnmounted, withDirectives, openBlock, createElementBlock, normalizeClass, normalizeStyle, vShow, createCommentVNode, renderSlot } from 'vue';
2
1
  import '../../../utils/index.mjs';
3
- import '../../../hooks/index.mjs';
4
- import '../../../tokens/index.mjs';
5
- import { carouselItemProps } from './carousel-item2.mjs';
6
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
7
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
8
- import { carouselContextKey } from '../../../tokens/carousel.mjs';
9
- import { debugWarn } from '../../../utils/error.mjs';
10
- import { isUndefined } from '../../../utils/types.mjs';
2
+ import { buildProps } from '../../../utils/vue/props.mjs';
11
3
 
12
- const __default__ = {
13
- name: "PsCarouselItem"
14
- };
15
- const _sfc_main = /* @__PURE__ */ defineComponent({
16
- ...__default__,
17
- props: carouselItemProps,
18
- setup(__props) {
19
- const props = __props;
20
- const ns = useNamespace("carousel");
21
- const COMPONENT_NAME = "PsCarouselItem";
22
- const carouselContext = inject(carouselContextKey);
23
- const instance = getCurrentInstance();
24
- if (!carouselContext) {
25
- debugWarn(COMPONENT_NAME, "usage: <ps-carousel></ps-carousel-item></ps-carousel>");
26
- }
27
- if (!instance) {
28
- debugWarn(COMPONENT_NAME, "compositional hook can only be invoked inside setups");
29
- }
30
- const CARD_SCALE = 0.83;
31
- const hover = ref(false);
32
- const translate = ref(0);
33
- const scale = ref(1);
34
- const active = ref(false);
35
- const ready = ref(false);
36
- const inStage = ref(false);
37
- const animating = ref(false);
38
- const { isCardType, isVertical } = carouselContext;
39
- const itemStyle = computed(() => {
40
- const translateType = `translate${unref(isVertical) ? "Y" : "X"}`;
41
- const _translate = `${translateType}(${unref(translate)}px)`;
42
- const _scale = `scale(${unref(scale)})`;
43
- const transform = [_translate, _scale].join(" ");
44
- return {
45
- transform
46
- };
47
- });
48
- function processIndex(index, activeIndex, length) {
49
- const lastItemIndex = length - 1;
50
- const prevItemIndex = activeIndex - 1;
51
- const nextItemIndex = activeIndex + 1;
52
- const halfItemIndex = length / 2;
53
- if (activeIndex === 0 && index === lastItemIndex) {
54
- return -1;
55
- } else if (activeIndex === lastItemIndex && index === 0) {
56
- return length;
57
- } else if (index < prevItemIndex && activeIndex - index >= halfItemIndex) {
58
- return length + 1;
59
- } else if (index > nextItemIndex && index - activeIndex >= halfItemIndex) {
60
- return -2;
61
- }
62
- return index;
63
- }
64
- function calcCardTranslate(index, activeIndex) {
65
- var _a;
66
- const parentWidth = ((_a = carouselContext.root.value) == null ? void 0 : _a.offsetWidth) || 0;
67
- if (inStage.value) {
68
- return parentWidth * ((2 - CARD_SCALE) * (index - activeIndex) + 1) / 4;
69
- } else if (index < activeIndex) {
70
- return -(1 + CARD_SCALE) * parentWidth / 4;
71
- } else {
72
- return (3 + CARD_SCALE) * parentWidth / 4;
73
- }
74
- }
75
- function calcTranslate(index, activeIndex, isVertical2) {
76
- const rootEl = carouselContext.root.value;
77
- if (!rootEl)
78
- return 0;
79
- const distance = (isVertical2 ? rootEl.offsetHeight : rootEl.offsetWidth) || 0;
80
- return distance * (index - activeIndex);
81
- }
82
- const translateItem = (index, activeIndex, oldIndex) => {
83
- var _a;
84
- const _isCardType = unref(isCardType);
85
- const carouselItemLength = (_a = carouselContext.items.value.length) != null ? _a : Number.NaN;
86
- const isActive = index === activeIndex;
87
- if (!_isCardType && !isUndefined(oldIndex)) {
88
- animating.value = isActive || index === oldIndex;
89
- }
90
- if (!isActive && carouselItemLength > 2 && carouselContext.loop) {
91
- index = processIndex(index, activeIndex, carouselItemLength);
92
- }
93
- const _isVertical = unref(isVertical);
94
- active.value = isActive;
95
- if (_isCardType) {
96
- if (_isVertical) {
97
- debugWarn("Carousel", "vertical direction is not supported for card mode");
98
- }
99
- inStage.value = Math.round(Math.abs(index - activeIndex)) <= 1;
100
- translate.value = calcCardTranslate(index, activeIndex);
101
- scale.value = unref(active) ? 1 : CARD_SCALE;
102
- } else {
103
- translate.value = calcTranslate(index, activeIndex, _isVertical);
104
- }
105
- ready.value = true;
106
- };
107
- onMounted(() => {
108
- carouselContext.addItem({
109
- props,
110
- states: reactive({
111
- hover,
112
- translate,
113
- scale,
114
- active,
115
- ready,
116
- inStage,
117
- animating
118
- }),
119
- uid: instance.uid,
120
- translateItem
121
- });
122
- });
123
- onUnmounted(() => {
124
- carouselContext.removeItem(instance.uid);
125
- });
126
- return (_ctx, _cache) => {
127
- return withDirectives((openBlock(), createElementBlock("div", {
128
- class: normalizeClass([
129
- unref(ns).e("item"),
130
- unref(ns).is("active", active.value),
131
- unref(ns).is("in-stage", inStage.value),
132
- unref(ns).is("hover", hover.value),
133
- unref(ns).is("animating", animating.value),
134
- { [unref(ns).em("item", "card")]: unref(isCardType) }
135
- ]),
136
- style: normalizeStyle(unref(itemStyle))
137
- }, [
138
- unref(isCardType) ? withDirectives((openBlock(), createElementBlock("div", {
139
- key: 0,
140
- class: normalizeClass(unref(ns).e("mask"))
141
- }, null, 2)), [
142
- [vShow, !active.value]
143
- ]) : createCommentVNode("v-if", true),
144
- renderSlot(_ctx.$slots, "default")
145
- ], 6)), [
146
- [vShow, ready.value]
147
- ]);
148
- };
4
+ const carouselItemProps = buildProps({
5
+ name: { type: String, default: "" },
6
+ label: {
7
+ type: [String, Number],
8
+ default: ""
149
9
  }
150
10
  });
151
- var CarouselItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/carousel/src/carousel-item.vue"]]);
152
11
 
153
- export { CarouselItem as default };
12
+ export { carouselItemProps };
154
13
  //# sourceMappingURL=carousel-item.mjs.map