element-ps 2.0.19 → 2.0.20

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 (382) hide show
  1. package/dist/index.full.js +2 -2
  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 +2 -2
  7. package/dist/locale/en.js +1 -1
  8. package/dist/locale/en.min.js +1 -1
  9. package/dist/locale/en.min.mjs +1 -1
  10. package/dist/locale/en.mjs +1 -1
  11. package/dist/locale/zh-cn.js +1 -1
  12. package/dist/locale/zh-cn.min.js +1 -1
  13. package/dist/locale/zh-cn.min.mjs +1 -1
  14. package/dist/locale/zh-cn.mjs +1 -1
  15. package/es/components/affix/index.mjs +2 -2
  16. package/es/components/affix/src/affix.mjs +82 -19
  17. package/es/components/affix/src/affix.mjs.map +1 -1
  18. package/es/components/affix/src/affix2.mjs +19 -82
  19. package/es/components/affix/src/affix2.mjs.map +1 -1
  20. package/es/components/alert/index.mjs +2 -2
  21. package/es/components/alert/src/alert.mjs +83 -33
  22. package/es/components/alert/src/alert.mjs.map +1 -1
  23. package/es/components/alert/src/alert2.mjs +33 -83
  24. package/es/components/alert/src/alert2.mjs.map +1 -1
  25. package/es/components/autocomplete/src/autocomplete.mjs +1 -1
  26. package/es/components/avatar/index.mjs +2 -2
  27. package/es/components/avatar/src/avatar.mjs +61 -29
  28. package/es/components/avatar/src/avatar.mjs.map +1 -1
  29. package/es/components/avatar/src/avatar2.mjs +29 -61
  30. package/es/components/avatar/src/avatar2.mjs.map +1 -1
  31. package/es/components/badge/index.mjs +2 -2
  32. package/es/components/badge/src/badge.mjs +54 -17
  33. package/es/components/badge/src/badge.mjs.map +1 -1
  34. package/es/components/badge/src/badge2.mjs +17 -54
  35. package/es/components/badge/src/badge2.mjs.map +1 -1
  36. package/es/components/breadcrumb/index.mjs +2 -2
  37. package/es/components/breadcrumb/src/breadcrumb.mjs +12 -37
  38. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  39. package/es/components/breadcrumb/src/breadcrumb2.mjs +37 -12
  40. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  41. package/es/components/calendar/index.mjs +2 -2
  42. package/es/components/calendar/src/calendar.mjs +188 -9
  43. package/es/components/calendar/src/calendar.mjs.map +1 -1
  44. package/es/components/calendar/src/calendar2.mjs +9 -188
  45. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  46. package/es/components/calendar/src/date-table.mjs +146 -27
  47. package/es/components/calendar/src/date-table.mjs.map +1 -1
  48. package/es/components/calendar/src/date-table2.mjs +27 -146
  49. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  50. package/es/components/card/index.mjs +2 -2
  51. package/es/components/card/src/card.mjs +35 -15
  52. package/es/components/card/src/card.mjs.map +1 -1
  53. package/es/components/card/src/card2.mjs +15 -35
  54. package/es/components/card/src/card2.mjs.map +1 -1
  55. package/es/components/cascader/src/index.mjs +2 -2
  56. package/es/components/cascader-panel/src/config.mjs +1 -1
  57. package/es/components/cascader-panel/src/index.mjs +1 -1
  58. package/es/components/cascader-panel/src/menu.mjs +1 -1
  59. package/es/components/cascader-panel/src/node.mjs +120 -200
  60. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  61. package/es/components/cascader-panel/src/node2.mjs +200 -120
  62. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  63. package/es/components/cascader-panel/src/store.mjs +1 -1
  64. package/es/components/collapse/index.mjs +4 -4
  65. package/es/components/collapse/src/collapse-item.mjs +91 -12
  66. package/es/components/collapse/src/collapse-item.mjs.map +1 -1
  67. package/es/components/collapse/src/collapse-item2.mjs +12 -91
  68. package/es/components/collapse/src/collapse-item2.mjs.map +1 -1
  69. package/es/components/collapse/src/collapse.mjs +14 -61
  70. package/es/components/collapse/src/collapse.mjs.map +1 -1
  71. package/es/components/collapse/src/collapse2.mjs +61 -14
  72. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  73. package/es/components/dropdown/src/dropdown.mjs +1 -1
  74. package/es/components/form/index.mjs +2 -2
  75. package/es/components/form/src/form.mjs +45 -40
  76. package/es/components/form/src/form.mjs.map +1 -1
  77. package/es/components/form/src/form2.mjs +40 -45
  78. package/es/components/form/src/form2.mjs.map +1 -1
  79. package/es/components/icon/index.mjs +2 -2
  80. package/es/components/icon/src/icon.mjs +35 -8
  81. package/es/components/icon/src/icon.mjs.map +1 -1
  82. package/es/components/icon/src/icon2.mjs +8 -35
  83. package/es/components/icon/src/icon2.mjs.map +1 -1
  84. package/es/components/image-viewer/index.mjs +2 -2
  85. package/es/components/image-viewer/src/image-viewer.mjs +210 -31
  86. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  87. package/es/components/image-viewer/src/image-viewer2.mjs +31 -210
  88. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  89. package/es/components/index.mjs +30 -30
  90. package/es/components/input/index.mjs +2 -2
  91. package/es/components/input/src/input.mjs +296 -85
  92. package/es/components/input/src/input.mjs.map +1 -1
  93. package/es/components/input/src/input2.mjs +85 -296
  94. package/es/components/input/src/input2.mjs.map +1 -1
  95. package/es/components/menu/index.mjs +2 -2
  96. package/es/components/menu/src/menu-item-group.mjs +4 -56
  97. package/es/components/menu/src/menu-item-group.mjs.map +1 -1
  98. package/es/components/menu/src/menu-item-group2.mjs +56 -4
  99. package/es/components/menu/src/menu-item-group2.mjs.map +1 -1
  100. package/es/components/menu/src/menu-item.mjs +1 -1
  101. package/es/components/page-header/index.mjs +2 -2
  102. package/es/components/page-header/src/page-header.mjs +55 -14
  103. package/es/components/page-header/src/page-header.mjs.map +1 -1
  104. package/es/components/page-header/src/page-header2.mjs +14 -55
  105. package/es/components/page-header/src/page-header2.mjs.map +1 -1
  106. package/es/components/popconfirm/src/popconfirm2.mjs +1 -1
  107. package/es/components/popover/src/popover.mjs +1 -1
  108. package/es/components/popper/index.mjs +4 -4
  109. package/es/components/popper/src/popper.mjs +20 -27
  110. package/es/components/popper/src/popper.mjs.map +1 -1
  111. package/es/components/popper/src/popper2.mjs +27 -20
  112. package/es/components/popper/src/popper2.mjs.map +1 -1
  113. package/es/components/popper/src/trigger.mjs +28 -17
  114. package/es/components/popper/src/trigger.mjs.map +1 -1
  115. package/es/components/popper/src/trigger2.mjs +17 -28
  116. package/es/components/popper/src/trigger2.mjs.map +1 -1
  117. package/es/components/progress/index.mjs +2 -2
  118. package/es/components/progress/src/progress.mjs +57 -230
  119. package/es/components/progress/src/progress.mjs.map +1 -1
  120. package/es/components/progress/src/progress2.mjs +230 -57
  121. package/es/components/progress/src/progress2.mjs.map +1 -1
  122. package/es/components/radio/index.mjs +4 -4
  123. package/es/components/radio/src/radio-button.mjs +9 -80
  124. package/es/components/radio/src/radio-button.mjs.map +1 -1
  125. package/es/components/radio/src/radio-button2.mjs +80 -9
  126. package/es/components/radio/src/radio-button2.mjs.map +1 -1
  127. package/es/components/radio/src/radio.mjs +74 -62
  128. package/es/components/radio/src/radio.mjs.map +1 -1
  129. package/es/components/radio/src/radio2.mjs +62 -74
  130. package/es/components/radio/src/radio2.mjs.map +1 -1
  131. package/es/components/result/index.mjs +2 -2
  132. package/es/components/result/src/result.mjs +73 -28
  133. package/es/components/result/src/result.mjs.map +1 -1
  134. package/es/components/result/src/result2.mjs +28 -73
  135. package/es/components/result/src/result2.mjs.map +1 -1
  136. package/es/components/scrollbar/index.mjs +1 -1
  137. package/es/components/scrollbar/src/bar.mjs +1 -1
  138. package/es/components/scrollbar/src/thumb.mjs +59 -11
  139. package/es/components/scrollbar/src/thumb.mjs.map +1 -1
  140. package/es/components/scrollbar/src/thumb2.mjs +11 -59
  141. package/es/components/scrollbar/src/thumb2.mjs.map +1 -1
  142. package/es/components/select/src/select.mjs +2 -2
  143. package/es/components/select-v2/src/defaults.mjs +1 -1
  144. package/es/components/skeleton/index.mjs +4 -4
  145. package/es/components/skeleton/src/skeleton-item.mjs +23 -18
  146. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  147. package/es/components/skeleton/src/skeleton-item2.mjs +18 -23
  148. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  149. package/es/components/skeleton/src/skeleton.mjs +49 -22
  150. package/es/components/skeleton/src/skeleton.mjs.map +1 -1
  151. package/es/components/skeleton/src/skeleton2.mjs +22 -49
  152. package/es/components/skeleton/src/skeleton2.mjs.map +1 -1
  153. package/es/components/tabs/index.mjs +2 -2
  154. package/es/components/tabs/src/tab-pane.mjs +60 -14
  155. package/es/components/tabs/src/tab-pane.mjs.map +1 -1
  156. package/es/components/tabs/src/tab-pane2.mjs +14 -60
  157. package/es/components/tabs/src/tab-pane2.mjs.map +1 -1
  158. package/es/components/tag/index.mjs +2 -2
  159. package/es/components/tag/src/tag.mjs +33 -81
  160. package/es/components/tag/src/tag.mjs.map +1 -1
  161. package/es/components/tag/src/tag2.mjs +81 -33
  162. package/es/components/tag/src/tag2.mjs.map +1 -1
  163. package/es/components/tooltip/index.mjs +2 -2
  164. package/es/components/tooltip/src/tooltip.mjs +51 -64
  165. package/es/components/tooltip/src/tooltip.mjs.map +1 -1
  166. package/es/components/tooltip/src/tooltip2.mjs +64 -51
  167. package/es/components/tooltip/src/tooltip2.mjs.map +1 -1
  168. package/es/components/tooltip/src/trigger.mjs +2 -2
  169. package/es/components/tooltip-v2/index.mjs +3 -3
  170. package/es/components/tooltip-v2/src/arrow.mjs +38 -22
  171. package/es/components/tooltip-v2/src/arrow.mjs.map +1 -1
  172. package/es/components/tooltip-v2/src/arrow2.mjs +22 -38
  173. package/es/components/tooltip-v2/src/arrow2.mjs.map +1 -1
  174. package/es/components/tooltip-v2/src/content.mjs +50 -113
  175. package/es/components/tooltip-v2/src/content.mjs.map +1 -1
  176. package/es/components/tooltip-v2/src/content2.mjs +113 -50
  177. package/es/components/tooltip-v2/src/content2.mjs.map +1 -1
  178. package/es/components/tooltip-v2/src/root.mjs +81 -17
  179. package/es/components/tooltip-v2/src/root.mjs.map +1 -1
  180. package/es/components/tooltip-v2/src/root2.mjs +17 -81
  181. package/es/components/tooltip-v2/src/root2.mjs.map +1 -1
  182. package/es/components/tooltip-v2/src/tooltip.mjs +3 -3
  183. package/es/components/tooltip-v2/src/tooltip2.mjs +6 -6
  184. package/es/components/upload/index.mjs +3 -3
  185. package/es/components/upload/src/upload-content.mjs +46 -15
  186. package/es/components/upload/src/upload-content.mjs.map +1 -1
  187. package/es/components/upload/src/upload-content2.mjs +15 -46
  188. package/es/components/upload/src/upload-content2.mjs.map +1 -1
  189. package/es/components/upload/src/upload-list2.mjs +1 -1
  190. package/es/components/upload/src/upload.mjs +99 -106
  191. package/es/components/upload/src/upload.mjs.map +1 -1
  192. package/es/components/upload/src/upload2.mjs +106 -99
  193. package/es/components/upload/src/upload2.mjs.map +1 -1
  194. package/es/index.mjs +30 -30
  195. package/es/version.d.ts +1 -1
  196. package/es/version.mjs +1 -1
  197. package/es/version.mjs.map +1 -1
  198. package/lib/components/affix/index.js +2 -2
  199. package/lib/components/affix/src/affix.js +82 -19
  200. package/lib/components/affix/src/affix.js.map +1 -1
  201. package/lib/components/affix/src/affix2.js +19 -82
  202. package/lib/components/affix/src/affix2.js.map +1 -1
  203. package/lib/components/alert/index.js +2 -2
  204. package/lib/components/alert/src/alert.js +82 -33
  205. package/lib/components/alert/src/alert.js.map +1 -1
  206. package/lib/components/alert/src/alert2.js +33 -82
  207. package/lib/components/alert/src/alert2.js.map +1 -1
  208. package/lib/components/autocomplete/src/autocomplete.js +1 -1
  209. package/lib/components/avatar/index.js +2 -2
  210. package/lib/components/avatar/src/avatar.js +61 -29
  211. package/lib/components/avatar/src/avatar.js.map +1 -1
  212. package/lib/components/avatar/src/avatar2.js +29 -61
  213. package/lib/components/avatar/src/avatar2.js.map +1 -1
  214. package/lib/components/badge/index.js +2 -2
  215. package/lib/components/badge/src/badge.js +54 -17
  216. package/lib/components/badge/src/badge.js.map +1 -1
  217. package/lib/components/badge/src/badge2.js +17 -54
  218. package/lib/components/badge/src/badge2.js.map +1 -1
  219. package/lib/components/breadcrumb/index.js +2 -2
  220. package/lib/components/breadcrumb/src/breadcrumb.js +12 -37
  221. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  222. package/lib/components/breadcrumb/src/breadcrumb2.js +37 -12
  223. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  224. package/lib/components/calendar/index.js +2 -2
  225. package/lib/components/calendar/src/calendar.js +192 -9
  226. package/lib/components/calendar/src/calendar.js.map +1 -1
  227. package/lib/components/calendar/src/calendar2.js +9 -192
  228. package/lib/components/calendar/src/calendar2.js.map +1 -1
  229. package/lib/components/calendar/src/date-table.js +151 -30
  230. package/lib/components/calendar/src/date-table.js.map +1 -1
  231. package/lib/components/calendar/src/date-table2.js +30 -151
  232. package/lib/components/calendar/src/date-table2.js.map +1 -1
  233. package/lib/components/card/index.js +2 -2
  234. package/lib/components/card/src/card.js +35 -15
  235. package/lib/components/card/src/card.js.map +1 -1
  236. package/lib/components/card/src/card2.js +15 -35
  237. package/lib/components/card/src/card2.js.map +1 -1
  238. package/lib/components/cascader/src/index.js +2 -2
  239. package/lib/components/cascader-panel/src/config.js +1 -1
  240. package/lib/components/cascader-panel/src/index.js +1 -1
  241. package/lib/components/cascader-panel/src/menu.js +1 -1
  242. package/lib/components/cascader-panel/src/node.js +121 -200
  243. package/lib/components/cascader-panel/src/node.js.map +1 -1
  244. package/lib/components/cascader-panel/src/node2.js +200 -121
  245. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  246. package/lib/components/cascader-panel/src/store.js +1 -1
  247. package/lib/components/collapse/index.js +4 -4
  248. package/lib/components/collapse/src/collapse-item.js +91 -12
  249. package/lib/components/collapse/src/collapse-item.js.map +1 -1
  250. package/lib/components/collapse/src/collapse-item2.js +12 -91
  251. package/lib/components/collapse/src/collapse-item2.js.map +1 -1
  252. package/lib/components/collapse/src/collapse.js +16 -61
  253. package/lib/components/collapse/src/collapse.js.map +1 -1
  254. package/lib/components/collapse/src/collapse2.js +61 -16
  255. package/lib/components/collapse/src/collapse2.js.map +1 -1
  256. package/lib/components/dropdown/src/dropdown.js +1 -1
  257. package/lib/components/form/index.js +2 -2
  258. package/lib/components/form/src/form.js +45 -40
  259. package/lib/components/form/src/form.js.map +1 -1
  260. package/lib/components/form/src/form2.js +40 -45
  261. package/lib/components/form/src/form2.js.map +1 -1
  262. package/lib/components/icon/index.js +2 -2
  263. package/lib/components/icon/src/icon.js +35 -8
  264. package/lib/components/icon/src/icon.js.map +1 -1
  265. package/lib/components/icon/src/icon2.js +8 -35
  266. package/lib/components/icon/src/icon2.js.map +1 -1
  267. package/lib/components/image-viewer/index.js +2 -2
  268. package/lib/components/image-viewer/src/image-viewer.js +210 -31
  269. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  270. package/lib/components/image-viewer/src/image-viewer2.js +31 -210
  271. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  272. package/lib/components/index.js +30 -30
  273. package/lib/components/input/index.js +2 -2
  274. package/lib/components/input/src/input.js +295 -84
  275. package/lib/components/input/src/input.js.map +1 -1
  276. package/lib/components/input/src/input2.js +84 -295
  277. package/lib/components/input/src/input2.js.map +1 -1
  278. package/lib/components/menu/index.js +2 -2
  279. package/lib/components/menu/src/menu-item-group.js +4 -56
  280. package/lib/components/menu/src/menu-item-group.js.map +1 -1
  281. package/lib/components/menu/src/menu-item-group2.js +56 -4
  282. package/lib/components/menu/src/menu-item-group2.js.map +1 -1
  283. package/lib/components/menu/src/menu-item.js +1 -1
  284. package/lib/components/page-header/index.js +2 -2
  285. package/lib/components/page-header/src/page-header.js +55 -14
  286. package/lib/components/page-header/src/page-header.js.map +1 -1
  287. package/lib/components/page-header/src/page-header2.js +14 -55
  288. package/lib/components/page-header/src/page-header2.js.map +1 -1
  289. package/lib/components/popconfirm/src/popconfirm2.js +1 -1
  290. package/lib/components/popover/src/popover.js +1 -1
  291. package/lib/components/popper/index.js +4 -4
  292. package/lib/components/popper/src/popper.js +21 -27
  293. package/lib/components/popper/src/popper.js.map +1 -1
  294. package/lib/components/popper/src/popper2.js +27 -21
  295. package/lib/components/popper/src/popper2.js.map +1 -1
  296. package/lib/components/popper/src/trigger.js +28 -17
  297. package/lib/components/popper/src/trigger.js.map +1 -1
  298. package/lib/components/popper/src/trigger2.js +17 -28
  299. package/lib/components/popper/src/trigger2.js.map +1 -1
  300. package/lib/components/progress/index.js +2 -2
  301. package/lib/components/progress/src/progress.js +57 -230
  302. package/lib/components/progress/src/progress.js.map +1 -1
  303. package/lib/components/progress/src/progress2.js +230 -57
  304. package/lib/components/progress/src/progress2.js.map +1 -1
  305. package/lib/components/radio/index.js +4 -4
  306. package/lib/components/radio/src/radio-button.js +9 -80
  307. package/lib/components/radio/src/radio-button.js.map +1 -1
  308. package/lib/components/radio/src/radio-button2.js +80 -9
  309. package/lib/components/radio/src/radio-button2.js.map +1 -1
  310. package/lib/components/radio/src/radio.js +73 -64
  311. package/lib/components/radio/src/radio.js.map +1 -1
  312. package/lib/components/radio/src/radio2.js +64 -73
  313. package/lib/components/radio/src/radio2.js.map +1 -1
  314. package/lib/components/result/index.js +2 -2
  315. package/lib/components/result/src/result.js +73 -30
  316. package/lib/components/result/src/result.js.map +1 -1
  317. package/lib/components/result/src/result2.js +30 -73
  318. package/lib/components/result/src/result2.js.map +1 -1
  319. package/lib/components/scrollbar/index.js +1 -1
  320. package/lib/components/scrollbar/src/bar.js +1 -1
  321. package/lib/components/scrollbar/src/thumb.js +59 -11
  322. package/lib/components/scrollbar/src/thumb.js.map +1 -1
  323. package/lib/components/scrollbar/src/thumb2.js +11 -59
  324. package/lib/components/scrollbar/src/thumb2.js.map +1 -1
  325. package/lib/components/select/src/select.js +2 -2
  326. package/lib/components/select-v2/src/defaults.js +1 -1
  327. package/lib/components/skeleton/index.js +4 -4
  328. package/lib/components/skeleton/src/skeleton-item.js +23 -18
  329. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  330. package/lib/components/skeleton/src/skeleton-item2.js +18 -23
  331. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  332. package/lib/components/skeleton/src/skeleton.js +49 -22
  333. package/lib/components/skeleton/src/skeleton.js.map +1 -1
  334. package/lib/components/skeleton/src/skeleton2.js +22 -49
  335. package/lib/components/skeleton/src/skeleton2.js.map +1 -1
  336. package/lib/components/tabs/index.js +2 -2
  337. package/lib/components/tabs/src/tab-pane.js +60 -14
  338. package/lib/components/tabs/src/tab-pane.js.map +1 -1
  339. package/lib/components/tabs/src/tab-pane2.js +14 -60
  340. package/lib/components/tabs/src/tab-pane2.js.map +1 -1
  341. package/lib/components/tag/index.js +2 -2
  342. package/lib/components/tag/src/tag.js +34 -81
  343. package/lib/components/tag/src/tag.js.map +1 -1
  344. package/lib/components/tag/src/tag2.js +81 -34
  345. package/lib/components/tag/src/tag2.js.map +1 -1
  346. package/lib/components/tooltip/index.js +2 -2
  347. package/lib/components/tooltip/src/tooltip.js +50 -65
  348. package/lib/components/tooltip/src/tooltip.js.map +1 -1
  349. package/lib/components/tooltip/src/tooltip2.js +65 -50
  350. package/lib/components/tooltip/src/tooltip2.js.map +1 -1
  351. package/lib/components/tooltip/src/trigger.js +2 -2
  352. package/lib/components/tooltip-v2/index.js +3 -3
  353. package/lib/components/tooltip-v2/src/arrow.js +38 -23
  354. package/lib/components/tooltip-v2/src/arrow.js.map +1 -1
  355. package/lib/components/tooltip-v2/src/arrow2.js +23 -38
  356. package/lib/components/tooltip-v2/src/arrow2.js.map +1 -1
  357. package/lib/components/tooltip-v2/src/content.js +50 -113
  358. package/lib/components/tooltip-v2/src/content.js.map +1 -1
  359. package/lib/components/tooltip-v2/src/content2.js +113 -50
  360. package/lib/components/tooltip-v2/src/content2.js.map +1 -1
  361. package/lib/components/tooltip-v2/src/root.js +81 -17
  362. package/lib/components/tooltip-v2/src/root.js.map +1 -1
  363. package/lib/components/tooltip-v2/src/root2.js +17 -81
  364. package/lib/components/tooltip-v2/src/root2.js.map +1 -1
  365. package/lib/components/tooltip-v2/src/tooltip.js +3 -3
  366. package/lib/components/tooltip-v2/src/tooltip2.js +6 -6
  367. package/lib/components/upload/index.js +3 -3
  368. package/lib/components/upload/src/upload-content.js +46 -15
  369. package/lib/components/upload/src/upload-content.js.map +1 -1
  370. package/lib/components/upload/src/upload-content2.js +15 -46
  371. package/lib/components/upload/src/upload-content2.js.map +1 -1
  372. package/lib/components/upload/src/upload-list2.js +1 -1
  373. package/lib/components/upload/src/upload.js +99 -109
  374. package/lib/components/upload/src/upload.js.map +1 -1
  375. package/lib/components/upload/src/upload2.js +109 -99
  376. package/lib/components/upload/src/upload2.js.map +1 -1
  377. package/lib/index.js +30 -30
  378. package/lib/version.d.ts +1 -1
  379. package/lib/version.js +1 -1
  380. package/lib/version.js.map +1 -1
  381. package/package.json +3 -5
  382. package/web-types.json +1 -1
