element-ps 2.0.13 → 2.0.14

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 (584) hide show
  1. package/dist/index.full.js +1805 -1282
  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 +1808 -1286
  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/alert/index.mjs +2 -2
  16. package/es/components/alert/src/alert.mjs +83 -33
  17. package/es/components/alert/src/alert.mjs.map +1 -1
  18. package/es/components/alert/src/alert2.mjs +33 -83
  19. package/es/components/alert/src/alert2.mjs.map +1 -1
  20. package/es/components/autocomplete/index.d.ts +3 -3
  21. package/es/components/autocomplete/index.mjs +2 -2
  22. package/es/components/autocomplete/src/autocomplete.mjs +58 -96
  23. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  24. package/es/components/autocomplete/src/autocomplete.vue.d.ts +8 -8
  25. package/es/components/autocomplete/src/autocomplete2.mjs +94 -58
  26. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  27. package/es/components/backtop/src/backtop2.mjs +16 -24
  28. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  29. package/es/components/badge/index.mjs +2 -2
  30. package/es/components/badge/src/badge.mjs +54 -17
  31. package/es/components/badge/src/badge.mjs.map +1 -1
  32. package/es/components/badge/src/badge2.mjs +17 -54
  33. package/es/components/badge/src/badge2.mjs.map +1 -1
  34. package/es/components/breadcrumb/index.mjs +4 -4
  35. package/es/components/breadcrumb/src/breadcrumb-item.mjs +46 -11
  36. package/es/components/breadcrumb/src/breadcrumb-item.mjs.map +1 -1
  37. package/es/components/breadcrumb/src/breadcrumb-item2.mjs +11 -46
  38. package/es/components/breadcrumb/src/breadcrumb-item2.mjs.map +1 -1
  39. package/es/components/breadcrumb/src/breadcrumb.mjs +12 -37
  40. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  41. package/es/components/breadcrumb/src/breadcrumb2.mjs +37 -12
  42. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  43. package/es/components/button/index.mjs +2 -2
  44. package/es/components/button/src/button-group.mjs +1 -1
  45. package/es/components/button/src/button.mjs +96 -48
  46. package/es/components/button/src/button.mjs.map +1 -1
  47. package/es/components/button/src/button2.mjs +48 -96
  48. package/es/components/button/src/button2.mjs.map +1 -1
  49. package/es/components/calendar/index.mjs +2 -2
  50. package/es/components/calendar/src/calendar.mjs +9 -188
  51. package/es/components/calendar/src/calendar.mjs.map +1 -1
  52. package/es/components/calendar/src/calendar2.mjs +188 -9
  53. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  54. package/es/components/calendar/src/date-table.mjs +146 -27
  55. package/es/components/calendar/src/date-table.mjs.map +1 -1
  56. package/es/components/calendar/src/date-table2.mjs +27 -146
  57. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  58. package/es/components/card/index.mjs +2 -2
  59. package/es/components/card/src/card.mjs +35 -15
  60. package/es/components/card/src/card.mjs.map +1 -1
  61. package/es/components/card/src/card2.mjs +15 -35
  62. package/es/components/card/src/card2.mjs.map +1 -1
  63. package/es/components/carousel/src/carousel.mjs.map +1 -1
  64. package/es/components/carousel/src/carousel2.mjs +23 -49
  65. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  66. package/es/components/cascader/src/index.mjs +1 -1
  67. package/es/components/cascader-panel/index.d.ts +14 -0
  68. package/es/components/cascader-panel/src/config.mjs +1 -1
  69. package/es/components/cascader-panel/src/index.mjs +110 -6
  70. package/es/components/cascader-panel/src/index.mjs.map +1 -1
  71. package/es/components/cascader-panel/src/index.vue.d.ts +7 -0
  72. package/es/components/cascader-panel/src/menu.mjs +17 -2
  73. package/es/components/cascader-panel/src/menu.mjs.map +1 -1
  74. package/es/components/cascader-panel/src/node.mjs +120 -138
  75. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  76. package/es/components/cascader-panel/src/node.vue.d.ts +9 -2
  77. package/es/components/cascader-panel/src/node2.mjs +200 -120
  78. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  79. package/es/components/cascader-panel/src/store.mjs +1 -1
  80. package/es/components/cascader-panel/src/utils.mjs.map +1 -1
  81. package/es/components/check-tag/index.mjs +2 -2
  82. package/es/components/check-tag/src/check-tag.mjs +7 -20
  83. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  84. package/es/components/check-tag/src/check-tag2.mjs +20 -7
  85. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  86. package/es/components/checkbox/index.d.ts +2 -6
  87. package/es/components/checkbox/src/checkbox.mjs +5 -14
  88. package/es/components/checkbox/src/checkbox.mjs.map +1 -1
  89. package/es/components/checkbox/src/checkbox.vue.d.ts +2 -6
  90. package/es/components/checkbox/src/useCheckbox.d.ts +0 -1
  91. package/es/components/checkbox/src/useCheckbox.mjs +2 -26
  92. package/es/components/checkbox/src/useCheckbox.mjs.map +1 -1
  93. package/es/components/collapse/index.d.ts +2 -2
  94. package/es/components/collapse/src/collapse-item.vue.d.ts +1 -1
  95. package/es/components/collapse/src/collapse-item2.mjs +9 -9
  96. package/es/components/collapse/src/collapse-item2.mjs.map +1 -1
  97. package/es/components/descriptions/index.d.ts +2 -0
  98. package/es/components/descriptions/src/descriptions-cell.mjs +2 -1
  99. package/es/components/descriptions/src/descriptions-cell.mjs.map +1 -1
  100. package/es/components/descriptions/src/index.mjs +18 -9
  101. package/es/components/descriptions/src/index.mjs.map +1 -1
  102. package/es/components/descriptions/src/index.vue.d.ts +2 -0
  103. package/es/components/dialog/index.d.ts +97 -0
  104. package/es/components/dialog/src/dialog-content2.mjs +6 -4
  105. package/es/components/dialog/src/dialog-content2.mjs.map +1 -1
  106. package/es/components/dialog/src/dialog.mjs +44 -54
  107. package/es/components/dialog/src/dialog.mjs.map +1 -1
  108. package/es/components/dialog/src/dialog.vue.d.ts +97 -0
  109. package/es/components/dialog/src/use-dialog.d.ts +0 -1
  110. package/es/components/dialog/src/use-dialog.mjs +18 -22
  111. package/es/components/dialog/src/use-dialog.mjs.map +1 -1
  112. package/es/components/divider/index.mjs +2 -2
  113. package/es/components/divider/src/divider.mjs +17 -34
  114. package/es/components/divider/src/divider.mjs.map +1 -1
  115. package/es/components/divider/src/divider2.mjs +34 -17
  116. package/es/components/divider/src/divider2.mjs.map +1 -1
  117. package/es/components/drawer/index.d.ts +0 -1
  118. package/es/components/drawer/src/drawer.vue.d.ts +0 -1
  119. package/es/components/dropdown/index.mjs +2 -2
  120. package/es/components/dropdown/src/dropdown-item-impl.mjs +2 -2
  121. package/es/components/dropdown/src/dropdown-item.mjs +1 -1
  122. package/es/components/dropdown/src/dropdown-menu.mjs +2 -2
  123. package/es/components/dropdown/src/dropdown.mjs +109 -100
  124. package/es/components/dropdown/src/dropdown.mjs.map +1 -1
  125. package/es/components/dropdown/src/dropdown2.mjs +100 -109
  126. package/es/components/dropdown/src/dropdown2.mjs.map +1 -1
  127. package/es/components/form/index.mjs +2 -2
  128. package/es/components/form/src/form.mjs +40 -45
  129. package/es/components/form/src/form.mjs.map +1 -1
  130. package/es/components/form/src/form2.mjs +45 -40
  131. package/es/components/form/src/form2.mjs.map +1 -1
  132. package/es/components/icon/index.mjs +2 -2
  133. package/es/components/icon/src/icon.mjs +35 -8
  134. package/es/components/icon/src/icon.mjs.map +1 -1
  135. package/es/components/icon/src/icon2.mjs +8 -35
  136. package/es/components/icon/src/icon2.mjs.map +1 -1
  137. package/es/components/image/index.d.ts +10 -6
  138. package/es/components/image/src/image.d.ts +0 -1
  139. package/es/components/image/src/image.mjs +0 -4
  140. package/es/components/image/src/image.mjs.map +1 -1
  141. package/es/components/image/src/image.vue.d.ts +10 -6
  142. package/es/components/image/src/image2.mjs +31 -19
  143. package/es/components/image/src/image2.mjs.map +1 -1
  144. package/es/components/index.d.ts +1 -0
  145. package/es/components/index.mjs +33 -32
  146. package/es/components/index.mjs.map +1 -1
  147. package/es/components/input/index.mjs +2 -2
  148. package/es/components/input/src/input.mjs +296 -85
  149. package/es/components/input/src/input.mjs.map +1 -1
  150. package/es/components/input/src/input2.mjs +85 -296
  151. package/es/components/input/src/input2.mjs.map +1 -1
  152. package/es/components/input-number/index.mjs +2 -2
  153. package/es/components/input-number/src/input-number.mjs +171 -46
  154. package/es/components/input-number/src/input-number.mjs.map +1 -1
  155. package/es/components/input-number/src/input-number2.mjs +46 -171
  156. package/es/components/input-number/src/input-number2.mjs.map +1 -1
  157. package/es/components/link/index.d.ts +29 -2
  158. package/es/components/link/src/link.mjs +3 -0
  159. package/es/components/link/src/link.mjs.map +1 -1
  160. package/es/components/link/src/link.vue.d.ts +29 -2
  161. package/es/components/menu/index.mjs +2 -2
  162. package/es/components/menu/src/menu-item-group.mjs +4 -56
  163. package/es/components/menu/src/menu-item-group.mjs.map +1 -1
  164. package/es/components/menu/src/menu-item-group2.mjs +56 -4
  165. package/es/components/menu/src/menu-item-group2.mjs.map +1 -1
  166. package/es/components/menu/src/menu-item2.mjs +1 -9
  167. package/es/components/menu/src/menu-item2.mjs.map +1 -1
  168. package/es/components/popconfirm/src/popconfirm.mjs +1 -1
  169. package/es/components/popover/index.d.ts +2 -2
  170. package/es/components/popover/src/index.vue.d.ts +1 -1
  171. package/es/components/popover/src/popover.mjs +1 -1
  172. package/es/components/popper/index.mjs +4 -4
  173. package/es/components/popper/src/arrow.mjs +31 -7
  174. package/es/components/popper/src/arrow.mjs.map +1 -1
  175. package/es/components/popper/src/arrow2.mjs +7 -31
  176. package/es/components/popper/src/arrow2.mjs.map +1 -1
  177. package/es/components/popper/src/content.vue.d.ts +1 -1
  178. package/es/components/popper/src/trigger.mjs +17 -36
  179. package/es/components/popper/src/trigger.mjs.map +1 -1
  180. package/es/components/popper/src/trigger.vue.d.ts +0 -1
  181. package/es/components/popper/src/trigger2.mjs +28 -17
  182. package/es/components/popper/src/trigger2.mjs.map +1 -1
  183. package/es/components/progress/index.d.ts +3 -3
  184. package/es/components/progress/src/progress.d.ts +1 -1
  185. package/es/components/progress/src/progress.vue.d.ts +3 -3
  186. package/es/components/radio/index.mjs +2 -2
  187. package/es/components/radio/src/radio-button.mjs +1 -1
  188. package/es/components/radio/src/radio-button2.mjs +1 -1
  189. package/es/components/radio/src/radio.mjs +62 -74
  190. package/es/components/radio/src/radio.mjs.map +1 -1
  191. package/es/components/radio/src/radio2.mjs +74 -67
  192. package/es/components/radio/src/radio2.mjs.map +1 -1
  193. package/es/components/rate/index.mjs +2 -2
  194. package/es/components/rate/src/rate.mjs +169 -84
  195. package/es/components/rate/src/rate.mjs.map +1 -1
  196. package/es/components/rate/src/rate2.mjs +84 -169
  197. package/es/components/rate/src/rate2.mjs.map +1 -1
  198. package/es/components/result/index.mjs +2 -2
  199. package/es/components/result/src/result.mjs +73 -28
  200. package/es/components/result/src/result.mjs.map +1 -1
  201. package/es/components/result/src/result2.mjs +28 -73
  202. package/es/components/result/src/result2.mjs.map +1 -1
  203. package/es/components/roving-focus-group/index.mjs +3 -3
  204. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  205. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -29
  206. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  207. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +29 -27
  208. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  209. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  210. package/es/components/scrollbar/index.mjs +2 -2
  211. package/es/components/scrollbar/src/scrollbar.mjs +42 -112
  212. package/es/components/scrollbar/src/scrollbar.mjs.map +1 -1
  213. package/es/components/scrollbar/src/scrollbar2.mjs +112 -42
  214. package/es/components/scrollbar/src/scrollbar2.mjs.map +1 -1
  215. package/es/components/scrollbar/src/thumb.vue.d.ts +1 -1
  216. package/es/components/select/index.d.ts +4 -4
  217. package/es/components/select/src/select.mjs +1 -1
  218. package/es/components/select/src/select.vue.d.ts +4 -4
  219. package/es/components/select/src/useSelect.d.ts +3 -3
  220. package/es/components/select-v2/index.d.ts +8 -8
  221. package/es/components/select-v2/src/select.vue.d.ts +4 -4
  222. package/es/components/select-v2/src/useSelect.d.ts +3 -3
  223. package/es/components/skeleton/index.mjs +2 -2
  224. package/es/components/skeleton/src/skeleton-item.mjs +23 -18
  225. package/es/components/skeleton/src/skeleton-item.mjs.map +1 -1
  226. package/es/components/skeleton/src/skeleton-item2.mjs +18 -23
  227. package/es/components/skeleton/src/skeleton-item2.mjs.map +1 -1
  228. package/es/components/skeleton/src/skeleton.mjs +1 -1
  229. package/es/components/switch/index.d.ts +1 -1
  230. package/es/components/switch/index.mjs +2 -2
  231. package/es/components/switch/src/switch.mjs +176 -81
  232. package/es/components/switch/src/switch.mjs.map +1 -1
  233. package/es/components/switch/src/switch.vue.d.ts +1 -1
  234. package/es/components/switch/src/switch2.mjs +81 -176
  235. package/es/components/switch/src/switch2.mjs.map +1 -1
  236. package/es/components/table/index.d.ts +1 -1
  237. package/es/components/table/src/filter-panel.vue.d.ts +3 -3
  238. package/es/components/table/src/table.vue.d.ts +1 -1
  239. package/es/components/tabs/index.mjs +2 -2
  240. package/es/components/tabs/src/tab-pane.mjs +14 -60
  241. package/es/components/tabs/src/tab-pane.mjs.map +1 -1
  242. package/es/components/tabs/src/tab-pane2.mjs +60 -14
  243. package/es/components/tabs/src/tab-pane2.mjs.map +1 -1
  244. package/es/components/tag/index.mjs +2 -2
  245. package/es/components/tag/src/tag.mjs +33 -81
  246. package/es/components/tag/src/tag.mjs.map +1 -1
  247. package/es/components/tag/src/tag2.mjs +81 -33
  248. package/es/components/tag/src/tag2.mjs.map +1 -1
  249. package/es/components/text/index.d.ts +2 -0
  250. package/es/components/text/index.mjs +8 -0
  251. package/es/components/text/index.mjs.map +1 -0
  252. package/es/components/text/src/text.mjs +15 -0
  253. package/es/components/text/src/text.mjs.map +1 -0
  254. package/es/components/text/src/text.vue.d.ts +2 -0
  255. package/es/components/time-picker/src/common/picker.vue.d.ts +3 -3
  256. package/es/components/time-select/index.d.ts +4 -4
  257. package/es/components/time-select/src/time-select.vue.d.ts +2 -2
  258. package/es/components/timeline/index.mjs +2 -2
  259. package/es/components/timeline/src/timeline-item.mjs +39 -73
  260. package/es/components/timeline/src/timeline-item.mjs.map +1 -1
  261. package/es/components/timeline/src/timeline-item2.mjs +73 -39
  262. package/es/components/timeline/src/timeline-item2.mjs.map +1 -1
  263. package/es/components/tooltip/index.d.ts +1 -1
  264. package/es/components/tooltip/src/tooltip.mjs +1 -1
  265. package/es/components/tooltip/src/tooltip.vue.d.ts +1 -1
  266. package/es/components/tooltip/src/tooltip2.mjs +1 -1
  267. package/es/components/tooltip/src/trigger.mjs +1 -1
  268. package/es/components/tooltip-v2/index.mjs +1 -1
  269. package/es/components/tooltip-v2/src/arrow.mjs +22 -38
  270. package/es/components/tooltip-v2/src/arrow.mjs.map +1 -1
  271. package/es/components/tooltip-v2/src/arrow2.mjs +38 -22
  272. package/es/components/tooltip-v2/src/arrow2.mjs.map +1 -1
  273. package/es/components/tooltip-v2/src/tooltip.mjs +1 -1
  274. package/es/components/tooltip-v2/src/tooltip2.mjs +2 -2
  275. package/es/components/upload/index.d.ts +313 -0
  276. package/es/components/upload/index.mjs +4 -4
  277. package/es/components/upload/src/upload-content.mjs +46 -15
  278. package/es/components/upload/src/upload-content.mjs.map +1 -1
  279. package/es/components/upload/src/upload-content2.mjs +15 -46
  280. package/es/components/upload/src/upload-content2.mjs.map +1 -1
  281. package/es/components/upload/src/upload-list.mjs +26 -155
  282. package/es/components/upload/src/upload-list.mjs.map +1 -1
  283. package/es/components/upload/src/upload-list.vue.d.ts +3 -3
  284. package/es/components/upload/src/upload-list2.mjs +155 -26
  285. package/es/components/upload/src/upload-list2.mjs.map +1 -1
  286. package/es/components/upload/src/upload.mjs +106 -99
  287. package/es/components/upload/src/upload.mjs.map +1 -1
  288. package/es/components/upload/src/upload.vue.d.ts +313 -0
  289. package/es/components/upload/src/upload2.mjs +99 -106
  290. package/es/components/upload/src/upload2.mjs.map +1 -1
  291. package/es/components/virtual-list/src/builders/build-list.d.ts +1 -1
  292. package/es/components/virtual-list/src/components/dynamic-size-list.d.ts +1 -1
  293. package/es/components/virtual-list/src/components/fixed-size-list.d.ts +1 -1
  294. package/es/index.mjs +33 -32
  295. package/es/index.mjs.map +1 -1
  296. package/es/version.d.ts +1 -1
  297. package/es/version.mjs +1 -1
  298. package/es/version.mjs.map +1 -1
  299. package/lib/components/alert/index.js +2 -2
  300. package/lib/components/alert/src/alert.js +82 -33
  301. package/lib/components/alert/src/alert.js.map +1 -1
  302. package/lib/components/alert/src/alert2.js +33 -82
  303. package/lib/components/alert/src/alert2.js.map +1 -1
  304. package/lib/components/autocomplete/index.d.ts +3 -3
  305. package/lib/components/autocomplete/index.js +2 -2
  306. package/lib/components/autocomplete/src/autocomplete.js +58 -96
  307. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  308. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +8 -8
  309. package/lib/components/autocomplete/src/autocomplete2.js +94 -58
  310. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  311. package/lib/components/backtop/src/backtop2.js +15 -23
  312. package/lib/components/backtop/src/backtop2.js.map +1 -1
  313. package/lib/components/badge/index.js +2 -2
  314. package/lib/components/badge/src/badge.js +54 -17
  315. package/lib/components/badge/src/badge.js.map +1 -1
  316. package/lib/components/badge/src/badge2.js +17 -54
  317. package/lib/components/badge/src/badge2.js.map +1 -1
  318. package/lib/components/breadcrumb/index.js +4 -4
  319. package/lib/components/breadcrumb/src/breadcrumb-item.js +46 -11
  320. package/lib/components/breadcrumb/src/breadcrumb-item.js.map +1 -1
  321. package/lib/components/breadcrumb/src/breadcrumb-item2.js +11 -46
  322. package/lib/components/breadcrumb/src/breadcrumb-item2.js.map +1 -1
  323. package/lib/components/breadcrumb/src/breadcrumb.js +12 -37
  324. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  325. package/lib/components/breadcrumb/src/breadcrumb2.js +37 -12
  326. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  327. package/lib/components/button/index.js +2 -2
  328. package/lib/components/button/src/button-group.js +1 -1
  329. package/lib/components/button/src/button.js +96 -50
  330. package/lib/components/button/src/button.js.map +1 -1
  331. package/lib/components/button/src/button2.js +50 -96
  332. package/lib/components/button/src/button2.js.map +1 -1
  333. package/lib/components/calendar/index.js +2 -2
  334. package/lib/components/calendar/src/calendar.js +9 -192
  335. package/lib/components/calendar/src/calendar.js.map +1 -1
  336. package/lib/components/calendar/src/calendar2.js +192 -9
  337. package/lib/components/calendar/src/calendar2.js.map +1 -1
  338. package/lib/components/calendar/src/date-table.js +151 -30
  339. package/lib/components/calendar/src/date-table.js.map +1 -1
  340. package/lib/components/calendar/src/date-table2.js +30 -151
  341. package/lib/components/calendar/src/date-table2.js.map +1 -1
  342. package/lib/components/card/index.js +2 -2
  343. package/lib/components/card/src/card.js +35 -15
  344. package/lib/components/card/src/card.js.map +1 -1
  345. package/lib/components/card/src/card2.js +15 -35
  346. package/lib/components/card/src/card2.js.map +1 -1
  347. package/lib/components/carousel/src/carousel.js.map +1 -1
  348. package/lib/components/carousel/src/carousel2.js +22 -48
  349. package/lib/components/carousel/src/carousel2.js.map +1 -1
  350. package/lib/components/cascader/src/index.js +1 -1
  351. package/lib/components/cascader-panel/index.d.ts +14 -0
  352. package/lib/components/cascader-panel/src/config.js +1 -1
  353. package/lib/components/cascader-panel/src/index.js +117 -13
  354. package/lib/components/cascader-panel/src/index.js.map +1 -1
  355. package/lib/components/cascader-panel/src/index.vue.d.ts +7 -0
  356. package/lib/components/cascader-panel/src/menu.js +16 -1
  357. package/lib/components/cascader-panel/src/menu.js.map +1 -1
  358. package/lib/components/cascader-panel/src/node.js +121 -138
  359. package/lib/components/cascader-panel/src/node.js.map +1 -1
  360. package/lib/components/cascader-panel/src/node.vue.d.ts +9 -2
  361. package/lib/components/cascader-panel/src/node2.js +200 -121
  362. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  363. package/lib/components/cascader-panel/src/store.js +1 -1
  364. package/lib/components/cascader-panel/src/utils.js.map +1 -1
  365. package/lib/components/check-tag/index.js +2 -2
  366. package/lib/components/check-tag/src/check-tag.js +7 -20
  367. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  368. package/lib/components/check-tag/src/check-tag2.js +20 -7
  369. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  370. package/lib/components/checkbox/index.d.ts +2 -6
  371. package/lib/components/checkbox/src/checkbox.js +5 -14
  372. package/lib/components/checkbox/src/checkbox.js.map +1 -1
  373. package/lib/components/checkbox/src/checkbox.vue.d.ts +2 -6
  374. package/lib/components/checkbox/src/useCheckbox.d.ts +0 -1
  375. package/lib/components/checkbox/src/useCheckbox.js +1 -25
  376. package/lib/components/checkbox/src/useCheckbox.js.map +1 -1
  377. package/lib/components/collapse/index.d.ts +2 -2
  378. package/lib/components/collapse/src/collapse-item.vue.d.ts +1 -1
  379. package/lib/components/collapse/src/collapse-item2.js +8 -8
  380. package/lib/components/collapse/src/collapse-item2.js.map +1 -1
  381. package/lib/components/descriptions/index.d.ts +2 -0
  382. package/lib/components/descriptions/src/descriptions-cell.js +2 -1
  383. package/lib/components/descriptions/src/descriptions-cell.js.map +1 -1
  384. package/lib/components/descriptions/src/index.js +18 -9
  385. package/lib/components/descriptions/src/index.js.map +1 -1
  386. package/lib/components/descriptions/src/index.vue.d.ts +2 -0
  387. package/lib/components/dialog/index.d.ts +97 -0
  388. package/lib/components/dialog/src/dialog-content2.js +8 -6
  389. package/lib/components/dialog/src/dialog-content2.js.map +1 -1
  390. package/lib/components/dialog/src/dialog.js +43 -53
  391. package/lib/components/dialog/src/dialog.js.map +1 -1
  392. package/lib/components/dialog/src/dialog.vue.d.ts +97 -0
  393. package/lib/components/dialog/src/use-dialog.d.ts +0 -1
  394. package/lib/components/dialog/src/use-dialog.js +19 -23
  395. package/lib/components/dialog/src/use-dialog.js.map +1 -1
  396. package/lib/components/divider/index.js +2 -2
  397. package/lib/components/divider/src/divider.js +17 -34
  398. package/lib/components/divider/src/divider.js.map +1 -1
  399. package/lib/components/divider/src/divider2.js +34 -17
  400. package/lib/components/divider/src/divider2.js.map +1 -1
  401. package/lib/components/drawer/index.d.ts +0 -1
  402. package/lib/components/drawer/src/drawer.vue.d.ts +0 -1
  403. package/lib/components/dropdown/index.js +2 -2
  404. package/lib/components/dropdown/src/dropdown-item-impl.js +2 -2
  405. package/lib/components/dropdown/src/dropdown-item.js +1 -1
  406. package/lib/components/dropdown/src/dropdown-menu.js +2 -2
  407. package/lib/components/dropdown/src/dropdown.js +109 -109
  408. package/lib/components/dropdown/src/dropdown.js.map +1 -1
  409. package/lib/components/dropdown/src/dropdown2.js +109 -109
  410. package/lib/components/dropdown/src/dropdown2.js.map +1 -1
  411. package/lib/components/form/index.js +2 -2
  412. package/lib/components/form/src/form.js +40 -45
  413. package/lib/components/form/src/form.js.map +1 -1
  414. package/lib/components/form/src/form2.js +45 -40
  415. package/lib/components/form/src/form2.js.map +1 -1
  416. package/lib/components/icon/index.js +2 -2
  417. package/lib/components/icon/src/icon.js +35 -8
  418. package/lib/components/icon/src/icon.js.map +1 -1
  419. package/lib/components/icon/src/icon2.js +8 -35
  420. package/lib/components/icon/src/icon2.js.map +1 -1
  421. package/lib/components/image/index.d.ts +10 -6
  422. package/lib/components/image/src/image.d.ts +0 -1
  423. package/lib/components/image/src/image.js +0 -4
  424. package/lib/components/image/src/image.js.map +1 -1
  425. package/lib/components/image/src/image.vue.d.ts +10 -6
  426. package/lib/components/image/src/image2.js +35 -23
  427. package/lib/components/image/src/image2.js.map +1 -1
  428. package/lib/components/index.d.ts +1 -0
  429. package/lib/components/index.js +41 -39
  430. package/lib/components/index.js.map +1 -1
  431. package/lib/components/input/index.js +2 -2
  432. package/lib/components/input/src/input.js +295 -84
  433. package/lib/components/input/src/input.js.map +1 -1
  434. package/lib/components/input/src/input2.js +84 -295
  435. package/lib/components/input/src/input2.js.map +1 -1
  436. package/lib/components/input-number/index.js +2 -2
  437. package/lib/components/input-number/src/input-number.js +171 -46
  438. package/lib/components/input-number/src/input-number.js.map +1 -1
  439. package/lib/components/input-number/src/input-number2.js +46 -171
  440. package/lib/components/input-number/src/input-number2.js.map +1 -1
  441. package/lib/components/link/index.d.ts +29 -2
  442. package/lib/components/link/src/link.js +3 -0
  443. package/lib/components/link/src/link.js.map +1 -1
  444. package/lib/components/link/src/link.vue.d.ts +29 -2
  445. package/lib/components/menu/index.js +2 -2
  446. package/lib/components/menu/src/menu-item-group.js +4 -56
  447. package/lib/components/menu/src/menu-item-group.js.map +1 -1
  448. package/lib/components/menu/src/menu-item-group2.js +56 -4
  449. package/lib/components/menu/src/menu-item-group2.js.map +1 -1
  450. package/lib/components/menu/src/menu-item2.js +0 -8
  451. package/lib/components/menu/src/menu-item2.js.map +1 -1
  452. package/lib/components/popconfirm/src/popconfirm.js +1 -1
  453. package/lib/components/popover/index.d.ts +2 -2
  454. package/lib/components/popover/src/index.vue.d.ts +1 -1
  455. package/lib/components/popover/src/popover.js +1 -1
  456. package/lib/components/popper/index.js +4 -4
  457. package/lib/components/popper/src/arrow.js +31 -7
  458. package/lib/components/popper/src/arrow.js.map +1 -1
  459. package/lib/components/popper/src/arrow2.js +7 -31
  460. package/lib/components/popper/src/arrow2.js.map +1 -1
  461. package/lib/components/popper/src/content.vue.d.ts +1 -1
  462. package/lib/components/popper/src/trigger.js +17 -36
  463. package/lib/components/popper/src/trigger.js.map +1 -1
  464. package/lib/components/popper/src/trigger.vue.d.ts +0 -1
  465. package/lib/components/popper/src/trigger2.js +28 -17
  466. package/lib/components/popper/src/trigger2.js.map +1 -1
  467. package/lib/components/progress/index.d.ts +3 -3
  468. package/lib/components/progress/src/progress.d.ts +1 -1
  469. package/lib/components/progress/src/progress.vue.d.ts +3 -3
  470. package/lib/components/radio/index.js +2 -2
  471. package/lib/components/radio/src/radio-button.js +1 -1
  472. package/lib/components/radio/src/radio-button2.js +1 -1
  473. package/lib/components/radio/src/radio.js +64 -73
  474. package/lib/components/radio/src/radio.js.map +1 -1
  475. package/lib/components/radio/src/radio2.js +73 -69
  476. package/lib/components/radio/src/radio2.js.map +1 -1
  477. package/lib/components/rate/index.js +2 -2
  478. package/lib/components/rate/src/rate.js +169 -84
  479. package/lib/components/rate/src/rate.js.map +1 -1
  480. package/lib/components/rate/src/rate2.js +84 -169
  481. package/lib/components/rate/src/rate2.js.map +1 -1
  482. package/lib/components/result/index.js +2 -2
  483. package/lib/components/result/src/result.js +73 -30
  484. package/lib/components/result/src/result.js.map +1 -1
  485. package/lib/components/result/src/result2.js +30 -73
  486. package/lib/components/result/src/result2.js.map +1 -1
  487. package/lib/components/roving-focus-group/index.js +2 -2
  488. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  489. package/lib/components/roving-focus-group/src/roving-focus-group.js +27 -33
  490. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  491. package/lib/components/roving-focus-group/src/roving-focus-group2.js +33 -27
  492. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  493. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  494. package/lib/components/scrollbar/index.js +2 -2
  495. package/lib/components/scrollbar/src/scrollbar.js +42 -112
  496. package/lib/components/scrollbar/src/scrollbar.js.map +1 -1
  497. package/lib/components/scrollbar/src/scrollbar2.js +112 -42
  498. package/lib/components/scrollbar/src/scrollbar2.js.map +1 -1
  499. package/lib/components/scrollbar/src/thumb.vue.d.ts +1 -1
  500. package/lib/components/select/index.d.ts +4 -4
  501. package/lib/components/select/src/select.js +1 -1
  502. package/lib/components/select/src/select.vue.d.ts +4 -4
  503. package/lib/components/select/src/useSelect.d.ts +3 -3
  504. package/lib/components/select-v2/index.d.ts +8 -8
  505. package/lib/components/select-v2/src/select.vue.d.ts +4 -4
  506. package/lib/components/select-v2/src/useSelect.d.ts +3 -3
  507. package/lib/components/skeleton/index.js +2 -2
  508. package/lib/components/skeleton/src/skeleton-item.js +23 -18
  509. package/lib/components/skeleton/src/skeleton-item.js.map +1 -1
  510. package/lib/components/skeleton/src/skeleton-item2.js +18 -23
  511. package/lib/components/skeleton/src/skeleton-item2.js.map +1 -1
  512. package/lib/components/skeleton/src/skeleton.js +1 -1
  513. package/lib/components/switch/index.d.ts +1 -1
  514. package/lib/components/switch/index.js +2 -2
  515. package/lib/components/switch/src/switch.js +176 -81
  516. package/lib/components/switch/src/switch.js.map +1 -1
  517. package/lib/components/switch/src/switch.vue.d.ts +1 -1
  518. package/lib/components/switch/src/switch2.js +81 -176
  519. package/lib/components/switch/src/switch2.js.map +1 -1
  520. package/lib/components/table/index.d.ts +1 -1
  521. package/lib/components/table/src/filter-panel.vue.d.ts +3 -3
  522. package/lib/components/table/src/table.vue.d.ts +1 -1
  523. package/lib/components/tabs/index.js +2 -2
  524. package/lib/components/tabs/src/tab-pane.js +14 -60
  525. package/lib/components/tabs/src/tab-pane.js.map +1 -1
  526. package/lib/components/tabs/src/tab-pane2.js +60 -14
  527. package/lib/components/tabs/src/tab-pane2.js.map +1 -1
  528. package/lib/components/tag/index.js +2 -2
  529. package/lib/components/tag/src/tag.js +34 -81
  530. package/lib/components/tag/src/tag.js.map +1 -1
  531. package/lib/components/tag/src/tag2.js +81 -34
  532. package/lib/components/tag/src/tag2.js.map +1 -1
  533. package/lib/components/text/index.d.ts +2 -0
  534. package/lib/components/text/index.js +13 -0
  535. package/lib/components/text/index.js.map +1 -0
  536. package/lib/components/text/src/text.js +19 -0
  537. package/lib/components/text/src/text.js.map +1 -0
  538. package/lib/components/text/src/text.vue.d.ts +2 -0
  539. package/lib/components/time-picker/src/common/picker.vue.d.ts +3 -3
  540. package/lib/components/time-select/index.d.ts +4 -4
  541. package/lib/components/time-select/src/time-select.vue.d.ts +2 -2
  542. package/lib/components/timeline/index.js +2 -2
  543. package/lib/components/timeline/src/timeline-item.js +39 -73
  544. package/lib/components/timeline/src/timeline-item.js.map +1 -1
  545. package/lib/components/timeline/src/timeline-item2.js +73 -39
  546. package/lib/components/timeline/src/timeline-item2.js.map +1 -1
  547. package/lib/components/tooltip/index.d.ts +1 -1
  548. package/lib/components/tooltip/src/tooltip.js +1 -1
  549. package/lib/components/tooltip/src/tooltip.vue.d.ts +1 -1
  550. package/lib/components/tooltip/src/tooltip2.js +1 -1
  551. package/lib/components/tooltip/src/trigger.js +1 -1
  552. package/lib/components/tooltip-v2/index.js +1 -1
  553. package/lib/components/tooltip-v2/src/arrow.js +23 -38
  554. package/lib/components/tooltip-v2/src/arrow.js.map +1 -1
  555. package/lib/components/tooltip-v2/src/arrow2.js +38 -23
  556. package/lib/components/tooltip-v2/src/arrow2.js.map +1 -1
  557. package/lib/components/tooltip-v2/src/tooltip.js +1 -1
  558. package/lib/components/tooltip-v2/src/tooltip2.js +2 -2
  559. package/lib/components/upload/index.d.ts +313 -0
  560. package/lib/components/upload/index.js +4 -4
  561. package/lib/components/upload/src/upload-content.js +46 -15
  562. package/lib/components/upload/src/upload-content.js.map +1 -1
  563. package/lib/components/upload/src/upload-content2.js +15 -46
  564. package/lib/components/upload/src/upload-content2.js.map +1 -1
  565. package/lib/components/upload/src/upload-list.js +27 -155
  566. package/lib/components/upload/src/upload-list.js.map +1 -1
  567. package/lib/components/upload/src/upload-list.vue.d.ts +3 -3
  568. package/lib/components/upload/src/upload-list2.js +155 -27
  569. package/lib/components/upload/src/upload-list2.js.map +1 -1
  570. package/lib/components/upload/src/upload.js +109 -99
  571. package/lib/components/upload/src/upload.js.map +1 -1
  572. package/lib/components/upload/src/upload.vue.d.ts +313 -0
  573. package/lib/components/upload/src/upload2.js +99 -109
  574. package/lib/components/upload/src/upload2.js.map +1 -1
  575. package/lib/components/virtual-list/src/builders/build-list.d.ts +1 -1
  576. package/lib/components/virtual-list/src/components/dynamic-size-list.d.ts +1 -1
  577. package/lib/components/virtual-list/src/components/fixed-size-list.d.ts +1 -1
  578. package/lib/index.js +128 -126
  579. package/lib/index.js.map +1 -1
  580. package/lib/version.d.ts +1 -1
  581. package/lib/version.js +1 -1
  582. package/lib/version.js.map +1 -1
  583. package/package.json +3 -3
  584. package/web-types.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"card2.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":"card2.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;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"carousel.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.ts"],"sourcesContent":["import { buildProps, isNumber } from '@element-ps/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Carousel from './carousel.vue'\n\nexport const carouselProps = buildProps({\n initialIndex: {\n type: Number,\n default: 0,\n },\n height: { type: String, default: '' },\n trigger: {\n type: String,\n default: 'hover',\n },\n autoplay: {\n type: Boolean,\n default: true,\n },\n interval: {\n type: Number,\n default: 3000,\n },\n indicatorPosition: { type: String, default: '' },\n indicator: {\n type: Boolean,\n default: true,\n },\n arrow: {\n type: String,\n default: 'hover',\n },\n type: { type: String, default: '' },\n loop: {\n type: Boolean,\n default: true,\n },\n direction: {\n type: String,\n default: 'horizontal',\n validator(val: string) {\n return ['horizontal', 'vertical'].includes(val)\n },\n },\n pauseOnHover: {\n type: Boolean,\n default: true,\n },\n} as const)\n\nexport type CarouselProps = ExtractPropTypes<typeof carouselProps>\n\nexport type CarouselInstance = InstanceType<typeof Carousel>\n"],"names":[],"mappings":";;;AACY,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AACvC,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,iBAAiB,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AAClD,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AACrC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,YAAY;AACzB,IAAI,SAAS,CAAC,GAAG,EAAE;AACnB,MAAM,OAAO,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AACtD,KAAK;AACL,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"carousel.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.ts"],"sourcesContent":["import { buildProps } from '@element-ps/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Carousel from './carousel.vue'\n\nexport const carouselProps = buildProps({\n initialIndex: {\n type: Number,\n default: 0,\n },\n height: { type: String, default: '' },\n trigger: {\n type: String,\n default: 'hover',\n },\n autoplay: {\n type: Boolean,\n default: true,\n },\n interval: {\n type: Number,\n default: 3000,\n },\n indicatorPosition: { type: String, default: '' },\n indicator: {\n type: Boolean,\n default: true,\n },\n arrow: {\n type: String,\n default: 'hover',\n },\n type: { type: String, default: '' },\n loop: {\n type: Boolean,\n default: true,\n },\n direction: {\n type: String,\n default: 'horizontal',\n validator(val: string) {\n return ['horizontal', 'vertical'].includes(val)\n },\n },\n pauseOnHover: {\n type: Boolean,\n default: true,\n },\n} as const)\n\nexport type CarouselProps = ExtractPropTypes<typeof carouselProps>\n\nexport type CarouselInstance = InstanceType<typeof Carousel>\n"],"names":[],"mappings":";;;AACY,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,CAAC;AACd,GAAG;AACH,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AACvC,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,GAAG;AAChB,GAAG;AACH,EAAE,iBAAiB,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AAClD,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,GAAG;AACH,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;AACrC,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,YAAY;AACzB,IAAI,SAAS,CAAC,GAAG,EAAE;AACnB,MAAM,OAAO,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AACtD,KAAK;AACL,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,CAAC;;;;"}
