sl-ui-pc 2.12.7-beta1 → 2.12.7

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 (610) hide show
  1. package/dist/index.css +1 -1
  2. package/es/components/alert/index.mjs +2 -2
  3. package/es/components/alert/src/alert.mjs +41 -108
  4. package/es/components/alert/src/alert.mjs.map +1 -1
  5. package/es/components/alert/src/alert2.mjs +108 -41
  6. package/es/components/alert/src/alert2.mjs.map +1 -1
  7. package/es/components/anchor/index.mjs +3 -3
  8. package/es/components/anchor/src/anchor-link.mjs +80 -5
  9. package/es/components/anchor/src/anchor-link.mjs.map +1 -1
  10. package/es/components/anchor/src/anchor-link2.mjs +5 -80
  11. package/es/components/anchor/src/anchor-link2.mjs.map +1 -1
  12. package/es/components/anchor/src/anchor.mjs +42 -206
  13. package/es/components/anchor/src/anchor.mjs.map +1 -1
  14. package/es/components/anchor/src/anchor2.mjs +206 -42
  15. package/es/components/anchor/src/anchor2.mjs.map +1 -1
  16. package/es/components/autocomplete/index.mjs +2 -2
  17. package/es/components/autocomplete/src/autocomplete.mjs +58 -366
  18. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  19. package/es/components/autocomplete/src/autocomplete2.mjs +366 -58
  20. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  21. package/es/components/backtop/index.mjs +2 -2
  22. package/es/components/backtop/src/backtop.mjs +21 -53
  23. package/es/components/backtop/src/backtop.mjs.map +1 -1
  24. package/es/components/backtop/src/backtop2.mjs +53 -21
  25. package/es/components/backtop/src/backtop2.mjs.map +1 -1
  26. package/es/components/badge/index.mjs +2 -2
  27. package/es/components/badge/src/badge.mjs +71 -32
  28. package/es/components/badge/src/badge.mjs.map +1 -1
  29. package/es/components/badge/src/badge2.mjs +32 -71
  30. package/es/components/badge/src/badge2.mjs.map +1 -1
  31. package/es/components/breadcrumb/index.mjs +2 -2
  32. package/es/components/breadcrumb/src/breadcrumb.mjs +10 -37
  33. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  34. package/es/components/breadcrumb/src/breadcrumb2.mjs +37 -10
  35. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  36. package/es/components/button/index.mjs +3 -3
  37. package/es/components/button/src/button-group.mjs +29 -6
  38. package/es/components/button/src/button-group.mjs.map +1 -1
  39. package/es/components/button/src/button-group2.mjs +6 -29
  40. package/es/components/button/src/button-group2.mjs.map +1 -1
  41. package/es/components/button/src/button.mjs +62 -87
  42. package/es/components/button/src/button.mjs.map +1 -1
  43. package/es/components/button/src/button2.mjs +87 -62
  44. package/es/components/button/src/button2.mjs.map +1 -1
  45. package/es/components/calendar/index.mjs +2 -2
  46. package/es/components/calendar/src/calendar.mjs +44 -377
  47. package/es/components/calendar/src/calendar.mjs.map +1 -1
  48. package/es/components/calendar/src/calendar2.mjs +377 -44
  49. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  50. package/es/components/calendar/src/date-table.mjs +31 -89
  51. package/es/components/calendar/src/date-table.mjs.map +1 -1
  52. package/es/components/calendar/src/date-table2.mjs +89 -31
  53. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  54. package/es/components/calendar/src/use-date-table.mjs +1 -1
  55. package/es/components/card/index.mjs +2 -2
  56. package/es/components/card/src/card.mjs +22 -42
  57. package/es/components/card/src/card.mjs.map +1 -1
  58. package/es/components/card/src/card2.mjs +42 -22
  59. package/es/components/card/src/card2.mjs.map +1 -1
  60. package/es/components/carousel/index.mjs +4 -4
  61. package/es/components/carousel/src/carousel-item.mjs +7 -69
  62. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  63. package/es/components/carousel/src/carousel-item2.mjs +69 -7
  64. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  65. package/es/components/carousel/src/carousel.mjs +214 -61
  66. package/es/components/carousel/src/carousel.mjs.map +1 -1
  67. package/es/components/carousel/src/carousel2.mjs +61 -214
  68. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  69. package/es/components/cascader/index.mjs +2 -2
  70. package/es/components/cascader/src/cascader.mjs +719 -93
  71. package/es/components/cascader/src/cascader.mjs.map +1 -1
  72. package/es/components/cascader/src/cascader2.mjs +93 -719
  73. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  74. package/es/components/cascader-panel/src/index.mjs +1 -1
  75. package/es/components/cascader-panel/src/menu.mjs +1 -1
  76. package/es/components/cascader-panel/src/node.mjs +115 -194
  77. package/es/components/cascader-panel/src/node.mjs.map +1 -1
  78. package/es/components/cascader-panel/src/node2.mjs +194 -115
  79. package/es/components/cascader-panel/src/node2.mjs.map +1 -1
  80. package/es/components/cascader-panel/src/store.mjs +1 -1
  81. package/es/components/check-tag/index.mjs +2 -2
  82. package/es/components/check-tag/src/check-tag.mjs +38 -14
  83. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  84. package/es/components/check-tag/src/check-tag2.mjs +14 -38
  85. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  86. package/es/components/collection/index.mjs +1 -1
  87. package/es/components/collection/src/collection.mjs +10 -62
  88. package/es/components/collection/src/collection.mjs.map +1 -1
  89. package/es/components/collection/src/collection2.mjs +62 -10
  90. package/es/components/collection/src/collection2.mjs.map +1 -1
  91. package/es/components/color-picker/index.mjs +2 -2
  92. package/es/components/color-picker/src/color-picker.mjs +399 -44
  93. package/es/components/color-picker/src/color-picker.mjs.map +1 -1
  94. package/es/components/color-picker/src/color-picker2.mjs +44 -399
  95. package/es/components/color-picker/src/color-picker2.mjs.map +1 -1
  96. package/es/components/color-picker/src/components/predefine.mjs +1 -1
  97. package/es/components/descriptions/index.mjs +2 -2
  98. package/es/components/descriptions/src/description.mjs +30 -164
  99. package/es/components/descriptions/src/description.mjs.map +1 -1
  100. package/es/components/descriptions/src/description2.mjs +164 -30
  101. package/es/components/descriptions/src/description2.mjs.map +1 -1
  102. package/es/components/descriptions/src/descriptions-row.mjs +6 -63
  103. package/es/components/descriptions/src/descriptions-row.mjs.map +1 -1
  104. package/es/components/descriptions/src/descriptions-row2.mjs +63 -6
  105. package/es/components/descriptions/src/descriptions-row2.mjs.map +1 -1
  106. package/es/components/dialog/index.mjs +2 -2
  107. package/es/components/dialog/src/dialog.mjs +192 -81
  108. package/es/components/dialog/src/dialog.mjs.map +1 -1
  109. package/es/components/dialog/src/dialog2.mjs +81 -192
  110. package/es/components/dialog/src/dialog2.mjs.map +1 -1
  111. package/es/components/divider/index.mjs +2 -2
  112. package/es/components/divider/src/divider.mjs +16 -34
  113. package/es/components/divider/src/divider.mjs.map +1 -1
  114. package/es/components/divider/src/divider2.mjs +34 -16
  115. package/es/components/divider/src/divider2.mjs.map +1 -1
  116. package/es/components/drawer/src/drawer.mjs +1 -1
  117. package/es/components/dropdown/src/dropdown-item-impl.mjs +2 -2
  118. package/es/components/dropdown/src/dropdown-menu.mjs +1 -1
  119. package/es/components/dropdown/src/dropdown.mjs +2 -2
  120. package/es/components/dropdown/src/dropdown2.mjs +1 -1
  121. package/es/components/empty/index.mjs +2 -2
  122. package/es/components/empty/src/empty.mjs +11 -52
  123. package/es/components/empty/src/empty.mjs.map +1 -1
  124. package/es/components/empty/src/empty2.mjs +52 -11
  125. package/es/components/empty/src/empty2.mjs.map +1 -1
  126. package/es/components/form/index.mjs +2 -2
  127. package/es/components/form/src/form-item.mjs +371 -56
  128. package/es/components/form/src/form-item.mjs.map +1 -1
  129. package/es/components/form/src/form-item2.mjs +56 -371
  130. package/es/components/form/src/form-item2.mjs.map +1 -1
  131. package/es/components/index.mjs +45 -45
  132. package/es/components/link/index.mjs +2 -2
  133. package/es/components/link/src/link.mjs +25 -71
  134. package/es/components/link/src/link.mjs.map +1 -1
  135. package/es/components/link/src/link2.mjs +71 -25
  136. package/es/components/link/src/link2.mjs.map +1 -1
  137. package/es/components/pagination/src/components/pager.mjs +210 -16
  138. package/es/components/pagination/src/components/pager.mjs.map +1 -1
  139. package/es/components/pagination/src/components/pager2.mjs +16 -210
  140. package/es/components/pagination/src/components/pager2.mjs.map +1 -1
  141. package/es/components/pagination/src/components/prev.mjs +35 -17
  142. package/es/components/pagination/src/components/prev.mjs.map +1 -1
  143. package/es/components/pagination/src/components/prev2.mjs +17 -35
  144. package/es/components/pagination/src/components/prev2.mjs.map +1 -1
  145. package/es/components/pagination/src/components/total.mjs +6 -26
  146. package/es/components/pagination/src/components/total.mjs.map +1 -1
  147. package/es/components/pagination/src/components/total2.mjs +26 -6
  148. package/es/components/pagination/src/components/total2.mjs.map +1 -1
  149. package/es/components/pagination/src/pagination.mjs +3 -3
  150. package/es/components/popconfirm/src/popconfirm2.mjs +1 -1
  151. package/es/components/popover/src/popover2.mjs +1 -1
  152. package/es/components/popper/index.mjs +4 -4
  153. package/es/components/popper/src/arrow.mjs +30 -7
  154. package/es/components/popper/src/arrow.mjs.map +1 -1
  155. package/es/components/popper/src/arrow2.mjs +7 -30
  156. package/es/components/popper/src/arrow2.mjs.map +1 -1
  157. package/es/components/popper/src/content.mjs +1 -1
  158. package/es/components/popper/src/trigger.mjs +127 -31
  159. package/es/components/popper/src/trigger.mjs.map +1 -1
  160. package/es/components/popper/src/trigger2.mjs +31 -127
  161. package/es/components/popper/src/trigger2.mjs.map +1 -1
  162. package/es/components/radio/index.mjs +2 -2
  163. package/es/components/radio/src/radio-button.mjs +1 -1
  164. package/es/components/radio/src/radio-group copy.mjs +1 -1
  165. package/es/components/radio/src/radio-group.mjs +1 -1
  166. package/es/components/radio/src/radio-group2.mjs +1 -1
  167. package/es/components/radio/src/radio.mjs +83 -32
  168. package/es/components/radio/src/radio.mjs.map +1 -1
  169. package/es/components/radio/src/radio2.mjs +32 -83
  170. package/es/components/radio/src/radio2.mjs.map +1 -1
  171. package/es/components/roving-focus-group/index.mjs +3 -3
  172. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  173. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -27
  174. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  175. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +27 -27
  176. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  177. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  178. package/es/components/row/index.mjs +2 -2
  179. package/es/components/row/src/row.mjs +51 -28
  180. package/es/components/row/src/row.mjs.map +1 -1
  181. package/es/components/row/src/row2.mjs +28 -51
  182. package/es/components/row/src/row2.mjs.map +1 -1
  183. package/es/components/scrollbar/index.mjs +2 -2
  184. package/es/components/scrollbar/src/bar.mjs +10 -64
  185. package/es/components/scrollbar/src/bar.mjs.map +1 -1
  186. package/es/components/scrollbar/src/bar2.mjs +64 -10
  187. package/es/components/scrollbar/src/bar2.mjs.map +1 -1
  188. package/es/components/scrollbar/src/scrollbar.mjs +187 -53
  189. package/es/components/scrollbar/src/scrollbar.mjs.map +1 -1
  190. package/es/components/scrollbar/src/scrollbar2.mjs +53 -187
  191. package/es/components/scrollbar/src/scrollbar2.mjs.map +1 -1
  192. package/es/components/segmented/index.mjs +2 -2
  193. package/es/components/segmented/src/segmented.mjs +42 -168
  194. package/es/components/segmented/src/segmented.mjs.map +1 -1
  195. package/es/components/segmented/src/segmented2.mjs +168 -42
  196. package/es/components/segmented/src/segmented2.mjs.map +1 -1
  197. package/es/components/select/index.mjs +1 -1
  198. package/es/components/select/src/option.mjs +13 -104
  199. package/es/components/select/src/option.mjs.map +1 -1
  200. package/es/components/select/src/option2.mjs +104 -13
  201. package/es/components/select/src/option2.mjs.map +1 -1
  202. package/es/components/select/src/select.mjs +1 -1
  203. package/es/components/select/src/select2.mjs +1 -1
  204. package/es/components/select/src/useOption.mjs +1 -1
  205. package/es/components/slider-block-vertify/index.mjs +2 -2
  206. package/es/components/slider-block-vertify/src/slider-block-vertify.mjs +196 -4
  207. package/es/components/slider-block-vertify/src/slider-block-vertify.mjs.map +1 -1
  208. package/es/components/slider-block-vertify/src/slider-block-vertify2.mjs +4 -196
  209. package/es/components/slider-block-vertify/src/slider-block-vertify2.mjs.map +1 -1
  210. package/es/components/splitter/index.mjs +2 -2
  211. package/es/components/splitter/src/split-panel.mjs +152 -17
  212. package/es/components/splitter/src/split-panel.mjs.map +1 -1
  213. package/es/components/splitter/src/split-panel2.mjs +17 -152
  214. package/es/components/splitter/src/split-panel2.mjs.map +1 -1
  215. package/es/components/statistic/index.mjs +2 -2
  216. package/es/components/statistic/src/statistic.mjs +25 -69
  217. package/es/components/statistic/src/statistic.mjs.map +1 -1
  218. package/es/components/statistic/src/statistic2.mjs +69 -25
  219. package/es/components/statistic/src/statistic2.mjs.map +1 -1
  220. package/es/components/steps/index.mjs +2 -2
  221. package/es/components/steps/src/item.mjs +192 -19
  222. package/es/components/steps/src/item.mjs.map +1 -1
  223. package/es/components/steps/src/item2.mjs +19 -192
  224. package/es/components/steps/src/item2.mjs.map +1 -1
  225. package/es/components/switch/index.mjs +2 -2
  226. package/es/components/switch/src/switch.mjs +72 -228
  227. package/es/components/switch/src/switch.mjs.map +1 -1
  228. package/es/components/switch/src/switch2.mjs +228 -72
  229. package/es/components/switch/src/switch2.mjs.map +1 -1
  230. package/es/components/tabs/index.mjs +3 -3
  231. package/es/components/tabs/src/tab-bar.mjs +11 -87
  232. package/es/components/tabs/src/tab-bar.mjs.map +1 -1
  233. package/es/components/tabs/src/tab-bar2.mjs +87 -11
  234. package/es/components/tabs/src/tab-bar2.mjs.map +1 -1
  235. package/es/components/tabs/src/tab-nav.mjs +1 -1
  236. package/es/components/tabs/src/tab-pane.mjs +82 -13
  237. package/es/components/tabs/src/tab-pane.mjs.map +1 -1
  238. package/es/components/tabs/src/tab-pane2.mjs +13 -82
  239. package/es/components/tabs/src/tab-pane2.mjs.map +1 -1
  240. package/es/components/tooltip/index.mjs +3 -3
  241. package/es/components/tooltip/src/tooltip.mjs +30 -169
  242. package/es/components/tooltip/src/tooltip.mjs.map +1 -1
  243. package/es/components/tooltip/src/tooltip2.mjs +169 -30
  244. package/es/components/tooltip/src/tooltip2.mjs.map +1 -1
  245. package/es/components/tooltip/src/trigger.mjs +14 -72
  246. package/es/components/tooltip/src/trigger.mjs.map +1 -1
  247. package/es/components/tooltip/src/trigger2.mjs +72 -14
  248. package/es/components/tooltip/src/trigger2.mjs.map +1 -1
  249. package/es/components/tooltip-v2/index.mjs +2 -2
  250. package/es/components/tooltip-v2/src/content.mjs +110 -48
  251. package/es/components/tooltip-v2/src/content.mjs.map +1 -1
  252. package/es/components/tooltip-v2/src/content2.mjs +48 -110
  253. package/es/components/tooltip-v2/src/content2.mjs.map +1 -1
  254. package/es/components/tooltip-v2/src/root.mjs +79 -17
  255. package/es/components/tooltip-v2/src/root.mjs.map +1 -1
  256. package/es/components/tooltip-v2/src/root2.mjs +17 -79
  257. package/es/components/tooltip-v2/src/root2.mjs.map +1 -1
  258. package/es/components/tooltip-v2/src/tooltip.mjs +4 -4
  259. package/es/components/tooltip-v2/src/tooltip2.mjs +2 -2
  260. package/es/components/tour/index.mjs +3 -3
  261. package/es/components/tour/src/content.mjs +67 -43
  262. package/es/components/tour/src/content.mjs.map +1 -1
  263. package/es/components/tour/src/content2.mjs +43 -67
  264. package/es/components/tour/src/content2.mjs.map +1 -1
  265. package/es/components/tour/src/mask.mjs +18 -75
  266. package/es/components/tour/src/mask.mjs.map +1 -1
  267. package/es/components/tour/src/mask2.mjs +75 -18
  268. package/es/components/tour/src/mask2.mjs.map +1 -1
  269. package/es/components/tour/src/step.mjs +168 -44
  270. package/es/components/tour/src/step.mjs.map +1 -1
  271. package/es/components/tour/src/step2.mjs +44 -168
  272. package/es/components/tour/src/step2.mjs.map +1 -1
  273. package/es/components/tour/src/tour.mjs +1 -1
  274. package/es/components/tour/src/tour2.mjs +2 -2
  275. package/es/components/transfer/src/composables/use-check.mjs +1 -1
  276. package/es/components/transfer/src/transfer-panel.mjs +19 -130
  277. package/es/components/transfer/src/transfer-panel.mjs.map +1 -1
  278. package/es/components/transfer/src/transfer-panel2.mjs +130 -19
  279. package/es/components/transfer/src/transfer-panel2.mjs.map +1 -1
  280. package/es/components/transfer/src/transfer.mjs +1 -1
  281. package/es/components/upload/index.mjs +2 -2
  282. package/es/components/upload/src/upload-content.mjs +1 -1
  283. package/es/components/upload/src/upload-content2.mjs +1 -1
  284. package/es/components/upload/src/upload-list.mjs +1 -1
  285. package/es/components/upload/src/upload.mjs +97 -125
  286. package/es/components/upload/src/upload.mjs.map +1 -1
  287. package/es/components/upload/src/upload2.mjs +125 -97
  288. package/es/components/upload/src/upload2.mjs.map +1 -1
  289. package/es/components/upload/src/use-handlers.mjs +1 -1
  290. package/es/components/visual-hidden/index.mjs +3 -3
  291. package/es/components/visual-hidden/src/visual-hidden.mjs +35 -6
  292. package/es/components/visual-hidden/src/visual-hidden.mjs.map +1 -1
  293. package/es/components/visual-hidden/src/visual-hidden2.mjs +6 -35
  294. package/es/components/visual-hidden/src/visual-hidden2.mjs.map +1 -1
  295. package/es/components/watermark/index.mjs +2 -2
  296. package/es/components/watermark/src/watermark.mjs +27 -220
  297. package/es/components/watermark/src/watermark.mjs.map +1 -1
  298. package/es/components/watermark/src/watermark2.mjs +220 -27
  299. package/es/components/watermark/src/watermark2.mjs.map +1 -1
  300. package/es/directives/click-outside/index.mjs +1 -1
  301. package/es/hooks/use-focus-controller/index.mjs +1 -1
  302. package/es/hooks/use-lockscreen/index.mjs +1 -1
  303. package/es/index.mjs +45 -45
  304. package/lib/components/alert/index.js +2 -2
  305. package/lib/components/alert/src/alert.js +42 -107
  306. package/lib/components/alert/src/alert.js.map +1 -1
  307. package/lib/components/alert/src/alert2.js +107 -42
  308. package/lib/components/alert/src/alert2.js.map +1 -1
  309. package/lib/components/anchor/index.js +3 -3
  310. package/lib/components/anchor/src/anchor-link.js +80 -5
  311. package/lib/components/anchor/src/anchor-link.js.map +1 -1
  312. package/lib/components/anchor/src/anchor-link2.js +5 -80
  313. package/lib/components/anchor/src/anchor-link2.js.map +1 -1
  314. package/lib/components/anchor/src/anchor.js +42 -205
  315. package/lib/components/anchor/src/anchor.js.map +1 -1
  316. package/lib/components/anchor/src/anchor2.js +205 -42
  317. package/lib/components/anchor/src/anchor2.js.map +1 -1
  318. package/lib/components/autocomplete/index.js +2 -2
  319. package/lib/components/autocomplete/src/autocomplete.js +57 -364
  320. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  321. package/lib/components/autocomplete/src/autocomplete2.js +364 -57
  322. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  323. package/lib/components/backtop/index.js +2 -2
  324. package/lib/components/backtop/src/backtop.js +22 -53
  325. package/lib/components/backtop/src/backtop.js.map +1 -1
  326. package/lib/components/backtop/src/backtop2.js +53 -22
  327. package/lib/components/backtop/src/backtop2.js.map +1 -1
  328. package/lib/components/badge/index.js +2 -2
  329. package/lib/components/badge/src/badge.js +71 -32
  330. package/lib/components/badge/src/badge.js.map +1 -1
  331. package/lib/components/badge/src/badge2.js +32 -71
  332. package/lib/components/badge/src/badge2.js.map +1 -1
  333. package/lib/components/breadcrumb/index.js +2 -2
  334. package/lib/components/breadcrumb/src/breadcrumb.js +10 -37
  335. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  336. package/lib/components/breadcrumb/src/breadcrumb2.js +37 -10
  337. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  338. package/lib/components/button/index.js +3 -3
  339. package/lib/components/button/src/button-group.js +29 -6
  340. package/lib/components/button/src/button-group.js.map +1 -1
  341. package/lib/components/button/src/button-group2.js +6 -29
  342. package/lib/components/button/src/button-group2.js.map +1 -1
  343. package/lib/components/button/src/button.js +65 -87
  344. package/lib/components/button/src/button.js.map +1 -1
  345. package/lib/components/button/src/button2.js +87 -65
  346. package/lib/components/button/src/button2.js.map +1 -1
  347. package/lib/components/calendar/index.js +2 -2
  348. package/lib/components/calendar/src/calendar.js +45 -377
  349. package/lib/components/calendar/src/calendar.js.map +1 -1
  350. package/lib/components/calendar/src/calendar2.js +377 -45
  351. package/lib/components/calendar/src/calendar2.js.map +1 -1
  352. package/lib/components/calendar/src/date-table.js +35 -89
  353. package/lib/components/calendar/src/date-table.js.map +1 -1
  354. package/lib/components/calendar/src/date-table2.js +89 -35
  355. package/lib/components/calendar/src/date-table2.js.map +1 -1
  356. package/lib/components/calendar/src/use-date-table.js +1 -1
  357. package/lib/components/card/index.js +2 -2
  358. package/lib/components/card/src/card.js +22 -42
  359. package/lib/components/card/src/card.js.map +1 -1
  360. package/lib/components/card/src/card2.js +42 -22
  361. package/lib/components/card/src/card2.js.map +1 -1
  362. package/lib/components/carousel/index.js +4 -4
  363. package/lib/components/carousel/src/carousel-item.js +7 -69
  364. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  365. package/lib/components/carousel/src/carousel-item2.js +69 -7
  366. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  367. package/lib/components/carousel/src/carousel.js +214 -62
  368. package/lib/components/carousel/src/carousel.js.map +1 -1
  369. package/lib/components/carousel/src/carousel2.js +62 -214
  370. package/lib/components/carousel/src/carousel2.js.map +1 -1
  371. package/lib/components/cascader/index.js +2 -2
  372. package/lib/components/cascader/src/cascader.js +719 -94
  373. package/lib/components/cascader/src/cascader.js.map +1 -1
  374. package/lib/components/cascader/src/cascader2.js +94 -719
  375. package/lib/components/cascader/src/cascader2.js.map +1 -1
  376. package/lib/components/cascader-panel/src/index.js +1 -1
  377. package/lib/components/cascader-panel/src/menu.js +1 -1
  378. package/lib/components/cascader-panel/src/node.js +115 -194
  379. package/lib/components/cascader-panel/src/node.js.map +1 -1
  380. package/lib/components/cascader-panel/src/node2.js +194 -115
  381. package/lib/components/cascader-panel/src/node2.js.map +1 -1
  382. package/lib/components/cascader-panel/src/store.js +1 -1
  383. package/lib/components/check-tag/index.js +2 -2
  384. package/lib/components/check-tag/src/check-tag.js +38 -15
  385. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  386. package/lib/components/check-tag/src/check-tag2.js +15 -38
  387. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  388. package/lib/components/collection/index.js +1 -1
  389. package/lib/components/collection/src/collection.js +9 -62
  390. package/lib/components/collection/src/collection.js.map +1 -1
  391. package/lib/components/collection/src/collection2.js +62 -9
  392. package/lib/components/collection/src/collection2.js.map +1 -1
  393. package/lib/components/color-picker/index.js +2 -2
  394. package/lib/components/color-picker/src/color-picker.js +398 -45
  395. package/lib/components/color-picker/src/color-picker.js.map +1 -1
  396. package/lib/components/color-picker/src/color-picker2.js +45 -398
  397. package/lib/components/color-picker/src/color-picker2.js.map +1 -1
  398. package/lib/components/color-picker/src/components/predefine.js +1 -1
  399. package/lib/components/descriptions/index.js +2 -2
  400. package/lib/components/descriptions/src/description.js +30 -164
  401. package/lib/components/descriptions/src/description.js.map +1 -1
  402. package/lib/components/descriptions/src/description2.js +164 -30
  403. package/lib/components/descriptions/src/description2.js.map +1 -1
  404. package/lib/components/descriptions/src/descriptions-row.js +6 -63
  405. package/lib/components/descriptions/src/descriptions-row.js.map +1 -1
  406. package/lib/components/descriptions/src/descriptions-row2.js +63 -6
  407. package/lib/components/descriptions/src/descriptions-row2.js.map +1 -1
  408. package/lib/components/dialog/index.js +2 -2
  409. package/lib/components/dialog/src/dialog.js +192 -82
  410. package/lib/components/dialog/src/dialog.js.map +1 -1
  411. package/lib/components/dialog/src/dialog2.js +82 -192
  412. package/lib/components/dialog/src/dialog2.js.map +1 -1
  413. package/lib/components/divider/index.js +2 -2
  414. package/lib/components/divider/src/divider.js +16 -34
  415. package/lib/components/divider/src/divider.js.map +1 -1
  416. package/lib/components/divider/src/divider2.js +34 -16
  417. package/lib/components/divider/src/divider2.js.map +1 -1
  418. package/lib/components/drawer/src/drawer.js +1 -1
  419. package/lib/components/dropdown/src/dropdown-item-impl.js +2 -2
  420. package/lib/components/dropdown/src/dropdown-menu.js +1 -1
  421. package/lib/components/dropdown/src/dropdown.js +2 -2
  422. package/lib/components/dropdown/src/dropdown2.js +1 -1
  423. package/lib/components/empty/index.js +2 -2
  424. package/lib/components/empty/src/empty.js +11 -52
  425. package/lib/components/empty/src/empty.js.map +1 -1
  426. package/lib/components/empty/src/empty2.js +52 -11
  427. package/lib/components/empty/src/empty2.js.map +1 -1
  428. package/lib/components/form/index.js +2 -2
  429. package/lib/components/form/src/form-item.js +375 -57
  430. package/lib/components/form/src/form-item.js.map +1 -1
  431. package/lib/components/form/src/form-item2.js +57 -375
  432. package/lib/components/form/src/form-item2.js.map +1 -1
  433. package/lib/components/index.js +50 -50
  434. package/lib/components/link/index.js +2 -2
  435. package/lib/components/link/src/link.js +26 -71
  436. package/lib/components/link/src/link.js.map +1 -1
  437. package/lib/components/link/src/link2.js +71 -26
  438. package/lib/components/link/src/link2.js.map +1 -1
  439. package/lib/components/pagination/src/components/pager.js +210 -16
  440. package/lib/components/pagination/src/components/pager.js.map +1 -1
  441. package/lib/components/pagination/src/components/pager2.js +16 -210
  442. package/lib/components/pagination/src/components/pager2.js.map +1 -1
  443. package/lib/components/pagination/src/components/prev.js +35 -18
  444. package/lib/components/pagination/src/components/prev.js.map +1 -1
  445. package/lib/components/pagination/src/components/prev2.js +18 -35
  446. package/lib/components/pagination/src/components/prev2.js.map +1 -1
  447. package/lib/components/pagination/src/components/total.js +6 -26
  448. package/lib/components/pagination/src/components/total.js.map +1 -1
  449. package/lib/components/pagination/src/components/total2.js +26 -6
  450. package/lib/components/pagination/src/components/total2.js.map +1 -1
  451. package/lib/components/pagination/src/pagination.js +3 -3
  452. package/lib/components/popconfirm/src/popconfirm2.js +1 -1
  453. package/lib/components/popover/src/popover2.js +1 -1
  454. package/lib/components/popper/index.js +4 -4
  455. package/lib/components/popper/src/arrow.js +30 -8
  456. package/lib/components/popper/src/arrow.js.map +1 -1
  457. package/lib/components/popper/src/arrow2.js +8 -30
  458. package/lib/components/popper/src/arrow2.js.map +1 -1
  459. package/lib/components/popper/src/content.js +1 -1
  460. package/lib/components/popper/src/trigger.js +127 -32
  461. package/lib/components/popper/src/trigger.js.map +1 -1
  462. package/lib/components/popper/src/trigger2.js +32 -127
  463. package/lib/components/popper/src/trigger2.js.map +1 -1
  464. package/lib/components/radio/index.js +2 -2
  465. package/lib/components/radio/src/radio-button.js +1 -1
  466. package/lib/components/radio/src/radio-group copy.js +1 -1
  467. package/lib/components/radio/src/radio-group.js +1 -1
  468. package/lib/components/radio/src/radio-group2.js +1 -1
  469. package/lib/components/radio/src/radio.js +82 -33
  470. package/lib/components/radio/src/radio.js.map +1 -1
  471. package/lib/components/radio/src/radio2.js +33 -82
  472. package/lib/components/radio/src/radio2.js.map +1 -1
  473. package/lib/components/roving-focus-group/index.js +2 -2
  474. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  475. package/lib/components/roving-focus-group/src/roving-focus-group.js +31 -27
  476. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  477. package/lib/components/roving-focus-group/src/roving-focus-group2.js +27 -31
  478. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  479. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  480. package/lib/components/row/index.js +2 -2
  481. package/lib/components/row/src/row.js +51 -30
  482. package/lib/components/row/src/row.js.map +1 -1
  483. package/lib/components/row/src/row2.js +30 -51
  484. package/lib/components/row/src/row2.js.map +1 -1
  485. package/lib/components/scrollbar/index.js +2 -2
  486. package/lib/components/scrollbar/src/bar.js +10 -64
  487. package/lib/components/scrollbar/src/bar.js.map +1 -1
  488. package/lib/components/scrollbar/src/bar2.js +64 -10
  489. package/lib/components/scrollbar/src/bar2.js.map +1 -1
  490. package/lib/components/scrollbar/src/scrollbar.js +187 -54
  491. package/lib/components/scrollbar/src/scrollbar.js.map +1 -1
  492. package/lib/components/scrollbar/src/scrollbar2.js +54 -187
  493. package/lib/components/scrollbar/src/scrollbar2.js.map +1 -1
  494. package/lib/components/segmented/index.js +2 -2
  495. package/lib/components/segmented/src/segmented.js +44 -168
  496. package/lib/components/segmented/src/segmented.js.map +1 -1
  497. package/lib/components/segmented/src/segmented2.js +168 -44
  498. package/lib/components/segmented/src/segmented2.js.map +1 -1
  499. package/lib/components/select/index.js +1 -1
  500. package/lib/components/select/src/option.js +14 -104
  501. package/lib/components/select/src/option.js.map +1 -1
  502. package/lib/components/select/src/option2.js +104 -14
  503. package/lib/components/select/src/option2.js.map +1 -1
  504. package/lib/components/select/src/select.js +1 -1
  505. package/lib/components/select/src/select2.js +1 -1
  506. package/lib/components/select/src/useOption.js +1 -1
  507. package/lib/components/slider-block-vertify/index.js +2 -2
  508. package/lib/components/slider-block-vertify/src/slider-block-vertify.js +196 -5
  509. package/lib/components/slider-block-vertify/src/slider-block-vertify.js.map +1 -1
  510. package/lib/components/slider-block-vertify/src/slider-block-vertify2.js +5 -196
  511. package/lib/components/slider-block-vertify/src/slider-block-vertify2.js.map +1 -1
  512. package/lib/components/splitter/index.js +2 -2
  513. package/lib/components/splitter/src/split-panel.js +152 -17
  514. package/lib/components/splitter/src/split-panel.js.map +1 -1
  515. package/lib/components/splitter/src/split-panel2.js +17 -152
  516. package/lib/components/splitter/src/split-panel2.js.map +1 -1
  517. package/lib/components/statistic/index.js +2 -2
  518. package/lib/components/statistic/src/statistic.js +25 -69
  519. package/lib/components/statistic/src/statistic.js.map +1 -1
  520. package/lib/components/statistic/src/statistic2.js +69 -25
  521. package/lib/components/statistic/src/statistic2.js.map +1 -1
  522. package/lib/components/steps/index.js +2 -2
  523. package/lib/components/steps/src/item.js +192 -19
  524. package/lib/components/steps/src/item.js.map +1 -1
  525. package/lib/components/steps/src/item2.js +19 -192
  526. package/lib/components/steps/src/item2.js.map +1 -1
  527. package/lib/components/switch/index.js +2 -2
  528. package/lib/components/switch/src/switch.js +72 -227
  529. package/lib/components/switch/src/switch.js.map +1 -1
  530. package/lib/components/switch/src/switch2.js +227 -72
  531. package/lib/components/switch/src/switch2.js.map +1 -1
  532. package/lib/components/tabs/index.js +3 -3
  533. package/lib/components/tabs/src/tab-bar.js +11 -87
  534. package/lib/components/tabs/src/tab-bar.js.map +1 -1
  535. package/lib/components/tabs/src/tab-bar2.js +87 -11
  536. package/lib/components/tabs/src/tab-bar2.js.map +1 -1
  537. package/lib/components/tabs/src/tab-nav.js +1 -1
  538. package/lib/components/tabs/src/tab-pane.js +82 -13
  539. package/lib/components/tabs/src/tab-pane.js.map +1 -1
  540. package/lib/components/tabs/src/tab-pane2.js +13 -82
  541. package/lib/components/tabs/src/tab-pane2.js.map +1 -1
  542. package/lib/components/tooltip/index.js +3 -3
  543. package/lib/components/tooltip/src/tooltip.js +32 -167
  544. package/lib/components/tooltip/src/tooltip.js.map +1 -1
  545. package/lib/components/tooltip/src/tooltip2.js +167 -32
  546. package/lib/components/tooltip/src/tooltip2.js.map +1 -1
  547. package/lib/components/tooltip/src/trigger.js +14 -72
  548. package/lib/components/tooltip/src/trigger.js.map +1 -1
  549. package/lib/components/tooltip/src/trigger2.js +72 -14
  550. package/lib/components/tooltip/src/trigger2.js.map +1 -1
  551. package/lib/components/tooltip-v2/index.js +2 -2
  552. package/lib/components/tooltip-v2/src/content.js +110 -48
  553. package/lib/components/tooltip-v2/src/content.js.map +1 -1
  554. package/lib/components/tooltip-v2/src/content2.js +48 -110
  555. package/lib/components/tooltip-v2/src/content2.js.map +1 -1
  556. package/lib/components/tooltip-v2/src/root.js +79 -17
  557. package/lib/components/tooltip-v2/src/root.js.map +1 -1
  558. package/lib/components/tooltip-v2/src/root2.js +17 -79
  559. package/lib/components/tooltip-v2/src/root2.js.map +1 -1
  560. package/lib/components/tooltip-v2/src/tooltip.js +4 -4
  561. package/lib/components/tooltip-v2/src/tooltip2.js +2 -2
  562. package/lib/components/tour/index.js +3 -3
  563. package/lib/components/tour/src/content.js +67 -46
  564. package/lib/components/tour/src/content.js.map +1 -1
  565. package/lib/components/tour/src/content2.js +46 -67
  566. package/lib/components/tour/src/content2.js.map +1 -1
  567. package/lib/components/tour/src/mask.js +18 -75
  568. package/lib/components/tour/src/mask.js.map +1 -1
  569. package/lib/components/tour/src/mask2.js +75 -18
  570. package/lib/components/tour/src/mask2.js.map +1 -1
  571. package/lib/components/tour/src/step.js +167 -44
  572. package/lib/components/tour/src/step.js.map +1 -1
  573. package/lib/components/tour/src/step2.js +44 -167
  574. package/lib/components/tour/src/step2.js.map +1 -1
  575. package/lib/components/tour/src/tour.js +1 -1
  576. package/lib/components/tour/src/tour2.js +2 -2
  577. package/lib/components/transfer/src/composables/use-check.js +1 -1
  578. package/lib/components/transfer/src/transfer-panel.js +21 -130
  579. package/lib/components/transfer/src/transfer-panel.js.map +1 -1
  580. package/lib/components/transfer/src/transfer-panel2.js +130 -21
  581. package/lib/components/transfer/src/transfer-panel2.js.map +1 -1
  582. package/lib/components/transfer/src/transfer.js +1 -1
  583. package/lib/components/upload/index.js +2 -2
  584. package/lib/components/upload/src/upload-content.js +1 -1
  585. package/lib/components/upload/src/upload-content2.js +1 -1
  586. package/lib/components/upload/src/upload-list.js +1 -1
  587. package/lib/components/upload/src/upload.js +100 -125
  588. package/lib/components/upload/src/upload.js.map +1 -1
  589. package/lib/components/upload/src/upload2.js +125 -100
  590. package/lib/components/upload/src/upload2.js.map +1 -1
  591. package/lib/components/upload/src/use-handlers.js +1 -1
  592. package/lib/components/visual-hidden/index.js +2 -2
  593. package/lib/components/visual-hidden/src/visual-hidden.js +35 -6
  594. package/lib/components/visual-hidden/src/visual-hidden.js.map +1 -1
  595. package/lib/components/visual-hidden/src/visual-hidden2.js +6 -35
  596. package/lib/components/visual-hidden/src/visual-hidden2.js.map +1 -1
  597. package/lib/components/watermark/index.js +2 -2
  598. package/lib/components/watermark/src/watermark.js +27 -220
  599. package/lib/components/watermark/src/watermark.js.map +1 -1
  600. package/lib/components/watermark/src/watermark2.js +220 -27
  601. package/lib/components/watermark/src/watermark2.js.map +1 -1
  602. package/lib/directives/click-outside/index.js +1 -1
  603. package/lib/hooks/use-focus-controller/index.js +1 -1
  604. package/lib/hooks/use-lockscreen/index.js +1 -1
  605. package/lib/index.js +50 -50
  606. package/package.json +1 -1
  607. package/theme-chalk/index.css +1 -1
  608. package/theme-chalk/sl-calendar.css +1 -1
  609. package/theme-chalk/src/calendar.scss +1 -1
  610. package/web-types.json +1 -1
