element-pe 2.0.3 → 2.0.4

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 (490) hide show
  1. package/dist/index.full.js +1 -1
  2. package/dist/index.full.min.js +1 -1
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +1 -1
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +1 -1
  7. package/es/components/autocomplete/index.d.ts +51 -51
  8. package/es/components/autocomplete/src/autocomplete.vue.d.ts +51 -51
  9. package/es/components/backtop/index.mjs +2 -2
  10. package/es/components/backtop/src/backtop.mjs +100 -21
  11. package/es/components/backtop/src/backtop.mjs.map +1 -1
  12. package/es/components/backtop/src/backtop2.mjs +21 -100
  13. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  14. package/es/components/button/index.mjs +3 -3
  15. package/es/components/button/src/button-group.mjs +30 -5
  16. package/es/components/button/src/button-group.mjs.map +1 -1
  17. package/es/components/button/src/button-group2.mjs +5 -30
  18. package/es/components/button/src/button-group2.mjs.map +1 -1
  19. package/es/components/button/src/button.mjs +106 -51
  20. package/es/components/button/src/button.mjs.map +1 -1
  21. package/es/components/button/src/button2.mjs +51 -106
  22. package/es/components/button/src/button2.mjs.map +1 -1
  23. package/es/components/calendar/index.mjs +2 -2
  24. package/es/components/calendar/src/calendar.mjs +237 -15
  25. package/es/components/calendar/src/calendar.mjs.map +1 -1
  26. package/es/components/calendar/src/calendar2.mjs +15 -237
  27. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  28. package/es/components/calendar/src/date-table.mjs +152 -31
  29. package/es/components/calendar/src/date-table.mjs.map +1 -1
  30. package/es/components/calendar/src/date-table2.mjs +31 -152
  31. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  32. package/es/components/card/index.mjs +2 -2
  33. package/es/components/card/src/card.mjs +35 -15
  34. package/es/components/card/src/card.mjs.map +1 -1
  35. package/es/components/card/src/card2.mjs +15 -35
  36. package/es/components/card/src/card2.mjs.map +1 -1
  37. package/es/components/carousel/index.mjs +4 -4
  38. package/es/components/carousel/src/carousel-item.mjs +155 -7
  39. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  40. package/es/components/carousel/src/carousel-item2.mjs +7 -155
  41. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  42. package/es/components/carousel/src/carousel.mjs +319 -48
  43. package/es/components/carousel/src/carousel.mjs.map +1 -1
  44. package/es/components/carousel/src/carousel2.mjs +48 -319
  45. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  46. package/es/components/cascader/index.d.ts +68 -68
  47. package/es/components/cascader/src/index.mjs +1 -1
  48. package/es/components/cascader/src/index.vue.d.ts +34 -34
  49. package/es/components/cascader-panel/src/config.mjs +1 -1
  50. package/es/components/cascader-panel/src/index.mjs +1 -1
  51. package/es/components/cascader-panel/src/menu.mjs +1 -1
  52. package/es/components/cascader-panel/src/node.mjs +120 -209
  53. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  54. package/es/components/cascader-panel/src/node2.mjs +209 -120
  55. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  56. package/es/components/cascader-panel/src/store.mjs +1 -1
  57. package/es/components/collapse/index.mjs +2 -2
  58. package/es/components/collapse/src/collapse.mjs +61 -14
  59. package/es/components/collapse/src/collapse.mjs.map +1 -1
  60. package/es/components/collapse/src/collapse2.mjs +14 -61
  61. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  62. package/es/components/collection/index.mjs +1 -1
  63. package/es/components/collection/src/collection.mjs +10 -63
  64. package/es/components/collection/src/collection.mjs.map +1 -1
  65. package/es/components/collection/src/collection2.mjs +63 -10
  66. package/es/components/collection/src/collection2.mjs.map +1 -1
  67. package/es/components/dialog/index.mjs +2 -2
  68. package/es/components/dialog/src/dialog.mjs +70 -113
  69. package/es/components/dialog/src/dialog.mjs.map +1 -1
  70. package/es/components/dialog/src/dialog2.mjs +113 -70
  71. package/es/components/dialog/src/dialog2.mjs.map +1 -1
  72. package/es/components/divider/index.mjs +2 -2
  73. package/es/components/divider/src/divider.mjs +34 -17
  74. package/es/components/divider/src/divider.mjs.map +1 -1
  75. package/es/components/divider/src/divider2.mjs +17 -34
  76. package/es/components/divider/src/divider2.mjs.map +1 -1
  77. package/es/components/drawer/src/drawer2.mjs +1 -1
  78. package/es/components/dropdown/index.d.ts +10 -10
  79. package/es/components/dropdown/index.mjs +2 -2
  80. package/es/components/dropdown/src/dropdown-item-impl.mjs +3 -3
  81. package/es/components/dropdown/src/dropdown-item-impl.vue.d.ts +1 -1
  82. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  83. package/es/components/dropdown/src/dropdown-item.vue.d.ts +1 -1
  84. package/es/components/dropdown/src/dropdown-menu.mjs +2 -2
  85. package/es/components/dropdown/src/dropdown.d.ts +1 -1
  86. package/es/components/dropdown/src/dropdown.mjs +100 -247
  87. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  88. package/es/components/dropdown/src/dropdown.vue.d.ts +8 -8
  89. package/es/components/dropdown/src/dropdown2.mjs +247 -100
  90. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  91. package/es/components/icon/index.mjs +2 -2
  92. package/es/components/icon/src/icon.mjs +35 -8
  93. package/es/components/icon/src/icon.mjs.map +1 -1
  94. package/es/components/icon/src/icon2.mjs +8 -35
  95. package/es/components/icon/src/icon2.mjs.map +1 -1
  96. package/es/components/image/index.d.ts +1 -1
  97. package/es/components/image/src/image.vue.d.ts +1 -1
  98. package/es/components/image-viewer/index.d.ts +1 -1
  99. package/es/components/image-viewer/src/image-viewer.vue.d.ts +1 -1
  100. package/es/components/index.mjs +29 -29
  101. package/es/components/input/index.d.ts +11 -11
  102. package/es/components/input/src/input.vue.d.ts +11 -11
  103. package/es/components/input-number/index.d.ts +22 -22
  104. package/es/components/input-number/index.mjs +2 -2
  105. package/es/components/input-number/src/input-number.mjs +53 -284
  106. package/es/components/input-number/src/input-number.mjs.map +1 -1
  107. package/es/components/input-number/src/input-number.vue.d.ts +22 -22
  108. package/es/components/input-number/src/input-number2.mjs +284 -53
  109. package/es/components/input-number/src/input-number2.mjs.map +1 -1
  110. package/es/components/link/index.mjs +2 -2
  111. package/es/components/link/src/link.mjs +49 -22
  112. package/es/components/link/src/link.mjs.map +1 -1
  113. package/es/components/link/src/link2.mjs +22 -49
  114. package/es/components/link/src/link2.mjs.map +1 -1
  115. package/es/components/menu/index.mjs +2 -2
  116. package/es/components/menu/src/menu-item.mjs +14 -94
  117. package/es/components/menu/src/menu-item.mjs.map +1 -1
  118. package/es/components/menu/src/menu-item2.mjs +94 -14
  119. package/es/components/menu/src/menu-item2.mjs.map +1 -1
  120. package/es/components/message/index.mjs +1 -1
  121. package/es/components/message/src/message-method.mjs +2 -2
  122. package/es/components/message/src/message.mjs +67 -151
  123. package/es/components/message/src/message.mjs.map +1 -1
  124. package/es/components/message/src/message2.mjs +151 -67
  125. package/es/components/message/src/message2.mjs.map +1 -1
  126. package/es/components/notification/index.mjs +1 -1
  127. package/es/components/notification/src/notification.mjs +68 -150
  128. package/es/components/notification/src/notification.mjs.map +1 -1
  129. package/es/components/notification/src/notification2.mjs +150 -68
  130. package/es/components/notification/src/notification2.mjs.map +1 -1
  131. package/es/components/notification/src/notify.mjs +2 -2
  132. package/es/components/page-header/index.mjs +2 -2
  133. package/es/components/page-header/src/page-header.mjs +60 -17
  134. package/es/components/page-header/src/page-header.mjs.map +1 -1
  135. package/es/components/page-header/src/page-header2.mjs +17 -60
  136. package/es/components/page-header/src/page-header2.mjs.map +1 -1
  137. package/es/components/popconfirm/index.mjs +2 -2
  138. package/es/components/popconfirm/src/popconfirm.mjs +119 -52
  139. package/es/components/popconfirm/src/popconfirm.mjs.map +1 -1
  140. package/es/components/popconfirm/src/popconfirm2.mjs +52 -119
  141. package/es/components/popconfirm/src/popconfirm2.mjs.map +1 -1
  142. package/es/components/popover/index.d.ts +16 -16
  143. package/es/components/popover/src/index.vue.d.ts +8 -8
  144. package/es/components/popover/src/popover.d.ts +1 -1
  145. package/es/components/popover/src/popover.mjs +1 -1
  146. package/es/components/popper/index.mjs +2 -2
  147. package/es/components/popper/src/arrow.mjs +37 -7
  148. package/es/components/popper/src/arrow.mjs.map +1 -1
  149. package/es/components/popper/src/arrow2.mjs +7 -37
  150. package/es/components/popper/src/arrow2.mjs.map +1 -1
  151. package/es/components/popper/src/content.vue.d.ts +3 -3
  152. package/es/components/radio/index.mjs +2 -2
  153. package/es/components/radio/src/radio-button.mjs +85 -9
  154. package/es/components/radio/src/radio-button.mjs.map +1 -1
  155. package/es/components/radio/src/radio-button2.mjs +9 -85
  156. package/es/components/radio/src/radio-button2.mjs.map +1 -1
  157. package/es/components/rate/index.mjs +2 -2
  158. package/es/components/rate/src/rate.mjs +239 -88
  159. package/es/components/rate/src/rate.mjs.map +1 -1
  160. package/es/components/rate/src/rate2.mjs +88 -239
  161. package/es/components/rate/src/rate2.mjs.map +1 -1
  162. package/es/components/roving-focus-group/index.mjs +3 -3
  163. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  164. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -29
  165. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  166. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +29 -27
  167. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  168. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  169. package/es/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  170. package/es/components/scrollbar/index.mjs +2 -2
  171. package/es/components/scrollbar/src/bar.mjs +22 -45
  172. package/es/components/scrollbar/src/bar.mjs.map +1 -1
  173. package/es/components/scrollbar/src/bar2.mjs +45 -22
  174. package/es/components/scrollbar/src/bar2.mjs.map +1 -1
  175. package/es/components/scrollbar/src/scrollbar.mjs +175 -49
  176. package/es/components/scrollbar/src/scrollbar.mjs.map +1 -1
  177. package/es/components/scrollbar/src/scrollbar2.mjs +49 -175
  178. package/es/components/scrollbar/src/scrollbar2.mjs.map +1 -1
  179. package/es/components/select/index.d.ts +7 -7
  180. package/es/components/select/src/select.mjs +1 -1
  181. package/es/components/select/src/select.vue.d.ts +7 -7
  182. package/es/components/select/src/useSelect.d.ts +5 -5
  183. package/es/components/select-v2/index.d.ts +14 -14
  184. package/es/components/select-v2/src/option-item.vue.d.ts +1 -1
  185. package/es/components/select-v2/src/select.vue.d.ts +7 -7
  186. package/es/components/select-v2/src/useSelect.d.ts +5 -5
  187. package/es/components/skeleton/index.mjs +2 -2
  188. package/es/components/skeleton/src/skeleton-item.mjs +18 -23
  189. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  190. package/es/components/skeleton/src/skeleton-item2.mjs +23 -18
  191. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  192. package/es/components/skeleton/src/skeleton.mjs +1 -1
  193. package/es/components/switch/index.mjs +2 -2
  194. package/es/components/switch/src/switch.mjs +250 -87
  195. package/es/components/switch/src/switch.mjs.map +1 -1
  196. package/es/components/switch/src/switch2.mjs +87 -250
  197. package/es/components/switch/src/switch2.mjs.map +1 -1
  198. package/es/components/table/index.d.ts +1 -1
  199. package/es/components/table/src/filter-panel.vue.d.ts +5 -5
  200. package/es/components/table/src/table.vue.d.ts +1 -1
  201. package/es/components/tag/index.d.ts +1 -1
  202. package/es/components/tag/index.mjs +2 -2
  203. package/es/components/tag/src/tag.mjs +93 -33
  204. package/es/components/tag/src/tag.mjs.map +1 -1
  205. package/es/components/tag/src/tag.vue.d.ts +1 -1
  206. package/es/components/tag/src/tag2.mjs +33 -93
  207. package/es/components/tag/src/tag2.mjs.map +1 -1
  208. package/es/components/teleport/index.mjs +2 -2
  209. package/es/components/teleport/src/teleport.mjs +43 -18
  210. package/es/components/teleport/src/teleport.mjs.map +1 -1
  211. package/es/components/teleport/src/teleport2.mjs +18 -43
  212. package/es/components/teleport/src/teleport2.mjs.map +1 -1
  213. package/es/components/time-picker/src/common/picker.vue.d.ts +6 -6
  214. package/es/components/time-select/index.d.ts +2 -2
  215. package/es/components/time-select/src/time-select.vue.d.ts +1 -1
  216. package/es/components/timeline/index.mjs +2 -2
  217. package/es/components/timeline/src/timeline-item.mjs +39 -73
  218. package/es/components/timeline/src/timeline-item.mjs.map +1 -1
  219. package/es/components/timeline/src/timeline-item2.mjs +73 -39
  220. package/es/components/timeline/src/timeline-item2.mjs.map +1 -1
  221. package/es/components/tooltip/index.d.ts +3 -3
  222. package/es/components/tooltip/src/content.vue.d.ts +5 -5
  223. package/es/components/tooltip/src/tooltip.d.ts +1 -1
  224. package/es/components/tooltip/src/tooltip.mjs +2 -2
  225. package/es/components/tooltip/src/tooltip.vue.d.ts +3 -3
  226. package/es/components/tooltip/src/trigger.vue.d.ts +3 -3
  227. package/es/components/tooltip-v2/index.mjs +2 -2
  228. package/es/components/tooltip-v2/src/tooltip.mjs +73 -20
  229. package/es/components/tooltip-v2/src/tooltip.mjs.map +1 -1
  230. package/es/components/tooltip-v2/src/tooltip2.mjs +20 -73
  231. package/es/components/tooltip-v2/src/tooltip2.mjs.map +1 -1
  232. package/es/components/upload/index.d.ts +1 -1
  233. package/es/components/upload/index.mjs +3 -3
  234. package/es/components/upload/src/upload-content.mjs +1 -1
  235. package/es/components/upload/src/upload-content2.mjs +2 -2
  236. package/es/components/upload/src/upload-dragger.mjs +70 -11
  237. package/es/components/upload/src/upload-dragger.mjs.map +1 -1
  238. package/es/components/upload/src/upload-dragger2.mjs +11 -70
  239. package/es/components/upload/src/upload-dragger2.mjs.map +1 -1
  240. package/es/components/upload/src/upload-list2.mjs +1 -1
  241. package/es/components/upload/src/upload.mjs +106 -121
  242. package/es/components/upload/src/upload.mjs.map +1 -1
  243. package/es/components/upload/src/upload.vue.d.ts +1 -1
  244. package/es/components/upload/src/upload2.mjs +121 -106
  245. package/es/components/upload/src/upload2.mjs.map +1 -1
  246. package/es/components/upload/src/use-handlers.mjs +1 -1
  247. package/es/index.mjs +29 -29
  248. package/lib/components/autocomplete/index.d.ts +51 -51
  249. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +51 -51
  250. package/lib/components/backtop/index.js +2 -2
  251. package/lib/components/backtop/src/backtop.js +100 -22
  252. package/lib/components/backtop/src/backtop.js.map +1 -1
  253. package/lib/components/backtop/src/backtop2.js +22 -100
  254. package/lib/components/backtop/src/backtop2.js.map +1 -1
  255. package/lib/components/button/index.js +3 -3
  256. package/lib/components/button/src/button-group.js +30 -5
  257. package/lib/components/button/src/button-group.js.map +1 -1
  258. package/lib/components/button/src/button-group2.js +5 -30
  259. package/lib/components/button/src/button-group2.js.map +1 -1
  260. package/lib/components/button/src/button.js +106 -54
  261. package/lib/components/button/src/button.js.map +1 -1
  262. package/lib/components/button/src/button2.js +54 -106
  263. package/lib/components/button/src/button2.js.map +1 -1
  264. package/lib/components/calendar/index.js +2 -2
  265. package/lib/components/calendar/src/calendar.js +241 -16
  266. package/lib/components/calendar/src/calendar.js.map +1 -1
  267. package/lib/components/calendar/src/calendar2.js +16 -241
  268. package/lib/components/calendar/src/calendar2.js.map +1 -1
  269. package/lib/components/calendar/src/date-table.js +157 -35
  270. package/lib/components/calendar/src/date-table.js.map +1 -1
  271. package/lib/components/calendar/src/date-table2.js +35 -157
  272. package/lib/components/calendar/src/date-table2.js.map +1 -1
  273. package/lib/components/card/index.js +2 -2
  274. package/lib/components/card/src/card.js +35 -15
  275. package/lib/components/card/src/card.js.map +1 -1
  276. package/lib/components/card/src/card2.js +15 -35
  277. package/lib/components/card/src/card2.js.map +1 -1
  278. package/lib/components/carousel/index.js +4 -4
  279. package/lib/components/carousel/src/carousel-item.js +155 -7
  280. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  281. package/lib/components/carousel/src/carousel-item2.js +7 -155
  282. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  283. package/lib/components/carousel/src/carousel.js +319 -49
  284. package/lib/components/carousel/src/carousel.js.map +1 -1
  285. package/lib/components/carousel/src/carousel2.js +49 -319
  286. package/lib/components/carousel/src/carousel2.js.map +1 -1
  287. package/lib/components/cascader/index.d.ts +68 -68
  288. package/lib/components/cascader/src/index.js +1 -1
  289. package/lib/components/cascader/src/index.vue.d.ts +34 -34
  290. package/lib/components/cascader-panel/src/config.js +1 -1
  291. package/lib/components/cascader-panel/src/index.js +1 -1
  292. package/lib/components/cascader-panel/src/menu.js +1 -1
  293. package/lib/components/cascader-panel/src/node.js +121 -209
  294. package/lib/components/cascader-panel/src/node.js.map +1 -1
  295. package/lib/components/cascader-panel/src/node2.js +209 -121
  296. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  297. package/lib/components/cascader-panel/src/store.js +1 -1
  298. package/lib/components/collapse/index.js +2 -2
  299. package/lib/components/collapse/src/collapse.js +61 -16
  300. package/lib/components/collapse/src/collapse.js.map +1 -1
  301. package/lib/components/collapse/src/collapse2.js +16 -61
  302. package/lib/components/collapse/src/collapse2.js.map +1 -1
  303. package/lib/components/collection/index.js +1 -1
  304. package/lib/components/collection/src/collection.js +9 -63
  305. package/lib/components/collection/src/collection.js.map +1 -1
  306. package/lib/components/collection/src/collection2.js +63 -9
  307. package/lib/components/collection/src/collection2.js.map +1 -1
  308. package/lib/components/dialog/index.js +2 -2
  309. package/lib/components/dialog/src/dialog.js +71 -113
  310. package/lib/components/dialog/src/dialog.js.map +1 -1
  311. package/lib/components/dialog/src/dialog2.js +113 -71
  312. package/lib/components/dialog/src/dialog2.js.map +1 -1
  313. package/lib/components/divider/index.js +2 -2
  314. package/lib/components/divider/src/divider.js +34 -17
  315. package/lib/components/divider/src/divider.js.map +1 -1
  316. package/lib/components/divider/src/divider2.js +17 -34
  317. package/lib/components/divider/src/divider2.js.map +1 -1
  318. package/lib/components/drawer/src/drawer2.js +1 -1
  319. package/lib/components/dropdown/index.d.ts +10 -10
  320. package/lib/components/dropdown/index.js +2 -2
  321. package/lib/components/dropdown/src/dropdown-item-impl.js +3 -3
  322. package/lib/components/dropdown/src/dropdown-item-impl.vue.d.ts +1 -1
  323. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  324. package/lib/components/dropdown/src/dropdown-item.vue.d.ts +1 -1
  325. package/lib/components/dropdown/src/dropdown-menu.js +2 -2
  326. package/lib/components/dropdown/src/dropdown.d.ts +1 -1
  327. package/lib/components/dropdown/src/dropdown.js +108 -246
  328. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  329. package/lib/components/dropdown/src/dropdown.vue.d.ts +8 -8
  330. package/lib/components/dropdown/src/dropdown2.js +246 -108
  331. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  332. package/lib/components/icon/index.js +2 -2
  333. package/lib/components/icon/src/icon.js +35 -8
  334. package/lib/components/icon/src/icon.js.map +1 -1
  335. package/lib/components/icon/src/icon2.js +8 -35
  336. package/lib/components/icon/src/icon2.js.map +1 -1
  337. package/lib/components/image/index.d.ts +1 -1
  338. package/lib/components/image/src/image.vue.d.ts +1 -1
  339. package/lib/components/image-viewer/index.d.ts +1 -1
  340. package/lib/components/image-viewer/src/image-viewer.vue.d.ts +1 -1
  341. package/lib/components/index.js +29 -29
  342. package/lib/components/input/index.d.ts +11 -11
  343. package/lib/components/input/src/input.vue.d.ts +11 -11
  344. package/lib/components/input-number/index.d.ts +22 -22
  345. package/lib/components/input-number/index.js +2 -2
  346. package/lib/components/input-number/src/input-number.js +54 -284
  347. package/lib/components/input-number/src/input-number.js.map +1 -1
  348. package/lib/components/input-number/src/input-number.vue.d.ts +22 -22
  349. package/lib/components/input-number/src/input-number2.js +284 -54
  350. package/lib/components/input-number/src/input-number2.js.map +1 -1
  351. package/lib/components/link/index.js +2 -2
  352. package/lib/components/link/src/link.js +49 -23
  353. package/lib/components/link/src/link.js.map +1 -1
  354. package/lib/components/link/src/link2.js +23 -49
  355. package/lib/components/link/src/link2.js.map +1 -1
  356. package/lib/components/menu/index.js +2 -2
  357. package/lib/components/menu/src/menu-item.js +15 -94
  358. package/lib/components/menu/src/menu-item.js.map +1 -1
  359. package/lib/components/menu/src/menu-item2.js +94 -15
  360. package/lib/components/menu/src/menu-item2.js.map +1 -1
  361. package/lib/components/message/index.js +1 -1
  362. package/lib/components/message/src/message-method.js +2 -2
  363. package/lib/components/message/src/message.js +68 -150
  364. package/lib/components/message/src/message.js.map +1 -1
  365. package/lib/components/message/src/message2.js +150 -68
  366. package/lib/components/message/src/message2.js.map +1 -1
  367. package/lib/components/notification/index.js +1 -1
  368. package/lib/components/notification/src/notification.js +70 -150
  369. package/lib/components/notification/src/notification.js.map +1 -1
  370. package/lib/components/notification/src/notification2.js +150 -70
  371. package/lib/components/notification/src/notification2.js.map +1 -1
  372. package/lib/components/notification/src/notify.js +2 -2
  373. package/lib/components/page-header/index.js +2 -2
  374. package/lib/components/page-header/src/page-header.js +60 -18
  375. package/lib/components/page-header/src/page-header.js.map +1 -1
  376. package/lib/components/page-header/src/page-header2.js +18 -60
  377. package/lib/components/page-header/src/page-header2.js.map +1 -1
  378. package/lib/components/popconfirm/index.js +2 -2
  379. package/lib/components/popconfirm/src/popconfirm.js +119 -52
  380. package/lib/components/popconfirm/src/popconfirm.js.map +1 -1
  381. package/lib/components/popconfirm/src/popconfirm2.js +52 -119
  382. package/lib/components/popconfirm/src/popconfirm2.js.map +1 -1
  383. package/lib/components/popover/index.d.ts +16 -16
  384. package/lib/components/popover/src/index.vue.d.ts +8 -8
  385. package/lib/components/popover/src/popover.d.ts +1 -1
  386. package/lib/components/popover/src/popover.js +1 -1
  387. package/lib/components/popper/index.js +2 -2
  388. package/lib/components/popper/src/arrow.js +37 -7
  389. package/lib/components/popper/src/arrow.js.map +1 -1
  390. package/lib/components/popper/src/arrow2.js +7 -37
  391. package/lib/components/popper/src/arrow2.js.map +1 -1
  392. package/lib/components/popper/src/content.vue.d.ts +3 -3
  393. package/lib/components/radio/index.js +2 -2
  394. package/lib/components/radio/src/radio-button.js +84 -8
  395. package/lib/components/radio/src/radio-button.js.map +1 -1
  396. package/lib/components/radio/src/radio-button2.js +8 -84
  397. package/lib/components/radio/src/radio-button2.js.map +1 -1
  398. package/lib/components/rate/index.js +2 -2
  399. package/lib/components/rate/src/rate.js +239 -89
  400. package/lib/components/rate/src/rate.js.map +1 -1
  401. package/lib/components/rate/src/rate2.js +89 -239
  402. package/lib/components/rate/src/rate2.js.map +1 -1
  403. package/lib/components/roving-focus-group/index.js +2 -2
  404. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  405. package/lib/components/roving-focus-group/src/roving-focus-group.js +27 -33
  406. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  407. package/lib/components/roving-focus-group/src/roving-focus-group2.js +33 -27
  408. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  409. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  410. package/lib/components/roving-focus-group/src/roving-focus-item.vue.d.ts +1 -1
  411. package/lib/components/scrollbar/index.js +2 -2
  412. package/lib/components/scrollbar/src/bar.js +22 -45
  413. package/lib/components/scrollbar/src/bar.js.map +1 -1
  414. package/lib/components/scrollbar/src/bar2.js +45 -22
  415. package/lib/components/scrollbar/src/bar2.js.map +1 -1
  416. package/lib/components/scrollbar/src/scrollbar.js +175 -50
  417. package/lib/components/scrollbar/src/scrollbar.js.map +1 -1
  418. package/lib/components/scrollbar/src/scrollbar2.js +50 -175
  419. package/lib/components/scrollbar/src/scrollbar2.js.map +1 -1
  420. package/lib/components/select/index.d.ts +7 -7
  421. package/lib/components/select/src/select.js +1 -1
  422. package/lib/components/select/src/select.vue.d.ts +7 -7
  423. package/lib/components/select/src/useSelect.d.ts +5 -5
  424. package/lib/components/select-v2/index.d.ts +14 -14
  425. package/lib/components/select-v2/src/option-item.vue.d.ts +1 -1
  426. package/lib/components/select-v2/src/select.vue.d.ts +7 -7
  427. package/lib/components/select-v2/src/useSelect.d.ts +5 -5
  428. package/lib/components/skeleton/index.js +2 -2
  429. package/lib/components/skeleton/src/skeleton-item.js +18 -23
  430. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  431. package/lib/components/skeleton/src/skeleton-item2.js +23 -18
  432. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  433. package/lib/components/skeleton/src/skeleton.js +1 -1
  434. package/lib/components/switch/index.js +2 -2
  435. package/lib/components/switch/src/switch.js +249 -87
  436. package/lib/components/switch/src/switch.js.map +1 -1
  437. package/lib/components/switch/src/switch2.js +87 -249
  438. package/lib/components/switch/src/switch2.js.map +1 -1
  439. package/lib/components/table/index.d.ts +1 -1
  440. package/lib/components/table/src/filter-panel.vue.d.ts +5 -5
  441. package/lib/components/table/src/table.vue.d.ts +1 -1
  442. package/lib/components/tag/index.d.ts +1 -1
  443. package/lib/components/tag/index.js +2 -2
  444. package/lib/components/tag/src/tag.js +93 -34
  445. package/lib/components/tag/src/tag.js.map +1 -1
  446. package/lib/components/tag/src/tag.vue.d.ts +1 -1
  447. package/lib/components/tag/src/tag2.js +34 -93
  448. package/lib/components/tag/src/tag2.js.map +1 -1
  449. package/lib/components/teleport/index.js +2 -2
  450. package/lib/components/teleport/src/teleport.js +43 -18
  451. package/lib/components/teleport/src/teleport.js.map +1 -1
  452. package/lib/components/teleport/src/teleport2.js +18 -43
  453. package/lib/components/teleport/src/teleport2.js.map +1 -1
  454. package/lib/components/time-picker/src/common/picker.vue.d.ts +6 -6
  455. package/lib/components/time-select/index.d.ts +2 -2
  456. package/lib/components/time-select/src/time-select.vue.d.ts +1 -1
  457. package/lib/components/timeline/index.js +2 -2
  458. package/lib/components/timeline/src/timeline-item.js +39 -73
  459. package/lib/components/timeline/src/timeline-item.js.map +1 -1
  460. package/lib/components/timeline/src/timeline-item2.js +73 -39
  461. package/lib/components/timeline/src/timeline-item2.js.map +1 -1
  462. package/lib/components/tooltip/index.d.ts +3 -3
  463. package/lib/components/tooltip/src/content.vue.d.ts +5 -5
  464. package/lib/components/tooltip/src/tooltip.d.ts +1 -1
  465. package/lib/components/tooltip/src/tooltip.js +2 -2
  466. package/lib/components/tooltip/src/tooltip.vue.d.ts +3 -3
  467. package/lib/components/tooltip/src/trigger.vue.d.ts +3 -3
  468. package/lib/components/tooltip-v2/index.js +2 -2
  469. package/lib/components/tooltip-v2/src/tooltip.js +73 -20
  470. package/lib/components/tooltip-v2/src/tooltip.js.map +1 -1
  471. package/lib/components/tooltip-v2/src/tooltip2.js +20 -73
  472. package/lib/components/tooltip-v2/src/tooltip2.js.map +1 -1
  473. package/lib/components/upload/index.d.ts +1 -1
  474. package/lib/components/upload/index.js +3 -3
  475. package/lib/components/upload/src/upload-content.js +1 -1
  476. package/lib/components/upload/src/upload-content2.js +2 -2
  477. package/lib/components/upload/src/upload-dragger.js +70 -12
  478. package/lib/components/upload/src/upload-dragger.js.map +1 -1
  479. package/lib/components/upload/src/upload-dragger2.js +12 -70
  480. package/lib/components/upload/src/upload-dragger2.js.map +1 -1
  481. package/lib/components/upload/src/upload-list2.js +1 -1
  482. package/lib/components/upload/src/upload.js +109 -121
  483. package/lib/components/upload/src/upload.js.map +1 -1
  484. package/lib/components/upload/src/upload.vue.d.ts +1 -1
  485. package/lib/components/upload/src/upload2.js +121 -109
  486. package/lib/components/upload/src/upload2.js.map +1 -1
  487. package/lib/components/upload/src/use-handlers.js +1 -1
  488. package/lib/index.js +29 -29
  489. package/package.json +1 -1
  490. package/web-types.json +1 -1