@@ -1,4 +1,4 @@
1
- import { defineComponent, ref, computed, unref, shallowRef, onMounted, nextTick, onBeforeUnmount, provide, openBlock, createElementBlock, normalizeClass, createElementVNode, normalizeStyle, createBlock, Transition, withCtx, withDirectives, createVNode, vShow, createCommentVNode, renderSlot, Fragment, renderList, toDisplayString } from 'vue';
1
+ import { defineComponent, ref, computed, unref, shallowRef, onMounted, nextTick, onBeforeUnmount, provide, openBlock, createElementBlock, normalizeClass, createElementVNode, normalizeStyle, createVNode, withCtx, renderSlot, Fragment, renderList, toDisplayString, createCommentVNode } from 'vue';
2
2
  import { useResizeObserver } from '@vueuse/core';
3
3
  import '../../../utils/index.mjs';
4
4
  import { PsIcon } from '../../icon/index.mjs';
@@ -153,54 +153,28 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
153
153
  class: normalizeClass(unref(ns).e("container")),
154
154
  style: normalizeStyle({ height: _ctx.height })
155
155
  }, [
156
- unref(arrowDisplay) ? (openBlock(), createBlock(Transition, {
157
- key: 0,
158
- name: "carousel-arrow-left"
159
- }, {
160
- default: withCtx(() => [
161
- withDirectives(createElementVNode("button", {
162
- type: "button",
163
- class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "left")])
164
- }, [
165
- createVNode(unref(PsIcon), null, {
166
- default: withCtx(() => [
167
- createVNode(unref(ArrowLeft))
168
- ]),
169
- _: 1
170
- })
171
- ], 2), [
172
- [
173
- vShow,
174
- (_ctx.arrow === "always" || hover.value) && (props.loop || activeIndex.value > 0)
175
- ]
176
- ])
177
- ]),
178
- _: 1
179
- })) : createCommentVNode("v-if", true),
180
- unref(arrowDisplay) ? (openBlock(), createBlock(Transition, {
181
- key: 1,
182
- name: "carousel-arrow-right"
183
- }, {
184
- default: withCtx(() => [
185
- withDirectives(createElementVNode("button", {
186
- type: "button",
187
- class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "right")])
188
- }, [
189
- createVNode(unref(PsIcon), null, {
190
- default: withCtx(() => [
191
- createVNode(unref(ArrowRight))
192
- ]),
193
- _: 1
194
- })
195
- ], 2), [
196
- [
197
- vShow,
198
- (_ctx.arrow === "always" || hover.value) && (props.loop || activeIndex.value < items.value.length - 1)
199
- ]
200
- ])
201
- ]),
202
- _: 1
203
- })) : createCommentVNode("v-if", true),
156
+ createElementVNode("button", {
157
+ type: "button",
158
+ class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "left")])
159
+ }, [
160
+ createVNode(unref(PsIcon), null, {
161
+ default: withCtx(() => [
162
+ createVNode(unref(ArrowLeft))
163
+ ]),
164
+ _: 1
165
+ })
166
+ ], 2),
167
+ createElementVNode("button", {
168
+ type: "button",
169
+ class: normalizeClass([unref(ns).e("arrow"), unref(ns).em("arrow", "right")])
170
+ }, [
171
+ createVNode(unref(PsIcon), null, {
172
+ default: withCtx(() => [
173
+ createVNode(unref(ArrowRight))
174
+ ]),
175
+ _: 1
176
+ })
177
+ ], 2),
204
178
  renderSlot(_ctx.$slots, "default")