@@ -1,199 +1,7 @@
1
- import { defineComponent, computed, ref, onMounted, onUnmounted, resolveComponent, openBlock, createElementBlock, normalizeClass, unref, normalizeStyle, createElementVNode, createBlock, withCtx, createVNode, toDisplayString } from 'vue';
2
- import { sum, square } from './sliderVertify.mjs';
3
- import { Loading, SuccessFilled, DArrowRight } from '@sl-design/icons-vue';
4
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
5
- import { useLocale } from '../../../hooks/use-locale/index.mjs';
6
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
1
+ import { buildProps } from '../../../utils/vue/props/runtime.mjs';
7
2
 
8
- const __default__ = defineComponent({
9
- name: "SlSliderBlockVertify"
10
- });
11
- const _sfc_main = /* @__PURE__ */ defineComponent({
12
- ...__default__,
13
- props: {
14
- placeholder: {
15
- type: String,
16
- default: ""
17
- },
18
- width: {
19
- type: Number,
20
- default: 330
21
- },
22
- height: {
23
- type: Number,
24
- default: 40
25
- },
26
- successText: {
27
- type: String,
28
- default: ""
29
- },
30
- onVertify: {
31
- type: Function,
32
- required: false
33
- },
34
- loadingText: {
35
- type: String,
36
- default: ""
37
- }
38
- },
39
- emits: ["handleSuccess", "handleFail"],
40
- setup(__props, { expose, emit: emits }) {
41
- const props = __props;
42
- const { t } = useLocale();
43
- const ns = useNamespace("slider-verify");
44
- const width = computed(() => props.width || Number.parseInt(getComputedStyle(document.documentElement).getPropertyValue("--sl-slider-verify-width")));
45
- const height = computed(() => props.height || Number.parseInt(getComputedStyle(document.documentElement).getPropertyValue("--sl-slider-verify-height")));
46
- const defaultPlaceholder = t("el.sliderBlockVertify.defaultPlaceholder");
47
- const defaultSuccessText = t("el.sliderBlockVertify.defaultSuccessText");
48
- const defaultLoadingText = t("el.sliderBlockVertify.defaultLoadingText");
49
- const currentLoadingText = computed(() => props.loadingText || defaultLoadingText);
50
- const textTip = ref(props.placeholder || defaultPlaceholder);
51
- const sliderLeft = ref(0);
52
- const trailRef = ref([]);
53
- const isMouseDownRef = ref(false);
54
- const isActive = ref(false);
55
- const isSuccess = ref(false);
56
- const isFail = ref(false);
57
- const originX = ref(0);
58
- const originY = ref(0);
59
- const isLoading = ref(false);
60
- const handleDragStart = (e) => {
61
- originX.value = e.clientX || e.touches[0].clientX;
62
- originY.value = e.clientY || e.touches[0].clientY;
63
- isMouseDownRef.value = true;
64
- };
65
- const handleDragMove = async (e) => {
66
- if (!isMouseDownRef.value)
67
- return;
68
- e.preventDefault();
69
- const eventX = e.clientX || e.touches[0].clientX;
70
- const eventY = e.clientY || e.touches[0].clientY;
71
- const moveX = eventX - originX.value;
72
- const moveY = eventY - originY.value;
73
- isActive.value = true;
74
- trailRef.value.push(moveY);
75
- if (moveX < 0) {
76
- sliderLeft.value = 0;
77
- return;
78
- }
79
- if (moveX + 40 >= width.value) {
80
- isMouseDownRef.value = false;
81
- isActive.value = false;
82
- sliderLeft.value = width.value - 40;
83
- const verified = verify();
84
- if (verified) {
85
- if (props.onVertify && typeof props.onVertify === "function") {
86
- isLoading.value = true;
87
- const res = await props.onVertify({ moveX, verified });
88
- isLoading.value = false;
89
- res ? verifySuccess(moveX, verified) : reset();
90
- } else {
91
- verifySuccess(moveX, verified);
92
- }
93
- } else {
94
- isFail.value = true;
95
- textTip.value = "\u8BF7\u518D\u8BD5\u4E00\u6B21";
96
- emits("handleFail");
97
- reset();
98
- }
99
- return;
100
- }
101
- sliderLeft.value = moveX;
102
- };
103
- const handleDragEnd = () => {
104
- if (!isMouseDownRef.value)
105
- return;
106
- emits("handleFail");
107
- reset();
108
- };
109
- const verify = () => {
110
- const arr = trailRef.value;
111
- const average = arr.reduce(sum) / arr.length;
112
- const deviations = arr.map((x) => x - average);
113
- const stddev = Math.sqrt(deviations.map(square).reduce(sum) / arr.length);
114
- return stddev !== 0;
115
- };
116
- const verifySuccess = (moveX, verified) => {
117
- isSuccess.value = true;
118
- textTip.value = props.successText || defaultSuccessText;
119
- emits("handleSuccess", { moveX, verified });
120
- };
121
- const reset = () => {
122
- isMouseDownRef.value = false;
123
- trailRef.value = [];
124
- sliderLeft.value = 0;
125
- isActive.value = false;
126
- isSuccess.value = false;
127
- isFail.value = false;
128
- textTip.value = props.placeholder || defaultPlaceholder;
129
- };
130
- expose({
131
- reset
132
- });
133
- onMounted(() => {
134
- document.addEventListener("mousemove", handleDragMove);
135
- document.addEventListener("mouseup", handleDragEnd);
136
- });
137
- onUnmounted(() => {
138
- document.removeEventListener("mousemove", handleDragMove);
139
- document.removeEventListener("mouseup", handleDragEnd);
140
- });
141
- return (_ctx, _cache) => {
142
- const _component_sl_icon = resolveComponent("sl-icon");
143
- return openBlock(), createElementBlock("div", {
144
- class: normalizeClass([
145
- unref(ns).b(),
146
- unref(ns).is("active", isActive.value),
147
- unref(ns).is("success", isSuccess.value),
148
- unref(ns).is("fail", isFail.value)
149
- ]),
150
- style: normalizeStyle({
151
- width: unref(width) + "px",
152
- height: unref(height) + "px"
153
- })
154
- }, [
155
- createElementVNode("div", {
156
- class: normalizeClass(unref(ns).e("mask")),
157
- style: normalizeStyle({ width: sliderLeft.value + 40 + "px" })
158
- }, [
159
- createElementVNode("div", {
160
- class: normalizeClass(unref(ns).e("slider")),
161
- style: normalizeStyle({ left: sliderLeft.value + "px" }),
162
- onMousedown: handleDragStart
163
- }, [
164
- createElementVNode("div", {
165
- class: normalizeClass(unref(ns).e("icon"))
166
- }, [
167
- isLoading.value ? (openBlock(), createBlock(_component_sl_icon, {
168
- key: 0,
169
- class: normalizeClass(unref(ns).em("icon", "loading"))
170
- }, {
171
- default: withCtx(() => [
172
- createVNode(unref(Loading))
173
- ]),
174
- _: 1
175
- }, 8, ["class"])) : isSuccess.value ? (openBlock(), createBlock(_component_sl_icon, { key: 1 }, {
176
- default: withCtx(() => [
177
- createVNode(unref(SuccessFilled))
178
- ]),
179
- _: 1
180
- })) : (openBlock(), createBlock(_component_sl_icon, { key: 2 }, {
181
- default: withCtx(() => [
182
- createVNode(unref(DArrowRight))
183
- ]),
184
- _: 1
185
- }))
186
- ], 2)
187
- ], 38)
188
- ], 6),
189
- createElementVNode("div", {
190
- class: normalizeClass(unref(ns).e("text"))
191
- }, toDisplayString(isLoading.value ? unref(currentLoadingText) : textTip.value), 3)
192
- ], 6);
193
- };
194
- }
195
- });
196
- var SliderBlockVertify = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "slider-block-vertify.vue"]]);
3
+ const sliderBlockVertifyProps = buildProps({});
4
+ const sliderBlockVertifyEmits = {};
197
5
 