@@ -1,243 +1,21 @@
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 { ElButtonGroup, ElButton } 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, calendarEmits } 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 '../../../constants/index.mjs';
3
+ import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
4
+ import { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';
12
5
 
13
- const __default__ = {
14
- name: "ElCalendar"
15
- };
16
- const _sfc_main = /* @__PURE__ */ defineComponent({
17
- ...__default__,
18
- props: calendarProps,
19
- emits: calendarEmits,
20
- setup(__props, { expose, emit }) {
21
- const props = __props;
22
- const COMPONENT_NAME = "ElCalendar";
23
- const ns = useNamespace("calendar");
24
- const { t, lang } = useLocale();
25
- const selectedDay = ref();
26
- const now = dayjs().locale(lang.value);
27
- const prevMonthDayjs = computed(() => {
28
- return date.value.subtract(1, "month").date(1);
29
- });
30
- const nextMonthDayjs = computed(() => {
31
- return date.value.add(1, "month").date(1);
32
- });
33
- const prevYearDayjs = computed(() => {
34
- return date.value.subtract(1, "year").date(1);
35
- });
36
- const nextYearDayjs = computed(() => {
37
- return date.value.add(1, "year").date(1);
38
- });
39
- const i18nDate = computed(() => {
40
- const pickedMonth = `el.datepicker.month${date.value.format("M")}`;
41
- return `${date.value.year()} ${t("el.datepicker.year")} ${t(pickedMonth)}`;
42
- });
43
- const realSelectedDay = computed({
44
- get() {
45
- if (!props.modelValue)
46
- return selectedDay.value;
47
- return date.value;
48
- },
49
- set(val) {
50
- if (!val)
51
- return;
52
- selectedDay.value = val;
53
- const result = val.toDate();
54
- emit("input", result);
55
- emit("update:modelValue", result);
56
- }
57
- });
58
- const date = computed(() => {
59
- if (!props.modelValue) {
60
- if (realSelectedDay.value) {
61
- return realSelectedDay.value;
62
- } else if (validatedRange.value.length) {
63
- return validatedRange.value[0][0];
64
- }
65
- return now;
66
- } else {
67
- return dayjs(props.modelValue).locale(lang.value);
68
- }
69
- });
70
- const calculateValidatedDateRange = (startDayjs, endDayjs) => {
71
- const firstDay = startDayjs.startOf("week");
72
- const lastDay = endDayjs.endOf("week");
73
- const firstMonth = firstDay.get("month");
74
- const lastMonth = lastDay.get("month");
75
- if (firstMonth === lastMonth) {
76
- return [[firstDay, lastDay]];
77
- } else if (firstMonth + 1 === lastMonth) {
78
- const firstMonthLastDay = firstDay.endOf("month");
79
- const lastMonthFirstDay = lastDay.startOf("month");
80
- const isSameWeek = firstMonthLastDay.isSame(lastMonthFirstDay, "week");
81
- const lastMonthStartDay = isSameWeek ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
82
- return [
83
- [firstDay, firstMonthLastDay],
84
- [lastMonthStartDay.startOf("week"), lastDay]
85
- ];
86
- } else if (firstMonth + 2 === lastMonth) {
87
- const firstMonthLastDay = firstDay.endOf("month");
88
- const secondMonthFirstDay = firstDay.add(1, "month").startOf("month");
89
- const secondMonthStartDay = firstMonthLastDay.isSame(secondMonthFirstDay, "week") ? secondMonthFirstDay.add(1, "week") : secondMonthFirstDay;
90
- const secondMonthLastDay = secondMonthStartDay.endOf("month");
91
- const lastMonthFirstDay = lastDay.startOf("month");
92
- const lastMonthStartDay = secondMonthLastDay.isSame(lastMonthFirstDay, "week") ? lastMonthFirstDay.add(1, "week") : lastMonthFirstDay;
93
- return [
94
- [firstDay, firstMonthLastDay],
95
- [secondMonthStartDay.startOf("week"), secondMonthLastDay],
96
- [lastMonthStartDay.startOf("week"), lastDay]
97
- ];
98
- } else {
99
- debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
100
- return [];
101
- }
102
- };
103
- const validatedRange = computed(() => {
104
- if (!props.range)
105
- return [];
106
- const rangeArrDayjs = props.range.map((_) => dayjs(_).locale(lang.value));
107
- const [startDayjs, endDayjs] = rangeArrDayjs;
108
- if (startDayjs.isAfter(endDayjs)) {
109
- debugWarn(COMPONENT_NAME, "end time should be greater than start time");
110
- return [];
111
- }
112
- if (startDayjs.isSame(endDayjs, "month")) {
113
- return calculateValidatedDateRange(startDayjs, endDayjs);
114
- } else {
115
- if (startDayjs.add(1, "month").month() !== endDayjs.month()) {
116
- debugWarn(COMPONENT_NAME, "start time and end time interval must not exceed two months");
117
- return [];
118
- }
119
- return calculateValidatedDateRange(startDayjs, endDayjs);
120
- }
121
- });
122
- const pickDay = (day) => {
123
- realSelectedDay.value = day;
124
- };
125
- const selectDate = (type) => {
126
- let day;
127
- if (type === "prev-month") {
128
- day = prevMonthDayjs.value;
129
- } else if (type === "next-month") {
130
- day = nextMonthDayjs.value;
131
- } else if (type === "prev-year") {
132
- day = prevYearDayjs.value;
133
- } else if (type === "next-year") {
134
- day = nextYearDayjs.value;
135
- } else {
136
- day = now;
137
- }
138
- if (day.isSame(date.value, "day"))
139
- return;
140
- pickDay(day);
141
- };
142
- expose({
143
- selectedDay: realSelectedDay,
144
- pickDay,
145
- selectDate,
146
- calculateValidatedDateRange
147
- });
148
- return (_ctx, _cache) => {
149
- return openBlock(), createElementBlock("div", {
150
- class: normalizeClass(unref(ns).b())
151
- }, [
152
- createElementVNode("div", {
153
- class: normalizeClass(unref(ns).e("header"))
154
- }, [
155
- renderSlot(_ctx.$slots, "header", { date: unref(i18nDate) }, () => [
156
- createElementVNode("div", {
157
- class: normalizeClass(unref(ns).e("title"))
158
- }, toDisplayString(unref(i18nDate)), 3),
159
- unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", {
160
- key: 0,
161
- class: normalizeClass(unref(ns).e("button-group"))
162
- }, [
163
- createVNode(unref(ElButtonGroup), null, {
164
- default: withCtx(() => [
165
- createVNode(unref(ElButton), {
166
- size: "small",
167
- onClick: _cache[0] || (_cache[0] = ($event) => selectDate("prev-month"))
168
- }, {
169
- default: withCtx(() => [
170
- createTextVNode(toDisplayString(unref(t)("el.datepicker.prevMonth")), 1)
171
- ]),
172
- _: 1
173
- }),
174
- createVNode(unref(ElButton), {
175
- size: "small",
176
- onClick: _cache[1] || (_cache[1] = ($event) => selectDate("today"))
177
- }, {
178
- default: withCtx(() => [
179
- createTextVNode(toDisplayString(unref(t)("el.datepicker.today")), 1)
180
- ]),
181
- _: 1
182
- }),
183
- createVNode(unref(ElButton), {
184
- size: "small",
185
- onClick: _cache[2] || (_cache[2] = ($event) => selectDate("next-month"))
186
- }, {
187
- default: withCtx(() => [
188
- createTextVNode(toDisplayString(unref(t)("el.datepicker.nextMonth")), 1)
189
- ]),
190
- _: 1
191
- })
192
- ]),
193
- _: 1
194
- })
195
- ], 2)) : createCommentVNode("v-if", true)
196
- ])
197
- ], 2),
198
- unref(validatedRange).length === 0 ? (openBlock(), createElementBlock("div", {
199
- key: 0,
200
- class: normalizeClass(unref(ns).e("body"))
201
- }, [
202
- createVNode(DateTable, {
203
- date: unref(date),
204
- "selected-day": unref(realSelectedDay),
205
- onPick: pickDay
206
- }, createSlots({ _: 2 }, [
207
- _ctx.$slots.dateCell ? {
208
- name: "dateCell",
209
- fn: withCtx((data) => [
210
- renderSlot(_ctx.$slots, "dateCell", normalizeProps(guardReactiveProps(data)))
211
- ])
212
- } : void 0
213
- ]), 1032, ["date", "selected-day"])
214
- ], 2)) : (openBlock(), createElementBlock("div", {
215
- key: 1,
216
- class: normalizeClass(unref(ns).e("body"))
217
- }, [
218
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(validatedRange), (range_, index) => {
219
- return openBlock(), createBlock(DateTable, {
220
- key: index,
221
- date: range_[0],
222
- "selected-day": unref(realSelectedDay),
223
- range: range_,
224
- "hide-header": index !== 0,
225
- onPick: pickDay
226
- }, createSlots({ _: 2 }, [
227
- _ctx.$slots.dateCell ? {
228
- name: "dateCell",
229
- fn: withCtx((data) => [
230
- renderSlot(_ctx.$slots, "dateCell", normalizeProps(guardReactiveProps(data)))
231
- ])
232
- } : void 0
233
- ]), 1032, ["date", "selected-day", "range", "hide-header"]);
234
- }), 128))
235
- ], 2))
236
- ], 2);
237
- };
6
+ const calendarProps = buildProps({
7
+ modelValue: {
8
+ type: Date
9
+ },
10
+ range: {
11
+ type: definePropType(Array),
12
+ validator: (range) => Array.isArray(range) && range.length === 2 && range.every((item) => item instanceof Date)
238
13
  }
239
14
  });
