element-ps 2.0.38 → 2.0.39

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 (434) hide show
  1. package/dist/index.full.js +443 -326
  2. package/dist/index.full.min.js +8 -8
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +8 -8
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +443 -326
  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/autocomplete/index.mjs +2 -2
  16. package/es/components/autocomplete/src/autocomplete.mjs +94 -58
  17. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  18. package/es/components/autocomplete/src/autocomplete2.mjs +58 -94
  19. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  20. package/es/components/avatar/index.mjs +2 -2
  21. package/es/components/avatar/src/avatar.mjs +61 -29
  22. package/es/components/avatar/src/avatar.mjs.map +1 -1
  23. package/es/components/avatar/src/avatar2.mjs +29 -61
  24. package/es/components/avatar/src/avatar2.mjs.map +1 -1
  25. package/es/components/backtop/index.mjs +2 -2
  26. package/es/components/backtop/src/backtop.mjs +18 -59
  27. package/es/components/backtop/src/backtop.mjs.map +1 -1
  28. package/es/components/backtop/src/backtop2.mjs +59 -18
  29. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  30. package/es/components/badge/index.mjs +2 -2
  31. package/es/components/badge/src/badge.mjs +17 -54
  32. package/es/components/badge/src/badge.mjs.map +1 -1
  33. package/es/components/badge/src/badge2.mjs +54 -17
  34. package/es/components/badge/src/badge2.mjs.map +1 -1
  35. package/es/components/breadcrumb/index.mjs +2 -2
  36. package/es/components/breadcrumb/src/breadcrumb-item.mjs +46 -11
  37. package/es/components/breadcrumb/src/breadcrumb-item.mjs.map +1 -1
  38. package/es/components/breadcrumb/src/breadcrumb-item2.mjs +11 -46
  39. package/es/components/breadcrumb/src/breadcrumb-item2.mjs.map +1 -1
  40. package/es/components/calendar/src/calendar2.mjs +1 -1
  41. package/es/components/calendar/src/date-table.mjs +146 -27
  42. package/es/components/calendar/src/date-table.mjs.map +1 -1
  43. package/es/components/calendar/src/date-table2.mjs +27 -146
  44. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  45. package/es/components/card/index.mjs +2 -2
  46. package/es/components/card/src/card.mjs +15 -35
  47. package/es/components/card/src/card.mjs.map +1 -1
  48. package/es/components/card/src/card2.mjs +35 -15
  49. package/es/components/card/src/card2.mjs.map +1 -1
  50. package/es/components/carousel/index.mjs +2 -2
  51. package/es/components/carousel/src/carousel-item.mjs +148 -7
  52. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  53. package/es/components/carousel/src/carousel-item2.mjs +7 -148
  54. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  55. package/es/components/cascader-panel/src/config.mjs +1 -1
  56. package/es/components/cascader-panel/src/index.mjs +1 -1
  57. package/es/components/cascader-panel/src/menu.mjs +1 -1
  58. package/es/components/cascader-panel/src/node.mjs +200 -120
  59. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  60. package/es/components/cascader-panel/src/node2.mjs +120 -200
  61. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  62. package/es/components/cascader-panel/src/store.mjs +1 -1
  63. package/es/components/collapse/index.mjs +2 -2
  64. package/es/components/collapse/src/collapse.mjs +14 -61
  65. package/es/components/collapse/src/collapse.mjs.map +1 -1
  66. package/es/components/collapse/src/collapse2.mjs +61 -14
  67. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  68. package/es/components/dialog/index.mjs +2 -2
  69. package/es/components/dialog/src/dialog.mjs +87 -61
  70. package/es/components/dialog/src/dialog.mjs.map +1 -1
  71. package/es/components/dialog/src/dialog2.mjs +61 -87
  72. package/es/components/dialog/src/dialog2.mjs.map +1 -1
  73. package/es/components/divider/index.mjs +2 -2
  74. package/es/components/divider/src/divider.mjs +34 -17
  75. package/es/components/divider/src/divider.mjs.map +1 -1
  76. package/es/components/divider/src/divider2.mjs +17 -34
  77. package/es/components/divider/src/divider2.mjs.map +1 -1
  78. package/es/components/drawer/src/drawer.mjs +1 -1
  79. package/es/components/dropdown/index.mjs +2 -2
  80. package/es/components/dropdown/src/dropdown-item-impl.mjs +1 -1
  81. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  82. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  83. package/es/components/dropdown/src/dropdown.mjs +100 -109
  84. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  85. package/es/components/dropdown/src/dropdown2.mjs +109 -100
  86. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  87. package/es/components/empty/index.mjs +2 -2
  88. package/es/components/empty/src/empty.mjs +11 -56
  89. package/es/components/empty/src/empty.mjs.map +1 -1
  90. package/es/components/empty/src/empty2.mjs +56 -11
  91. package/es/components/empty/src/empty2.mjs.map +1 -1
  92. package/es/components/image/index.mjs +2 -2
  93. package/es/components/image/src/image.mjs +127 -50
  94. package/es/components/image/src/image.mjs.map +1 -1
  95. package/es/components/image/src/image2.mjs +50 -127
  96. package/es/components/image/src/image2.mjs.map +1 -1
  97. package/es/components/index.mjs +29 -29
  98. package/es/components/page-header/index.mjs +2 -2
  99. package/es/components/page-header/src/page-header.mjs +55 -14
  100. package/es/components/page-header/src/page-header.mjs.map +1 -1
  101. package/es/components/page-header/src/page-header2.mjs +14 -55
  102. package/es/components/page-header/src/page-header2.mjs.map +1 -1
  103. package/es/components/popover/src/popover.mjs +1 -1
  104. package/es/components/popper/index.mjs +6 -6
  105. package/es/components/popper/src/arrow.mjs +31 -7
  106. package/es/components/popper/src/arrow.mjs.map +1 -1
  107. package/es/components/popper/src/arrow2.mjs +7 -31
  108. package/es/components/popper/src/arrow2.mjs.map +1 -1
  109. package/es/components/popper/src/content.mjs +52 -64
  110. package/es/components/popper/src/content.mjs.map +1 -1
  111. package/es/components/popper/src/content2.mjs +64 -52
  112. package/es/components/popper/src/content2.mjs.map +1 -1
  113. package/es/components/popper/src/trigger.mjs +17 -28
  114. package/es/components/popper/src/trigger.mjs.map +1 -1
  115. package/es/components/popper/src/trigger2.mjs +28 -17
  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 +230 -57
  119. package/es/components/progress/src/progress.mjs.map +1 -1
  120. package/es/components/progress/src/progress2.mjs +57 -230
  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 +80 -9
  124. package/es/components/radio/src/radio-button.mjs.map +1 -1
  125. package/es/components/radio/src/radio-button2.mjs +9 -80
  126. package/es/components/radio/src/radio-button2.mjs.map +1 -1
  127. package/es/components/radio/src/radio.mjs +62 -74
  128. package/es/components/radio/src/radio.mjs.map +1 -1
  129. package/es/components/radio/src/radio2.mjs +74 -62
  130. package/es/components/radio/src/radio2.mjs.map +1 -1
  131. package/es/components/scrollbar/src/bar.mjs +35 -22
  132. package/es/components/scrollbar/src/bar.mjs.map +1 -1
  133. package/es/components/scrollbar/src/bar2.mjs +22 -35
  134. package/es/components/scrollbar/src/bar2.mjs.map +1 -1
  135. package/es/components/scrollbar/src/scrollbar2.mjs +1 -1
  136. package/es/components/skeleton/index.mjs +2 -2
  137. package/es/components/skeleton/src/skeleton-item.mjs +23 -18
  138. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  139. package/es/components/skeleton/src/skeleton-item2.mjs +18 -23
  140. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  141. package/es/components/skeleton/src/skeleton.mjs +1 -1
  142. package/es/components/switch/index.mjs +2 -2
  143. package/es/components/switch/src/switch.mjs +81 -176
  144. package/es/components/switch/src/switch.mjs.map +1 -1
  145. package/es/components/switch/src/switch2.mjs +176 -81
  146. package/es/components/switch/src/switch2.mjs.map +1 -1
  147. package/es/components/table/index.d.ts +38 -85
  148. package/es/components/table/src/config.mjs +3 -0
  149. package/es/components/table/src/config.mjs.map +1 -1
  150. package/es/components/table/src/filter-panel.mjs +8 -1
  151. package/es/components/table/src/filter-panel.mjs.map +1 -1
  152. package/es/components/table/src/store/current.mjs +14 -12
  153. package/es/components/table/src/store/current.mjs.map +1 -1
  154. package/es/components/table/src/store/index.mjs +9 -9
  155. package/es/components/table/src/store/index.mjs.map +1 -1
  156. package/es/components/table/src/store/watcher.mjs +11 -1
  157. package/es/components/table/src/store/watcher.mjs.map +1 -1
  158. package/es/components/table/src/table/defaults.d.ts +8 -4
  159. package/es/components/table/src/table/defaults.mjs +3 -4
  160. package/es/components/table/src/table/defaults.mjs.map +1 -1
  161. package/es/components/table/src/table/style-helper.d.ts +24 -34
  162. package/es/components/table/src/table/style-helper.mjs +107 -120
  163. package/es/components/table/src/table/style-helper.mjs.map +1 -1
  164. package/es/components/table/src/table/utils-helper.d.ts +1 -1
  165. package/es/components/table/src/table/utils-helper.mjs.map +1 -1
  166. package/es/components/table/src/table-body/events-helper.d.ts +1 -3
  167. package/es/components/table/src/table-body/events-helper.mjs +3 -3
  168. package/es/components/table/src/table-body/events-helper.mjs.map +1 -1
  169. package/es/components/table/src/table-body/index.mjs +1 -5
  170. package/es/components/table/src/table-body/index.mjs.map +1 -1
  171. package/es/components/table/src/table-body/render-helper.mjs +6 -3
  172. package/es/components/table/src/table-body/render-helper.mjs.map +1 -1
  173. package/es/components/table/src/table-body/styles-helper.d.ts +1 -1
  174. package/es/components/table/src/table-body/styles-helper.mjs +3 -3
  175. package/es/components/table/src/table-body/styles-helper.mjs.map +1 -1
  176. package/es/components/table/src/table-column/render-helper.mjs +4 -2
  177. package/es/components/table/src/table-column/render-helper.mjs.map +1 -1
  178. package/es/components/table/src/table-header/event-helper.mjs +5 -9
  179. package/es/components/table/src/table-header/event-helper.mjs.map +1 -1
  180. package/es/components/table/src/table-header/index.mjs +1 -2
  181. package/es/components/table/src/table-header/index.mjs.map +1 -1
  182. package/es/components/table/src/table-header/style.helper.mjs +2 -2
  183. package/es/components/table/src/table-header/style.helper.mjs.map +1 -1
  184. package/es/components/table/src/table-layout.d.ts +1 -6
  185. package/es/components/table/src/table-layout.mjs +0 -64
  186. package/es/components/table/src/table-layout.mjs.map +1 -1
  187. package/es/components/table/src/table.mjs +31 -35
  188. package/es/components/table/src/table.mjs.map +1 -1
  189. package/es/components/table/src/table.vue.d.ts +38 -85
  190. package/es/components/table/src/util.d.ts +7 -7
  191. package/es/components/table/src/util.mjs +68 -52
  192. package/es/components/table/src/util.mjs.map +1 -1
  193. package/es/components/table-v2/src/components/header.d.ts +1 -1
  194. package/es/components/table-v2/src/table-grid.d.ts +1 -1
  195. package/es/components/table-v2/src/table-v2.d.ts +1 -1
  196. package/es/components/tabs/index.mjs +3 -3
  197. package/es/components/tabs/src/tab-bar.mjs +76 -7
  198. package/es/components/tabs/src/tab-bar.mjs.map +1 -1
  199. package/es/components/tabs/src/tab-bar2.mjs +7 -76
  200. package/es/components/tabs/src/tab-bar2.mjs.map +1 -1
  201. package/es/components/tabs/src/tab-nav.mjs +1 -1
  202. package/es/components/tabs/src/tab-pane.mjs +61 -15
  203. package/es/components/tabs/src/tab-pane.mjs.map +1 -1
  204. package/es/components/tabs/src/tab-pane2.mjs +15 -61
  205. package/es/components/tabs/src/tab-pane2.mjs.map +1 -1
  206. package/es/components/timeline/index.mjs +2 -2
  207. package/es/components/timeline/src/timeline-item.mjs +39 -73
  208. package/es/components/timeline/src/timeline-item.mjs.map +1 -1
  209. package/es/components/timeline/src/timeline-item2.mjs +73 -39
  210. package/es/components/timeline/src/timeline-item2.mjs.map +1 -1
  211. package/es/components/tooltip/src/tooltip.mjs +2 -2
  212. package/es/components/tooltip/src/tooltip2.mjs +1 -1
  213. package/es/components/tooltip/src/trigger.mjs +1 -1
  214. package/es/components/upload/index.mjs +1 -1
  215. package/es/components/upload/src/upload-list.mjs +155 -26
  216. package/es/components/upload/src/upload-list.mjs.map +1 -1
  217. package/es/components/upload/src/upload-list2.mjs +26 -155
  218. package/es/components/upload/src/upload-list2.mjs.map +1 -1
  219. package/es/components/upload/src/upload.mjs +1 -1
  220. package/es/index.mjs +29 -29
  221. package/es/version.d.ts +1 -1
  222. package/es/version.mjs +1 -1
  223. package/es/version.mjs.map +1 -1
  224. package/lib/components/autocomplete/index.js +2 -2
  225. package/lib/components/autocomplete/src/autocomplete.js +94 -58
  226. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  227. package/lib/components/autocomplete/src/autocomplete2.js +58 -94
  228. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  229. package/lib/components/avatar/index.js +2 -2
  230. package/lib/components/avatar/src/avatar.js +61 -29
  231. package/lib/components/avatar/src/avatar.js.map +1 -1
  232. package/lib/components/avatar/src/avatar2.js +29 -61
  233. package/lib/components/avatar/src/avatar2.js.map +1 -1
  234. package/lib/components/backtop/index.js +2 -2
  235. package/lib/components/backtop/src/backtop.js +18 -59
  236. package/lib/components/backtop/src/backtop.js.map +1 -1
  237. package/lib/components/backtop/src/backtop2.js +59 -18
  238. package/lib/components/backtop/src/backtop2.js.map +1 -1
  239. package/lib/components/badge/index.js +2 -2
  240. package/lib/components/badge/src/badge.js +17 -54
  241. package/lib/components/badge/src/badge.js.map +1 -1
  242. package/lib/components/badge/src/badge2.js +54 -17
  243. package/lib/components/badge/src/badge2.js.map +1 -1
  244. package/lib/components/breadcrumb/index.js +2 -2
  245. package/lib/components/breadcrumb/src/breadcrumb-item.js +46 -11
  246. package/lib/components/breadcrumb/src/breadcrumb-item.js.map +1 -1
  247. package/lib/components/breadcrumb/src/breadcrumb-item2.js +11 -46
  248. package/lib/components/breadcrumb/src/breadcrumb-item2.js.map +1 -1
  249. package/lib/components/calendar/src/calendar2.js +1 -1
  250. package/lib/components/calendar/src/date-table.js +151 -30
  251. package/lib/components/calendar/src/date-table.js.map +1 -1
  252. package/lib/components/calendar/src/date-table2.js +30 -151
  253. package/lib/components/calendar/src/date-table2.js.map +1 -1
  254. package/lib/components/card/index.js +2 -2
  255. package/lib/components/card/src/card.js +15 -35
  256. package/lib/components/card/src/card.js.map +1 -1
  257. package/lib/components/card/src/card2.js +35 -15
  258. package/lib/components/card/src/card2.js.map +1 -1
  259. package/lib/components/carousel/index.js +2 -2
  260. package/lib/components/carousel/src/carousel-item.js +148 -7
  261. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  262. package/lib/components/carousel/src/carousel-item2.js +7 -148
  263. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  264. package/lib/components/cascader-panel/src/config.js +1 -1
  265. package/lib/components/cascader-panel/src/index.js +1 -1
  266. package/lib/components/cascader-panel/src/menu.js +1 -1
  267. package/lib/components/cascader-panel/src/node.js +200 -121
  268. package/lib/components/cascader-panel/src/node.js.map +1 -1
  269. package/lib/components/cascader-panel/src/node2.js +121 -200
  270. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  271. package/lib/components/cascader-panel/src/store.js +1 -1
  272. package/lib/components/collapse/index.js +2 -2
  273. package/lib/components/collapse/src/collapse.js +16 -61
  274. package/lib/components/collapse/src/collapse.js.map +1 -1
  275. package/lib/components/collapse/src/collapse2.js +61 -16
  276. package/lib/components/collapse/src/collapse2.js.map +1 -1
  277. package/lib/components/dialog/index.js +2 -2
  278. package/lib/components/dialog/src/dialog.js +87 -61
  279. package/lib/components/dialog/src/dialog.js.map +1 -1
  280. package/lib/components/dialog/src/dialog2.js +61 -87
  281. package/lib/components/dialog/src/dialog2.js.map +1 -1
  282. package/lib/components/divider/index.js +2 -2
  283. package/lib/components/divider/src/divider.js +34 -17
  284. package/lib/components/divider/src/divider.js.map +1 -1
  285. package/lib/components/divider/src/divider2.js +17 -34
  286. package/lib/components/divider/src/divider2.js.map +1 -1
  287. package/lib/components/drawer/src/drawer.js +1 -1
  288. package/lib/components/dropdown/index.js +2 -2
  289. package/lib/components/dropdown/src/dropdown-item-impl.js +1 -1
  290. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  291. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  292. package/lib/components/dropdown/src/dropdown.js +109 -109
  293. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  294. package/lib/components/dropdown/src/dropdown2.js +109 -109
  295. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  296. package/lib/components/empty/index.js +2 -2
  297. package/lib/components/empty/src/empty.js +11 -56
  298. package/lib/components/empty/src/empty.js.map +1 -1
  299. package/lib/components/empty/src/empty2.js +56 -11
  300. package/lib/components/empty/src/empty2.js.map +1 -1
  301. package/lib/components/image/index.js +2 -2
  302. package/lib/components/image/src/image.js +127 -50
  303. package/lib/components/image/src/image.js.map +1 -1
  304. package/lib/components/image/src/image2.js +50 -127
  305. package/lib/components/image/src/image2.js.map +1 -1
  306. package/lib/components/index.js +29 -29
  307. package/lib/components/page-header/index.js +2 -2
  308. package/lib/components/page-header/src/page-header.js +55 -14
  309. package/lib/components/page-header/src/page-header.js.map +1 -1
  310. package/lib/components/page-header/src/page-header2.js +14 -55
  311. package/lib/components/page-header/src/page-header2.js.map +1 -1
  312. package/lib/components/popover/src/popover.js +1 -1
  313. package/lib/components/popper/index.js +6 -6
  314. package/lib/components/popper/src/arrow.js +31 -7
  315. package/lib/components/popper/src/arrow.js.map +1 -1
  316. package/lib/components/popper/src/arrow2.js +7 -31
  317. package/lib/components/popper/src/arrow2.js.map +1 -1
  318. package/lib/components/popper/src/content.js +52 -65
  319. package/lib/components/popper/src/content.js.map +1 -1
  320. package/lib/components/popper/src/content2.js +65 -52
  321. package/lib/components/popper/src/content2.js.map +1 -1
  322. package/lib/components/popper/src/trigger.js +17 -28
  323. package/lib/components/popper/src/trigger.js.map +1 -1
  324. package/lib/components/popper/src/trigger2.js +28 -17
  325. package/lib/components/popper/src/trigger2.js.map +1 -1
  326. package/lib/components/progress/index.js +2 -2
  327. package/lib/components/progress/src/progress.js +230 -57
  328. package/lib/components/progress/src/progress.js.map +1 -1
  329. package/lib/components/progress/src/progress2.js +57 -230
  330. package/lib/components/progress/src/progress2.js.map +1 -1
  331. package/lib/components/radio/index.js +4 -4
  332. package/lib/components/radio/src/radio-button.js +80 -9
  333. package/lib/components/radio/src/radio-button.js.map +1 -1
  334. package/lib/components/radio/src/radio-button2.js +9 -80
  335. package/lib/components/radio/src/radio-button2.js.map +1 -1
  336. package/lib/components/radio/src/radio.js +64 -73
  337. package/lib/components/radio/src/radio.js.map +1 -1
  338. package/lib/components/radio/src/radio2.js +73 -64
  339. package/lib/components/radio/src/radio2.js.map +1 -1
  340. package/lib/components/scrollbar/src/bar.js +35 -22
  341. package/lib/components/scrollbar/src/bar.js.map +1 -1
  342. package/lib/components/scrollbar/src/bar2.js +22 -35
  343. package/lib/components/scrollbar/src/bar2.js.map +1 -1
  344. package/lib/components/scrollbar/src/scrollbar2.js +1 -1
  345. package/lib/components/skeleton/index.js +2 -2
  346. package/lib/components/skeleton/src/skeleton-item.js +23 -18
  347. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  348. package/lib/components/skeleton/src/skeleton-item2.js +18 -23
  349. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  350. package/lib/components/skeleton/src/skeleton.js +1 -1
  351. package/lib/components/switch/index.js +2 -2
  352. package/lib/components/switch/src/switch.js +81 -176
  353. package/lib/components/switch/src/switch.js.map +1 -1
  354. package/lib/components/switch/src/switch2.js +176 -81
  355. package/lib/components/switch/src/switch2.js.map +1 -1
  356. package/lib/components/table/index.d.ts +38 -85
  357. package/lib/components/table/src/config.js +3 -0
  358. package/lib/components/table/src/config.js.map +1 -1
  359. package/lib/components/table/src/filter-panel.js +7 -0
  360. package/lib/components/table/src/filter-panel.js.map +1 -1
  361. package/lib/components/table/src/store/current.js +14 -12
  362. package/lib/components/table/src/store/current.js.map +1 -1
  363. package/lib/components/table/src/store/index.js +8 -8
  364. package/lib/components/table/src/store/index.js.map +1 -1
  365. package/lib/components/table/src/store/watcher.js +11 -1
  366. package/lib/components/table/src/store/watcher.js.map +1 -1
  367. package/lib/components/table/src/table/defaults.d.ts +8 -4
  368. package/lib/components/table/src/table/defaults.js +3 -4
  369. package/lib/components/table/src/table/defaults.js.map +1 -1
  370. package/lib/components/table/src/table/style-helper.d.ts +24 -34
  371. package/lib/components/table/src/table/style-helper.js +106 -119
  372. package/lib/components/table/src/table/style-helper.js.map +1 -1
  373. package/lib/components/table/src/table/utils-helper.d.ts +1 -1
  374. package/lib/components/table/src/table/utils-helper.js.map +1 -1
  375. package/lib/components/table/src/table-body/events-helper.d.ts +1 -3
  376. package/lib/components/table/src/table-body/events-helper.js +3 -3
  377. package/lib/components/table/src/table-body/events-helper.js.map +1 -1
  378. package/lib/components/table/src/table-body/index.js +0 -4
  379. package/lib/components/table/src/table-body/index.js.map +1 -1
  380. package/lib/components/table/src/table-body/render-helper.js +6 -3
  381. package/lib/components/table/src/table-body/render-helper.js.map +1 -1
  382. package/lib/components/table/src/table-body/styles-helper.d.ts +1 -1
  383. package/lib/components/table/src/table-body/styles-helper.js +3 -3
  384. package/lib/components/table/src/table-body/styles-helper.js.map +1 -1
  385. package/lib/components/table/src/table-column/render-helper.js +4 -2
  386. package/lib/components/table/src/table-column/render-helper.js.map +1 -1
  387. package/lib/components/table/src/table-header/event-helper.js +5 -9
  388. package/lib/components/table/src/table-header/event-helper.js.map +1 -1
  389. package/lib/components/table/src/table-header/index.js +1 -2
  390. package/lib/components/table/src/table-header/index.js.map +1 -1
  391. package/lib/components/table/src/table-header/style.helper.js +2 -2
  392. package/lib/components/table/src/table-header/style.helper.js.map +1 -1
  393. package/lib/components/table/src/table-layout.d.ts +1 -6
  394. package/lib/components/table/src/table-layout.js +0 -64
  395. package/lib/components/table/src/table-layout.js.map +1 -1
  396. package/lib/components/table/src/table.js +31 -35
  397. package/lib/components/table/src/table.js.map +1 -1
  398. package/lib/components/table/src/table.vue.d.ts +38 -85
  399. package/lib/components/table/src/util.d.ts +7 -7
  400. package/lib/components/table/src/util.js +68 -52
  401. package/lib/components/table/src/util.js.map +1 -1
  402. package/lib/components/table-v2/src/components/header.d.ts +1 -1
  403. package/lib/components/table-v2/src/table-grid.d.ts +1 -1
  404. package/lib/components/table-v2/src/table-v2.d.ts +1 -1
  405. package/lib/components/tabs/index.js +3 -3
  406. package/lib/components/tabs/src/tab-bar.js +76 -7
  407. package/lib/components/tabs/src/tab-bar.js.map +1 -1
  408. package/lib/components/tabs/src/tab-bar2.js +7 -76
  409. package/lib/components/tabs/src/tab-bar2.js.map +1 -1
  410. package/lib/components/tabs/src/tab-nav.js +1 -1
  411. package/lib/components/tabs/src/tab-pane.js +61 -15
  412. package/lib/components/tabs/src/tab-pane.js.map +1 -1
  413. package/lib/components/tabs/src/tab-pane2.js +15 -61
  414. package/lib/components/tabs/src/tab-pane2.js.map +1 -1
  415. package/lib/components/timeline/index.js +2 -2
  416. package/lib/components/timeline/src/timeline-item.js +39 -73
  417. package/lib/components/timeline/src/timeline-item.js.map +1 -1
  418. package/lib/components/timeline/src/timeline-item2.js +73 -39
  419. package/lib/components/timeline/src/timeline-item2.js.map +1 -1
  420. package/lib/components/tooltip/src/tooltip.js +2 -2
  421. package/lib/components/tooltip/src/tooltip2.js +1 -1
  422. package/lib/components/tooltip/src/trigger.js +1 -1
  423. package/lib/components/upload/index.js +1 -1
  424. package/lib/components/upload/src/upload-list.js +155 -27
  425. package/lib/components/upload/src/upload-list.js.map +1 -1
  426. package/lib/components/upload/src/upload-list2.js +27 -155
  427. package/lib/components/upload/src/upload-list2.js.map +1 -1
  428. package/lib/components/upload/src/upload.js +1 -1
  429. package/lib/index.js +29 -29
  430. package/lib/version.d.ts +1 -1
  431. package/lib/version.js +1 -1
  432. package/lib/version.js.map +1 -1
  433. package/package.json +1 -1
  434. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"breadcrumb-item.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb-item.ts"],"sourcesContent":["import { buildProps, definePropType } from '@element-ps/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { RouteLocationRaw } from 'vue-router'\nimport type BreadcrumbItem from './breadcrumb-item.vue'\n\nexport const breadcrumbItemProps = buildProps({\n to: {\n type: definePropType<RouteLocationRaw>([String, Object]),\n default: '',\n },\n replace: {\n type: Boolean,\n default: false,\n },\n} as const)\nexport type BreadcrumbItemProps = ExtractPropTypes<typeof breadcrumbItemProps>\n\nexport type BreadcrumbItemInstance = InstanceType<typeof BreadcrumbItem>\n"],"names":[],"mappings":";;;AACY,MAAC,mBAAmB,GAAG,UAAU,CAAC;AAC9C,EAAE,EAAE,EAAE;AACN,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC1C,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"breadcrumb-item.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb-item.vue"],"sourcesContent":["<template>\n <span :class=\"ns.e('item')\">\n <span\n ref=\"link\"\n :class=\"[ns.e('inner'), ns.is('link', !!to)]\"\n role=\"link\"\n >\n <slot />\n </span>\n <ps-icon v-if=\"separatorIcon\" :class=\"ns.e('separator')\">\n <component :is=\"separatorIcon\" />\n </ps-icon>\n <span v-else :class=\"ns.e('separator')\" role=\"presentation\">\n {{ separator }}\n </span>\n </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { inject, ref } from 'vue'\nimport PsIcon from '@element-ps/components/icon'\nimport { breadcrumbKey } from '@element-ps/tokens'\nimport { useNamespace } from '@element-ps/hooks'\nimport type { BreadcrumbProps } from './breadcrumb'\n\ndefineOptions({\n name: 'PsBreadcrumbItem',\n})\n\nconst breadcrumbInjection = inject(breadcrumbKey, {} as BreadcrumbProps)!\n\nconst ns = useNamespace('breadcrumb')\n\nconst { separator, separatorIcon } = breadcrumbInjection\n\nconst link = ref<HTMLSpanElement>()\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;AA6BA,IAAA,MAAA,mBAAA,GAAA,MAAA,CAAA,aAAA,EAAA,EAAA,CAAA,CAAA;AAEA,IAAA,MAAA,EAAA,GAAA,aAAA,YAAA,CAAA,CAAA;AAEA,IAAA,MAAA,EAAA,WAAA,aAAA,EAAA,GAAA,mBAAA,CAAA;AAEA,IAAA,MAAA,OAAA,GAAA,EAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,51 +1,16 @@