198
- export { SliderBlockVertify as default };
6
+ export { sliderBlockVertifyEmits, sliderBlockVertifyProps };
199
7
  //# sourceMappingURL=slider-block-vertify2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"slider-block-vertify2.mjs","sources":["../../../../../../packages/components/slider-block-vertify/src/slider-block-vertify.vue"],"sourcesContent":["<template>\n <div\n :class=\"[\n ns.b(),\n ns.is('active', isActive),\n ns.is('success', isSuccess),\n ns.is('fail', isFail),\n ]\"\n :style=\"{\n width: width + 'px',\n height: height + 'px',\n }\"\n >\n <div :class=\"ns.e('mask')\" :style=\"{ width: sliderLeft + 40 + 'px' }\">\n <div\n :class=\"ns.e('slider')\"\n :style=\"{ left: sliderLeft + 'px' }\"\n @mousedown=\"handleDragStart\"\n >\n <div :class=\"ns.e('icon')\">\n <sl-icon v-if=\"isLoading\" :class=\"ns.em('icon', 'loading')\"\n ><Loading\n /></sl-icon>\n <sl-icon v-else-if=\"isSuccess\"><SuccessFilled /></sl-icon>\n <sl-icon v-else><DArrowRight /></sl-icon>\n </div>\n </div>\n </div>\n <div :class=\"ns.e('text')\">\n {{ isLoading ? currentLoadingText : textTip }}\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport {\n computed,\n defineEmits,\n defineExpose,\n onMounted,\n onUnmounted,\n ref,\n} from 'vue'\nimport { square, sum } from './sliderVertify'\nimport { DArrowRight, Loading, SuccessFilled } from '@sl-design/icons-vue'\nimport { useLocale, useNamespace } from '@sl-ui-pc/hooks'\n\ndefineOptions({\n name: 'SlSliderBlockVertify',\n})\n\nconst { t } = useLocale()\nconst ns = useNamespace('slider-verify')\n\nconst props = defineProps({\n /**\n * @description 提示文字\n */\n placeholder: {\n type: String,\n default: '',\n },\n /**\n * @description 滑块宽度\n */\n width: {\n type: Number,\n default: 330,\n },\n /**\n * @description 滑块高度\n */\n height: {\n type: Number,\n default: 40,\n },\n /**\n * @description 验证成功的文案\n */\n successText: {\n type: String,\n default: '',\n },\n /**\n * @description 异步验证函数,成功返回true,失败返回false\n */\n onVertify: {\n type: Function,\n required: false,\n },\n /**\n * @description loading状态的文案\n */\n loadingText: {\n type: String,\n default: '',\n },\n})\n//成功失败回调函数\nconst emits = defineEmits(['handleSuccess', 'handleFail'])\nconst width = computed(\n () =>\n props.width ||\n Number.parseInt(\n getComputedStyle(document.documentElement).getPropertyValue(\n '--sl-slider-verify-width'\n )\n )\n)\nconst height = computed(\n () =>\n props.height ||\n Number.parseInt(\n getComputedStyle(document.documentElement).getPropertyValue(\n '--sl-slider-verify-height'\n )\n )\n)\nconst defaultPlaceholder = t('el.sliderBlockVertify.defaultPlaceholder')\nconst defaultSuccessText = t('el.sliderBlockVertify.defaultSuccessText')\nconst defaultLoadingText = t('el.sliderBlockVertify.defaultLoadingText')\nconst currentLoadingText = computed(\n () => props.loadingText || defaultLoadingText\n)\nconst textTip = ref(props.placeholder || defaultPlaceholder)\nconst sliderLeft = ref<number>(0)\nconst trailRef = ref<number[]>([])\nconst isMouseDownRef = ref<boolean>(false)\nconst isActive = ref(false)\nconst isSuccess = ref(false)\nconst isFail = ref(false)\nconst originX = ref<number>(0)\nconst originY = ref<number>(0)\nconst isLoading = ref<boolean>(false)\n\nconst handleDragStart = (e: any) => {\n originX.value = e.clientX || e.touches[0].clientX\n originY.value = e.clientY || e.touches[0].clientY\n isMouseDownRef.value = true\n}\n\nconst handleDragMove = async (e: any) => {\n if (!isMouseDownRef.value) return\n e.preventDefault()\n const eventX = e.clientX || e.touches[0].clientX\n const eventY = e.clientY || e.touches[0].clientY\n const moveX = eventX - originX.value\n const moveY = eventY - originY.value\n isActive.value = true\n trailRef.value.push(moveY)\n if (moveX < 0) {\n sliderLeft.value = 0\n return\n }\n // 滑动到最右边\n if (moveX + 40 >= width.value) {\n isMouseDownRef.value = false\n isActive.value = false\n sliderLeft.value = width.value - 40\n const verified = verify()\n if (verified) {\n if (props.onVertify && typeof props.onVertify === 'function') {\n isLoading.value = true\n const res = await props.onVertify({ moveX, verified })\n isLoading.value = false\n res ? verifySuccess(moveX, verified) : reset()\n } else {\n verifySuccess(moveX, verified)\n }\n } else {\n isFail.value = true\n textTip.value = '请再试一次'\n emits('handleFail')\n reset()\n }\n return\n }\n sliderLeft.value = moveX\n}\n\nconst handleDragEnd = () => {\n if (!isMouseDownRef.value) return\n emits('handleFail')\n reset()\n}\n\nconst verify = () => {\n const arr = trailRef.value // 拖动时y轴的移动距离\n const average = arr.reduce(sum) / arr.length\n const deviations = arr.map((x) => x - average)\n const stddev = Math.sqrt(deviations.map(square).reduce(sum) / arr.length)\n return stddev !== 0 // 简单验证拖动轨迹,为零时表示Y轴上下没有波动,可能非人为操作\n}\n\nconst verifySuccess = (moveX: number, verified: boolean) => {\n isSuccess.value = true\n textTip.value = props.successText || defaultSuccessText\n emits('handleSuccess', { moveX, verified })\n}\nconst reset = () => {\n isMouseDownRef.value = false\n trailRef.value = []\n sliderLeft.value = 0\n isActive.value = false\n isSuccess.value = false\n isFail.value = false\n textTip.value = props.placeholder || defaultPlaceholder\n}\n\ndefineExpose({\n reset,\n})\n\nonMounted(() => {\n document.addEventListener('mousemove', handleDragMove)\n document.addEventListener('mouseup', handleDragEnd)\n})\nonUnmounted(() => {\n document.removeEventListener('mousemove', handleDragMove)\n document.removeEventListener('mouseup', handleDragEnd)\n})\n</script>\n"],"names":["_resolveComponent","_openBlock","_createElementBlock","_normalizeClass","_unref","_normalizeStyle","_createElementVNode","_createBlock"],"mappings":"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"}