240
- var Calendar = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-pe/packages/components/calendar/src/calendar.vue"]]);
15
+ const calendarEmits = {
16
+ [UPDATE_MODEL_EVENT]: (value) => value instanceof Date,
17
+ input: (value) => value instanceof Date
18
+ };
241
19
 
242
- export { Calendar as default };
20
+ export { calendarEmits, calendarProps };
243
21
  //# 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 <el-button-group>\n <el-button size=\"small\" @click=\"selectDate('prev-month')\">\n {{ t('el.datepicker.prevMonth') }}\n </el-button>\n <el-button size=\"small\" @click=\"selectDate('today')\">\n {{ t('el.datepicker.today') }}\n </el-button>\n <el-button size=\"small\" @click=\"selectDate('next-month')\">\n {{ t('el.datepicker.nextMonth') }}\n </el-button>\n </el-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\" @pick=\"pickDay\">\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 @pick=\"pickDay\"\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 { ElButton, ElButtonGroup } from '@element-plus/components/button'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { debugWarn } from '@element-plus/utils'\nimport DateTable from './date-table.vue'\nimport { calendarEmits, calendarProps } from './calendar'\n\nimport type { CalendarDateType } from './calendar'\nimport type { ComputedRef } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nconst COMPONENT_NAME = 'ElCalendar'\n\ndefineOptions({\n name: 'ElCalendar',\n})\n\nconst props = defineProps(calendarProps)\nconst emit = defineEmits(calendarEmits)\n\nconst ns = useNamespace('calendar')\n\nconst { t, lang } = useLocale()\nconst selectedDay = ref<Dayjs>()\nconst now = dayjs().locale(lang.value)\n\nconst prevMonthDayjs = computed(() => {\n return date.value.subtract(1, 'month').date(1)\n})\n\nconst nextMonthDayjs = computed(() => {\n return date.value.add(1, 'month').date(1)\n})\n\nconst prevYearDayjs = computed(() => {\n return date.value.subtract(1, 'year').date(1)\n})\n\nconst nextYearDayjs = computed(() => {\n return date.value.add(1, 'year').date(1)\n})\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 const result = val.toDate()\n\n emit('input', result)\n emit('update:modelValue', result)\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-plus/element-plus/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 (firstMonth + 2 === lastMonth) {\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\nconst pickDay = (day: Dayjs) => {\n realSelectedDay.value = day\n}\n\nconst selectDate = (type: CalendarDateType) => {\n let day: Dayjs\n if (type === 'prev-month') {\n day = prevMonthDayjs.value\n } else if (type === 'next-month') {\n day = nextMonthDayjs.value\n } else if (type === 'prev-year') {\n day = prevYearDayjs.value\n } else if (type === 'next-year') {\n day = nextYearDayjs.value\n } else {\n day = now\n }\n\n if (day.isSame(date.value, 'day')) return\n pickDay(day)\n}\n\ndefineExpose({\n /** @description currently selected date */\n selectedDay: realSelectedDay,\n /** @description select a specific date */\n pickDay,\n /** @description select date */\n selectDate,\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-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/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 const calendarEmits = {\n [UPDATE_MODEL_EVENT]: (value: Date) => value instanceof Date,\n input: (value: Date) => value instanceof Date,\n}\nexport type CalendarEmits = typeof calendarEmits\n\nexport type CalendarInstance = InstanceType<typeof Calendar>\n"],"names":[],"mappings":";;;;;AAEY,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,EAAE;AACS,MAAC,aAAa,GAAG;AAC7B,EAAE,CAAC,kBAAkB,GAAG,CAAC,KAAK,KAAK,KAAK,YAAY,IAAI;AACxD,EAAE,KAAK,EAAE,CAAC,KAAK,KAAK,KAAK,YAAY,IAAI;AACzC;;;;"}