1
- import { defineComponent, inject, ref, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, renderSlot, createBlock, withCtx, resolveDynamicComponent, toDisplayString } from 'vue';
2
- import { PsIcon } from '../../icon/index.mjs';
3
- import '../../../tokens/index.mjs';
4
- import '../../../hooks/index.mjs';
5
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
6
- import { breadcrumbKey } from '../../../tokens/breadcrumb.mjs';
7
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
1
+ import '../../../utils/index.mjs';
2
+ import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
8
3
 
9
- const __default__ = {
10
- name: "PsBreadcrumbItem"
11
- };
12
- const _sfc_main = /* @__PURE__ */ defineComponent({
13
- ...__default__,
14
- setup(__props) {
15
- const breadcrumbInjection = inject(breadcrumbKey, {});
16
- const ns = useNamespace("breadcrumb");
17
- const { separator, separatorIcon } = breadcrumbInjection;
18
- const link = ref();
19
- return (_ctx, _cache) => {
20
- return openBlock(), createElementBlock("span", {
21
- class: normalizeClass(unref(ns).e("item"))
22
- }, [
23
- createElementVNode("span", {
24
- ref_key: "link",
25
- ref: link,
26
- class: normalizeClass([unref(ns).e("inner"), unref(ns).is("link", !!_ctx.to)]),
27
- role: "link"
28
- }, [
29
- renderSlot(_ctx.$slots, "default")
30
- ], 2),
31
- unref(separatorIcon) ? (openBlock(), createBlock(unref(PsIcon), {
32
- key: 0,
33
- class: normalizeClass(unref(ns).e("separator"))
34
- }, {
35
- default: withCtx(() => [
36
- (openBlock(), createBlock(resolveDynamicComponent(unref(separatorIcon))))
37
- ]),
38
- _: 1
39
- }, 8, ["class"])) : (openBlock(), createElementBlock("span", {
40
- key: 1,
41
- class: normalizeClass(unref(ns).e("separator")),
42
- role: "presentation"
43
- }, toDisplayString(unref(separator)), 3))
44
- ], 2);
45
- };
4
+ const breadcrumbItemProps = buildProps({
5
+ to: {
6
+ type: definePropType([String, Object]),
7
+ default: ""
8
+ },
9
+ replace: {
10
+ type: Boolean,
11
+ default: false
46
12
  }
47
13
  });
48
- var BreadcrumbItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/breadcrumb/src/breadcrumb-item.vue"]]);
49
14
 
50
- export { BreadcrumbItem as default };
15
+ export { breadcrumbItemProps };
51
16
  //# sourceMappingURL=breadcrumb-item2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"breadcrumb-item2.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb-item.vue"],"sourcesContent":["<template>\n <span :class=\"ns.e('item')\">\n <span\n ref=\"link\"\n :class=\"[ns.e('inner'), ns.is('link', !!to)]\"\n role=\"link\"\n >\n <slot />\n </span>\n <ps-icon v-if=\"separatorIcon\" :class=\"ns.e('separator')\">\n <component :is=\"separatorIcon\" />\n </ps-icon>\n <span v-else :class=\"ns.e('separator')\" role=\"presentation\">\n {{ separator }}\n </span>\n </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { inject, ref } from 'vue'\nimport PsIcon from '@element-ps/components/icon'\nimport { breadcrumbKey } from '@element-ps/tokens'\nimport { useNamespace } from '@element-ps/hooks'\nimport type { BreadcrumbProps } from './breadcrumb'\n\ndefineOptions({\n name: 'PsBreadcrumbItem',\n})\n\nconst breadcrumbInjection = inject(breadcrumbKey, {} as BreadcrumbProps)!\n\nconst ns = useNamespace('breadcrumb')\n\nconst { separator, separatorIcon } = breadcrumbInjection\n\nconst link = ref<HTMLSpanElement>()\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;AA6BA,IAAA,MAAA,mBAAA,GAAA,MAAA,CAAA,aAAA,EAAA,EAAA,CAAA,CAAA;AAEA,IAAA,MAAA,EAAA,GAAA,aAAA,YAAA,CAAA,CAAA;AAEA,IAAA,MAAA,EAAA,WAAA,aAAA,EAAA,GAAA,mBAAA,CAAA;AAEA,IAAA,MAAA,OAAA,GAAA,EAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"breadcrumb-item2.mjs","sources":["../../../../../../packages/components/breadcrumb/src/breadcrumb-item.ts"],"sourcesContent":["import { buildProps, definePropType } from '@element-ps/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { RouteLocationRaw } from 'vue-router'\nimport type BreadcrumbItem from './breadcrumb-item.vue'\n\nexport const breadcrumbItemProps = buildProps({\n to: {\n type: definePropType<RouteLocationRaw>([String, Object]),\n default: '',\n },\n replace: {\n type: Boolean,\n default: false,\n },\n} as const)\nexport type BreadcrumbItemProps = ExtractPropTypes<typeof breadcrumbItemProps>\n\nexport type BreadcrumbItemInstance = InstanceType<typeof BreadcrumbItem>\n"],"names":[],"mappings":";;;AACY,MAAC,mBAAmB,GAAG,UAAU,CAAC;AAC9C,EAAE,EAAE,EAAE;AACN,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC1C,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,CAAC;;;;"}
@@ -3,7 +3,7 @@ import dayjs from 'dayjs';
3
3
  import { PsButtonGroup, PsButton } from '../../button/index.mjs';
4
4
  import '../../../hooks/index.mjs';
5
5
  import '../../../utils/index.mjs';
6
- import DateTable from './date-table2.mjs';
6
+ import DateTable from './date-table.mjs';
7
7
  import { calendarProps } from './calendar.mjs';
8
8
  import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
9
  import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
@@ -1,35 +1,154 @@
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, 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';
12
+ import { WEEK_DAYS } from '../../../constants/date.mjs';
5
13
 
6
- const getPrevMonthLastDays = (date, count) => {
7
- const lastDay = date.subtract(1, "month").endOf("month").date();
8
- return rangeArr(count).map((_, index) => lastDay - (count - index - 1));
14
+ const _hoisted_1 = { key: 0 };
15
+ const __default__ = {
16
+ name: "DateTable"
9
17
  };
10
- const getMonthDays = (date) => {
11
- const days = date.daysInMonth();
12
- return rangeArr(days).map((_, index) => index + 1);
13
- };
14
- const toNestedArr = (days) => rangeArr(days.length / 7).map((index) => {
15
- const start = index * 7;
16
- return days.slice(start, start + 7);
17
- });
18
- const dateTableProps = buildProps({
19
- selectedDay: {
20
- type: definePropType(Object)
21
- },
22
- range: {
23
- type: definePropType(Array)
24
- },
25
- date: {
26
- type: definePropType(Object),
27
- required: true
28
- },
29
- hideHeader: {
30
- type: Boolean
18
+ const _sfc_main = /* @__PURE__ */ defineComponent({
19
+ ...__default__,
20
+ props: dateTableProps,
21
+ setup(__props, { expose }) {
22
+ const props = __props;
23
+ dayjs.extend(localeData);
24
+ const { t, lang } = useLocale();
25
+ const nsTable = useNamespace("calendar-table");
26
+ const nsDay = useNamespace("calendar-day");
27
+ const now = dayjs().locale(lang.value);
28
+ const firstDayOfWeek = now.$locale().weekStart || 0;
29
+ const isInRange = computed(() => !!props.range && !!props.range.length);
30
+ const rows = computed(() => {
31
+ let days = [];
32
+ if (isInRange.value) {
33
+ const [start, end] = props.range;
34
+ const currentMonthRange = rangeArr(end.date() - start.date() + 1).map((index) => ({
35
+ text: start.date() + index,
36
+ type: "current"
37
+ }));
38
+ let remaining = currentMonthRange.length % 7;
39
+ remaining = remaining === 0 ? 0 : 7 - remaining;
40
+ const nextMonthRange = rangeArr(remaining).map((_, index) => ({
41
+ text: index + 1,
42
+ type: "next"
43
+ }));
44
+ days = currentMonthRange.concat(nextMonthRange);
45
+ } else {
46
+ const firstDay = props.date.startOf("month").day();
47
+ const prevMonthDays = getPrevMonthLastDays(props.date, firstDay - firstDayOfWeek).map((day) => ({
48
+ text: day,
49
+ type: "prev"
50
+ }));
51
+ const currentMonthDays = getMonthDays(props.date).map((day) => ({
52
+ text: day,
53
+ type: "current"
54
+ }));
55
+ days = [...prevMonthDays, ...currentMonthDays];
56
+ const remaining = 7 - (days.length % 7 || 7);
57
+ const nextMonthDays = rangeArr(remaining).map((_, index) => ({
58
+ text: index + 1,
59
+ type: "next"
60
+ }));
61
+ days = days.concat(nextMonthDays);
62
+ }
63
+ return toNestedArr(days);
64
+ });
65
+ const weekDays = computed(() => {
66
+ const start = firstDayOfWeek;
67
+ if (start === 0) {
68
+ return WEEK_DAYS.map((_) => t(`el.datepicker.weeks.${_}`));
69
+ } else {
70
+ return WEEK_DAYS.slice(start).concat(WEEK_DAYS.slice(0, start)).map((_) => t(`el.datepicker.weeks.${_}`));
71
+ }
72
+ });
73
+ const getFormattedDate = (day, type) => {
74
+ switch (type) {
75
+ case "prev":
76
+ return props.date.startOf("month").subtract(1, "month").date(day);
77
+ case "next":
78
+ return props.date.startOf("month").add(1, "month").date(day);
79
+ case "current":
80
+ return props.date.date(day);
81
+ }
82
+ };
83
+ const getCellClass = ({ text, type }) => {
84
+ const classes = [type];
85
+ if (type === "current") {
86
+ const date = getFormattedDate(text, type);
87
+ if (date.isSame(props.selectedDay, "day")) {
88
+ classes.push(nsDay.is("selected"));
89
+ }
90
+ if (date.isSame(now, "day")) {
91
+ classes.push(nsDay.is("today"));
92
+ }
93
+ }
94
+ return classes;
95
+ };
96
+ const getSlotData = ({ text, type }) => {
97
+ const day = getFormattedDate(text, type);
98
+ return {
99
+ isSelected: day.isSame(props.selectedDay),
100
+ type: `${type}-month`,
101
+ day: day.format("YYYY-MM-DD"),
102
+ date: day.toDate()
103
+ };
104
+ };
105
+ expose({
106
+ getFormattedDate
107
+ });
108
+ return (_ctx, _cache) => {
109
+ return openBlock(), createElementBlock("table", {
110
+ class: normalizeClass([unref(nsTable).b(), unref(nsTable).is("range", unref(isInRange))]),
111
+ cellspacing: "0",
112
+ cellpadding: "0"
113
+ }, [
114
+ !_ctx.hideHeader ? (openBlock(), createElementBlock("thead", _hoisted_1, [
115
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(weekDays), (day) => {
116
+ return openBlock(), createElementBlock("th", { key: day }, toDisplayString(day), 1);
117
+ }), 128))
118
+ ])) : createCommentVNode("v-if", true),
119
+ createElementVNode("tbody", null, [
120
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(rows), (row, index) => {
121
+ return openBlock(), createElementBlock("tr", {
122
+ key: index,
123
+ class: normalizeClass({
124
+ [unref(nsTable).e("row")]: true,
125
+ [unref(nsTable).em("row", "hide-border")]: index === 0 && _ctx.hideHeader
126
+ })
127
+ }, [
128
+ (openBlock(true), createElementBlock(Fragment, null, renderList(row, (cell, key) => {
129
+ return openBlock(), createElementBlock("td", {
130
+ key,
131
+ class: normalizeClass(getCellClass(cell))
132
+ }, [
133
+ createElementVNode("div", {
134
+ class: normalizeClass(unref(nsDay).b())
135
+ }, [
136
+ renderSlot(_ctx.$slots, "dateCell", {
137
+ data: getSlotData(cell)
138
+ }, () => [
139
+ createElementVNode("span", null, toDisplayString(cell.text), 1)
140
+ ])
141
+ ], 2)
142
+ ], 2);
143
+ }), 128))
144
+ ], 2);
145
+ }), 128))
146
+ ])
147
+ ], 2);
148
+ };
31
149
  }
32
150
  });
151
+ var DateTable = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/calendar/src/date-table.vue"]]);
33
152
 
34
- export { dateTableProps, getMonthDays, getPrevMonthLastDays, toNestedArr };
153
+ export { DateTable as default };
35
154
  //# 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-ps/utils'\nimport { rangeArr } from '@element-ps/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 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;;;;"}
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 >\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-ps/hooks'\nimport { rangeArr } from '@element-ps/components/time-picker'\nimport { WEEK_DAYS } from '@element-ps/constants'\nimport {\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)\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()\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 remaining = 7 - (days.length % 7 || 7)\n const nextMonthDays: CalendarDateCell[] = rangeArr(remaining).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 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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"}
@@ -1,154 +1,35 @@
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';
1
+ import '../../../utils/index.mjs';
5
2
  import '../../time-picker/index.mjs';
6
- import '../../../constants/index.mjs';
7
- import { dateTableProps, getPrevMonthLastDays, getMonthDays, toNestedArr } from './date-table.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';
11
3
  import { rangeArr } from '../../time-picker/src/common/date-utils.mjs';
12
- import { WEEK_DAYS } from '../../../constants/date.mjs';
4
+ import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
13
5
 
14
- const _hoisted_1 = { key: 0 };
15
- const __default__ = {
16
- name: "DateTable"
6
+ const getPrevMonthLastDays = (date, count) => {
7
+ const lastDay = date.subtract(1, "month").endOf("month").date();
8
+ return rangeArr(count).map((_, index) => lastDay - (count - index - 1));
17
9
  };
18
- const _sfc_main = /* @__PURE__ */ defineComponent({
19
- ...__default__,
20
- props: dateTableProps,
21
- setup(__props, { expose }) {
22
- const props = __props;
23
- dayjs.extend(localeData);
24
- const { t, lang } = useLocale();
25
- const nsTable = useNamespace("calendar-table");
26
- const nsDay = useNamespace("calendar-day");
27
- const now = dayjs().locale(lang.value);
28
- const firstDayOfWeek = now.$locale().weekStart || 0;
29
- const isInRange = computed(() => !!props.range && !!props.range.length);
30
- const rows = computed(() => {
31
- let days = [];
32
- if (isInRange.value) {
33
- const [start, end] = props.range;
34
- const currentMonthRange = rangeArr(end.date() - start.date() + 1).map((index) => ({
35
- text: start.date() + index,
36
- type: "current"
37
- }));
38
- let remaining = currentMonthRange.length % 7;
39
- remaining = remaining === 0 ? 0 : 7 - remaining;
40
- const nextMonthRange = rangeArr(remaining).map((_, index) => ({
41
- text: index + 1,
42
- type: "next"
43
- }));
44
- days = currentMonthRange.concat(nextMonthRange);
45
- } else {
46
- const firstDay = props.date.startOf("month").day();
47
- const prevMonthDays = getPrevMonthLastDays(props.date, firstDay - firstDayOfWeek).map((day) => ({
48
- text: day,
49
- type: "prev"
50
- }));
51
- const currentMonthDays = getMonthDays(props.date).map((day) => ({
52
- text: day,
53
- type: "current"
54
- }));
55
- days = [...prevMonthDays, ...currentMonthDays];
56
- const remaining = 7 - (days.length % 7 || 7);
57
- const nextMonthDays = rangeArr(remaining).map((_, index) => ({
58
- text: index + 1,
59
- type: "next"
60
- }));
61
- days = days.concat(nextMonthDays);
62
- }
63
- return toNestedArr(days);
64
- });
65
- const weekDays = computed(() => {
66
- const start = firstDayOfWeek;
67
- if (start === 0) {
68
- return WEEK_DAYS.map((_) => t(`el.datepicker.weeks.${_}`));
69
- } else {
70
- return WEEK_DAYS.slice(start).concat(WEEK_DAYS.slice(0, start)).map((_) => t(`el.datepicker.weeks.${_}`));
71
- }
72
- });
73
- const getFormattedDate = (day, type) => {
74
- switch (type) {
75
- case "prev":
76
- return props.date.startOf("month").subtract(1, "month").date(day);
77
- case "next":
78
- return props.date.startOf("month").add(1, "month").date(day);
79
- case "current":
80
- return props.date.date(day);
81
- }
82
- };
83
- const getCellClass = ({ text, type }) => {
84
- const classes = [type];
85
- if (type === "current") {
86
- const date = getFormattedDate(text, type);
87
- if (date.isSame(props.selectedDay, "day")) {
88
- classes.push(nsDay.is("selected"));
89
- }
90
- if (date.isSame(now, "day")) {
91
- classes.push(nsDay.is("today"));
92
- }
93
- }
94
- return classes;
95
- };
96
- const getSlotData = ({ text, type }) => {
97
- const day = getFormattedDate(text, type);
98
- return {
99
- isSelected: day.isSame(props.selectedDay),
100
- type: `${type}-month`,
101
- day: day.format("YYYY-MM-DD"),
102
- date: day.toDate()
103
- };
104
- };
105
- expose({
106
- getFormattedDate
107
- });
108
- return (_ctx, _cache) => {
109
- return openBlock(), createElementBlock("table", {
110
- class: normalizeClass([unref(nsTable).b(), unref(nsTable).is("range", unref(isInRange))]),
111
- cellspacing: "0",
112
- cellpadding: "0"
113
- }, [
114
- !_ctx.hideHeader ? (openBlock(), createElementBlock("thead", _hoisted_1, [
115
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(weekDays), (day) => {
116
- return openBlock(), createElementBlock("th", { key: day }, toDisplayString(day), 1);
117
- }), 128))
118
- ])) : createCommentVNode("v-if", true),
119
- createElementVNode("tbody", null, [
120
- (openBlock(true), createElementBlock(Fragment, null, renderList(unref(rows), (row, index) => {
121
- return openBlock(), createElementBlock("tr", {
122
- key: index,
123
- class: normalizeClass({
124
- [unref(nsTable).e("row")]: true,
125
- [unref(nsTable).em("row", "hide-border")]: index === 0 && _ctx.hideHeader
126
- })
127
- }, [
128
- (openBlock(true), createElementBlock(Fragment, null, renderList(row, (cell, key) => {
129
- return openBlock(), createElementBlock("td", {
130
- key,
131
- class: normalizeClass(getCellClass(cell))
132
- }, [
133
- createElementVNode("div", {
134
- class: normalizeClass(unref(nsDay).b())
135
- }, [
136
- renderSlot(_ctx.$slots, "dateCell", {
137
- data: getSlotData(cell)
138
- }, () => [
139
- createElementVNode("span", null, toDisplayString(cell.text), 1)
140
- ])
141
- ], 2)
142
- ], 2);
143
- }), 128))
144
- ], 2);
145
- }), 128))
146
- ])
147
- ], 2);
148
- };
10
+ const getMonthDays = (date) => {
11
+ const days = date.daysInMonth();
12
+ return rangeArr(days).map((_, index) => index + 1);
13
+ };
14
+ const toNestedArr = (days) => rangeArr(days.length / 7).map((index) => {
15
+ const start = index * 7;
16
+ return days.slice(start, start + 7);
17
+ });
18
+ const dateTableProps = buildProps({
19
+ selectedDay: {
20
+ type: definePropType(Object)
21
+ },
22
+ range: {
23
+ type: definePropType(Array)
24
+ },
25
+ date: {
26
+ type: definePropType(Object),
27
+ required: true
28
+ },
29
+ hideHeader: {
30
+ type: Boolean
149
31
  }
150
32
  });
151
- var DateTable = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/calendar/src/date-table.vue"]]);
152
33
 
153
- export { DateTable as default };
34
+ export { dateTableProps, getMonthDays, getPrevMonthLastDays, toNestedArr };
154
35
  //# sourceMappingURL=date-table2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"date-table2.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 >\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-ps/hooks'\nimport { rangeArr } from '@element-ps/components/time-picker'\nimport { WEEK_DAYS } from '@element-ps/constants'\nimport {\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)\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()\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 remaining = 7 - (days.length % 7 || 7)\n const nextMonthDays: CalendarDateCell[] = rangeArr(remaining).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 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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"}
1
+ {"version":3,"file":"date-table2.mjs","sources":["../../../../../../packages/components/calendar/src/date-table.ts"],"sourcesContent":["import { buildProps, definePropType, isObject } from '@element-ps/utils'\nimport { rangeArr } from '@element-ps/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 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;;;;"}
@@ -1,6 +1,6 @@
1
1
  import '../../utils/index.mjs';
2
- import Card from './src/card.mjs';
3
- export { cardProps } from './src/card2.mjs';
2
+ import Card from './src/card2.mjs';
3
+ export { cardProps } from './src/card.mjs';
4
4
  import { withInstall } from '../../utils/vue/install.mjs';
5
5
 
6
6
  const PsCard = withInstall(Card);
@@ -1,40 +1,20 @@
1
- import { defineComponent, openBlock, createElementBlock, normalizeClass, unref, renderSlot, createTextVNode, toDisplayString, createCommentVNode, createElementVNode, normalizeStyle } from 'vue';
2
- import '../../../hooks/index.mjs';
3
- import { cardProps } from './card2.mjs';
4
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
5
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
1
+ import '../../../utils/index.mjs';
2
+ import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
6
3
 
7
- const __default__ = {
8
- name: "PsCard"
9
- };
10
- const _sfc_main = /* @__PURE__ */ defineComponent({
11
- ...__default__,
12
- props: cardProps,
13
- setup(__props) {
14
- const ns = useNamespace("card");
15
- return (_ctx, _cache) => {
16
- return openBlock(), createElementBlock("div", {
17
- class: normalizeClass([unref(ns).b(), unref(ns).is(`${_ctx.shadow}-shadow`)])
18
- }, [
19
- _ctx.$slots.header || _ctx.header ? (openBlock(), createElementBlock("div", {
20
- key: 0,
21
- class: normalizeClass(unref(ns).e("header"))
22
- }, [
23
- renderSlot(_ctx.$slots, "header", {}, () => [
24
- createTextVNode(toDisplayString(_ctx.header), 1)
25
- ])
26
- ], 2)) : createCommentVNode("v-if", true),
27
- createElementVNode("div", {
28
- class: normalizeClass(unref(ns).e("body")),
29
- style: normalizeStyle(_ctx.bodyStyle)
30
- }, [
31
- renderSlot(_ctx.$slots, "default")
32
- ], 6)
33
- ], 2);
34
- };
4
+ const cardProps = buildProps({
5
+ header: {
6
+ type: String,
7
+ default: ""
8
+ },
9
+ bodyStyle: {
10
+ type: definePropType([String, Object, Array]),
11
+ default: ""
12
+ },
13
+ shadow: {
14
+ type: String,
15
+ default: "always"
35
16
  }
36
17
  });
37
- var Card = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/card/src/card.vue"]]);
38
18
 
39
- export { Card as default };
19
+ export { cardProps };
40
20
  //# sourceMappingURL=card.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"card.mjs","sources":["../../../../../../packages/components/card/src/card.vue"],"sourcesContent":["<template>\n <div :class=\"[ns.b(), ns.is(`${shadow}-shadow`)]\">\n <div v-if=\"$slots.header || header\" :class=\"ns.e('header')\">\n <slot name=\"header\">{{ header }}</slot>\n </div>\n <div :class=\"ns.e('body')\" :style=\"bodyStyle\">\n <slot />\n </div>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-ps/hooks'\nimport { cardProps } from './card'\n\ndefineOptions({\n name: 'PsCard',\n})\n\ndefineProps(cardProps)\n\nconst ns = useNamespace('card')\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;AAoBA,IAAA,MAAA,EAAA,GAAA,aAAA,MAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"card.mjs","sources":["../../../../../../packages/components/card/src/card.ts"],"sourcesContent":["import { buildProps, definePropType } from '@element-ps/utils'\nimport type Card from './card.vue'\nimport type { ExtractPropTypes, StyleValue } from 'vue'\n\nexport const cardProps = buildProps({\n header: {\n type: String,\n default: '',\n },\n bodyStyle: {\n type: definePropType<StyleValue>([String, Object, Array]),\n default: '',\n },\n shadow: {\n type: String,\n default: 'always',\n },\n} as const)\nexport type CardProps = ExtractPropTypes<typeof cardProps>\nexport type CardInstance = InstanceType<typeof Card>\n"],"names":[],"mappings":";;;AACY,MAAC,SAAS,GAAG,UAAU,CAAC;AACpC,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AACjD,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,QAAQ;AACrB,GAAG;AACH,CAAC;;;;"}