1
+ {"version":3,"file":"slider-block-vertify2.mjs","sources":["../../../../../../packages/components/slider-block-vertify/src/slider-block-vertify.ts"],"sourcesContent":["import { buildProps } from '@sl-ui-pc/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const sliderBlockVertifyProps = buildProps({} as const)\nexport type SliderBlockVertifyProps = ExtractPropTypes<\n typeof sliderBlockVertifyProps\n>\nexport type SliderBlockVertifyPropsPublic = __ExtractPublicPropTypes<\n typeof sliderBlockVertifyProps\n>\n\nexport const sliderBlockVertifyEmits = {}\nexport type SliderBlockVertifyEmits = typeof sliderBlockVertifyEmits\n"],"names":[],"mappings":";;AACY,MAAC,uBAAuB,GAAG,UAAU,CAAC,EAAE,EAAE;AAC1C,MAAC,uBAAuB,GAAG;;;;"}
@@ -1,7 +1,7 @@
1
1
  import Splitter from './src/splitter.mjs';
2
- import SplitPanel from './src/split-panel2.mjs';
2
+ import SplitPanel from './src/split-panel.mjs';
3
3
  export { splitterProps } from './src/splitter2.mjs';
4
- export { splitterPanelProps } from './src/split-panel.mjs';
4
+ export { splitterPanelProps } from './src/split-panel2.mjs';
5
5
  import { withInstall, withNoopInstall } from '../../utils/vue/install.mjs';