@@ -1,39 +1,160 @@
1
- import '../../../utils/index.mjs';
1
+ import { defineComponent, computed, openBlock, createElementBlock, normalizeClass, unref, Fragment, renderList, toDisplayString, createCommentVNode, createElementVNode, renderSlot } from 'vue';
2
+ import dayjs from 'dayjs';
3
+ import localeData from 'dayjs/plugin/localeData.js';
4
+ import '../../../hooks/index.mjs';
2
5
  import '../../time-picker/index.mjs';
6
+ import '../../../constants/index.mjs';
7
+ import { dateTableProps, dateTableEmits, getPrevMonthLastDays, getMonthDays, toNestedArr } from './date-table2.mjs';
8
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
+ import { useLocale } from '../../../hooks/use-locale/index.mjs';
10
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
3
11
  import { rangeArr } from '../../time-picker/src/common/date-utils.mjs';
4
- import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
5
- import { isObject } from '@vue/shared';
12
+ import { WEEK_DAYS } from '../../../constants/date.mjs';
6
13
 
7
- const getPrevMonthLastDays = (date, count) => {
8
- const lastDay = date.subtract(1, "month").endOf("month").date();
9
- return rangeArr(count).map((_, index) => lastDay - (count - index - 1));
14
+ const _hoisted_1 = { key: 0 };
15
+ const _hoisted_2 = ["onClick"];
16
+ const __default__ = {
17
+ name: "DateTable"
10
18
  };
11
- const getMonthDays = (date) => {
12
- const days = date.daysInMonth();
13
- return rangeArr(days).map((_, index) => index + 1);
14
- };
15
- const toNestedArr = (days) => rangeArr(days.length / 7).map((index) => {
16
- const start = index * 7;
17
- return days.slice(start, start + 7);
18
- });
19
- const dateTableProps = buildProps({
20
- selectedDay: {
21
- type: definePropType(Object)
22
- },
23
- range: {
24
- type: definePropType(Array)
25
- },
26
- date: {
27
- type: definePropType(Object),
28
- required: true
29
- },
30
- hideHeader: {
31
- type: Boolean
19
+ const _sfc_main = /* @__PURE__ */ defineComponent({
20
+ ...__default__,
21
+ props: dateTableProps,
22
+ emits: dateTableEmits,
23
+ setup(__props, { expose, emit }) {
24
+ const props = __props;
25
+ dayjs.extend(localeData);
26
+ const { t, lang } = useLocale();
27
+ const nsTable = useNamespace("calendar-table");
28
+ const nsDay = useNamespace("calendar-day");
29
+ const now = dayjs().locale(lang.value);
30
+ const firstDayOfWeek = now.$locale().weekStart || 0;
31
+ const isInRange = computed(() => !!props.range && !!props.range.length);
32
+ const rows = computed(() => {
33
+ let days = [];
34
+ if (isInRange.value) {
35
+ const [start, end] = props.range;
36
+ const currentMonthRange = rangeArr(end.date() - start.date() + 1).map((index) => ({
37
+ text: start.date() + index,
38
+ type: "current"
39
+ }));
40
+ let remaining = currentMonthRange.length % 7;
41
+ remaining = remaining === 0 ? 0 : 7 - remaining;
42
+ const nextMonthRange = rangeArr(remaining).map((_, index) => ({
43
+ text: index + 1,
44
+ type: "next"
45
+ }));
46
+ days = currentMonthRange.concat(nextMonthRange);
47
+ } else {
48
+ const firstDay = props.date.startOf("month").day() || 7;
49
+ const prevMonthDays = getPrevMonthLastDays(props.date, firstDay - firstDayOfWeek).map((day) => ({
50
+ text: day,
51
+ type: "prev"
52
+ }));
53
+ const currentMonthDays = getMonthDays(props.date).map((day) => ({
54
+ text: day,
55
+ type: "current"
56
+ }));
57
+ days = [...prevMonthDays, ...currentMonthDays];
58
+ const nextMonthDays = rangeArr(42 - days.length).map((_, index) => ({
59
+ text: index + 1,
60
+ type: "next"
61
+ }));
62
+ days = days.concat(nextMonthDays);
63
+ }
64
+ return toNestedArr(days);
65
+ });
66
+ const weekDays = computed(() => {
67
+ const start = firstDayOfWeek;
68
+ if (start === 0) {
69
+ return WEEK_DAYS.map((_) => t(`el.datepicker.weeks.${_}`));
70
+ } else {
71
+ return WEEK_DAYS.slice(start).concat(WEEK_DAYS.slice(0, start)).map((_) => t(`el.datepicker.weeks.${_}`));
72
+ }
73
+ });
74
+ const getFormattedDate = (day, type) => {
75
+ switch (type) {
76
+ case "prev":
77
+ return props.date.startOf("month").subtract(1, "month").date(day);
78
+ case "next":
79
+ return props.date.startOf("month").add(1, "month").date(day);
80
+ case "current":
81
+ return props.date.date(day);
82
+ }
83
+ };
84
+ const getCellClass = ({ text, type }) => {
85
+ const classes = [type];
86
+ if (type === "current") {
87
+ const date = getFormattedDate(text, type);
88
+ if (date.isSame(props.selectedDay, "day")) {
89
+ classes.push(nsDay.is("selected"));
90
+ }
91
+ if (date.isSame(now, "day")) {
92
+ classes.push(nsDay.is("today"));
93
+ }
94
+ }
95
+ return classes;
96
+ };
97
+ const handlePickDay = ({ text, type }) => {
98
+ const date = getFormattedDate(text, type);
99
+ emit("pick", date);
100
+ };
101
+ const getSlotData = ({ text, type }) => {
102
+ const day = getFormattedDate(text, type);
103
+ return {
104
+ isSelected: day.isSame(props.selectedDay),
105
+ type: `${type}-month`,
106
+ day: day.format("YYYY-MM-DD"),
107
+ date: day.toDate()
108
+ };
109
+ };
110
+ expose({
111
+ getFormattedDate
112
+ });
113
+ return (_ctx, _cache) => {
114
+ return openBlock(), createElementBlock("table", {
115
+ class: normalizeClass([unref(nsTable).b(), unref(nsTable).is("range", unref(isInRange))]),
116
+ cellspacing: "0",
117
+ cellpadding: "0"
118
+ }, [
119
+ !_ctx.hideHeader ? (openBlock(), createElementBlock("thead", _hoisted_1, [
120
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(weekDays), (day) => {
121
+ return openBlock(), createElementBlock("th", { key: day }, toDisplayString(day), 1);
122
+ }), 128))
123
+ ])) : createCommentVNode("v-if", true),
124
+ createElementVNode("tbody", null, [
125
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(rows), (row, index) => {
126
+ return openBlock(), createElementBlock("tr", {
127
+ key: index,
128
+ class: normalizeClass({
129
+ [unref(nsTable).e("row")]: true,
130
+ [unref(nsTable).em("row", "hide-border")]: index === 0 && _ctx.hideHeader
131
+ })
132
+ }, [
133
+ (openBlock(true), createElementBlock(Fragment, null, renderList(row, (cell, key) => {
134
+ return openBlock(), createElementBlock("td", {
135
+ key,
136
+ class: normalizeClass(getCellClass(cell)),
137
+ onClick: ($event) => handlePickDay(cell)
138
+ }, [
139
+ createElementVNode("div", {
140
+ class: normalizeClass(unref(nsDay).b())
141
+ }, [
142
+ renderSlot(_ctx.$slots, "dateCell", {
143
+ data: getSlotData(cell)
144
+ }, () => [
145
+ createElementVNode("span", null, toDisplayString(cell.text), 1)
146
+ ])
147
+ ], 2)
148
+ ], 10, _hoisted_2);
149
+ }), 128))
150
+ ], 2);
151
+ }), 128))
152
+ ])
153
+ ], 2);
154
+ };
32
155
  }