@@ -1,42 +1,17 @@
1
- import { defineComponent, ref, provide, onMounted, openBlock, createElementBlock, normalizeClass, unref, renderSlot } from 'vue';
2
- import '../../../tokens/index.mjs';
3
- import '../../../hooks/index.mjs';
4
- import { breadcrumbProps } from './breadcrumb2.mjs';
5
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
6
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
7
- import { breadcrumbKey } from '../../../tokens/breadcrumb.mjs';
1
+ import '../../../utils/index.mjs';
2
+ import { buildProps } from '../../../utils/vue/props.mjs';
3
+ import { iconPropType } from '../../../utils/vue/icon.mjs';
8
4
 
9
- const __default__ = {
10
- name: "PsBreadcrumb"
11
- };
12
- const _sfc_main = /* @__PURE__ */ defineComponent({
13
- ...__default__,
14
- props: breadcrumbProps,
15
- setup(__props) {
16
- const props = __props;
17
- const ns = useNamespace("breadcrumb");
18
- const breadcrumb = ref();
19
- provide(breadcrumbKey, props);
20
- onMounted(() => {
21
- const items = breadcrumb.value.querySelectorAll(`.${ns.e("item")}`);
22
- if (items.length) {
23
- items[items.length - 1].setAttribute("aria-current", "page");
24
- }
25
- });
26
- return (_ctx, _cache) => {
27
- return openBlock(), createElementBlock("div", {
28
- ref_key: "breadcrumb",
29
- ref: breadcrumb,
30
- class: normalizeClass(unref(ns).b()),
31
- "aria-label": "Breadcrumb",
32
- role: "navigation"
33
- }, [
34
- renderSlot(_ctx.$slots, "default")
35
- ], 2);
36
- };
5
+ const breadcrumbProps = buildProps({
6
+ separator: {
7
+ type: String,
8
+ default: "/"
9
+ },
10
+ separatorIcon: {
11
+ type: iconPropType,
12
+ default: ""
37
13
  }
38
14
  });
39
- var Breadcrumb = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/breadcrumb/src/breadcrumb.vue"]]);
40
15
 
41
- export { Breadcrumb as default };
16
+ export { breadcrumbProps };
42
17
  //# sourceMappingURL=breadcrumb.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"breadcrumb.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb.vue"],"sourcesContent":["<template>\n <div\n ref=\"breadcrumb\"\n :class=\"ns.b()\"\n aria-label=\"Breadcrumb\"\n role=\"navigation\"\n >\n <slot />\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { onMounted, provide, ref } from 'vue'\nimport { breadcrumbKey } from '@element-ps/tokens'\n\nimport { useNamespace } from '@element-ps/hooks'\nimport { breadcrumbProps } from './breadcrumb'\n\ndefineOptions({\n name: 'PsBreadcrumb',\n})\n\nconst props = defineProps(breadcrumbProps)\n\nconst ns = useNamespace('breadcrumb')\nconst breadcrumb = ref<HTMLDivElement>()\n\nprovide(breadcrumbKey, props)\n\nonMounted(() => {\n const items = breadcrumb.value!.querySelectorAll(`.${ns.e('item')}`)\n if (items.length) {\n items[items.length - 1].setAttribute('aria-current', 'page')\n }\n})\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAwBA,IAAA,MAAA,EAAA,GAAA,aAAA,YAAA,CAAA,CAAA;AACA,IAAA,MAAA,aAAA,GAAA,EAAA,CAAA;AAEA,IAAA,OAAA,CAAA,eAAA,KAAA,CAAA,CAAA;AAEA,IAAA,SAAA,CAAA,MAAA;AACA,MAAA,MAAA,KAAA,GAAA,WAAA,KAAA,CAAA,gBAAA,CAAA,IAAA,EAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,MAAA,IAAA,MAAA,MAAA,EAAA;AACA,QAAA,KAAA,CAAA,KAAA,CAAA,MAAA,GAAA,CAAA,CAAA,CAAA,YAAA,CAAA,gBAAA,MAAA,CAAA,CAAA;AAAA,OACA;AAAA,KACA,CAAA,CAAA;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"breadcrumb.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb.ts"],"sourcesContent":["import { buildProps, iconPropType } from '@element-ps/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Breadcrumb from './breadcrumb.vue'\n\nexport const breadcrumbProps = buildProps({\n separator: {\n type: String,\n default: '/',\n },\n separatorIcon: {\n type: iconPropType,\n default: '',\n },\n} as const)\nexport type BreadcrumbProps = ExtractPropTypes<typeof breadcrumbProps>\nexport type BreadcrumbInstance = InstanceType<typeof Breadcrumb>\n"],"names":[],"mappings":";;;;AACY,MAAC,eAAe,GAAG,UAAU,CAAC;AAC1C,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,YAAY;AACtB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,CAAC;;;;"}
@@ -1,17 +1,42 @@
1
- import '../../../utils/index.mjs';
2
- import { buildProps } from '../../../utils/vue/props.mjs';
3
- import { iconPropType } from '../../../utils/vue/icon.mjs';
1
+ import { defineComponent, ref, provide, onMounted, openBlock, createElementBlock, normalizeClass, unref, renderSlot } from 'vue';
2
+ import '../../../tokens/index.mjs';
3
+ import '../../../hooks/index.mjs';
4
+ import { breadcrumbProps } from './breadcrumb.mjs';
5
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
6
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
7
+ import { breadcrumbKey } from '../../../tokens/breadcrumb.mjs';
4
8
 
5
- const breadcrumbProps = buildProps({
6
- separator: {
7
- type: String,
8
- default: "/"
9
- },
10
- separatorIcon: {
11
- type: iconPropType,
12
- default: ""
9
+ const __default__ = {
10
+ name: "PsBreadcrumb"
11
+ };
12
+ const _sfc_main = /* @__PURE__ */ defineComponent({
13
+ ...__default__,
14
+ props: breadcrumbProps,
15
+ setup(__props) {
16
+ const props = __props;
17
+ const ns = useNamespace("breadcrumb");
18
+ const breadcrumb = ref();
19
+ provide(breadcrumbKey, props);
20
+ onMounted(() => {
21
+ const items = breadcrumb.value.querySelectorAll(`.${ns.e("item")}`);
22
+ if (items.length) {
23
+ items[items.length - 1].setAttribute("aria-current", "page");
24
+ }
25
+ });
26
+ return (_ctx, _cache) => {
27
+ return openBlock(), createElementBlock("div", {
28
+ ref_key: "breadcrumb",
29
+ ref: breadcrumb,
30
+ class: normalizeClass(unref(ns).b()),
31
+ "aria-label": "Breadcrumb",
32
+ role: "navigation"
33
+ }, [
34
+ renderSlot(_ctx.$slots, "default")
35
+ ], 2);
36
+ };
13
37
  }
14
38
  });
39
+ var Breadcrumb = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/breadcrumb/src/breadcrumb.vue"]]);
15
40
 
16
- export { breadcrumbProps };
41
+ export { Breadcrumb as default };
17
42
  //# sourceMappingURL=breadcrumb2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"breadcrumb2.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb.ts"],"sourcesContent":["import { buildProps, iconPropType } from '@element-ps/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Breadcrumb from './breadcrumb.vue'\n\nexport const breadcrumbProps = buildProps({\n separator: {\n type: String,\n default: '/',\n },\n separatorIcon: {\n type: iconPropType,\n default: '',\n },\n} as const)\nexport type BreadcrumbProps = ExtractPropTypes<typeof breadcrumbProps>\nexport type BreadcrumbInstance = InstanceType<typeof Breadcrumb>\n"],"names":[],"mappings":";;;;AACY,MAAC,eAAe,GAAG,UAAU,CAAC;AAC1C,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,YAAY;AACtB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"breadcrumb2.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb.vue"],"sourcesContent":["<template>\n <div\n ref=\"breadcrumb\"\n :class=\"ns.b()\"\n aria-label=\"Breadcrumb\"\n role=\"navigation\"\n >\n <slot />\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { onMounted, provide, ref } from 'vue'\nimport { breadcrumbKey } from '@element-ps/tokens'\n\nimport { useNamespace } from '@element-ps/hooks'\nimport { breadcrumbProps } from './breadcrumb'\n\ndefineOptions({\n name: 'PsBreadcrumb',\n})\n\nconst props = defineProps(breadcrumbProps)\n\nconst ns = useNamespace('breadcrumb')\nconst breadcrumb = ref<HTMLDivElement>()\n\nprovide(breadcrumbKey, props)\n\nonMounted(() => {\n const items = breadcrumb.value!.querySelectorAll(`.${ns.e('item')}`)\n if (items.length) {\n items[items.length - 1].setAttribute('aria-current', 'page')\n }\n})\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAwBA,IAAA,MAAA,EAAA,GAAA,aAAA,YAAA,CAAA,CAAA;AACA,IAAA,MAAA,aAAA,GAAA,EAAA,CAAA;AAEA,IAAA,OAAA,CAAA,eAAA,KAAA,CAAA,CAAA;AAEA,IAAA,SAAA,CAAA,MAAA;AACA,MAAA,MAAA,KAAA,GAAA,WAAA,KAAA,CAAA,gBAAA,CAAA,IAAA,EAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,MAAA,IAAA,MAAA,MAAA,EAAA;AACA,QAAA,KAAA,CAAA,KAAA,CAAA,MAAA,GAAA,CAAA,CAAA,CAAA,YAAA,CAAA,gBAAA,MAAA,CAAA,CAAA;AAAA,OACA;AAAA,KACA,CAAA,CAAA;;;;;;;;;;;;;;;;;;"}
@@ -1,6 +1,6 @@
1
1
  import '../../utils/index.mjs';
2
- import Calendar from './src/calendar2.mjs';
3
- export { calendarProps } from './src/calendar.mjs';
2
+ import Calendar from './src/calendar.mjs';
3
+ export { calendarProps } from './src/calendar2.mjs';
4
4
  import { withInstall } from '../../utils/vue/install.mjs';
5
5
 
6
6
  const PsCalendar = withInstall(Calendar);
@@ -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-table.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":";;;;;;;;;;;;;;;;;;;;AAwDA,IAAA,MAAA,cAAA,GAAA,YAAA,CAAA;AAQA,IAAA,MAAA,EAAA,GAAA,aAAA,UAAA,CAAA,CAAA;AAEA,IAAA,MAAA,EAAA,CAAA,EAAA,IAAA,EAAA,GAAA,SAAA,EAAA,CAAA;AACA,IAAA,MAAA,cAAA,GAAA,EAAA,CAAA;AACA,IAAA,MAAA,GAAA,GAAA,KAAA,EAAA,CAAA,MAAA,CAAA,KAAA,KAAA,CAAA,CAAA;AAEA,IAAA,MAAA,QAAA,GAAA,SAAA,MAAA;AACA,MAAA,MAAA,WAAA,GAAA,CAAA,mBAAA,EAAA,IAAA,CAAA,KAAA,CAAA,OAAA,GAAA,CAAA,CAAA,CAAA,CAAA;AACA,MAAA,OAAA,CAAA,EAAA,KAAA,KAAA,CAAA,IAAA,MAAA,CAAA,CAAA,oBAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,WAAA,CAAA,CAAA,CAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,MAAA,kBAAA,QAAA,CAAA;AAAA,MACA,GAAA,GAAA;AACA,QAAA,IAAA,CAAA,KAAA,CAAA,UAAA;AAAA,UAAA,OAAA,WAAA,CAAA,KAAA,CAAA;AACA,QAAA,OAAA,IAAA,CAAA,KAAA,CAAA;AAAA,OACA;AAAA,MACA,IAAA,GAAA,EAAA;AACA,QAAA,IAAA,CAAA,GAAA;AAAA,UAAA,OAAA;AACA,QAAA,WAAA,CAAA,KAAA,GAAA,GAAA,CAAA;AAAA,OACA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,MAAA,IAAA,GAAA,SAAA,MAAA;AACA,MAAA,IAAA,CAAA,MAAA,UAAA,EAAA;AACA,QAAA,IAAA,gBAAA,KAAA,EAAA;AACA,UAAA,OAAA,eAAA,CAAA,KAAA,CAAA;AAAA,SACA,MAAA,IAAA,cAAA,CAAA,KAAA,CAAA,MAAA,EAAA;AACA,UAAA,OAAA,cAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,SACA;AACA,QAAA,OAAA,GAAA,CAAA;AAAA,OACA,MAAA;AACA,QAAA,OAAA,MAAA,KAAA,CAAA,UAAA,CAAA,CAAA,MAAA,CAAA,KAAA,KAAA,CAAA,CAAA;AAAA,OACA;AAAA,KACA,CAAA,CAAA;AAIA,IAAA,MAAA,2BAAA,GAAA,CACA,UAAA,EACA,QACA,KAAA;AACA,MAAA,MAAA,QAAA,GAAA,UAAA,CAAA,OAAA,CAAA,MAAA,CAAA,CAAA;AACA,MAAA,MAAA,OAAA,GAAA,QAAA,CAAA,KAAA,CAAA,MAAA,CAAA,CAAA;AACA,MAAA,MAAA,UAAA,GAAA,QAAA,CAAA,GAAA,CAAA,OAAA,CAAA,CAAA;AACA,MAAA,MAAA,SAAA,GAAA,OAAA,CAAA,GAAA,CAAA,OAAA,CAAA,CAAA;AAGA,MAAA,IAAA,eAAA,SAAA,EAAA;AACA,QAAA,OAAA,CAAA,CAAA,QAAA,EAAA,OAAA,CAAA,CAAA,CAAA;AAAA,OACA,MAAA,IAEA,UAAA,GAAA,CAAA,KAAA,SAAA,EAAA;AACA,QAAA,MAAA,iBAAA,GAAA,QAAA,CAAA,KAAA,CAAA,OAAA,CAAA,CAAA;AACA,QAAA,MAAA,iBAAA,GAAA,OAAA,CAAA,OAAA,CAAA,OAAA,CAAA,CAAA;AAGA,QAAA,MAAA,UAAA,GAAA,iBAAA,CAAA,MAAA,CAAA,iBAAA,EAAA,MAAA,CAAA,CAAA;AACA,QAAA,MAAA,oBAAA,UACA,GAAA,iBAAA,CAAA,GAAA,CAAA,CAAA,EAAA,MAAA,CACA,GAAA,iBAAA,CAAA;AAEA,QAAA,OAAA;AAAA,UACA,CAAA,UAAA,iBAAA,CAAA;AAAA,UACA,CAAA,iBAAA,CAAA,OAAA,CAAA,MAAA,GAAA,OAAA,CAAA;AAAA,SACA,CAAA;AAAA,iBAIA,UAAA,GAAA,CAAA,KAAA,aACA,CAAA,UAAA,GAAA,CAAA,IAAA,OAAA,SACA,EAAA;AACA,QAAA,MAAA,iBAAA,GAAA,QAAA,CAAA,KAAA,CAAA,OAAA,CAAA,CAAA;AACA,QAAA,MAAA,sBAAA,QAAA,CAAA,GAAA,CAAA,GAAA,OAAA,CAAA,CAAA,QAAA,OAAA,CAAA,CAAA;AAGA,QAAA,MAAA,mBAAA,GAAA,iBAAA,CAAA,MAAA,CACA,mBACA,EAAA,MACA,IACA,mBAAA,CAAA,GAAA,CAAA,CAAA,EAAA,MAAA,CACA,GAAA,mBAAA,CAAA;AAEA,QAAA,MAAA,kBAAA,GAAA,mBAAA,CAAA,KAAA,CAAA,OAAA,CAAA,CAAA;AACA,QAAA,MAAA,iBAAA,GAAA,OAAA,CAAA,OAAA,CAAA,OAAA,CAAA,CAAA;AAGA,QAAA,MAAA,iBAAA,GAAA,kBAAA,CAAA,MAAA,CACA,iBACA,EAAA,MACA,IACA,iBAAA,CAAA,GAAA,CAAA,CAAA,EAAA,MAAA,CACA,GAAA,iBAAA,CAAA;AAEA,QAAA,OAAA;AAAA,UACA,CAAA,UAAA,iBAAA,CAAA;AAAA,UACA,CAAA,mBAAA,CAAA,OAAA,CAAA,MAAA,GAAA,kBAAA,CAAA;AAAA,UACA,CAAA,iBAAA,CAAA,OAAA,CAAA,MAAA,GAAA,OAAA,CAAA;AAAA,SACA,CAAA;AAAA,OAGA,MAAA;AACA,QAAA,SAAA,CACA,gBACA,6DACA,CAAA,CAAA;AACA,QAAA,OAAA,EAAA,CAAA;AAAA,OACA;AAAA,KACA,CAAA;AAGA,IAAA,MAAA,cAAA,GAAA,SAAA,MAAA;AACA,MAAA,IAAA,CAAA,KAAA,CAAA,KAAA;AAAA,QAAA,OAAA,EAAA,CAAA;AACA,MAAA,MAAA,aAAA,GAAA,KAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA,CAAA,KAAA,KAAA,CAAA,CAAA,CAAA,CAAA,MAAA,CAAA,IAAA,CAAA,KAAA,CAAA,CAAA,CAAA;AACA,MAAA,MAAA,CAAA,YAAA,QAAA,CAAA,GAAA,aAAA,CAAA;AACA,MAAA,IAAA,UAAA,CAAA,OAAA,CAAA,QAAA,CAAA,EAAA;AACA,QAAA,SAAA,CAAA,gBAAA,4CAAA,CAAA,CAAA;AACA,QAAA,OAAA,EAAA,CAAA;AAAA,OACA;AACA,MAAA,IAAA,UAAA,CAAA,MAAA,CAAA,QAAA,EAAA,OAAA,CAAA,EAAA;AAEA,QAAA,OAAA,2BAAA,CAAA,YAAA,QAAA,CAAA,CAAA;AAAA,OACA,MAAA;AAEA,QAAA,IAAA,UAAA,CAAA,IAAA,CAAA,EAAA,OAAA,EAAA,KAAA,EAAA,KAAA,QAAA,CAAA,KAAA,EAAA,EAAA;AACA,UAAA,SAAA,CACA,gBACA,6DACA,CAAA,CAAA;AACA,UAAA,OAAA,EAAA,CAAA;AAAA,SACA;AACA,QAAA,OAAA,2BAAA,CAAA,YAAA,QAAA,CAAA,CAAA;AAAA,OACA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,MAAA,CAAA;AAAA,MAEA,WAAA,EAAA,eAAA;AAAA,MAEA,2BAAA;AAAA,KACA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -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;;;;"}