6
6
 
7
7
  const SlSplitter = withInstall(Splitter, {
@@ -1,21 +1,156 @@
1
- import { buildProps } from '../../../utils/vue/props/runtime.mjs';
1
+ import { defineComponent, inject, toRefs, ref, getCurrentInstance, computed, watch, nextTick, reactive, onBeforeUnmount, openBlock, createElementBlock, Fragment, createElementVNode, mergeProps, unref, renderSlot, createBlock, withCtx, createCommentVNode } from 'vue';
2
+ import { isCollapsible, getCollapsible } from './hooks/usePanel.mjs';
3
+ import SplitBar from './split-bar.mjs';
4
+ import { splitterPanelProps } from './split-panel2.mjs';
5
+ import { splitterRootContextKey } from './type.mjs';
6
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
7
+ import { isPct, getPct, isPx, getPx } from './hooks/useSize.mjs';
8
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
9
+ import { throwError } from '../../../utils/error.mjs';
2
10
 
3
- const splitterPanelProps = buildProps({
4
- min: {
5
- type: [String, Number]
6
- },
7
- max: {
8
- type: [String, Number]
9
- },
10
- size: {
11
- type: [String, Number]
12
- },
13
- resizable: {
14
- type: Boolean,
15
- default: true
16
- },
17
- collapsible: Boolean
11
+ const COMPONENT_NAME = "SlSplitterPanel";
12
+ const __default__ = defineComponent({
13
+ name: COMPONENT_NAME
18
14
  });
15
+ const _sfc_main = /* @__PURE__ */ defineComponent({
16
+ ...__default__,
17
+ props: splitterPanelProps,
18
+ emits: ["update:size"],
19
+ setup(__props, { emit: emits }) {
20
+ const props = __props;
21
+ const ns = useNamespace("splitter-panel");
22
+ const splitterContext = inject(splitterRootContextKey);
23
+ if (!splitterContext)
24
+ throwError(COMPONENT_NAME, "usage: <sl-splitter><sl-splitter-panel /></sl-splitter/>");
25
+ const { panels, layout, containerSize, pxSizes } = toRefs(splitterContext);
26
+ const {
27
+ registerPanel,
28
+ unregisterPanel,
29
+ onCollapse,
30
+ onMoveEnd,
31
+ onMoveStart,
32
+ onMoving
33
+ } = splitterContext;
34
+ const panelSl = ref();
35
+ const instance = getCurrentInstance();
36
+ const uid = instance.uid;
37
+ const index = ref(0);
38
+ const panel = computed(() => panels.value[index.value]);
39
+ const setIndex = (val) => {
40
+ index.value = val;
41
+ };
42
+ const panelSize = computed(() => {
43
+ var _a;
44
+ if (!panel.value)
45
+ return 0;
46
+ return (_a = pxSizes.value[index.value]) != null ? _a : 0;
47
+ });
48
+ const nextSize = computed(() => {
49
+ var _a;
50
+ if (!panel.value)
51
+ return 0;
52
+ return (_a = pxSizes.value[index.value + 1]) != null ? _a : 0;
53
+ });
54
+ const nextPanel = computed(() => {
55
+ if (panel.value) {
56
+ return panels.value[index.value + 1];
57
+ }
58
+ return null;
59
+ });
60
+ const isResizable = computed(() => {
61
+ var _a;
62
+ if (!nextPanel.value)
63
+ return false;
64
+ return props.resizable && ((_a = nextPanel.value) == null ? void 0 : _a.resizable) && (panelSize.value !== 0 || !props.min) && (nextSize.value !== 0 || !nextPanel.value.min);
65
+ });
66
+ const isShowBar = computed(() => {
67
+ if (!panel.value)
68
+ return false;
69
+ return index.value !== panels.value.length - 1;
70
+ });
71
+ const startCollapsible = computed(() => isCollapsible(panel.value, panelSize.value, nextPanel.value, nextSize.value));
72
+ const endCollapsible = computed(() => isCollapsible(nextPanel.value, nextSize.value, panel.value, panelSize.value));
73
+ function sizeToPx(str) {
74
+ if (isPct(str)) {
75
+ return getPct(str) * containerSize.value || 0;
76
+ } else if (isPx(str)) {
77
+ return getPx(str);
78
+ }
79
+ return str != null ? str : 0;
80
+ }
81
+ let isSizeUpdating = false;
82
+ watch(() => props.size, () => {
83
+ if (panel.value) {
84
+ const size = sizeToPx(props.size);
85
+ const maxSize = sizeToPx(props.max);
86
+ const minSize = sizeToPx(props.min);
87
+ const finalSize = Math.min(Math.max(size, minSize || 0), maxSize || size);
88
+ if (finalSize !== size) {
89
+ isSizeUpdating = true;
90
+ emits("update:size", finalSize);
91
+ }
92
+ panel.value.size = finalSize;
93
+ nextTick(() => isSizeUpdating = false);
94
+ }
95
+ });
96
+ watch(() => {
97
+ var _a;
98
+ return (_a = panel.value) == null ? void 0 : _a.size;
99
+ }, (val) => {
100
+ if (!isSizeUpdating && val !== props.size) {
101
+ emits("update:size", val);
102
+ }
103
+ });
104
+ watch(() => props.resizable, (val) => {
105
+ if (panel.value) {
106
+ panel.value.resizable = val;
107
+ }
108
+ });
109
+ const _panel = reactive({
110
+ el: panelSl.value,
111
+ uid,
112
+ getVnode: () => instance.vnode,
113
+ setIndex,
114
+ ...props,
115
+ collapsible: getCollapsible(props.collapsible)
116
+ });
117
+ registerPanel(_panel);
118
+ onBeforeUnmount(() => unregisterPanel(_panel));
119
+ return (_ctx, _cache) => {
120
+ return openBlock(), createElementBlock(Fragment, null, [
121
+ createElementVNode("div", mergeProps({
122
+ ref_key: "panelSl",
123
+ ref: panelSl,
124
+ class: [unref(ns).b()],
125
+ style: { flexBasis: `${unref(panelSize)}px` }
126
+ }, _ctx.$attrs), [
127
+ renderSlot(_ctx.$slots, "default")
128
+ ], 16),
129
+ unref(isShowBar) ? (openBlock(), createBlock(SplitBar, {
130
+ key: 0,
131
+ index: index.value,
132
+ layout: unref(layout),
133
+ resizable: unref(isResizable),
134
+ "start-collapsible": unref(startCollapsible),
135
+ "end-collapsible": unref(endCollapsible),
136
+ onMoveStart: unref(onMoveStart),
137
+ onMoving: unref(onMoving),
138
+ onMoveEnd: unref(onMoveEnd),
139
+ onCollapse: unref(onCollapse)
140
+ }, {
141
+ "start-collapsible": withCtx(() => [
142
+ renderSlot(_ctx.$slots, "start-collapsible")
143
+ ]),
144
+ "end-collapsible": withCtx(() => [
145
+ renderSlot(_ctx.$slots, "end-collapsible")
146
+ ]),
147
+ _: 3
148
+ }, 8, ["index", "layout", "resizable", "start-collapsible", "end-collapsible", "onMoveStart", "onMoving", "onMoveEnd", "onCollapse"])) : createCommentVNode("v-if", true)
149
+ ], 64);
150
+ };
151
+ }
152
+ });
153
+ var SplitPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "split-panel.vue"]]);
19
154
 
20
- export { splitterPanelProps };
155
+ export { SplitPanel as default };
21
156
  //# sourceMappingURL=split-panel.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"split-panel.mjs","sources":["../../../../../../packages/components/splitter/src/split-panel.ts"],"sourcesContent":["import { buildProps } from '@sl-ui-pc/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type SplitterPanel from './split-panel.vue'\n\nexport const splitterPanelProps = buildProps({\n min: {\n type: [String, Number],\n },\n max: {\n type: [String, Number],\n },\n size: {\n type: [String, Number],\n },\n resizable: {\n type: Boolean,\n default: true,\n },\n collapsible: Boolean,\n} as const)\n\nexport type SplitterPanelProps = ExtractPropTypes<typeof splitterPanelProps>\nexport type SplitterPanelPropsPublic = __ExtractPublicPropTypes<\n typeof splitterPanelProps\n>\n\nexport type SplitterPanelInstance = InstanceType<typeof SplitterPanel> & unknown\n"],"names":[],"mappings":";;AACY,MAAC,kBAAkB,GAAG,UAAU,CAAC;AAC7C,EAAE,GAAG,EAAE;AACP,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,GAAG,EAAE;AACP,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,WAAW,EAAE,OAAO;AACtB,CAAC;;;;"}
1
+ {"version":3,"file":"split-panel.mjs","sources":["../../../../../../packages/components/splitter/src/split-panel.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport {\n computed,\n getCurrentInstance,\n inject,\n nextTick,\n onBeforeUnmount,\n reactive,\n ref,\n toRefs,\n watch,\n} from 'vue'\nimport { useNamespace } from '@sl-ui-pc/hooks'\nimport { throwError } from '@sl-ui-pc/utils'\nimport { getCollapsible, isCollapsible } from './hooks/usePanel'\nimport SplitBar from './split-bar.vue'\nimport { splitterPanelProps } from './split-panel'\nimport { getPct, getPx, isPct, isPx } from './hooks'\nimport { splitterRootContextKey } from './type'\n\nconst ns = useNamespace('splitter-panel')\n\nconst COMPONENT_NAME = 'SlSplitterPanel'\ndefineOptions({\n name: COMPONENT_NAME,\n})\n\nconst props = defineProps(splitterPanelProps)\n\nconst emits = defineEmits<{\n (e: 'update:size', value: number): void\n}>()\nconst splitterContext = inject(splitterRootContextKey)\nif (!splitterContext)\n throwError(\n COMPONENT_NAME,\n 'usage: <sl-splitter><sl-splitter-panel /></sl-splitter/>'\n )\n\nconst { panels, layout, containerSize, pxSizes } = toRefs(splitterContext)\n\nconst {\n registerPanel,\n unregisterPanel,\n onCollapse,\n onMoveEnd,\n onMoveStart,\n onMoving,\n} = splitterContext\n\nconst panelSl = ref<HTMLDivElement>()\nconst instance = getCurrentInstance()!\nconst uid = instance.uid\n\nconst index = ref(0)\nconst panel = computed(() => panels.value[index.value])\n\nconst setIndex = (val: number) => {\n index.value = val\n}\n\nconst panelSize = computed(() => {\n if (!panel.value) return 0\n return pxSizes.value[index.value] ?? 0\n})\n\nconst nextSize = computed(() => {\n if (!panel.value) return 0\n return pxSizes.value[index.value + 1] ?? 0\n})\n\nconst nextPanel = computed(() => {\n if (panel.value) {\n return panels.value[index.value + 1]\n }\n return null\n})\n\nconst isResizable = computed(() => {\n if (!nextPanel.value) return false\n return (\n props.resizable &&\n nextPanel.value?.resizable &&\n // If it is 0, it means it is collapsed => check if the minimum value is set\n (panelSize.value !== 0 || !props.min) &&\n (nextSize.value !== 0 || !nextPanel.value.min)\n )\n})\n\n// The last panel doesn't need a drag bar\nconst isShowBar = computed(() => {\n if (!panel.value) return false\n return index.value !== panels.value.length - 1\n})\n\nconst startCollapsible = computed(() =>\n isCollapsible(panel.value, panelSize.value, nextPanel.value, nextSize.value)\n)\n\nconst endCollapsible = computed(() =>\n isCollapsible(nextPanel.value, nextSize.value, panel.value, panelSize.value)\n)\n\nfunction sizeToPx(str: string | number | undefined) {\n if (isPct(str)) {\n return getPct(str) * containerSize.value || 0\n } else if (isPx(str)) {\n return getPx(str)\n }\n return str ?? 0\n}\n\n// Two-way binding for size\nlet isSizeUpdating = false\nwatch(\n () => props.size,\n () => {\n if (panel.value) {\n const size = sizeToPx(props.size)\n const maxSize = sizeToPx(props.max)\n const minSize = sizeToPx(props.min)\n\n // Ensure it is within the maximum and minimum value range\n const finalSize = Math.min(Math.max(size, minSize || 0), maxSize || size)\n\n if (finalSize !== size) {\n isSizeUpdating = true\n emits('update:size', finalSize)\n }\n\n panel.value.size = finalSize\n nextTick(() => (isSizeUpdating = false))\n }\n }\n)\n\nwatch(\n () => panel.value?.size,\n (val) => {\n if (!isSizeUpdating && val !== props.size) {\n emits('update:size', val as number)\n }\n }\n)\n\nwatch(\n () => props.resizable,\n (val) => {\n if (panel.value) {\n panel.value.resizable = val\n }\n }\n)\n\nconst _panel = reactive({\n el: panelSl.value!,\n uid,\n getVnode: () => instance.vnode,\n setIndex,\n ...props,\n collapsible: getCollapsible(props.collapsible),\n})\n\nregisterPanel(_panel)\nonBeforeUnmount(() => unregisterPanel(_panel))\n</script>\n\n<template>\n <div\n ref=\"panelSl\"\n :class=\"[ns.b()]\"\n :style=\"{ flexBasis: `${panelSize}px` }\"\n v-bind=\"$attrs\"\n >\n <slot />\n </div>\n <SplitBar\n v-if=\"isShowBar\"\n :index=\"index\"\n :layout=\"layout\"\n :resizable=\"isResizable\"\n :start-collapsible=\"startCollapsible\"\n :end-collapsible=\"endCollapsible\"\n @move-start=\"onMoveStart\"\n @moving=\"onMoving\"\n @move-end=\"onMoveEnd\"\n @collapse=\"onCollapse\"\n >\n <template #start-collapsible>\n <slot name=\"start-collapsible\" />\n </template>\n <template #end-collapsible>\n <slot name=\"end-collapsible\" />\n </template>\n </SplitBar>\n</template>\n"],"names":["_openBlock","_createElementBlock","_Fragment","_createElementVNode","_mergeProps","_unref"],"mappings":";;;;;;;;;;;mCAuBc,CAAA;AAAA,EACZ,IAAM,EAAA,cAAA;AACR;;;;;;;AALA,IAAM,MAAA,EAAA,GAAK,aAAa,gBAAgB,CAAA,CAAA;AAYxC,IAAM,MAAA,eAAA,GAAkB,OAAO,sBAAsB,CAAA,CAAA;AACrD,IAAA,IAAI,CAAC,eAAA;AACH,MAAA,UAAA,CAAA,cAAA,EAAA,0DAAA,CAAA,CAAA;AAAA,IACE,MAAA,EAAA,MAAA,EAAA,MAAA,EAAA,aAAA,EAAA,OAAA,EAAA,GAAA,MAAA,CAAA,eAAA,CAAA,CAAA;AAAA,IACA,MAAA;AAAA,MACF,aAAA;AAEF,MAAA,eAAgB;AAEhB,MAAM,UAAA;AAAA,MACJ,SAAA;AAAA,MACA,WAAA;AAAA,MACA,QAAA;AAAA,KACA,GAAA,eAAA,CAAA;AAAA,IACA,MAAA,OAAA,GAAA,GAAA,EAAA,CAAA;AAAA,IACA,MAAA,QAAA,GAAA,kBAAA,EAAA,CAAA;AAAA,IACF,MAAI,GAAA,GAAA,QAAA,CAAA,GAAA,CAAA;AAEJ,IAAA,MAAM,WAA8B,CAAA,CAAA,CAAA,CAAA;AACpC,IAAA,MAAM,gBAA8B,CAAA,MAAA,MAAA,CAAA,KAAA,CAAA,KAAA,CAAA,KAAA,CAAA,CAAA,CAAA;AACpC,IAAA,MAAM,QAAe,GAAA,CAAA,GAAA,KAAA;AAErB,MAAM,KAAA,CAAA,KAAA,MAAa,CAAA;AACnB,KAAA,CAAA;AAEA,IAAM,MAAA,SAAA,GAAY,QAAgB,CAAA,MAAA;AAChC,MAAA,IAAA,EAAM,CAAQ;AAAA,MAChB,IAAA,CAAA,KAAA,CAAA,KAAA;AAEA,QAAM,OAAA,CAAA,CAAA;AACJ,MAAI,OAAO,CAAA,EAAA,GAAA,OAAc,CAAA,KAAA,CAAA,KAAA,CAAA,KAAA,CAAA,KAAA,IAAA,GAAA,EAAA,GAAA,CAAA,CAAA;AACzB,KAAA,CAAA,CAAA;AAAqC,IACvC,MAAC,QAAA,GAAA,QAAA,CAAA,MAAA;AAED,MAAM,IAAA,EAAA,CAAA;AACJ,MAAI,IAAA,CAAC,KAAM,CAAA,KAAA;AACX,QAAA,OAAe,CAAA,CAAA;AAA0B,MAC1C,OAAA,CAAA,EAAA,GAAA,OAAA,CAAA,KAAA,CAAA,KAAA,CAAA,KAAA,GAAA,CAAA,CAAA,KAAA,IAAA,GAAA,EAAA,GAAA,CAAA,CAAA;AAED,KAAM,CAAA,CAAA;AACJ,IAAA,MAAI,SAAa,GAAA,QAAA,CAAA,MAAA;AACf,MAAA,IAAA,KAAO,CAAO,KAAA,EAAA;AAAqB,QACrC,OAAA,MAAA,CAAA,KAAA,CAAA,KAAA,CAAA,KAAA,GAAA,CAAA,CAAA,CAAA;AACA,OAAO;AAAA,MACR,OAAA,IAAA,CAAA;AAED,KAAM,CAAA,CAAA;AACJ,IAAI,MAAA,WAAW,GAAA,QAAc,CAAA,MAAA;AAC7B,MACE,IAAA,EAAA,CAAA;AACiB,MAEhB,IAAA,CAAA,SAAoB,CAAA,KAAA;AACqB,QAE7C,OAAA,KAAA,CAAA;AAGD,MAAM,OAAA,KAAA,CAAA,cAA2B,CAAA,EAAA,GAAA,SAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,SAAA,CAAA,KAAA,SAAA,CAAA,KAAA,KAAA,CAAA,IAAA,CAAA,KAAA,CAAA,GAAA,CAAA,KAAA,QAAA,CAAA,KAAA,KAAA,CAAA,IAAA,CAAA,SAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA;AAC/B,KAAI,CAAA,CAAA;AACJ,IAAA,MAAA,SAAa,GAAA,QAAiB,CAAA,MAAA;AAAe,MAC9C,IAAA,CAAA,KAAA,CAAA,KAAA;AAED,QAAA,OAAyB,KAAA,CAAA;AAAA,MAAS,uBACZ,MAAA,CAAA,eAAwB,CAAA,CAAA;AAA+B,KAC7E,CAAA,CAAA;AAEA,IAAA,MAAM,gBAAiB,GAAA,QAAA,CAAA,MAAA,aAAA,CAAA,KAAA,CAAA,KAAA,EAAA,SAAA,CAAA,KAAA,EAAA,SAAA,CAAA,KAAA,EAAA,QAAA,CAAA,KAAA,CAAA,CAAA,CAAA;AAAA,IAAS,MAAA,iBACN,QAAA,CAAA,MAAA,aAAuB,CAAA,SAAM,CAAO,KAAA,EAAA,QAAA,CAAU,KAAK,EAAA,KAAA,CAAA,KAAA,EAAA,SAAA,CAAA,KAAA,CAAA,CAAA,CAAA;AAAA,IAC7E,SAAA,QAAA,CAAA,GAAA,EAAA;AAEA,MAAA,IAAA,YAAkB;AAChB,QAAI,OAAA,MAAY,CAAA,GAAA,CAAA,GAAA,aAAA,CAAA,KAAA,IAAA,CAAA,CAAA;AACd,OAAA,MAAA,IAAc,IAAA,CAAA,GAAG,CAAI,EAAA;AAAuB,QAC9C,OAAA,KAAgB,CAAA,GAAA,CAAG,CAAG;AACpB,OAAA;AAAgB,MAClB,OAAA,GAAA,IAAA,IAAA,GAAA,GAAA,GAAA,CAAA,CAAA;AACA,KAAA;AAAc,IAChB,IAAA,cAAA,GAAA,KAAA,CAAA;AAGA,IAAA,KAAqB,CAAA,MAAA,KAAA,CAAA,IAAA,EAAA,MAAA;AACrB,MAAA,IAAA,KAAA,CAAA,KAAA,EAAA;AAAA,cACc,IAAA,GAAA,QAAA,CAAA,KAAA,CAAA,IAAA,CAAA,CAAA;AAAA,QACN,MAAA,OAAA,GAAA,QAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA;AACJ,QAAA,aAAiB,GAAA,QAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA;AACf,QAAM,MAAA,SAAO,GAAS,IAAA,CAAA,GAAA,CAAA,IAAU,CAAA,GAAA,CAAA,IAAA,EAAA,OAAA,IAAA,CAAA,CAAA,EAAA,OAAA,IAAA,IAAA,CAAA,CAAA;AAChC,QAAM,IAAA,SAAA,KAAU,IAAS,EAAA;AACzB,UAAM,cAAA,GAAmB,IAAA,CAAA;AAGzB,UAAM,KAAA,CAAA,aAAiB,EAAA,SAAS,CAAA,CAAA;AAEhC,SAAA;AACE,QAAiB,KAAA,CAAA,KAAA,CAAA,IAAA,GAAA,SAAA,CAAA;AACjB,QAAA,QAAA,CAAA,oBAA8B,GAAA,KAAA,CAAA,CAAA;AAAA,OAChC;AAEA,KAAA,CAAA,CAAA;AACA,IAAS,KAAA,CAAA,MAAA;AAA8B,MACzC,IAAA,EAAA,CAAA;AAAA,MACF,OAAA,CAAA,EAAA,GAAA,KAAA,CAAA,KAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,CAAA;AAAA,KACF,EAAA,CAAA,GAAA,KAAA;AAEA,MAAA,IAAA,CAAA,cAAA,IAAA,GAAA,KAAA,KAAA,CAAA,IAAA,EAAA;AAAA,QACE,mBAAmB,EAAA,GAAA,CAAA,CAAA;AAAA,OAClB;AACC,KAAA,CAAA,CAAA;AACE,IAAA,KAAA,CAAA,MAAM,eAAe,EAAa,CAAA,GAAA,KAAA;AAAA,MACpC,IAAA,KAAA,CAAA,KAAA,EAAA;AAAA,QACF,KAAA,CAAA,KAAA,CAAA,SAAA,GAAA,GAAA,CAAA;AAAA,OACF;AAEA,KAAA,CAAA,CAAA;AAAA,IAAA,YACc,GAAA,QAAA,CAAA;AAAA,MACZ,EAAS,EAAA,OAAA,CAAA,KAAA;AACP,MAAA,GAAA;AACE,MAAA,QAAA,EAAM,MAAM,QAAY,CAAA,KAAA;AAAA,MAC1B,QAAA;AAAA,MACF,GAAA,KAAA;AAAA,MACF,WAAA,EAAA,cAAA,CAAA,KAAA,CAAA,WAAA,CAAA;AAEA,KAAA,CAAA,CAAA;AAAwB,IAAA,aACV,CAAA,MAAA,CAAA,CAAA;AAAA,IACZ,eAAA,CAAA,MAAA,eAAA,CAAA,MAAA,CAAA,CAAA,CAAA;AAAA,IACA,OAAA,CAAA,IAAU,QAAe,KAAA;AAAA,MACzB,OAAAA,SAAA,EAAA,EAAAC,kBAAA,CAAAC,QAAA,EAAA,IAAA,EAAA;AAAA,QACGC,kBAAA,CAAA,KAAA,EAAAC,UAAA,CAAA;AAAA,UACH,OAAA,EAAa,SAAe;AAAiB,UAC9C,GAAA,EAAA,OAAA;AAED,UAAA,KAAA,EAAA,CAAcC,KAAM,CAAA,EAAA,CAAA,CAAA,CAAA,EAAA,CAAA;AACpB,UAAgB,KAAA,EAAA,EAAA,SAAsB,EAAA,CAAA,EAAAA,KAAA,CAAA,SAAO,CAAA,CAAA,EAAA,CAAA,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,156 +1,21 @@
1
- import { defineComponent, inject, toRefs, ref, getCurrentInstance, computed, watch, nextTick, reactive, onBeforeUnmount, openBlock, createElementBlock, Fragment, createElementVNode, mergeProps, unref, renderSlot, createBlock, withCtx, createCommentVNode } from 'vue';
2
- import { isCollapsible, getCollapsible } from './hooks/usePanel.mjs';
3
- import SplitBar from './split-bar.mjs';
4
- import { splitterPanelProps } from './split-panel.mjs';
5
- import { splitterRootContextKey } from './type.mjs';
6
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
7
- import { isPct, getPct, isPx, getPx } from './hooks/useSize.mjs';
8
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
9
- import { throwError } from '../../../utils/error.mjs';
1
+ import { buildProps } from '../../../utils/vue/props/runtime.mjs';
10
2
 
11
- const COMPONENT_NAME = "SlSplitterPanel";
12
- const __default__ = defineComponent({
13
- name: COMPONENT_NAME
3
+ const splitterPanelProps = buildProps({
4
+ min: {
5
+ type: [String, Number]
6
+ },
7
+ max: {
8
+ type: [String, Number]
9
+ },
10
+ size: {
11
+ type: [String, Number]
12
+ },
13
+ resizable: {
14
+ type: Boolean,
15
+ default: true
16
+ },
17
+ collapsible: Boolean
14
18
  });
15
- const _sfc_main = /* @__PURE__ */ defineComponent({
16
- ...__default__,
17
- props: splitterPanelProps,
18
- emits: ["update:size"],
19
- setup(__props, { emit: emits }) {
20
- const props = __props;
21
- const ns = useNamespace("splitter-panel");
22
- const splitterContext = inject(splitterRootContextKey);
23
- if (!splitterContext)
24
- throwError(COMPONENT_NAME, "usage: <sl-splitter><sl-splitter-panel /></sl-splitter/>");
25
- const { panels, layout, containerSize, pxSizes } = toRefs(splitterContext);
26
- const {
27
- registerPanel,
28
- unregisterPanel,
29
- onCollapse,
30
- onMoveEnd,
31
- onMoveStart,
32
- onMoving
33
- } = splitterContext;
34
- const panelSl = ref();
35
- const instance = getCurrentInstance();
36
- const uid = instance.uid;
37
- const index = ref(0);
38
- const panel = computed(() => panels.value[index.value]);
39
- const setIndex = (val) => {
40
- index.value = val;
41
- };
42
- const panelSize = computed(() => {
43
- var _a;
44
- if (!panel.value)
45
- return 0;
46
- return (_a = pxSizes.value[index.value]) != null ? _a : 0;
47
- });
48
- const nextSize = computed(() => {
49
- var _a;
50
- if (!panel.value)
51
- return 0;
52
- return (_a = pxSizes.value[index.value + 1]) != null ? _a : 0;
53
- });
54
- const nextPanel = computed(() => {
55
- if (panel.value) {
56
- return panels.value[index.value + 1];
57
- }
58
- return null;
59
- });
60
- const isResizable = computed(() => {
61
- var _a;
62
- if (!nextPanel.value)
63
- return false;
64
- return props.resizable && ((_a = nextPanel.value) == null ? void 0 : _a.resizable) && (panelSize.value !== 0 || !props.min) && (nextSize.value !== 0 || !nextPanel.value.min);
65
- });
66
- const isShowBar = computed(() => {
67
- if (!panel.value)
68
- return false;
69
- return index.value !== panels.value.length - 1;
70
- });
71
- const startCollapsible = computed(() => isCollapsible(panel.value, panelSize.value, nextPanel.value, nextSize.value));
72
- const endCollapsible = computed(() => isCollapsible(nextPanel.value, nextSize.value, panel.value, panelSize.value));
73
- function sizeToPx(str) {
74
- if (isPct(str)) {
75
- return getPct(str) * containerSize.value || 0;
76
- } else if (isPx(str)) {
77
- return getPx(str);
78
- }
79
- return str != null ? str : 0;
80
- }
81
- let isSizeUpdating = false;
82
- watch(() => props.size, () => {
83
- if (panel.value) {
84
- const size = sizeToPx(props.size);
85
- const maxSize = sizeToPx(props.max);
86
- const minSize = sizeToPx(props.min);
87
- const finalSize = Math.min(Math.max(size, minSize || 0), maxSize || size);
88
- if (finalSize !== size) {
89
- isSizeUpdating = true;
90
- emits("update:size", finalSize);
91
- }
92
- panel.value.size = finalSize;
93
- nextTick(() => isSizeUpdating = false);
94
- }
95
- });
96
- watch(() => {
97
- var _a;
98
- return (_a = panel.value) == null ? void 0 : _a.size;
99
- }, (val) => {
100
- if (!isSizeUpdating && val !== props.size) {
101
- emits("update:size", val);
102
- }
103
- });
104
- watch(() => props.resizable, (val) => {
105
- if (panel.value) {
106
- panel.value.resizable = val;
107
- }
108
- });
109
- const _panel = reactive({
110
- el: panelSl.value,
111
- uid,
112
- getVnode: () => instance.vnode,
113
- setIndex,
114
- ...props,
115
- collapsible: getCollapsible(props.collapsible)
116
- });
117
- registerPanel(_panel);
118
- onBeforeUnmount(() => unregisterPanel(_panel));
119
- return (_ctx, _cache) => {
120
- return openBlock(), createElementBlock(Fragment, null, [
121
- createElementVNode("div", mergeProps({
122
- ref_key: "panelSl",
123
- ref: panelSl,
124
- class: [unref(ns).b()],
125
- style: { flexBasis: `${unref(panelSize)}px` }
126
- }, _ctx.$attrs), [
127
- renderSlot(_ctx.$slots, "default")
128
- ], 16),
129
- unref(isShowBar) ? (openBlock(), createBlock(SplitBar, {
130
- key: 0,
131
- index: index.value,
132
- layout: unref(layout),
133
- resizable: unref(isResizable),
134
- "start-collapsible": unref(startCollapsible),
135
- "end-collapsible": unref(endCollapsible),
136
- onMoveStart: unref(onMoveStart),
137
- onMoving: unref(onMoving),
138
- onMoveEnd: unref(onMoveEnd),
139
- onCollapse: unref(onCollapse)
140
- }, {
141
- "start-collapsible": withCtx(() => [
142
- renderSlot(_ctx.$slots, "start-collapsible")
143
- ]),
144
- "end-collapsible": withCtx(() => [
145
- renderSlot(_ctx.$slots, "end-collapsible")
146
- ]),
147
- _: 3
148
- }, 8, ["index", "layout", "resizable", "start-collapsible", "end-collapsible", "onMoveStart", "onMoving", "onMoveEnd", "onCollapse"])) : createCommentVNode("v-if", true)
149
- ], 64);
150
- };
151
- }
152
- });
153
- var SplitPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "split-panel.vue"]]);
154
19
 
155
- export { SplitPanel as default };
20
+ export { splitterPanelProps };
156
21
  //# sourceMappingURL=split-panel2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"split-panel2.mjs","sources":["../../../../../../packages/components/splitter/src/split-panel.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport {\n computed,\n getCurrentInstance,\n inject,\n nextTick,\n onBeforeUnmount,\n reactive,\n ref,\n toRefs,\n watch,\n} from 'vue'\nimport { useNamespace } from '@sl-ui-pc/hooks'\nimport { throwError } from '@sl-ui-pc/utils'\nimport { getCollapsible, isCollapsible } from './hooks/usePanel'\nimport SplitBar from './split-bar.vue'\nimport { splitterPanelProps } from './split-panel'\nimport { getPct, getPx, isPct, isPx } from './hooks'\nimport { splitterRootContextKey } from './type'\n\nconst ns = useNamespace('splitter-panel')\n\nconst COMPONENT_NAME = 'SlSplitterPanel'\ndefineOptions({\n name: COMPONENT_NAME,\n})\n\nconst props = defineProps(splitterPanelProps)\n\nconst emits = defineEmits<{\n (e: 'update:size', value: number): void\n}>()\nconst splitterContext = inject(splitterRootContextKey)\nif (!splitterContext)\n throwError(\n COMPONENT_NAME,\n 'usage: <sl-splitter><sl-splitter-panel /></sl-splitter/>'\n )\n\nconst { panels, layout, containerSize, pxSizes } = toRefs(splitterContext)\n\nconst {\n registerPanel,\n unregisterPanel,\n onCollapse,\n onMoveEnd,\n onMoveStart,\n onMoving,\n} = splitterContext\n\nconst panelSl = ref<HTMLDivElement>()\nconst instance = getCurrentInstance()!\nconst uid = instance.uid\n\nconst index = ref(0)\nconst panel = computed(() => panels.value[index.value])\n\nconst setIndex = (val: number) => {\n index.value = val\n}\n\nconst panelSize = computed(() => {\n if (!panel.value) return 0\n return pxSizes.value[index.value] ?? 0\n})\n\nconst nextSize = computed(() => {\n if (!panel.value) return 0\n return pxSizes.value[index.value + 1] ?? 0\n})\n\nconst nextPanel = computed(() => {\n if (panel.value) {\n return panels.value[index.value + 1]\n }\n return null\n})\n\nconst isResizable = computed(() => {\n if (!nextPanel.value) return false\n return (\n props.resizable &&\n nextPanel.value?.resizable &&\n // If it is 0, it means it is collapsed => check if the minimum value is set\n (panelSize.value !== 0 || !props.min) &&\n (nextSize.value !== 0 || !nextPanel.value.min)\n )\n})\n\n// The last panel doesn't need a drag bar\nconst isShowBar = computed(() => {\n if (!panel.value) return false\n return index.value !== panels.value.length - 1\n})\n\nconst startCollapsible = computed(() =>\n isCollapsible(panel.value, panelSize.value, nextPanel.value, nextSize.value)\n)\n\nconst endCollapsible = computed(() =>\n isCollapsible(nextPanel.value, nextSize.value, panel.value, panelSize.value)\n)\n\nfunction sizeToPx(str: string | number | undefined) {\n if (isPct(str)) {\n return getPct(str) * containerSize.value || 0\n } else if (isPx(str)) {\n return getPx(str)\n }\n return str ?? 0\n}\n\n// Two-way binding for size\nlet isSizeUpdating = false\nwatch(\n () => props.size,\n () => {\n if (panel.value) {\n const size = sizeToPx(props.size)\n const maxSize = sizeToPx(props.max)\n const minSize = sizeToPx(props.min)\n\n // Ensure it is within the maximum and minimum value range\n const finalSize = Math.min(Math.max(size, minSize || 0), maxSize || size)\n\n if (finalSize !== size) {\n isSizeUpdating = true\n emits('update:size', finalSize)\n }\n\n panel.value.size = finalSize\n nextTick(() => (isSizeUpdating = false))\n }\n }\n)\n\nwatch(\n () => panel.value?.size,\n (val) => {\n if (!isSizeUpdating && val !== props.size) {\n emits('update:size', val as number)\n }\n }\n)\n\nwatch(\n () => props.resizable,\n (val) => {\n if (panel.value) {\n panel.value.resizable = val\n }\n }\n)\n\nconst _panel = reactive({\n el: panelSl.value!,\n uid,\n getVnode: () => instance.vnode,\n setIndex,\n ...props,\n collapsible: getCollapsible(props.collapsible),\n})\n\nregisterPanel(_panel)\nonBeforeUnmount(() => unregisterPanel(_panel))\n</script>\n\n<template>\n <div\n ref=\"panelSl\"\n :class=\"[ns.b()]\"\n :style=\"{ flexBasis: `${panelSize}px` }\"\n v-bind=\"$attrs\"\n >\n <slot />\n </div>\n <SplitBar\n v-if=\"isShowBar\"\n :index=\"index\"\n :layout=\"layout\"\n :resizable=\"isResizable\"\n :start-collapsible=\"startCollapsible\"\n :end-collapsible=\"endCollapsible\"\n @move-start=\"onMoveStart\"\n @moving=\"onMoving\"\n @move-end=\"onMoveEnd\"\n @collapse=\"onCollapse\"\n >\n <template #start-collapsible>\n <slot name=\"start-collapsible\" />\n </template>\n <template #end-collapsible>\n <slot name=\"end-collapsible\" />\n </template>\n </SplitBar>\n</template>\n"],"names":["_openBlock","_createElementBlock","_Fragment","_createElementVNode","_mergeProps","_unref"],"mappings":"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"}
1
+ {"version":3,"file":"split-panel2.mjs","sources":["../../../../../../packages/components/splitter/src/split-panel.ts"],"sourcesContent":["import { buildProps } from '@sl-ui-pc/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type SplitterPanel from './split-panel.vue'\n\nexport const splitterPanelProps = buildProps({\n min: {\n type: [String, Number],\n },\n max: {\n type: [String, Number],\n },\n size: {\n type: [String, Number],\n },\n resizable: {\n type: Boolean,\n default: true,\n },\n collapsible: Boolean,\n} as const)\n\nexport type SplitterPanelProps = ExtractPropTypes<typeof splitterPanelProps>\nexport type SplitterPanelPropsPublic = __ExtractPublicPropTypes<\n typeof splitterPanelProps\n>\n\nexport type SplitterPanelInstance = InstanceType<typeof SplitterPanel> & unknown\n"],"names":[],"mappings":";;AACY,MAAC,kBAAkB,GAAG,UAAU,CAAC;AAC7C,EAAE,GAAG,EAAE;AACP,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,GAAG,EAAE;AACP,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,WAAW,EAAE,OAAO;AACtB,CAAC;;;;"}