33
156
  });
34
- const dateTableEmits = {
35
- pick: (value) => isObject(value)
36
- };
157
+ var DateTable = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-pe/packages/components/calendar/src/date-table.vue"]]);
37
158
 
38
- export { dateTableEmits, dateTableProps, getMonthDays, getPrevMonthLastDays, toNestedArr };
159
+ export { DateTable as default };
39
160
  //# sourceMappingURL=date-table.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"date-table.mjs","sources":["../../../../../../packages/components/calendar/src/date-table.ts"],"sourcesContent":["import { buildProps, definePropType, isObject } from '@element-plus/utils'\nimport { rangeArr } from '@element-plus/components/time-picker'\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type DateTable from './date-table.vue'\n\nexport type CalendarDateCellType = 'next' | 'prev' | 'current'\nexport type CalendarDateCell = {\n text: number\n type: CalendarDateCellType\n}\n\nexport const getPrevMonthLastDays = (date: Dayjs, count: number) => {\n const lastDay = date.subtract(1, 'month').endOf('month').date()\n return rangeArr(count).map((_, index) => lastDay - (count - index - 1))\n}\n\nexport const getMonthDays = (date: Dayjs) => {\n const days = date.daysInMonth()\n return rangeArr(days).map((_, index) => index + 1)\n}\n\nexport const toNestedArr = (days: CalendarDateCell[]) =>\n rangeArr(days.length / 7).map((index) => {\n const start = index * 7\n return days.slice(start, start + 7)\n })\n\nexport const dateTableProps = buildProps({\n selectedDay: {\n type: definePropType<Dayjs>(Object),\n },\n range: {\n type: definePropType<[Dayjs, Dayjs]>(Array),\n },\n date: {\n type: definePropType<Dayjs>(Object),\n required: true,\n },\n hideHeader: {\n type: Boolean,\n },\n} as const)\nexport type DateTableProps = ExtractPropTypes<typeof dateTableProps>\n\nexport const dateTableEmits = {\n pick: (value: Dayjs) => isObject(value),\n}\nexport type DateTableEmits = typeof dateTableEmits\n\nexport type DateTableInstance = InstanceType<typeof DateTable>\n"],"names":[],"mappings":";;;;;;AAEY,MAAC,oBAAoB,GAAG,CAAC,IAAI,EAAE,KAAK,KAAK;AACrD,EAAE,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;AAClE,EAAE,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,OAAO,IAAI,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;AAC1E,EAAE;AACU,MAAC,YAAY,GAAG,CAAC,IAAI,KAAK;AACtC,EAAE,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;AAClC,EAAE,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC;AACrD,EAAE;AACU,MAAC,WAAW,GAAG,CAAC,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK;AAC9E,EAAE,MAAM,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC;AAC1B,EAAE,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;AACtC,CAAC,EAAE;AACS,MAAC,cAAc,GAAG,UAAU,CAAC;AACzC,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;AAC/B,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,IAAI,QAAQ,EAAE,IAAI;AAClB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,OAAO;AACjB,GAAG;AACH,CAAC,EAAE;AACS,MAAC,cAAc,GAAG;AAC9B,EAAE,IAAI,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAClC;;;;"}