205
179
  ], 6),
206
180
  _ctx.indicatorPosition !== "none" ? (openBlock(), createElementBlock("ul", {
@@ -1 +1 @@
1
- {"version":3,"file":"carousel2.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.vue"],"sourcesContent":["<template>\n <div\n ref=\"root\"\n :class=\"carouselClasses\"\n >\n <div :class=\"ns.e('container')\" :style=\"{ height: height }\">\n <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-left\">\n <button\n v-show=\"\n (arrow === 'always' || hover) && (props.loop || activeIndex > 0)\n \"\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'left')]\"\n >\n <PsIcon>\n <ArrowLeft />\n </PsIcon>\n </button>\n </transition>\n <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-right\">\n <button\n v-show=\"\n (arrow === 'always' || hover) &&\n (props.loop || activeIndex < items.length - 1)\n \"\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'right')]\"\n >\n <PsIcon>\n <ArrowRight />\n </PsIcon>\n </button>\n </transition>\n <slot />\n </div>\n <ul v-if=\"indicatorPosition !== 'none'\" :class=\"indicatorsClasses\">\n <li\n v-for=\"(item, index) in items\"\n :key=\"index\"\n :class=\"[\n ns.e('indicator'),\n ns.em('indicator', direction),\n ns.is('active', index === activeIndex),\n ]\"\n >\n <button :class=\"ns.e('button')\">\n <span v-if=\"hasLabel\">{{ item.props.label }}</span>\n </button>\n </li>\n </ul>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n nextTick,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n shallowRef,\n unref,\n} from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { debugWarn, isString } from '@element-ps/utils'\nimport { PsIcon } from '@element-ps/components/icon'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-ps/hooks'\nimport { carouselContextKey } from '@element-ps/tokens'\nimport { carouselProps } from './carousel'\nimport type { CarouselItemContext } from '@element-ps/tokens'\n\ndefineOptions({\n name: 'PsCarousel',\n})\n\nconst props = defineProps(carouselProps)\nconst ns = useNamespace('carousel')\nconst COMPONENT_NAME = 'PsCarousel'\nconst THROTTLE_TIME = 300\n\n// refs\nconst activeIndex = ref(-1)\nconst timer = ref<ReturnType<typeof setInterval> | null>(null)\nconst hover = ref(false)\nconst root = ref<HTMLDivElement>()\nconst items = ref<Array<CarouselItemContext>>([])\n\n// computed\nconst arrowDisplay = computed(\n () => props.arrow !== 'never' && !unref(isVertical)\n)\n\nconst hasLabel = computed(() => {\n return items.value.some((item) => item.props.label.toString().length > 0)\n})\n\nconst carouselClasses = computed(() => {\n const classes = [ns.b(), ns.m(props.direction)]\n if (unref(isCardType)) {\n classes.push(ns.m('card'))\n }\n return classes\n})\n\nconst indicatorsClasses = computed(() => {\n const classes = [ns.e('indicators'), ns.em('indicators', props.direction)]\n if (hasLabel.value) {\n classes.push(ns.em('indicators', 'labels'))\n }\n if (props.indicatorPosition === 'outside' || unref(isCardType)) {\n classes.push(ns.em('indicators', 'outside'))\n }\n return classes\n})\n\nconst isCardType = computed(() => props.type === 'card')\nconst isVertical = computed(() => props.direction === 'vertical')\n\nfunction pauseTimer() {\n if (timer.value) {\n clearInterval(timer.value)\n timer.value = null\n }\n}\n\nfunction startTimer() {\n if (props.interval <= 0 || !props.autoplay || timer.value) return\n timer.value = setInterval(() => playSlides(), props.interval)\n}\n\nconst playSlides = () => {\n if (activeIndex.value < items.value.length - 1) {\n activeIndex.value = activeIndex.value + 1\n } else if (props.loop) {\n activeIndex.value = 0\n }\n}\n\nfunction setActiveItem(index: number | string) {\n if (isString(index)) {\n const filteredItems = items.value.filter(\n (item) => item.props.name === index\n )\n if (filteredItems.length > 0) {\n index = items.value.indexOf(filteredItems[0])\n }\n }\n index = Number(index)\n if (Number.isNaN(index) || index !== Math.floor(index)) {\n debugWarn(COMPONENT_NAME, 'index must be integer.')\n return\n }\n const itemCount = items.value.length\n const oldIndex = activeIndex.value\n if (index < 0) {\n activeIndex.value = props.loop ? itemCount - 1 : 0\n } else if (index >= itemCount) {\n activeIndex.value = props.loop ? 0 : itemCount - 1\n } else {\n activeIndex.value = index\n }\n if (oldIndex === activeIndex.value) {\n resetItemPosition(oldIndex)\n }\n}\n\nfunction resetItemPosition(oldIndex?: number) {\n items.value.forEach((item, index) => {\n item.translateItem(index, activeIndex.value, oldIndex)\n })\n}\n\nfunction addItem(item: CarouselItemContext) {\n items.value.push(item)\n}\n\nfunction removeItem(uid?: number) {\n const index = items.value.findIndex((item) => item.uid === uid)\n if (index !== -1) {\n items.value.splice(index, 1)\n if (activeIndex.value === index) next()\n }\n}\n\nfunction next() {\n setActiveItem(activeIndex.value + 1)\n}\n\nconst resizeObserver = shallowRef<ReturnType<typeof useResizeObserver>>()\n// lifecycle\nonMounted(async () => {\n await nextTick()\n\n resizeObserver.value = useResizeObserver(root.value, () => {\n resetItemPosition()\n })\n if (props.initialIndex < items.value.length && props.initialIndex >= 0) {\n activeIndex.value = props.initialIndex\n }\n startTimer()\n})\n\nonBeforeUnmount(() => {\n pauseTimer()\n if (root.value && resizeObserver.value) resizeObserver.value.stop()\n})\n\n// provide\nprovide(carouselContextKey, {\n root,\n isCardType,\n isVertical,\n items,\n loop: props.loop,\n addItem,\n removeItem,\n setActiveItem,\n})\n\ndefineExpose({\n /** @description manually switch slide */\n setActiveItem,\n})\n</script>\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"carousel2.mjs","sources":["../../../../../../packages/components/carousel/src/carousel.vue"],"sourcesContent":["<template>\n <div\n ref=\"root\"\n :class=\"carouselClasses\"\n >\n <div :class=\"ns.e('container')\" :style=\"{ height: height }\">\n <button\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'left')]\"\n >\n <PsIcon>\n <ArrowLeft />\n </PsIcon>\n </button>\n <button\n type=\"button\"\n :class=\"[ns.e('arrow'), ns.em('arrow', 'right')]\"\n >\n <PsIcon>\n <ArrowRight />\n </PsIcon>\n </button>\n <slot />\n </div>\n <ul v-if=\"indicatorPosition !== 'none'\" :class=\"indicatorsClasses\">\n <li\n v-for=\"(item, index) in items\"\n :key=\"index\"\n :class=\"[\n ns.e('indicator'),\n ns.em('indicator', direction),\n ns.is('active', index === activeIndex),\n ]\"\n >\n <button :class=\"ns.e('button')\">\n <span v-if=\"hasLabel\">{{ item.props.label }}</span>\n </button>\n </li>\n </ul>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n nextTick,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n shallowRef,\n unref,\n} from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { debugWarn, isString } from '@element-ps/utils'\nimport { PsIcon } from '@element-ps/components/icon'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-ps/hooks'\nimport { carouselContextKey } from '@element-ps/tokens'\nimport { carouselProps } from './carousel'\nimport type { CarouselItemContext } from '@element-ps/tokens'\n\ndefineOptions({\n name: 'PsCarousel',\n})\n\nconst props = defineProps(carouselProps)\nconst ns = useNamespace('carousel')\nconst COMPONENT_NAME = 'PsCarousel'\nconst THROTTLE_TIME = 300\n\n// refs\nconst activeIndex = ref(-1)\nconst timer = ref<ReturnType<typeof setInterval> | null>(null)\nconst hover = ref(false)\nconst root = ref<HTMLDivElement>()\nconst items = ref<Array<CarouselItemContext>>([])\n\n// computed\nconst arrowDisplay = computed(\n () => props.arrow !== 'never' && !unref(isVertical)\n)\n\nconst hasLabel = computed(() => {\n return items.value.some((item) => item.props.label.toString().length > 0)\n})\n\nconst carouselClasses = computed(() => {\n const classes = [ns.b(), ns.m(props.direction)]\n if (unref(isCardType)) {\n classes.push(ns.m('card'))\n }\n return classes\n})\n\nconst indicatorsClasses = computed(() => {\n const classes = [ns.e('indicators'), ns.em('indicators', props.direction)]\n if (hasLabel.value) {\n classes.push(ns.em('indicators', 'labels'))\n }\n if (props.indicatorPosition === 'outside' || unref(isCardType)) {\n classes.push(ns.em('indicators', 'outside'))\n }\n return classes\n})\n\nconst isCardType = computed(() => props.type === 'card')\nconst isVertical = computed(() => props.direction === 'vertical')\n\nfunction pauseTimer() {\n if (timer.value) {\n clearInterval(timer.value)\n timer.value = null\n }\n}\n\nfunction startTimer() {\n if (props.interval <= 0 || !props.autoplay || timer.value) return\n timer.value = setInterval(() => playSlides(), props.interval)\n}\n\nconst playSlides = () => {\n if (activeIndex.value < items.value.length - 1) {\n activeIndex.value = activeIndex.value + 1\n } else if (props.loop) {\n activeIndex.value = 0\n }\n}\n\nfunction setActiveItem(index: number | string) {\n if (isString(index)) {\n const filteredItems = items.value.filter(\n (item) => item.props.name === index\n )\n if (filteredItems.length > 0) {\n index = items.value.indexOf(filteredItems[0])\n }\n }\n index = Number(index)\n if (Number.isNaN(index) || index !== Math.floor(index)) {\n debugWarn(COMPONENT_NAME, 'index must be integer.')\n return\n }\n const itemCount = items.value.length\n const oldIndex = activeIndex.value\n if (index < 0) {\n activeIndex.value = props.loop ? itemCount - 1 : 0\n } else if (index >= itemCount) {\n activeIndex.value = props.loop ? 0 : itemCount - 1\n } else {\n activeIndex.value = index\n }\n if (oldIndex === activeIndex.value) {\n resetItemPosition(oldIndex)\n }\n}\n\nfunction resetItemPosition(oldIndex?: number) {\n items.value.forEach((item, index) => {\n item.translateItem(index, activeIndex.value, oldIndex)\n })\n}\n\nfunction addItem(item: CarouselItemContext) {\n items.value.push(item)\n}\n\nfunction removeItem(uid?: number) {\n const index = items.value.findIndex((item) => item.uid === uid)\n if (index !== -1) {\n items.value.splice(index, 1)\n if (activeIndex.value === index) next()\n }\n}\n\nfunction next() {\n setActiveItem(activeIndex.value + 1)\n}\n\nconst resizeObserver = shallowRef<ReturnType<typeof useResizeObserver>>()\n// lifecycle\nonMounted(async () => {\n await nextTick()\n\n resizeObserver.value = useResizeObserver(root.value, () => {\n resetItemPosition()\n })\n if (props.initialIndex < items.value.length && props.initialIndex >= 0) {\n activeIndex.value = props.initialIndex\n }\n startTimer()\n})\n\nonBeforeUnmount(() => {\n pauseTimer()\n if (root.value && resizeObserver.value) resizeObserver.value.stop()\n})\n\n// provide\nprovide(carouselContextKey, {\n root,\n isCardType,\n isVertical,\n items,\n loop: props.loop,\n addItem,\n removeItem,\n setActiveItem,\n})\n\ndefineExpose({\n /** @description manually switch slide */\n setActiveItem,\n})\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAmEA,IAAA,MAAA,EAAA,GAAA,aAAA,UAAA,CAAA,CAAA;AACA,IAAA,MAAA,cAAA,GAAA,YAAA,CAAA;AACA,IAAA,MAAA,aAAA,GAAA,GAAA,CAAA;AAGA,IAAA,MAAA,WAAA,GAAA,IAAA,CAAA,CAAA,CAAA,CAAA;AACA,IAAA,MAAA,KAAA,GAAA,IAAA,IAAA,CAAA,CAAA;AACA,IAAA,MAAA,KAAA,GAAA,IAAA,KAAA,CAAA,CAAA;AACA,IAAA,MAAA,OAAA,GAAA,EAAA,CAAA;AACA,IAAA,MAAA,KAAA,GAAA,GAAA,CAAA,EAAA,CAAA,CAAA;AAGA,IAAA,MAAA,YAAA,GAAA,SACA,MAAA,KAAA,CAAA,UAAA,OAAA,IAAA,CAAA,KAAA,CAAA,UAAA,CACA,CAAA,CAAA;AAEA,IAAA,MAAA,QAAA,GAAA,SAAA,MAAA;AACA,MAAA,OAAA,KAAA,CAAA,KAAA,CAAA,IAAA,CAAA,CAAA,IAAA,KAAA,IAAA,CAAA,KAAA,CAAA,KAAA,CAAA,QAAA,EAAA,CAAA,MAAA,GAAA,CAAA,CAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,MAAA,eAAA,GAAA,SAAA,MAAA;AACA,MAAA,MAAA,OAAA,GAAA,CAAA,EAAA,CAAA,CAAA,IAAA,EAAA,CAAA,CAAA,CAAA,KAAA,CAAA,SAAA,CAAA,CAAA,CAAA;AACA,MAAA,IAAA,KAAA,CAAA,UAAA,CAAA,EAAA;AACA,QAAA,OAAA,CAAA,IAAA,CAAA,EAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA;AAAA,OACA;AACA,MAAA,OAAA,OAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,MAAA,iBAAA,GAAA,SAAA,MAAA;AACA,MAAA,MAAA,OAAA,GAAA,CAAA,EAAA,CAAA,CAAA,CAAA,YAAA,CAAA,EAAA,EAAA,CAAA,EAAA,CAAA,YAAA,EAAA,KAAA,CAAA,SAAA,CAAA,CAAA,CAAA;AACA,MAAA,IAAA,SAAA,KAAA,EAAA;AACA,QAAA,OAAA,CAAA,IAAA,CAAA,EAAA,CAAA,EAAA,CAAA,YAAA,EAAA,QAAA,CAAA,CAAA,CAAA;AAAA,OACA;AACA,MAAA,IAAA,KAAA,CAAA,iBAAA,KAAA,SAAA,IAAA,KAAA,CAAA,UAAA,CAAA,EAAA;AACA,QAAA,OAAA,CAAA,IAAA,CAAA,EAAA,CAAA,EAAA,CAAA,YAAA,EAAA,SAAA,CAAA,CAAA,CAAA;AAAA,OACA;AACA,MAAA,OAAA,OAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,MAAA,UAAA,GAAA,QAAA,CAAA,MAAA,KAAA,CAAA,SAAA,MAAA,CAAA,CAAA;AACA,IAAA,MAAA,UAAA,GAAA,QAAA,CAAA,MAAA,KAAA,CAAA,cAAA,UAAA,CAAA,CAAA;AAEA,IAAA,SAAA,UAAA,GAAA;AACA,MAAA,IAAA,MAAA,KAAA,EAAA;AACA,QAAA,aAAA,CAAA,MAAA,KAAA,CAAA,CAAA;AACA,QAAA,KAAA,CAAA,KAAA,GAAA,IAAA,CAAA;AAAA,OACA;AAAA,KACA;AAEA,IAAA,SAAA,UAAA,GAAA;AACA,MAAA,IAAA,MAAA,QAAA,IAAA,CAAA,IAAA,CAAA,KAAA,CAAA,YAAA,KAAA,CAAA,KAAA;AAAA,QAAA,OAAA;AACA,MAAA,KAAA,CAAA,QAAA,WAAA,CAAA,MAAA,UAAA,EAAA,EAAA,MAAA,QAAA,CAAA,CAAA;AAAA,KACA;AAEA,IAAA,MAAA,aAAA,MAAA;AACA,MAAA,IAAA,WAAA,CAAA,KAAA,GAAA,KAAA,CAAA,KAAA,CAAA,SAAA,CAAA,EAAA;AACA,QAAA,WAAA,CAAA,KAAA,GAAA,YAAA,KAAA,GAAA,CAAA,CAAA;AAAA,OACA,MAAA,IAAA,MAAA,IAAA,EAAA;AACA,QAAA,WAAA,CAAA,KAAA,GAAA,CAAA,CAAA;AAAA,OACA;AAAA,KACA,CAAA;AAEA,IAAA,SAAA,aAAA,CAAA,KAAA,EAAA;AACA,MAAA,IAAA,QAAA,CAAA,KAAA,CAAA,EAAA;AACA,QAAA,MAAA,aAAA,GAAA,MAAA,KAAA,CAAA,MAAA,CACA,CAAA,IAAA,KAAA,IAAA,CAAA,KAAA,CAAA,IAAA,KAAA,KACA,CAAA,CAAA;AACA,QAAA,IAAA,aAAA,CAAA,SAAA,CAAA,EAAA;AACA,UAAA,KAAA,GAAA,KAAA,CAAA,KAAA,CAAA,OAAA,CAAA,aAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,SACA;AAAA,OACA;AACA,MAAA,KAAA,GAAA,OAAA,KAAA,CAAA,CAAA;AACA,MAAA,IAAA,MAAA,CAAA,MAAA,KAAA,CAAA,IAAA,UAAA,IAAA,CAAA,KAAA,CAAA,KAAA,CAAA,EAAA;AACA,QAAA,SAAA,CAAA,gBAAA,wBAAA,CAAA,CAAA;AACA,QAAA,OAAA;AAAA,OACA;AACA,MAAA,MAAA,SAAA,GAAA,MAAA,KAAA,CAAA,MAAA,CAAA;AACA,MAAA,MAAA,WAAA,WAAA,CAAA,KAAA,CAAA;AACA,MAAA,IAAA,QAAA,CAAA,EAAA;AACA,QAAA,WAAA,CAAA,KAAA,GAAA,KAAA,CAAA,IAAA,GAAA,SAAA,GAAA,CAAA,GAAA,CAAA,CAAA;AAAA,OACA,MAAA,IAAA,SAAA,SAAA,EAAA;AACA,QAAA,WAAA,CAAA,KAAA,GAAA,KAAA,CAAA,IAAA,GAAA,CAAA,GAAA,SAAA,GAAA,CAAA,CAAA;AAAA,OACA,MAAA;AACA,QAAA,WAAA,CAAA,KAAA,GAAA,KAAA,CAAA;AAAA,OACA;AACA,MAAA,IAAA,QAAA,KAAA,YAAA,KAAA,EAAA;AACA,QAAA,iBAAA,CAAA,QAAA,CAAA,CAAA;AAAA,OACA;AAAA,KACA;AAEA,IAAA,SAAA,iBAAA,CAAA,QAAA,EAAA;AACA,MAAA,KAAA,CAAA,KAAA,CAAA,OAAA,CAAA,CAAA,IAAA,EAAA,KAAA,KAAA;AACA,QAAA,IAAA,CAAA,aAAA,CAAA,KAAA,EAAA,WAAA,CAAA,KAAA,EAAA,QAAA,CAAA,CAAA;AAAA,OACA,CAAA,CAAA;AAAA,KACA;AAEA,IAAA,SAAA,OAAA,CAAA,IAAA,EAAA;AACA,MAAA,KAAA,CAAA,KAAA,CAAA,KAAA,IAAA,CAAA,CAAA;AAAA,KACA;AAEA,IAAA,SAAA,UAAA,CAAA,GAAA,EAAA;AACA,MAAA,MAAA,KAAA,GAAA,MAAA,KAAA,CAAA,SAAA,CAAA,CAAA,IAAA,KAAA,IAAA,CAAA,QAAA,GAAA,CAAA,CAAA;AACA,MAAA,IAAA,UAAA,CAAA,CAAA,EAAA;AACA,QAAA,KAAA,CAAA,KAAA,CAAA,MAAA,CAAA,KAAA,EAAA,CAAA,CAAA,CAAA;AACA,QAAA,IAAA,YAAA,KAAA,KAAA,KAAA;AAAA,UAAA,IAAA,EAAA,CAAA;AAAA,OACA;AAAA,KACA;AAEA,IAAA,SAAA,IAAA,GAAA;AACA,MAAA,aAAA,CAAA,WAAA,CAAA,QAAA,CAAA,CAAA,CAAA;AAAA,KACA;AAEA,IAAA,MAAA,iBAAA,UAAA,EAAA,CAAA;AAEA,IAAA,SAAA,CAAA,YAAA;AACA,MAAA,MAAA,QAAA,EAAA,CAAA;AAEA,MAAA,cAAA,CAAA,KAAA,GAAA,iBAAA,CAAA,IAAA,CAAA,KAAA,EAAA,MAAA;AACA,QAAA,iBAAA,EAAA,CAAA;AAAA,OACA,CAAA,CAAA;AACA,MAAA,IAAA,MAAA,YAAA,GAAA,KAAA,CAAA,MAAA,MAAA,IAAA,KAAA,CAAA,gBAAA,CAAA,EAAA;AACA,QAAA,WAAA,CAAA,QAAA,KAAA,CAAA,YAAA,CAAA;AAAA,OACA;AACA,MAAA,UAAA,EAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,eAAA,CAAA,MAAA;AACA,MAAA,UAAA,EAAA,CAAA;AACA,MAAA,IAAA,IAAA,CAAA,SAAA,cAAA,CAAA,KAAA;AAAA,QAAA,cAAA,CAAA,MAAA,IAAA,EAAA,CAAA;AAAA,KACA,CAAA,CAAA;AAGA,IAAA,OAAA,CAAA,kBAAA,EAAA;AAAA,MACA,IAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,KAAA;AAAA,MACA,MAAA,KAAA,CAAA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA,aAAA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,MAAA,CAAA;AAAA,MAEA,aAAA;AAAA,KACA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -14,7 +14,7 @@ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
14
14
  import { CommonProps } from '../../cascader-panel/src/config.mjs';
15
15
  import { isValidComponentSize } from '../../../utils/vue/validator.mjs';
16
16
  import { useTooltipContentProps } from '../../tooltip/src/tooltip.mjs';
17
- import { tagProps } from '../../tag/src/tag2.mjs';
17
+ import { tagProps } from '../../tag/src/tag.mjs';
18
18
  import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
19
19
  import { useLocale } from '../../../hooks/use-locale/index.mjs';
20
20
  import { formContextKey } from '../../../tokens/form.mjs';
@@ -146,6 +146,13 @@ declare const _CascaderPanel: SFCWithInstall<import("vue").DefineComponent<{
146
146
  setCheckState: (checked: boolean) => void;
147
147
  doCheck: (checked: boolean) => void;
148
148
  }[]>;
149
+ handleKeyDown: (e: KeyboardEvent) => void;
150
+ handleCheckChange: (node: import("./src/node").default, checked: boolean, emitClose?: boolean | undefined) => void;
151
+ getFlattedNodes: (leafOnly: boolean) => import("./src/node").default[] | undefined;
152
+ getCheckedNodes: (leafOnly: boolean) => import("./src/node").default[] | undefined;
153
+ clearCheckedNodes: () => void;
154
+ calculateCheckedValue: () => void;
155
+ scrollToExpandingNode: () => void;
149
156
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, Record<string, any>, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
150
157
  border: {
151
158
  type: BooleanConstructor;
@@ -314,6 +321,13 @@ export declare const PsCascaderPanel: SFCWithInstall<import("vue").DefineCompone
314
321
  setCheckState: (checked: boolean) => void;
315
322
  doCheck: (checked: boolean) => void;
316
323
  }[]>;
324
+ handleKeyDown: (e: KeyboardEvent) => void;
325
+ handleCheckChange: (node: import("./src/node").default, checked: boolean, emitClose?: boolean | undefined) => void;
326
+ getFlattedNodes: (leafOnly: boolean) => import("./src/node").default[] | undefined;
327
+ getCheckedNodes: (leafOnly: boolean) => import("./src/node").default[] | undefined;
328
+ clearCheckedNodes: () => void;
329
+ calculateCheckedValue: () => void;
330
+ scrollToExpandingNode: () => void;
317
331
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, Record<string, any>, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
318
332
  border: {
319
333
  type: BooleanConstructor;
@@ -1,6 +1,6 @@
1
1
  import { computed } from 'vue';
2
2
  import { NOOP } from '@vue/shared';
3
- import { ExpandTrigger } from './node2.mjs';
3
+ import { ExpandTrigger } from './node.mjs';
4
4
 
5
5
  const CommonProps = {
6
6
  modelValue: [Number, String, Array],
@@ -1,17 +1,22 @@
1
- import { defineComponent, ref, computed, nextTick, provide, reactive, onBeforeUpdate, onMounted, resolveComponent, openBlock, createElementBlock, normalizeClass, Fragment, renderList, createBlock } from 'vue';
1
+ import { defineComponent, ref, computed, nextTick, provide, reactive, watch, onBeforeUpdate, onMounted, resolveComponent, openBlock, createElementBlock, normalizeClass, Fragment, renderList, createBlock } from 'vue';
2
2
  import { isEqual, flattenDeep } from 'lodash-unified';
3
3
  import { isClient } from '@vueuse/core';
4
4
  import '../../../utils/index.mjs';
5
+ import '../../../constants/index.mjs';
5
6
  import '../../../hooks/index.mjs';
6
7
  import PsCascaderMenu from './menu.mjs';
7
- import Node, { ExpandTrigger } from './node2.mjs';
8
+ import Store from './store.mjs';
9
+ import Node, { ExpandTrigger } from './node.mjs';
8
10
  import { CommonProps, useCascaderConfig } from './config.mjs';
11
+ import { sortByOriginalOrder, checkNode, getMenuIndex } from './utils.mjs';
9
12
  import { CASCADER_PANEL_INJECTION_KEY } from './types.mjs';
10
13
  import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
11
14
  import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
15
+ import { isEmpty } from '../../../utils/types.mjs';
12
16
  import { unique, castArray } from '../../../utils/arrays.mjs';
13
17
  import { scrollIntoView } from '../../../utils/dom/scroll.mjs';
14
- import { isEmpty } from '../../../utils/types.mjs';
18
+ import { EVENT_CODE } from '../../../constants/aria.mjs';
19
+ import { focusNode, getSibling } from '../../../utils/dom/aria.mjs';
15
20
 
16
21
  const _sfc_main = defineComponent({
17
22
  name: "PsCascaderPanel",
@@ -26,7 +31,7 @@ const _sfc_main = defineComponent({
26
31
  },
27
32
  renderLabel: Function
28
33
  },
29
- setup(props, { slots }) {
34
+ setup(props, { emit, slots }) {
30
35
  let manualChecked = false;
31
36
  const ns = useNamespace("cascader");
32
37
  const config = useCascaderConfig(props);
@@ -39,6 +44,26 @@ const _sfc_main = defineComponent({
39
44
  const checkedNodes = ref([]);
40
45
  const isHoverMenu = computed(() => config.value.expandTrigger === ExpandTrigger.HOVER);
41
46
  const renderLabelFn = computed(() => props.renderLabel || slots.default);
47
+ const initStore = () => {
48
+ const { options } = props;
49
+ const cfg = config.value;
50
+ manualChecked = false;
51
+ store = new Store(options, cfg);
52
+ menus.value = [store.getNodes()];
53
+ if (cfg.lazy && isEmpty(props.options)) {
54
+ initialLoaded.value = false;
55
+ lazyLoad(void 0, (list) => {
56
+ if (list) {
57
+ store = new Store(list, cfg);
58
+ menus.value = [store.getNodes()];
59
+ }
60
+ initialLoaded.value = true;
61
+ syncCheckedValue(false, true);
62
+ });
63
+ } else {
64
+ syncCheckedValue(false, true);
65
+ }
66
+ };
42
67
  const lazyLoad = (node, cb) => {
43
68
  const cfg = config.value;
44
69
  node = node || new Node({}, cfg, void 0, true);
@@ -71,6 +96,16 @@ const _sfc_main = defineComponent({
71
96
  !silent && emit("expand-change", (node == null ? void 0 : node.pathValues) || []);
72
97
  }
73
98
  };
99
+ const handleCheckChange = (node, checked, emitClose = true) => {
100
+ const { checkStrictly, multiple } = config.value;
101
+ const oldNode = checkedNodes.value[0];
102
+ manualChecked = true;
103
+ !multiple && (oldNode == null ? void 0 : oldNode.doCheck(false));
104
+ node.doCheck(checked);
105
+ calculateCheckedValue();
106
+ emitClose && !multiple && !checkStrictly && emit("close");
107
+ !emitClose && !multiple && !checkStrictly && expandParentNode(node);
108
+ };
74
109
  const expandParentNode = (node) => {
75
110
  if (!node)
76
111
  return;
@@ -78,6 +113,27 @@ const _sfc_main = defineComponent({
78
113
  expandParentNode(node);
79
114
  node && expandNode(node);
80
115
  };
116
+ const getFlattedNodes = (leafOnly) => {
117
+ return store == null ? void 0 : store.getFlattedNodes(leafOnly);
118
+ };
119
+ const getCheckedNodes = (leafOnly) => {
120
+ var _a;
121
+ return (_a = getFlattedNodes(leafOnly)) == null ? void 0 : _a.filter((node) => node.checked !== false);
122
+ };
123
+ const clearCheckedNodes = () => {
124
+ checkedNodes.value.forEach((node) => node.doCheck(false));
125
+ calculateCheckedValue();
126
+ };
127
+ const calculateCheckedValue = () => {
128
+ var _a;
129
+ const { checkStrictly, multiple } = config.value;
130
+ const oldNodes = checkedNodes.value;
131
+ const newNodes = getCheckedNodes(!checkStrictly);
132
+ const nodes = sortByOriginalOrder(oldNodes, newNodes);
133
+ const values = nodes.map((node) => node.valueByOption);
134
+ checkedNodes.value = nodes;
135
+ checkedValue.value = multiple ? values : (_a = values[0]) != null ? _a : null;
136
+ };
81
137
  const syncCheckedValue = (loaded = false, forced = false) => {
82
138
  const { modelValue } = props;
83
139
  const { lazy, multiple, checkStrictly } = config.value;
@@ -129,21 +185,69 @@ const _sfc_main = defineComponent({
129
185
  }
130
186
  });
131
187
  };
188
+ const handleKeyDown = (e) => {
189
+ const target = e.target;
190
+ const { code } = e;
191
+ switch (code) {
192
+ case EVENT_CODE.up:
193
+ case EVENT_CODE.down: {
194
+ e.preventDefault();
195
+ const distance = code === EVENT_CODE.up ? -1 : 1;
196
+ focusNode(getSibling(target, distance, `.${ns.b("node")}[tabindex="-1"]`));
197
+ break;
198
+ }
199
+ case EVENT_CODE.left: {
200
+ e.preventDefault();
201
+ const preMenu = menuList.value[getMenuIndex(target) - 1];
202
+ const expandedNode = preMenu == null ? void 0 : preMenu.$el.querySelector(`.${ns.b("node")}[aria-expanded="true"]`);
203
+ focusNode(expandedNode);
204
+ break;
205
+ }
206
+ case EVENT_CODE.right: {
207
+ e.preventDefault();
208
+ const nextMenu = menuList.value[getMenuIndex(target) + 1];
209
+ const firstNode = nextMenu == null ? void 0 : nextMenu.$el.querySelector(`.${ns.b("node")}[tabindex="-1"]`);
210
+ focusNode(firstNode);
211
+ break;
212
+ }
213
+ case EVENT_CODE.enter:
214
+ checkNode(target);
215
+ break;
216
+ case EVENT_CODE.esc:
217
+ case EVENT_CODE.tab:
218
+ emit("close");
219
+ break;
220
+ }
221
+ };
132
222
  provide(CASCADER_PANEL_INJECTION_KEY, reactive({
133
223
  config,
134
224
  expandingNode,
135
225
  checkedNodes,
136
226
  isHoverMenu,
137
227
  initialLoaded,
138
- renderLabelFn
228
+ renderLabelFn,
229
+ lazyLoad,
230
+ expandNode,
231
+ handleCheckChange
139
232
  }));
233
+ watch([config, () => props.options], initStore, {
234
+ deep: true,
235
+ immediate: true
236
+ });
140
237
  onBeforeUpdate(() => menuList.value = []);
141
238
  onMounted(() => !isEmpty(props.modelValue) && syncCheckedValue());
142
239
  return {
143
240
  ns,
144
241
  menuList,
145
242
  menus,
146
- checkedNodes
243
+ checkedNodes,
244
+ handleKeyDown,
245
+ handleCheckChange,
246
+ getFlattedNodes,
247
+ getCheckedNodes,
248
+ clearCheckedNodes,
249
+ calculateCheckedValue,
250
+ scrollToExpandingNode
147
251
  };
148
252
  }
149
253
  });
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../../../packages/components/cascader-panel/src/index.vue"],"sourcesContent":["<template>\n <div\n :class=\"[ns.b('panel'), ns.is('bordered', border)]\"\n >\n <ps-cascader-menu\n v-for=\"(menu, index) in menus\"\n :key=\"index\"\n :ref=\"(item) => (menuList[index] = item)\"\n :index=\"index\"\n :nodes=\"[...menu]\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n computed,\n defineComponent,\n nextTick,\n onBeforeUpdate,\n onMounted,\n provide,\n reactive,\n ref,\n} from 'vue'\nimport { flattenDeep, isEqual } from 'lodash-unified'\nimport { isClient } from '@vueuse/core'\nimport {\n castArray,\n isEmpty,\n scrollIntoView,\n unique,\n} from '@element-ps/utils'\nimport { useNamespace } from '@element-ps/hooks'\n\nimport PsCascaderMenu from './menu.vue'\nimport Store from './store'\nimport Node, { ExpandTrigger } from './node'\nimport { CommonProps, useCascaderConfig } from './config'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\n\nimport type { PropType } from 'vue'\nimport type { Nullable } from '@element-ps/utils'\nimport type {\n default as CascaderNode,\n CascaderNodeValue,\n CascaderOption,\n CascaderValue,\n RenderLabel,\n} from './node'\n\nimport type { PsCascaderPanelContext } from './types'\n\nexport default defineComponent({\n name: 'PsCascaderPanel',\n\n components: {\n PsCascaderMenu,\n },\n\n props: {\n ...CommonProps,\n border: {\n type: Boolean,\n default: true,\n },\n renderLabel: Function as PropType<RenderLabel>,\n },\n\n setup(props, { slots }) {\n // for interrupt sync check status in lazy mode\n let manualChecked = false\n\n const ns = useNamespace('cascader')\n const config = useCascaderConfig(props)\n\n let store: Nullable<Store> = null\n const initialLoaded = ref(true)\n const menuList = ref<any[]>([])\n const checkedValue = ref<Nullable<CascaderValue>>(null)\n const menus = ref<CascaderNode[][]>([])\n const expandingNode = ref<Nullable<CascaderNode>>(null)\n const checkedNodes = ref<CascaderNode[]>([])\n\n const isHoverMenu = computed(\n () => config.value.expandTrigger === ExpandTrigger.HOVER\n )\n const renderLabelFn = computed(() => props.renderLabel || slots.default)\n\n const lazyLoad: PsCascaderPanelContext['lazyLoad'] = (node, cb) => {\n const cfg = config.value\n node! = node || new Node({}, cfg, undefined, true)\n node.loading = true\n\n const resolve = (dataList: CascaderOption[]) => {\n const _node = node as Node\n const parent = _node.root ? null : _node\n dataList && store?.appendNodes(dataList, parent as any)\n _node.loading = false\n _node.loaded = true\n _node.childrenData = _node.childrenData || []\n cb && cb(dataList)\n }\n\n cfg.lazyLoad(node, resolve as any)\n }\n\n const expandNode: PsCascaderPanelContext['expandNode'] = (node, silent) => {\n const { level } = node\n const newMenus = menus.value.slice(0, level)\n let newExpandingNode: Nullable<CascaderNode>\n\n if (node.isLeaf) {\n newExpandingNode = node.pathNodes[level - 2]\n } else {\n newExpandingNode = node\n newMenus.push(node.children)\n }\n\n if (expandingNode.value?.uid !== newExpandingNode?.uid) {\n expandingNode.value = node\n menus.value = newMenus\n !silent && emit('expand-change', node?.pathValues || [])\n }\n }\n\n const expandParentNode = (node) => {\n if (!node) return\n node = node.parent\n expandParentNode(node)\n node && expandNode(node)\n }\n\n const syncCheckedValue = (loaded = false, forced = false) => {\n const { modelValue } = props\n const { lazy, multiple, checkStrictly } = config.value\n const leafOnly = !checkStrictly\n\n if (\n !initialLoaded.value ||\n manualChecked ||\n (!forced && isEqual(modelValue, checkedValue.value))\n )\n return\n\n if (lazy && !loaded) {\n const values: CascaderNodeValue[] = unique(\n flattenDeep(castArray(modelValue))\n )\n const nodes = values\n .map((val) => store?.getNodeByValue(val))\n .filter((node) => !!node && !node.loaded && !node.loading) as Node[]\n\n if (nodes.length) {\n nodes.forEach((node) => {\n lazyLoad(node, () => syncCheckedValue(false, forced))\n })\n } else {\n syncCheckedValue(true, forced)\n }\n } else {\n const values = multiple ? castArray(modelValue) : [modelValue]\n const nodes = unique(\n values.map((val) => store?.getNodeByValue(val, leafOnly))\n ) as Node[]\n syncMenuState(nodes, false)\n checkedValue.value = modelValue!\n }\n }\n\n const syncMenuState = (\n newCheckedNodes: CascaderNode[],\n reserveExpandingState = true\n ) => {\n const { checkStrictly } = config.value\n const oldNodes = checkedNodes.value\n const newNodes = newCheckedNodes.filter(\n (node) => !!node && (checkStrictly || node.isLeaf)\n )\n const oldExpandingNode = store?.getSameNode(expandingNode.value!)\n const newExpandingNode =\n (reserveExpandingState && oldExpandingNode) || newNodes[0]\n\n if (newExpandingNode) {\n newExpandingNode.pathNodes.forEach((node) => expandNode(node, true))\n } else {\n expandingNode.value = null\n }\n\n oldNodes.forEach((node) => node.doCheck(false))\n newNodes.forEach((node) => node.doCheck(true))\n\n checkedNodes.value = newNodes\n nextTick(scrollToExpandingNode)\n }\n\n const scrollToExpandingNode = () => {\n if (!isClient) return\n\n menuList.value.forEach((menu) => {\n const menuElement = menu?.$el\n if (menuElement) {\n const container = menuElement.querySelector(\n `.${ns.namespace.value}-scrollbar__wrap`\n )\n const activeNode =\n menuElement.querySelector(`.${ns.b('node')}.${ns.is('active')}`) ||\n menuElement.querySelector(`.${ns.b('node')}.in-active-path`)\n scrollIntoView(container, activeNode)\n }\n })\n }\n\n provide(\n CASCADER_PANEL_INJECTION_KEY,\n reactive({\n config,\n expandingNode,\n checkedNodes,\n isHoverMenu,\n initialLoaded,\n renderLabelFn,\n })\n )\n\n onBeforeUpdate(() => (menuList.value = []))\n\n onMounted(() => !isEmpty(props.modelValue) && syncCheckedValue())\n\n return {\n ns,\n menuList,\n menus,\n checkedNodes,\n }\n },\n})\n</script>\n"],"names":["_resolveComponent","_openBlock","_normalizeClass","_Fragment","_renderList","_createBlock"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../../../../../packages/components/cascader-panel/src/index.vue"],"sourcesContent":["<template>\n <div\n :class=\"[ns.b('panel'), ns.is('bordered', border)]\"\n >\n <ps-cascader-menu\n v-for=\"(menu, index) in menus\"\n :key=\"index\"\n :ref=\"(item) => (menuList[index] = item)\"\n :index=\"index\"\n :nodes=\"[...menu]\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n computed,\n defineComponent,\n nextTick,\n onBeforeUpdate,\n onMounted,\n provide,\n reactive,\n ref,\n watch,\n} from 'vue'\nimport { flattenDeep, isEqual } from 'lodash-unified'\nimport { isClient } from '@vueuse/core'\nimport {\n castArray,\n focusNode,\n getSibling,\n isEmpty,\n scrollIntoView,\n unique,\n} from '@element-ps/utils'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n UPDATE_MODEL_EVENT,\n} from '@element-ps/constants'\nimport { useNamespace } from '@element-ps/hooks'\n\nimport PsCascaderMenu from './menu.vue'\nimport Store from './store'\nimport Node, { ExpandTrigger } from './node'\nimport { CommonProps, useCascaderConfig } from './config'\nimport { checkNode, getMenuIndex, sortByOriginalOrder } from './utils'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\n\nimport type { PropType } from 'vue'\nimport type { Nullable } from '@element-ps/utils'\nimport type {\n default as CascaderNode,\n CascaderNodeValue,\n CascaderOption,\n CascaderValue,\n RenderLabel,\n} from './node'\n\nimport type { PsCascaderPanelContext } from './types'\n\nexport default defineComponent({\n name: 'PsCascaderPanel',\n components: {\n PsCascaderMenu,\n },\n props: {\n ...CommonProps,\n border: {\n type: Boolean,\n default: true,\n },\n renderLabel: Function as PropType<RenderLabel>,\n },\n setup(props, { emit, slots }) {\n // for interrupt sync check status in lazy mode\n let manualChecked = false\n\n const ns = useNamespace('cascader')\n const config = useCascaderConfig(props)\n\n let store: Nullable<Store> = null\n const initialLoaded = ref(true)\n const menuList = ref<any[]>([])\n const checkedValue = ref<Nullable<CascaderValue>>(null)\n const menus = ref<CascaderNode[][]>([])\n const expandingNode = ref<Nullable<CascaderNode>>(null)\n const checkedNodes = ref<CascaderNode[]>([])\n\n const isHoverMenu = computed(\n () => config.value.expandTrigger === ExpandTrigger.HOVER\n )\n const renderLabelFn = computed(() => props.renderLabel || slots.default)\n\n const initStore = () => {\n const { options } = props\n const cfg = config.value\n\n manualChecked = false\n store = new Store(options, cfg)\n menus.value = [store.getNodes()]\n\n if (cfg.lazy && isEmpty(props.options)) {\n initialLoaded.value = false\n lazyLoad(undefined, (list) => {\n if (list) {\n store = new Store(list, cfg)\n menus.value = [store.getNodes()]\n }\n initialLoaded.value = true\n syncCheckedValue(false, true)\n })\n } else {\n syncCheckedValue(false, true)\n }\n }\n\n const lazyLoad: PsCascaderPanelContext['lazyLoad'] = (node, cb) => {\n const cfg = config.value\n node! = node || new Node({}, cfg, undefined, true)\n node.loading = true\n\n const resolve = (dataList: CascaderOption[]) => {\n const _node = node as Node\n const parent = _node.root ? null : _node\n dataList && store?.appendNodes(dataList, parent as any)\n _node.loading = false\n _node.loaded = true\n _node.childrenData = _node.childrenData || []\n cb && cb(dataList)\n }\n\n cfg.lazyLoad(node, resolve as any)\n }\n\n const expandNode: PsCascaderPanelContext['expandNode'] = (node, silent) => {\n const { level } = node\n const newMenus = menus.value.slice(0, level)\n let newExpandingNode: Nullable<CascaderNode>\n\n if (node.isLeaf) {\n newExpandingNode = node.pathNodes[level - 2]\n } else {\n newExpandingNode = node\n newMenus.push(node.children)\n }\n\n if (expandingNode.value?.uid !== newExpandingNode?.uid) {\n expandingNode.value = node\n menus.value = newMenus\n !silent && emit('expand-change', node?.pathValues || [])\n }\n }\n\n const handleCheckChange: PsCascaderPanelContext['handleCheckChange'] = (\n node,\n checked,\n emitClose = true\n ) => {\n const { checkStrictly, multiple } = config.value\n const oldNode = checkedNodes.value[0]\n manualChecked = true\n\n !multiple && oldNode?.doCheck(false)\n node.doCheck(checked)\n calculateCheckedValue()\n emitClose && !multiple && !checkStrictly && emit('close')\n !emitClose && !multiple && !checkStrictly && expandParentNode(node)\n }\n\n const expandParentNode = (node) => {\n if (!node) return\n node = node.parent\n expandParentNode(node)\n node && expandNode(node)\n }\n\n const getFlattedNodes = (leafOnly: boolean) => {\n return store?.getFlattedNodes(leafOnly)\n }\n\n const getCheckedNodes = (leafOnly: boolean) => {\n return getFlattedNodes(leafOnly)?.filter((node) => node.checked !== false)\n }\n\n const clearCheckedNodes = () => {\n checkedNodes.value.forEach((node) => node.doCheck(false))\n calculateCheckedValue()\n }\n\n const calculateCheckedValue = () => {\n const { checkStrictly, multiple } = config.value\n const oldNodes = checkedNodes.value\n const newNodes = getCheckedNodes(!checkStrictly)!\n // ensure the original order\n const nodes = sortByOriginalOrder(oldNodes, newNodes)\n const values = nodes.map((node) => node.valueByOption)\n checkedNodes.value = nodes\n checkedValue.value = multiple ? values : values[0] ?? null\n }\n\n const syncCheckedValue = (loaded = false, forced = false) => {\n const { modelValue } = props\n const { lazy, multiple, checkStrictly } = config.value\n const leafOnly = !checkStrictly\n\n if (\n !initialLoaded.value ||\n manualChecked ||\n (!forced && isEqual(modelValue, checkedValue.value))\n )\n return\n\n if (lazy && !loaded) {\n const values: CascaderNodeValue[] = unique(\n flattenDeep(castArray(modelValue))\n )\n const nodes = values\n .map((val) => store?.getNodeByValue(val))\n .filter((node) => !!node && !node.loaded && !node.loading) as Node[]\n\n if (nodes.length) {\n nodes.forEach((node) => {\n lazyLoad(node, () => syncCheckedValue(false, forced))\n })\n } else {\n syncCheckedValue(true, forced)\n }\n } else {\n const values = multiple ? castArray(modelValue) : [modelValue]\n const nodes = unique(\n values.map((val) => store?.getNodeByValue(val, leafOnly))\n ) as Node[]\n syncMenuState(nodes, false)\n checkedValue.value = modelValue!\n }\n }\n\n const syncMenuState = (\n newCheckedNodes: CascaderNode[],\n reserveExpandingState = true\n ) => {\n const { checkStrictly } = config.value\n const oldNodes = checkedNodes.value\n const newNodes = newCheckedNodes.filter(\n (node) => !!node && (checkStrictly || node.isLeaf)\n )\n const oldExpandingNode = store?.getSameNode(expandingNode.value!)\n const newExpandingNode =\n (reserveExpandingState && oldExpandingNode) || newNodes[0]\n\n if (newExpandingNode) {\n newExpandingNode.pathNodes.forEach((node) => expandNode(node, true))\n } else {\n expandingNode.value = null\n }\n\n oldNodes.forEach((node) => node.doCheck(false))\n newNodes.forEach((node) => node.doCheck(true))\n\n checkedNodes.value = newNodes\n nextTick(scrollToExpandingNode)\n }\n\n const scrollToExpandingNode = () => {\n if (!isClient) return\n\n menuList.value.forEach((menu) => {\n const menuElement = menu?.$el\n if (menuElement) {\n const container = menuElement.querySelector(\n `.${ns.namespace.value}-scrollbar__wrap`\n )\n const activeNode =\n menuElement.querySelector(`.${ns.b('node')}.${ns.is('active')}`) ||\n menuElement.querySelector(`.${ns.b('node')}.in-active-path`)\n scrollIntoView(container, activeNode)\n }\n })\n }\n\n const handleKeyDown = (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n const { code } = e\n\n switch (code) {\n case EVENT_CODE.up:\n case EVENT_CODE.down: {\n e.preventDefault()\n const distance = code === EVENT_CODE.up ? -1 : 1\n focusNode(\n getSibling(target, distance, `.${ns.b('node')}[tabindex=\"-1\"]`)\n )\n break\n }\n case EVENT_CODE.left: {\n e.preventDefault()\n const preMenu = menuList.value[getMenuIndex(target) - 1]\n const expandedNode = preMenu?.$el.querySelector(\n `.${ns.b('node')}[aria-expanded=\"true\"]`\n )\n focusNode(expandedNode)\n break\n }\n case EVENT_CODE.right: {\n e.preventDefault()\n const nextMenu = menuList.value[getMenuIndex(target) + 1]\n const firstNode = nextMenu?.$el.querySelector(\n `.${ns.b('node')}[tabindex=\"-1\"]`\n )\n focusNode(firstNode)\n break\n }\n case EVENT_CODE.enter:\n checkNode(target)\n break\n case EVENT_CODE.esc:\n case EVENT_CODE.tab:\n emit('close')\n break\n }\n }\n\n provide(\n CASCADER_PANEL_INJECTION_KEY,\n reactive({\n config,\n expandingNode,\n checkedNodes,\n isHoverMenu,\n initialLoaded,\n renderLabelFn,\n lazyLoad,\n expandNode,\n handleCheckChange,\n })\n )\n\n watch([config, () => props.options], initStore, {\n deep: true,\n immediate: true,\n })\n\n onBeforeUpdate(() => (menuList.value = []))\n\n onMounted(() => !isEmpty(props.modelValue) && syncCheckedValue())\n\n return {\n ns,\n menuList,\n menus,\n checkedNodes,\n handleKeyDown,\n handleCheckChange,\n getFlattedNodes,\n getCheckedNodes,\n clearCheckedNodes,\n calculateCheckedValue,\n scrollToExpandingNode,\n }\n },\n})\n</script>\n"],"names":["_resolveComponent","_openBlock","_createElementBlock","_Fragment","_renderList","_createBlock"],"mappings":"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"}
@@ -148,6 +148,13 @@ declare const _default: import("vue").DefineComponent<{
148
148
  setCheckState: (checked: boolean) => void;
149
149
  doCheck: (checked: boolean) => void;
150
150
  }[]>;
151
+ handleKeyDown: (e: KeyboardEvent) => void;
152
+ handleCheckChange: (node: Node, checked: boolean, emitClose?: boolean | undefined) => void;
153
+ getFlattedNodes: (leafOnly: boolean) => Node[] | undefined;
154
+ getCheckedNodes: (leafOnly: boolean) => Node[] | undefined;
155
+ clearCheckedNodes: () => void;
156
+ calculateCheckedValue: () => void;
157
+ scrollToExpandingNode: () => void;
151
158
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, Record<string, any>, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
152
159
  border: {
153
160
  type: BooleanConstructor;
@@ -1,10 +1,10 @@
1
- import { defineComponent, inject, ref, computed, resolveComponent, openBlock, createBlock, normalizeClass, withCtx, createElementBlock, Fragment, renderList, createVNode, createTextVNode, toDisplayString, createCommentVNode } from 'vue';
1
+ import { defineComponent, getCurrentInstance, inject, ref, computed, resolveComponent, openBlock, createBlock, normalizeClass, withCtx, createElementBlock, Fragment, renderList, createVNode, createTextVNode, toDisplayString, createCommentVNode } from 'vue';
2
2
  import { PsScrollbar } from '../../scrollbar/index.mjs';
3
3
  import '../../../hooks/index.mjs';
4
4
  import '../../../utils/index.mjs';
5
5
  import { Loading } from '@element-plus/icons-vue';
6
6
  import { PsIcon } from '../../icon/index.mjs';
7
- import PsCascaderNode from './node.mjs';
7
+ import PsCascaderNode from './node2.mjs';
8
8
  import { CASCADER_PANEL_INJECTION_KEY } from './types.mjs';
9
9
  import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
10
10
  import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
@@ -30,14 +30,29 @@ const _sfc_main = defineComponent({
30
30
  }
31
31
  },
32
32
  setup(props) {
33
+ const instance = getCurrentInstance();
33
34
  const ns = useNamespace("cascader-menu");
34
35
  const { t } = useLocale();
35
36
  const id = generateId();
37
+ let activeNode = null;
38
+ let hoverTimer = null;
36
39
  const panel = inject(CASCADER_PANEL_INJECTION_KEY);
37
40
  const hoverZone = ref(null);
38
41
  const isEmpty = computed(() => !props.nodes.length);
39
42
  const isLoading = computed(() => !panel.initialLoaded);
40
43
  const menuId = computed(() => `cascader-menu-${id}-${props.index}`);
44
+ const clearHoverTimer = () => {
45
+ if (!hoverTimer)
46
+ return;
47
+ clearTimeout(hoverTimer);
48
+ hoverTimer = null;
49
+ };
50
+ const clearHoverZone = () => {
51
+ if (!hoverZone.value)
52
+ return;
53
+ hoverZone.value.innerHTML = "";
54
+ clearHoverTimer();
55
+ };
41
56
  return {
42
57
  ns,
43
58
  panel,
@@ -1 +1 @@
1
- {"version":3,"file":"menu.mjs","sources":["../../../../../../packages/components/cascader-panel/src/menu.vue"],"sourcesContent":["<template>\n <ps-scrollbar\n :key=\"menuId\"\n tag=\"ul\"\n role=\"menu\"\n :class=\"ns.b()\"\n :wrap-class=\"ns.e('wrap')\"\n :view-class=\"[ns.e('list'), ns.is('empty', isEmpty)]\"\n >\n <ps-cascader-node\n v-for=\"node in nodes\"\n :key=\"node.uid\"\n :node=\"node\"\n :menu-id=\"menuId\"\n />\n <div v-if=\"isLoading\" :class=\"ns.e('empty-text')\">\n <ps-icon size=\"14\" :class=\"ns.is('loading')\">\n <loading />\n </ps-icon>\n {{ t('el.cascader.loading') }}\n </div>\n <div v-else-if=\"isEmpty\" :class=\"ns.e('empty-text')\">\n {{ t('el.cascader.noData') }}\n </div>\n <svg\n v-else-if=\"panel?.isHoverMenu\"\n ref=\"hoverZone\"\n :class=\"ns.e('hover-zone')\"\n />\n </ps-scrollbar>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref } from 'vue'\nimport PsScrollbar from '@element-ps/components/scrollbar'\nimport { useLocale, useNamespace } from '@element-ps/hooks'\nimport { generateId } from '@element-ps/utils'\nimport { Loading } from '@element-plus/icons-vue'\nimport PsIcon from '@element-ps/components/icon'\nimport PsCascaderNode from './node.vue'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\n\nimport type { default as CascaderNode } from './node'\nimport type { PropType } from 'vue'\n\nexport default defineComponent({\n name: 'PsCascaderMenu',\n\n components: {\n Loading,\n PsIcon,\n PsScrollbar,\n PsCascaderNode,\n },\n\n props: {\n nodes: {\n type: Array as PropType<CascaderNode[]>,\n required: true,\n },\n index: {\n type: Number,\n required: true,\n },\n },\n\n setup(props) {\n const ns = useNamespace('cascader-menu')\n\n const { t } = useLocale()\n const id = generateId()\n\n const panel = inject(CASCADER_PANEL_INJECTION_KEY)!\n\n const hoverZone = ref<null | SVGSVGElement>(null)\n\n const isEmpty = computed(() => !props.nodes.length)\n const isLoading = computed(() => !panel.initialLoaded)\n const menuId = computed(() => `cascader-menu-${id}-${props.index}`)\n\n return {\n ns,\n panel,\n hoverZone,\n isEmpty,\n isLoading,\n menuId,\n t,\n }\n },\n})\n</script>\n"],"names":["_createBlock","_normalizeClass","_openBlock","_createElementBlock","_Fragment","_renderList","_createVNode","_withCtx","_createTextVNode","_toDisplayString"],"mappings":"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"}
1
+ {"version":3,"file":"menu.mjs","sources":["../../../../../../packages/components/cascader-panel/src/menu.vue"],"sourcesContent":["<template>\n <ps-scrollbar\n :key=\"menuId\"\n tag=\"ul\"\n role=\"menu\"\n :class=\"ns.b()\"\n :wrap-class=\"ns.e('wrap')\"\n :view-class=\"[ns.e('list'), ns.is('empty', isEmpty)]\"\n >\n <ps-cascader-node\n v-for=\"node in nodes\"\n :key=\"node.uid\"\n :node=\"node\"\n :menu-id=\"menuId\"\n />\n <div v-if=\"isLoading\" :class=\"ns.e('empty-text')\">\n <ps-icon size=\"14\" :class=\"ns.is('loading')\">\n <loading />\n </ps-icon>\n {{ t('el.cascader.loading') }}\n </div>\n <div v-else-if=\"isEmpty\" :class=\"ns.e('empty-text')\">\n {{ t('el.cascader.noData') }}\n </div>\n <svg\n v-else-if=\"panel?.isHoverMenu\"\n ref=\"hoverZone\"\n :class=\"ns.e('hover-zone')\"\n />\n </ps-scrollbar>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, getCurrentInstance, inject, ref } from 'vue'\nimport PsScrollbar from '@element-ps/components/scrollbar'\nimport { useLocale, useNamespace } from '@element-ps/hooks'\nimport { generateId } from '@element-ps/utils'\nimport { Loading } from '@element-plus/icons-vue'\nimport PsIcon from '@element-ps/components/icon'\nimport PsCascaderNode from './node.vue'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\n\nimport type { default as CascaderNode } from './node'\nimport type { PropType } from 'vue'\nimport type { Nullable } from '@element-ps/utils'\n\nexport default defineComponent({\n name: 'PsCascaderMenu',\n\n components: {\n Loading,\n PsIcon,\n PsScrollbar,\n PsCascaderNode,\n },\n\n props: {\n nodes: {\n type: Array as PropType<CascaderNode[]>,\n required: true,\n },\n index: {\n type: Number,\n required: true,\n },\n },\n\n setup(props) {\n const instance = getCurrentInstance()!\n const ns = useNamespace('cascader-menu')\n\n const { t } = useLocale()\n const id = generateId()\n let activeNode: Nullable<HTMLElement> = null\n let hoverTimer: Nullable<number> = null\n\n const panel = inject(CASCADER_PANEL_INJECTION_KEY)!\n\n const hoverZone = ref<null | SVGSVGElement>(null)\n\n const isEmpty = computed(() => !props.nodes.length)\n const isLoading = computed(() => !panel.initialLoaded)\n const menuId = computed(() => `cascader-menu-${id}-${props.index}`)\n\n const clearHoverTimer = () => {\n if (!hoverTimer) return\n clearTimeout(hoverTimer)\n hoverTimer = null\n }\n\n const clearHoverZone = () => {\n if (!hoverZone.value) return\n hoverZone.value.innerHTML = ''\n clearHoverTimer()\n }\n return {\n ns,\n panel,\n hoverZone,\n isEmpty,\n isLoading,\n menuId,\n t,\n }\n },\n})\n</script>\n"],"names":["_createBlock","_normalizeClass","_openBlock","_createElementBlock","_Fragment","_renderList","_createVNode","_withCtx","_createTextVNode","_toDisplayString"],"mappings":"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"}