1
+ {"version":3,"file":"date-table.mjs","sources":["../../../../../../packages/components/calendar/src/date-table.vue"],"sourcesContent":["<template>\n <table\n :class=\"[nsTable.b(), nsTable.is('range', isInRange)]\"\n cellspacing=\"0\"\n cellpadding=\"0\"\n >\n <thead v-if=\"!hideHeader\">\n <th v-for=\"day in weekDays\" :key=\"day\">{{ day }}</th>\n </thead>\n\n <tbody>\n <tr\n v-for=\"(row, index) in rows\"\n :key=\"index\"\n :class=\"{\n [nsTable.e('row')]: true,\n [nsTable.em('row', 'hide-border')]: index === 0 && hideHeader,\n }\"\n >\n <td\n v-for=\"(cell, key) in row\"\n :key=\"key\"\n :class=\"getCellClass(cell)\"\n @click=\"handlePickDay(cell)\"\n >\n <div :class=\"nsDay.b()\">\n <slot name=\"dateCell\" :data=\"getSlotData(cell)\">\n <span>{{ cell.text }}</span>\n </slot>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport dayjs from 'dayjs'\nimport localeData from 'dayjs/plugin/localeData.js'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { rangeArr } from '@element-plus/components/time-picker'\nimport { WEEK_DAYS } from '@element-plus/constants'\nimport {\n dateTableEmits,\n dateTableProps,\n getMonthDays,\n getPrevMonthLastDays,\n toNestedArr,\n} from './date-table'\nimport type { CalendarDateCell, CalendarDateCellType } from './date-table'\nimport type { Dayjs } from 'dayjs'\n\ndayjs.extend(localeData)\n\ndefineOptions({\n name: 'DateTable',\n})\n\nconst props = defineProps(dateTableProps)\nconst emit = defineEmits(dateTableEmits)\n\nconst { t, lang } = useLocale()\nconst nsTable = useNamespace('calendar-table')\nconst nsDay = useNamespace('calendar-day')\n\nconst now = dayjs().locale(lang.value)\n// todo better way to get Day.js locale object\nconst firstDayOfWeek: number = (now as any).$locale().weekStart || 0\n\nconst isInRange = computed(() => !!props.range && !!props.range.length)\n\nconst rows = computed(() => {\n let days: CalendarDateCell[] = []\n if (isInRange.value) {\n const [start, end] = props.range!\n const currentMonthRange: CalendarDateCell[] = rangeArr(\n end.date() - start.date() + 1\n ).map((index) => ({\n text: start.date() + index,\n type: 'current',\n }))\n\n let remaining = currentMonthRange.length % 7\n remaining = remaining === 0 ? 0 : 7 - remaining\n const nextMonthRange: CalendarDateCell[] = rangeArr(remaining).map(\n (_, index) => ({\n text: index + 1,\n type: 'next',\n })\n )\n days = currentMonthRange.concat(nextMonthRange)\n } else {\n const firstDay = props.date.startOf('month').day() || 7\n const prevMonthDays: CalendarDateCell[] = getPrevMonthLastDays(\n props.date,\n firstDay - firstDayOfWeek\n ).map((day) => ({\n text: day,\n type: 'prev',\n }))\n const currentMonthDays: CalendarDateCell[] = getMonthDays(props.date).map(\n (day) => ({\n text: day,\n type: 'current',\n })\n )\n days = [...prevMonthDays, ...currentMonthDays]\n const nextMonthDays: CalendarDateCell[] = rangeArr(42 - days.length).map(\n (_, index) => ({\n text: index + 1,\n type: 'next',\n })\n )\n days = days.concat(nextMonthDays)\n }\n return toNestedArr(days)\n})\n\nconst weekDays = computed(() => {\n const start = firstDayOfWeek\n if (start === 0) {\n return WEEK_DAYS.map((_) => t(`el.datepicker.weeks.${_}`))\n } else {\n return WEEK_DAYS.slice(start)\n .concat(WEEK_DAYS.slice(0, start))\n .map((_) => t(`el.datepicker.weeks.${_}`))\n }\n})\n\nconst getFormattedDate = (day: number, type: CalendarDateCellType): Dayjs => {\n switch (type) {\n case 'prev':\n return props.date.startOf('month').subtract(1, 'month').date(day)\n case 'next':\n return props.date.startOf('month').add(1, 'month').date(day)\n case 'current':\n return props.date.date(day)\n }\n}\n\nconst getCellClass = ({ text, type }: CalendarDateCell) => {\n const classes: string[] = [type]\n if (type === 'current') {\n const date = getFormattedDate(text, type)\n if (date.isSame(props.selectedDay, 'day')) {\n classes.push(nsDay.is('selected'))\n }\n if (date.isSame(now, 'day')) {\n classes.push(nsDay.is('today'))\n }\n }\n return classes\n}\n\nconst handlePickDay = ({ text, type }: CalendarDateCell) => {\n const date = getFormattedDate(text, type)\n emit('pick', date)\n}\n\nconst getSlotData = ({ text, type }: CalendarDateCell) => {\n const day = getFormattedDate(text, type)\n return {\n isSelected: day.isSame(props.selectedDay),\n type: `${type}-month`,\n day: day.format('YYYY-MM-DD'),\n date: day.toDate(),\n }\n}\n\ndefineExpose({\n /** @description toggle date panel */\n getFormattedDate,\n})\n</script>\n"],"names":[],"mappings":"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"}