@gv-tech/ui-web 2.22.2 → 2.23.1

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 (468) hide show
  1. package/dist/accordion-Dd8Hrexd.mjs +244 -0
  2. package/dist/accordion-DdSOiVyo.js +1 -0
  3. package/dist/accordion.cjs +1 -1
  4. package/dist/accordion.d.ts +5 -7
  5. package/dist/accordion.d.ts.map +1 -1
  6. package/dist/accordion.mjs +1 -2
  7. package/dist/alert-dialog-B7zX3gJX.js +7 -0
  8. package/dist/alert-dialog-BQoG5g_w.mjs +213 -0
  9. package/dist/alert-dialog.cjs +1 -1
  10. package/dist/alert-dialog.d.ts +17 -21
  11. package/dist/alert-dialog.d.ts.map +1 -1
  12. package/dist/alert-dialog.mjs +2 -4
  13. package/dist/alert.cjs +1 -1
  14. package/dist/alert.d.ts +8 -8
  15. package/dist/alert.d.ts.map +1 -1
  16. package/dist/alert.mjs +37 -29
  17. package/dist/{aspect-ratio-CFWobEnT.mjs → aspect-ratio-DnChDaBi.mjs} +10 -4
  18. package/dist/{aspect-ratio-D9dApiWv.js → aspect-ratio-QD1ZXP2B.js} +1 -1
  19. package/dist/aspect-ratio.cjs +1 -1
  20. package/dist/aspect-ratio.d.ts +2 -4
  21. package/dist/aspect-ratio.d.ts.map +1 -1
  22. package/dist/aspect-ratio.mjs +1 -1
  23. package/dist/avatar-C4onD8-4.mjs +127 -0
  24. package/dist/avatar-ki_M47qG.js +1 -0
  25. package/dist/avatar.cjs +1 -1
  26. package/dist/avatar.d.ts +10 -7
  27. package/dist/avatar.d.ts.map +1 -1
  28. package/dist/avatar.mjs +2 -3
  29. package/dist/badge.cjs +1 -1
  30. package/dist/badge.d.ts +4 -5
  31. package/dist/badge.d.ts.map +1 -1
  32. package/dist/badge.mjs +17 -13
  33. package/dist/breadcrumb.cjs +1 -1
  34. package/dist/breadcrumb.d.ts +9 -17
  35. package/dist/breadcrumb.d.ts.map +1 -1
  36. package/dist/breadcrumb.mjs +67 -58
  37. package/dist/button-group.cjs +1 -0
  38. package/dist/button-group.d.ts +11 -0
  39. package/dist/button-group.d.ts.map +1 -0
  40. package/dist/button-group.mjs +39 -0
  41. package/dist/button.cjs +1 -1
  42. package/dist/button.d.ts +3 -5
  43. package/dist/button.d.ts.map +1 -1
  44. package/dist/button.mjs +33 -26
  45. package/dist/calendar-D9sapvfY.js +1 -0
  46. package/dist/{calendar-DtFx4qdT.mjs → calendar-Dg6VGycy.mjs} +631 -625
  47. package/dist/calendar.cjs +1 -1
  48. package/dist/calendar.d.ts +5 -5
  49. package/dist/calendar.d.ts.map +1 -1
  50. package/dist/calendar.mjs +1 -2
  51. package/dist/card.cjs +1 -1
  52. package/dist/card.d.ts +10 -10
  53. package/dist/card.d.ts.map +1 -1
  54. package/dist/card.mjs +53 -40
  55. package/dist/carousel-6oFHLN7R.js +1 -0
  56. package/dist/{carousel-PQJ97GjQ.mjs → carousel-DbDoNdqJ.mjs} +54 -59
  57. package/dist/carousel.cjs +1 -1
  58. package/dist/carousel.d.ts +18 -13
  59. package/dist/carousel.d.ts.map +1 -1
  60. package/dist/carousel.mjs +2 -4
  61. package/dist/chart.cjs +3 -3
  62. package/dist/chart.d.ts +35 -7
  63. package/dist/chart.d.ts.map +1 -1
  64. package/dist/chart.mjs +64 -71
  65. package/dist/checkbox-BLgY82mB.js +1 -0
  66. package/dist/{checkbox-BOmSuATv.mjs → checkbox-Bts_zfqd.mjs} +32 -29
  67. package/dist/checkbox.cjs +1 -1
  68. package/dist/checkbox.d.ts +2 -5
  69. package/dist/checkbox.d.ts.map +1 -1
  70. package/dist/checkbox.mjs +1 -2
  71. package/dist/collapsible.cjs +1 -1
  72. package/dist/collapsible.d.ts +4 -6
  73. package/dist/collapsible.d.ts.map +1 -1
  74. package/dist/collapsible.mjs +21 -3
  75. package/dist/combobox-6qNx9Wbb.js +4 -0
  76. package/dist/combobox-yDMqxM_J.mjs +5522 -0
  77. package/dist/combobox.cjs +1 -0
  78. package/dist/combobox.d.ts +21 -0
  79. package/dist/combobox.d.ts.map +1 -0
  80. package/dist/combobox.mjs +4 -0
  81. package/dist/command-C6wJ5giF.mjs +576 -0
  82. package/dist/command-DCrPL1iW.js +1 -0
  83. package/dist/command.cjs +1 -1
  84. package/dist/command.d.ts +16 -80
  85. package/dist/command.d.ts.map +1 -1
  86. package/dist/command.mjs +1 -2
  87. package/dist/context-menu-CydUpD4W.mjs +349 -0
  88. package/dist/context-menu-DQ7XuuG5.js +1 -0
  89. package/dist/context-menu.cjs +1 -1
  90. package/dist/context-menu.d.ts +29 -21
  91. package/dist/context-menu.d.ts.map +1 -1
  92. package/dist/context-menu.mjs +1 -2
  93. package/dist/dialog.cjs +1 -1
  94. package/dist/dialog.d.ts +15 -17
  95. package/dist/dialog.d.ts.map +1 -1
  96. package/dist/dialog.mjs +89 -43
  97. package/dist/direction.cjs +1 -0
  98. package/dist/direction.d.ts +7 -0
  99. package/dist/direction.d.ts.map +1 -0
  100. package/dist/direction.mjs +15 -0
  101. package/dist/dist-1C8JOpVg.js +1 -0
  102. package/dist/{dist-CTaBktQl.mjs → dist-B1OcuinL.mjs} +93 -92
  103. package/dist/dist-BGZDG175.mjs +199 -0
  104. package/dist/dist-BPBwSSyk.mjs +8 -0
  105. package/dist/{dist-BTlmz3JV.js → dist-BPX1UGAz2.js} +1 -1
  106. package/dist/dist-BRsDdVlJ.js +1 -0
  107. package/dist/{dist-_LAgxsbh.mjs → dist-BWwCr-xN.mjs} +10 -9
  108. package/dist/dist-BYdcKuDi.mjs +16 -0
  109. package/dist/{dist-DCKyUINZ.mjs → dist-BlB11V_z.mjs} +1 -1
  110. package/dist/dist-CCXBcfM3.js +1 -0
  111. package/dist/{dist--EFQaGUD.mjs → dist-CDU9vno-.mjs} +4 -4
  112. package/dist/dist-CJolxugc.js +1 -0
  113. package/dist/dist-CQhWBhaI.mjs +91 -0
  114. package/dist/dist-CRLbUj9C.js +1 -0
  115. package/dist/dist-CWElW7UD.js +1 -0
  116. package/dist/{dist-NIAlh3KC.js → dist-CXbzwSnE.js} +1 -1
  117. package/dist/{dist-C5EZ0AD6.mjs → dist-CYj6O95k.mjs} +42 -41
  118. package/dist/{dist-Bjlzl0jN.mjs → dist-Cacc4QIh.mjs} +13 -10
  119. package/dist/dist-ChuP-5Gb.js +1 -0
  120. package/dist/dist-CiM892Rg.js +1 -0
  121. package/dist/{dist-Doq7FY_P.js → dist-CuMQq0hV.js} +1 -1
  122. package/dist/dist-DMnXk8Uo.js +1 -0
  123. package/dist/{dist-CRmJFaEL.mjs → dist-DPBTfUqI.mjs} +18 -17
  124. package/dist/dist-DR0lXVFG.js +1 -0
  125. package/dist/dist-Da7BU5sd.js +5 -0
  126. package/dist/{dist-D_tuvB-W.mjs → dist-Dz3LbuDd.mjs} +8 -9
  127. package/dist/{dist-9gQKRtL7.mjs → dist-GhACpuJb2.mjs} +1 -1
  128. package/dist/dist-o4zlRoDG.js +1 -0
  129. package/dist/{dist-DdVp13bp.mjs → dist-rGeQfsgN.mjs} +1 -1
  130. package/dist/{dist-BQOrag93.mjs → dist-tvb2Wafb.mjs} +22 -21
  131. package/dist/drawer.cjs +1 -1
  132. package/dist/drawer.d.ts +10 -21
  133. package/dist/drawer.d.ts.map +1 -1
  134. package/dist/drawer.mjs +74 -45
  135. package/dist/dropdown-menu-BoJvZ3Fj.js +1 -0
  136. package/dist/dropdown-menu-CriaO1_i.mjs +347 -0
  137. package/dist/dropdown-menu.cjs +1 -1
  138. package/dist/dropdown-menu.d.ts +27 -21
  139. package/dist/dropdown-menu.d.ts.map +1 -1
  140. package/dist/dropdown-menu.mjs +1 -1
  141. package/dist/empty.cjs +1 -0
  142. package/dist/empty.d.ts +13 -0
  143. package/dist/empty.d.ts.map +1 -0
  144. package/dist/empty.mjs +60 -0
  145. package/dist/{es2015-DkZq_IIO.mjs → es2015-BhmbVcui.mjs} +2 -2
  146. package/dist/{es2015-Ca60p53M.js → es2015-D22cM8Q_.js} +1 -1
  147. package/dist/field.cjs +1 -0
  148. package/dist/field.d.ts +18 -0
  149. package/dist/field.d.ts.map +1 -0
  150. package/dist/field.mjs +109 -0
  151. package/dist/floating-ui.react-dom-DgS_bqyY.mjs +1089 -0
  152. package/dist/floating-ui.react-dom-DpCJEf_x.js +1 -0
  153. package/dist/form.cjs +1 -1
  154. package/dist/form.mjs +8 -8
  155. package/dist/hooks/use-mobile.d.ts +2 -0
  156. package/dist/hooks/use-mobile.d.ts.map +1 -0
  157. package/dist/hooks/use-theme.d.ts +16 -0
  158. package/dist/hooks/use-theme.d.ts.map +1 -1
  159. package/dist/{hover-card-BOk3-K0k.mjs → hover-card-CJ-ibpbC.mjs} +53 -33
  160. package/dist/hover-card-CK5SjVLL.js +1 -0
  161. package/dist/hover-card.cjs +1 -1
  162. package/dist/hover-card.d.ts +4 -6
  163. package/dist/hover-card.d.ts.map +1 -1
  164. package/dist/hover-card.mjs +1 -2
  165. package/dist/index.cjs +1 -1
  166. package/dist/index.d.ts +14 -43
  167. package/dist/index.d.ts.map +1 -1
  168. package/dist/index.mjs +66 -54
  169. package/dist/input-group.cjs +1 -0
  170. package/dist/input-group.d.ts +18 -0
  171. package/dist/input-group.d.ts.map +1 -0
  172. package/dist/input-group.mjs +78 -0
  173. package/dist/input-otp-BH_9dVhh.mjs +391 -0
  174. package/dist/input-otp-BibboKMt.js +20 -0
  175. package/dist/input-otp.cjs +1 -0
  176. package/dist/input-otp.d.ts +9 -0
  177. package/dist/input-otp.d.ts.map +1 -0
  178. package/dist/input-otp.mjs +4 -0
  179. package/dist/input.cjs +1 -1
  180. package/dist/input.d.ts +1 -4
  181. package/dist/input.d.ts.map +1 -1
  182. package/dist/input.mjs +11 -11
  183. package/dist/item.cjs +1 -0
  184. package/dist/item.d.ts +25 -0
  185. package/dist/item.d.ts.map +1 -0
  186. package/dist/item.mjs +118 -0
  187. package/dist/kbd.cjs +1 -0
  188. package/dist/kbd.d.ts +5 -0
  189. package/dist/kbd.d.ts.map +1 -0
  190. package/dist/kbd.mjs +20 -0
  191. package/dist/label-BXMSoyyu.js +1 -0
  192. package/dist/label-C8GNfPU0.mjs +25 -0
  193. package/dist/label.cjs +1 -1
  194. package/dist/label.d.ts +2 -5
  195. package/dist/label.d.ts.map +1 -1
  196. package/dist/label.mjs +1 -2
  197. package/dist/menubar-BcyqIJgy.mjs +441 -0
  198. package/dist/menubar-DPxokWFI.js +1 -0
  199. package/dist/menubar.cjs +1 -1
  200. package/dist/menubar.d.ts +25 -19
  201. package/dist/menubar.d.ts.map +1 -1
  202. package/dist/menubar.mjs +1 -1
  203. package/dist/native-select.cjs +1 -0
  204. package/dist/native-select.d.ts +8 -0
  205. package/dist/native-select.d.ts.map +1 -0
  206. package/dist/native-select.mjs +39 -0
  207. package/dist/navigation-menu-2yE2MUu-.js +1 -0
  208. package/dist/navigation-menu-N8gkxEXE.mjs +628 -0
  209. package/dist/navigation-menu.cjs +1 -1
  210. package/dist/navigation-menu.d.ts +11 -11
  211. package/dist/navigation-menu.d.ts.map +1 -1
  212. package/dist/navigation-menu.mjs +1 -2
  213. package/dist/pagination.cjs +1 -1
  214. package/dist/pagination.d.ts +13 -26
  215. package/dist/pagination.d.ts.map +1 -1
  216. package/dist/pagination.mjs +76 -59
  217. package/dist/popover-D1AO-E8p.js +1 -0
  218. package/dist/popover-wQACF3ut.mjs +245 -0
  219. package/dist/popover.cjs +1 -1
  220. package/dist/popover.d.ts +9 -8
  221. package/dist/popover.d.ts.map +1 -1
  222. package/dist/popover.mjs +2 -3
  223. package/dist/{progress-30ehxjKg.mjs → progress-DPWSEWa5.mjs} +19 -14
  224. package/dist/{progress-BqWHea4f.js → progress-ShXZwOfj.js} +2 -2
  225. package/dist/progress.cjs +1 -1
  226. package/dist/progress.d.ts +2 -4
  227. package/dist/progress.d.ts.map +1 -1
  228. package/dist/progress.mjs +1 -1
  229. package/dist/radio-group-CQbZCQmj.mjs +199 -0
  230. package/dist/radio-group-DAEi5vW_.js +1 -0
  231. package/dist/radio-group.cjs +1 -1
  232. package/dist/radio-group.d.ts +3 -8
  233. package/dist/radio-group.d.ts.map +1 -1
  234. package/dist/radio-group.mjs +1 -2
  235. package/dist/resizable-Cv-mKMKP.js +1 -0
  236. package/dist/{resizable-DhOcAmNX.mjs → resizable-DJSE3e5L.mjs} +310 -282
  237. package/dist/resizable.cjs +1 -1
  238. package/dist/resizable.d.ts +6 -7
  239. package/dist/resizable.d.ts.map +1 -1
  240. package/dist/resizable.mjs +1 -1
  241. package/dist/{scroll-area-DJcPs0_v.mjs → scroll-area-8QcqkHnC.mjs} +69 -58
  242. package/dist/scroll-area-Cqqinhxf.js +1 -0
  243. package/dist/scroll-area.cjs +1 -1
  244. package/dist/scroll-area.d.ts +3 -5
  245. package/dist/scroll-area.d.ts.map +1 -1
  246. package/dist/scroll-area.mjs +1 -2
  247. package/dist/search.cjs +1 -1
  248. package/dist/search.d.ts +1 -1
  249. package/dist/search.d.ts.map +1 -1
  250. package/dist/search.mjs +15 -14
  251. package/dist/select-DdUveoSA.js +1 -0
  252. package/dist/{select-D4bxRFq5.mjs → select-yoeH35x2.mjs} +279 -245
  253. package/dist/select.cjs +1 -1
  254. package/dist/select.d.ts +13 -13
  255. package/dist/select.d.ts.map +1 -1
  256. package/dist/select.mjs +1 -1
  257. package/dist/{separator-DZACUutC.mjs → separator-BU1ea5gl.mjs} +14 -10
  258. package/dist/separator-DBjErwHf.js +1 -0
  259. package/dist/separator.cjs +1 -1
  260. package/dist/separator.d.ts +2 -4
  261. package/dist/separator.d.ts.map +1 -1
  262. package/dist/separator.mjs +1 -2
  263. package/dist/sheet.cjs +1 -1
  264. package/dist/sheet.d.ts +13 -26
  265. package/dist/sheet.d.ts.map +1 -1
  266. package/dist/sheet.mjs +84 -54
  267. package/dist/shim-B5sEfNEJ.js +1 -0
  268. package/dist/shim-DX33EwUw.mjs +91 -0
  269. package/dist/sidebar-B-sWccYh.mjs +355 -0
  270. package/dist/sidebar-DIW-1cin.js +1 -0
  271. package/dist/sidebar.cjs +1 -0
  272. package/dist/sidebar.d.ts +45 -0
  273. package/dist/sidebar.d.ts.map +1 -0
  274. package/dist/sidebar.mjs +5 -0
  275. package/dist/skeleton.cjs +1 -1
  276. package/dist/skeleton.d.ts +1 -4
  277. package/dist/skeleton.d.ts.map +1 -1
  278. package/dist/skeleton.mjs +2 -3
  279. package/dist/{slider-DTdrUy_s.mjs → slider-CCPXejUF.mjs} +81 -59
  280. package/dist/slider-w05gD_Ix.js +1 -0
  281. package/dist/slider.cjs +1 -1
  282. package/dist/slider.d.ts +2 -4
  283. package/dist/slider.d.ts.map +1 -1
  284. package/dist/slider.mjs +1 -1
  285. package/dist/sonner.cjs +1 -1
  286. package/dist/sonner.d.ts +1 -5
  287. package/dist/sonner.d.ts.map +1 -1
  288. package/dist/sonner.mjs +23 -16
  289. package/dist/spinner.cjs +1 -0
  290. package/dist/spinner.d.ts +4 -0
  291. package/dist/spinner.d.ts.map +1 -0
  292. package/dist/spinner.mjs +15 -0
  293. package/dist/support-fab.cjs +1 -1
  294. package/dist/support-fab.mjs +1 -1
  295. package/dist/switch-CDBqsWQa.mjs +112 -0
  296. package/dist/switch-X2WBJsUu.js +1 -0
  297. package/dist/switch.cjs +1 -1
  298. package/dist/switch.d.ts +4 -4
  299. package/dist/switch.d.ts.map +1 -1
  300. package/dist/switch.mjs +1 -1
  301. package/dist/table.cjs +1 -1
  302. package/dist/table.d.ts +8 -10
  303. package/dist/table.d.ts.map +1 -1
  304. package/dist/table.mjs +62 -54
  305. package/dist/tabs-DzvgrVzk.js +1 -0
  306. package/dist/tabs-KDeHjVQU.mjs +160 -0
  307. package/dist/tabs.cjs +1 -1
  308. package/dist/tabs.d.ts +10 -8
  309. package/dist/tabs.d.ts.map +1 -1
  310. package/dist/tabs.mjs +2 -2
  311. package/dist/text.d.ts +1 -1
  312. package/dist/textarea.cjs +1 -1
  313. package/dist/textarea.d.ts +1 -4
  314. package/dist/textarea.d.ts.map +1 -1
  315. package/dist/textarea.mjs +10 -10
  316. package/dist/{theme-toggle-Dtze9fyN.js → theme-toggle-C2Y4bIM3.js} +1 -1
  317. package/dist/{theme-toggle-DAHBgdy0.mjs → theme-toggle-clE-HpSS.mjs} +9 -9
  318. package/dist/theme-toggle.cjs +1 -1
  319. package/dist/theme-toggle.mjs +1 -2
  320. package/dist/toast-1keyrzem.js +1 -0
  321. package/dist/{toast-G9LdgDDE.mjs → toast-DVI6jPq5.mjs} +102 -101
  322. package/dist/toast.cjs +1 -1
  323. package/dist/toast.d.ts.map +1 -1
  324. package/dist/toast.mjs +1 -1
  325. package/dist/{toaster-WQJjavlc.mjs → toaster-Czhz-ktg.mjs} +1 -1
  326. package/dist/{toaster-CKD4CKAZ.js → toaster-DfDb2-aI.js} +1 -1
  327. package/dist/toaster.cjs +1 -1
  328. package/dist/toaster.mjs +1 -1
  329. package/dist/toggle-BGkq5XDM.js +1 -0
  330. package/dist/toggle-BfIIdlA6.mjs +58 -0
  331. package/dist/toggle-group-CbqgoPFU.mjs +167 -0
  332. package/dist/toggle-group-D7hR4BT2.js +1 -0
  333. package/dist/toggle-group.cjs +1 -1
  334. package/dist/toggle-group.d.ts +7 -9
  335. package/dist/toggle-group.d.ts.map +1 -1
  336. package/dist/toggle-group.mjs +1 -1
  337. package/dist/toggle.cjs +1 -1
  338. package/dist/toggle.d.ts +6 -5
  339. package/dist/toggle.d.ts.map +1 -1
  340. package/dist/toggle.mjs +2 -19
  341. package/dist/tooltip-CAIbshMk.js +1 -0
  342. package/dist/{tooltip-BHEcM7lO.mjs → tooltip-D_o8Z-Ya.mjs} +106 -90
  343. package/dist/tooltip.cjs +1 -1
  344. package/dist/tooltip.d.ts +5 -10
  345. package/dist/tooltip.d.ts.map +1 -1
  346. package/dist/tooltip.mjs +1 -1
  347. package/package.json +8 -6
  348. package/src/accordion.tsx +58 -51
  349. package/src/alert-dialog.tsx +140 -93
  350. package/src/alert.tsx +44 -33
  351. package/src/aspect-ratio.tsx +10 -4
  352. package/src/avatar.tsx +92 -37
  353. package/src/badge.tsx +24 -14
  354. package/src/breadcrumb.tsx +73 -85
  355. package/src/button-group.tsx +78 -0
  356. package/src/button.tsx +46 -24
  357. package/src/calendar.tsx +52 -40
  358. package/src/card.tsx +67 -42
  359. package/src/carousel.tsx +164 -174
  360. package/src/chart.tsx +206 -232
  361. package/src/checkbox.tsx +17 -17
  362. package/src/collapsible.tsx +16 -10
  363. package/src/combobox.tsx +282 -0
  364. package/src/command.tsx +123 -120
  365. package/src/context-menu.tsx +206 -179
  366. package/src/dialog.tsx +111 -65
  367. package/src/direction.tsx +18 -0
  368. package/src/drawer.tsx +75 -78
  369. package/src/dropdown-menu.tsx +211 -180
  370. package/src/empty.tsx +83 -0
  371. package/src/field.tsx +217 -0
  372. package/src/hooks/use-mobile.ts +19 -0
  373. package/src/hover-card.tsx +33 -27
  374. package/src/index.ts +108 -154
  375. package/src/input-group.tsx +143 -0
  376. package/src/input-otp.tsx +81 -0
  377. package/src/input.tsx +8 -8
  378. package/src/item.tsx +185 -0
  379. package/src/kbd.tsx +21 -0
  380. package/src/label.tsx +17 -14
  381. package/src/menubar.tsx +211 -199
  382. package/src/native-select.tsx +54 -0
  383. package/src/navigation-menu.tsx +115 -110
  384. package/src/pagination.tsx +65 -80
  385. package/src/popover.tsx +53 -41
  386. package/src/progress.tsx +22 -20
  387. package/src/radio-group.tsx +22 -34
  388. package/src/resizable.tsx +34 -49
  389. package/src/scroll-area.tsx +43 -35
  390. package/src/search.tsx +12 -9
  391. package/src/select.tsx +138 -133
  392. package/src/separator.tsx +25 -18
  393. package/src/sheet.tsx +97 -127
  394. package/src/sidebar.tsx +660 -0
  395. package/src/skeleton.tsx +7 -6
  396. package/src/slider.tsx +51 -19
  397. package/src/sonner.tsx +22 -12
  398. package/src/spinner.tsx +10 -0
  399. package/src/support-fab.tsx +1 -1
  400. package/src/switch.tsx +28 -21
  401. package/src/table.tsx +61 -87
  402. package/src/tabs.tsx +75 -56
  403. package/src/textarea.tsx +8 -10
  404. package/src/toast.tsx +5 -0
  405. package/src/toggle-group.tsx +76 -40
  406. package/src/toggle.tsx +35 -15
  407. package/src/tooltip.tsx +41 -43
  408. package/dist/accordion-BTF24dQU.js +0 -1
  409. package/dist/accordion-DHTV2Am8.mjs +0 -221
  410. package/dist/alert-dialog-Bwn2-Uyf.mjs +0 -164
  411. package/dist/alert-dialog-DBMX5E0-.js +0 -7
  412. package/dist/avatar-BI7s8omb.js +0 -1
  413. package/dist/avatar-hzlewncL.mjs +0 -185
  414. package/dist/calendar-ykdYhTj9.js +0 -1
  415. package/dist/carousel-DSmAn1nc.js +0 -1
  416. package/dist/checkbox-dK6DJKeV.js +0 -1
  417. package/dist/command-CDSbHz4C.js +0 -1
  418. package/dist/command-j0rZqZ7B.mjs +0 -531
  419. package/dist/context-menu-BWgLbKLP.js +0 -1
  420. package/dist/context-menu-CWSzssAO.mjs +0 -292
  421. package/dist/dist-B28N93_W.js +0 -1
  422. package/dist/dist-B43Kk7ii.js +0 -1
  423. package/dist/dist-BTPL2C0R.js +0 -1
  424. package/dist/dist-BjEG16aJ.mjs +0 -111
  425. package/dist/dist-BlKAvKHD.js +0 -1
  426. package/dist/dist-C3Z3atn0.mjs +0 -10
  427. package/dist/dist-C4q8IPk4.mjs +0 -28
  428. package/dist/dist-CPglx4om.js +0 -1
  429. package/dist/dist-CV2U2xFR.js +0 -1
  430. package/dist/dist-Cv9YaN1n.mjs +0 -61
  431. package/dist/dist-DAe-fOIM.mjs +0 -25
  432. package/dist/dist-DQAJMTj0.js +0 -1
  433. package/dist/dist-DaCPM8ia.js +0 -1
  434. package/dist/dist-DasmYflz.js +0 -1
  435. package/dist/dist-DneYUKe0.js +0 -1
  436. package/dist/dist-Du2jbEkG.mjs +0 -1282
  437. package/dist/dist-Dw6-GQAn.js +0 -1
  438. package/dist/dist-DwGlbIjj.js +0 -5
  439. package/dist/dist-Dzjlf9ug.js +0 -1
  440. package/dist/dist-GaBUW_Tu.js +0 -1
  441. package/dist/dropdown-menu-Bz5LlLjl.js +0 -1
  442. package/dist/dropdown-menu-Cp1qpOLk.mjs +0 -288
  443. package/dist/hover-card-CyKIuXGH.js +0 -1
  444. package/dist/label-DGuuPl_e.mjs +0 -22
  445. package/dist/label-gVkdll-j.js +0 -1
  446. package/dist/menubar-DNrIQhY5.mjs +0 -410
  447. package/dist/menubar-DkjAo6qJ.js +0 -1
  448. package/dist/navigation-menu-1cmCEi0j.mjs +0 -602
  449. package/dist/navigation-menu-qPt8hpr5.js +0 -1
  450. package/dist/popover-CbM1tqdC.mjs +0 -201
  451. package/dist/popover-DGTgqdKX.js +0 -1
  452. package/dist/radio-group-BGThTiQM.mjs +0 -193
  453. package/dist/radio-group-ClFpAswm.js +0 -1
  454. package/dist/resizable-D09wr7tV.js +0 -1
  455. package/dist/scroll-area-W_aOLOdE.js +0 -1
  456. package/dist/select-BQtkQBiD.js +0 -1
  457. package/dist/separator-BmkhoDge.js +0 -1
  458. package/dist/slider-Bkluwc3b.js +0 -1
  459. package/dist/switch-DENAxyga.js +0 -1
  460. package/dist/switch-DbsdyQVg.mjs +0 -103
  461. package/dist/tabs-C9sMowgZ.mjs +0 -136
  462. package/dist/tabs-DeK-zpy4.js +0 -1
  463. package/dist/toast-BtXY2QTe.js +0 -1
  464. package/dist/toggle-group-B0H9TwdD.mjs +0 -155
  465. package/dist/toggle-group-CAyztsIl.js +0 -1
  466. package/dist/tooltip-CKcMl7tK.js +0 -1
  467. /package/dist/{dist-C_45sBzc.js → dist-C_45sBzc2.js} +0 -0
  468. /package/dist/{dist-DGzGsPqo.mjs → dist-DGzGsPqo2.mjs} +0 -0
@@ -0,0 +1,660 @@
1
+ import { cva, type VariantProps } from 'class-variance-authority';
2
+ import { Slot } from 'radix-ui';
3
+ import * as React from 'react';
4
+
5
+ import type {
6
+ SidebarBaseProps,
7
+ SidebarContentBaseProps,
8
+ SidebarFooterBaseProps,
9
+ SidebarGroupActionBaseProps,
10
+ SidebarGroupBaseProps,
11
+ SidebarGroupContentBaseProps,
12
+ SidebarGroupLabelBaseProps,
13
+ SidebarHeaderBaseProps,
14
+ SidebarInputBaseProps,
15
+ SidebarInsetBaseProps,
16
+ SidebarMenuActionBaseProps,
17
+ SidebarMenuBadgeBaseProps,
18
+ SidebarMenuBaseProps,
19
+ SidebarMenuButtonBaseProps,
20
+ SidebarMenuItemBaseProps,
21
+ SidebarMenuSkeletonBaseProps,
22
+ SidebarMenuSubBaseProps,
23
+ SidebarMenuSubButtonBaseProps,
24
+ SidebarMenuSubItemBaseProps,
25
+ SidebarProviderBaseProps,
26
+ SidebarRailBaseProps,
27
+ SidebarSeparatorBaseProps,
28
+ SidebarTriggerBaseProps,
29
+ } from '@gv-tech/ui-core';
30
+ import { PanelLeftIcon } from 'lucide-react';
31
+ import { Button } from './button';
32
+ import { useIsMobile } from './hooks/use-mobile';
33
+ import { Input } from './input';
34
+ import { cn } from './lib/utils';
35
+ import { Separator } from './separator';
36
+ import { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle } from './sheet';
37
+ import { Skeleton } from './skeleton';
38
+ import { Tooltip, TooltipContent, TooltipTrigger } from './tooltip';
39
+
40
+ const SIDEBAR_COOKIE_NAME = 'sidebar_state';
41
+ const SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7;
42
+ const SIDEBAR_WIDTH = '16rem';
43
+ const SIDEBAR_WIDTH_MOBILE = '18rem';
44
+ const SIDEBAR_WIDTH_ICON = '3rem';
45
+ const SIDEBAR_KEYBOARD_SHORTCUT = 'b';
46
+
47
+ type SidebarContextProps = {
48
+ state: 'expanded' | 'collapsed';
49
+ open: boolean;
50
+ setOpen: (open: boolean) => void;
51
+ openMobile: boolean;
52
+ setOpenMobile: (open: boolean) => void;
53
+ isMobile: boolean;
54
+ toggleSidebar: () => void;
55
+ };
56
+
57
+ const SidebarContext = React.createContext<SidebarContextProps | null>(null);
58
+
59
+ function useSidebar() {
60
+ const context = React.useContext(SidebarContext);
61
+ if (!context) {
62
+ throw new Error('useSidebar must be used within a SidebarProvider.');
63
+ }
64
+
65
+ return context;
66
+ }
67
+
68
+ function SidebarProvider({
69
+ defaultOpen = true,
70
+ open: openProp,
71
+ onOpenChange: setOpenProp,
72
+ className,
73
+ style,
74
+ children,
75
+ ...props
76
+ }: React.ComponentProps<'div'> & SidebarProviderBaseProps) {
77
+ const isMobile = useIsMobile();
78
+ const [openMobile, setOpenMobile] = React.useState(false);
79
+
80
+ // This is the internal state of the sidebar.
81
+ // We use openProp and setOpenProp for control from outside the component.
82
+ const [_open, _setOpen] = React.useState(defaultOpen);
83
+ const open = openProp ?? _open;
84
+ const setOpen = React.useCallback(
85
+ (value: boolean | ((value: boolean) => boolean)) => {
86
+ const openState = typeof value === 'function' ? value(open) : value;
87
+ if (setOpenProp) {
88
+ setOpenProp(openState);
89
+ } else {
90
+ _setOpen(openState);
91
+ }
92
+
93
+ // This sets the cookie to keep the sidebar state.
94
+ document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`;
95
+ },
96
+ [setOpenProp, open],
97
+ );
98
+
99
+ // Helper to toggle the sidebar.
100
+ const toggleSidebar = React.useCallback(() => {
101
+ return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open);
102
+ }, [isMobile, setOpen, setOpenMobile]);
103
+
104
+ // Adds a keyboard shortcut to toggle the sidebar.
105
+ React.useEffect(() => {
106
+ const handleKeyDown = (event: KeyboardEvent) => {
107
+ if (event.key === SIDEBAR_KEYBOARD_SHORTCUT && (event.metaKey || event.ctrlKey)) {
108
+ event.preventDefault();
109
+ toggleSidebar();
110
+ }
111
+ };
112
+
113
+ window.addEventListener('keydown', handleKeyDown);
114
+ return () => window.removeEventListener('keydown', handleKeyDown);
115
+ }, [toggleSidebar]);
116
+
117
+ // We add a state so that we can do data-state="expanded" or "collapsed".
118
+ // This makes it easier to style the sidebar with Tailwind classes.
119
+ const state = open ? 'expanded' : 'collapsed';
120
+
121
+ const contextValue = React.useMemo<SidebarContextProps>(
122
+ () => ({
123
+ state,
124
+ open,
125
+ setOpen,
126
+ isMobile,
127
+ openMobile,
128
+ setOpenMobile,
129
+ toggleSidebar,
130
+ }),
131
+ [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar],
132
+ );
133
+
134
+ return (
135
+ <SidebarContext.Provider value={contextValue}>
136
+ <div
137
+ data-slot="sidebar-wrapper"
138
+ style={
139
+ {
140
+ '--sidebar-width': SIDEBAR_WIDTH,
141
+ '--sidebar-width-icon': SIDEBAR_WIDTH_ICON,
142
+ ...style,
143
+ } as React.CSSProperties
144
+ }
145
+ className={cn('group/sidebar-wrapper has-data-[variant=inset]:bg-sidebar flex min-h-svh w-full', className)}
146
+ {...props}
147
+ >
148
+ {children}
149
+ </div>
150
+ </SidebarContext.Provider>
151
+ );
152
+ }
153
+
154
+ function Sidebar({
155
+ side = 'left',
156
+ variant = 'sidebar',
157
+ collapsible = 'offcanvas',
158
+ className,
159
+ children,
160
+ dir,
161
+ ...props
162
+ }: React.ComponentProps<'div'> & SidebarBaseProps) {
163
+ const { isMobile, state, openMobile, setOpenMobile } = useSidebar();
164
+
165
+ if (collapsible === 'none') {
166
+ return (
167
+ <div
168
+ data-slot="sidebar"
169
+ className={cn('bg-sidebar text-sidebar-foreground flex h-full w-(--sidebar-width) flex-col', className)}
170
+ {...props}
171
+ >
172
+ {children}
173
+ </div>
174
+ );
175
+ }
176
+
177
+ if (isMobile) {
178
+ return (
179
+ <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>
180
+ <SheetContent
181
+ dir={dir}
182
+ data-sidebar="sidebar"
183
+ data-slot="sidebar"
184
+ data-mobile="true"
185
+ className="bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden"
186
+ style={
187
+ {
188
+ '--sidebar-width': SIDEBAR_WIDTH_MOBILE,
189
+ } as React.CSSProperties
190
+ }
191
+ side={side}
192
+ >
193
+ <SheetHeader className="sr-only">
194
+ <SheetTitle>Sidebar</SheetTitle>
195
+ <SheetDescription>Displays the mobile sidebar.</SheetDescription>
196
+ </SheetHeader>
197
+ <div className="flex h-full w-full flex-col">{children}</div>
198
+ </SheetContent>
199
+ </Sheet>
200
+ );
201
+ }
202
+
203
+ return (
204
+ <div
205
+ className="group peer text-sidebar-foreground hidden md:block"
206
+ data-state={state}
207
+ data-collapsible={state === 'collapsed' ? collapsible : ''}
208
+ data-variant={variant}
209
+ data-side={side}
210
+ data-slot="sidebar"
211
+ >
212
+ {/* This is what handles the sidebar gap on desktop */}
213
+ <div
214
+ data-slot="sidebar-gap"
215
+ className={cn(
216
+ 'relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear',
217
+ 'group-data-[collapsible=offcanvas]:w-0',
218
+ 'group-data-[side=right]:rotate-180',
219
+ variant === 'floating' || variant === 'inset'
220
+ ? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'
221
+ : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',
222
+ )}
223
+ />
224
+ <div
225
+ data-slot="sidebar-container"
226
+ data-side={side}
227
+ className={cn(
228
+ 'fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear data-[side=left]:left-0 data-[side=left]:group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)] data-[side=right]:right-0 data-[side=right]:group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)] md:flex',
229
+ // Adjust the padding for floating and inset variants.
230
+ variant === 'floating' || variant === 'inset'
231
+ ? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]'
232
+ : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-e group-data-[side=right]:border-s',
233
+ className,
234
+ )}
235
+ {...props}
236
+ >
237
+ <div
238
+ data-sidebar="sidebar"
239
+ data-slot="sidebar-inner"
240
+ className="bg-sidebar group-data-[variant=floating]:ring-sidebar-border flex size-full flex-col group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:shadow-sm group-data-[variant=floating]:ring-1"
241
+ >
242
+ {children}
243
+ </div>
244
+ </div>
245
+ </div>
246
+ );
247
+ }
248
+
249
+ function SidebarTrigger({
250
+ className,
251
+ onClick,
252
+ ...props
253
+ }: React.ComponentProps<typeof Button> & SidebarTriggerBaseProps) {
254
+ const { toggleSidebar } = useSidebar();
255
+
256
+ return (
257
+ <Button
258
+ data-sidebar="trigger"
259
+ data-slot="sidebar-trigger"
260
+ variant="ghost"
261
+ size="icon-sm"
262
+ className={cn(className)}
263
+ onClick={(event) => {
264
+ onClick?.(event);
265
+ toggleSidebar();
266
+ }}
267
+ {...props}
268
+ >
269
+ <PanelLeftIcon />
270
+ <span className="sr-only">Toggle Sidebar</span>
271
+ </Button>
272
+ );
273
+ }
274
+
275
+ function SidebarRail({ className, ...props }: React.ComponentProps<'button'> & SidebarRailBaseProps) {
276
+ const { toggleSidebar } = useSidebar();
277
+
278
+ return (
279
+ <button
280
+ data-sidebar="rail"
281
+ data-slot="sidebar-rail"
282
+ aria-label="Toggle Sidebar"
283
+ tabIndex={-1}
284
+ onClick={toggleSidebar}
285
+ title="Toggle Sidebar"
286
+ className={cn(
287
+ 'hover:after:bg-sidebar-border absolute inset-y-0 z-20 hidden w-4 transition-all ease-linear group-data-[side=left]:-right-4 group-data-[side=right]:left-0 after:absolute after:inset-y-0 after:start-1/2 after:w-[2px] sm:flex ltr:-translate-x-1/2 rtl:-translate-x-1/2 rtl:rtl:translate-x-1/2 rtl:ltr:translate-x-1/2',
288
+ 'in-data-[side=left]:cursor-w-resize in-data-[side=right]:cursor-e-resize rtl:in-data-[side=left]:cursor-e-resize rtl:in-data-[side=right]:cursor-w-resize',
289
+ '[[data-side=left][data-state=collapsed]_&]:cursor-e-resize rtl:[[data-side=left][data-state=collapsed]_&]:cursor-w-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize rtl:[[data-side=right][data-state=collapsed]_&]:cursor-e-resize',
290
+ 'hover:group-data-[collapsible=offcanvas]:bg-sidebar group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:start-full rtl:group-data-[collapsible=offcanvas]:-translate-x-0',
291
+ '[[data-side=left][data-collapsible=offcanvas]_&]:-end-2',
292
+ '[[data-side=right][data-collapsible=offcanvas]_&]:-start-2',
293
+ className,
294
+ )}
295
+ {...props}
296
+ />
297
+ );
298
+ }
299
+
300
+ function SidebarInset({ className, ...props }: React.ComponentProps<'main'> & SidebarInsetBaseProps) {
301
+ return (
302
+ <main
303
+ data-slot="sidebar-inset"
304
+ className={cn(
305
+ 'bg-background relative flex w-full flex-1 flex-col md:peer-data-[variant=inset]:m-2 md:peer-data-[variant=inset]:ms-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow-sm md:peer-data-[variant=inset]:peer-data-[state=collapsed]:ms-2',
306
+ className,
307
+ )}
308
+ {...props}
309
+ />
310
+ );
311
+ }
312
+
313
+ function SidebarInput({ className, ...props }: React.ComponentProps<typeof Input> & SidebarInputBaseProps) {
314
+ return (
315
+ <Input
316
+ data-slot="sidebar-input"
317
+ data-sidebar="input"
318
+ className={cn('bg-background h-8 w-full shadow-none', className)}
319
+ {...props}
320
+ />
321
+ );
322
+ }
323
+
324
+ function SidebarHeader({ className, ...props }: React.ComponentProps<'div'> & SidebarHeaderBaseProps) {
325
+ return (
326
+ <div
327
+ data-slot="sidebar-header"
328
+ data-sidebar="header"
329
+ className={cn('flex flex-col gap-2 p-2', className)}
330
+ {...props}
331
+ />
332
+ );
333
+ }
334
+
335
+ function SidebarFooter({ className, ...props }: React.ComponentProps<'div'> & SidebarFooterBaseProps) {
336
+ return (
337
+ <div
338
+ data-slot="sidebar-footer"
339
+ data-sidebar="footer"
340
+ className={cn('flex flex-col gap-2 p-2', className)}
341
+ {...props}
342
+ />
343
+ );
344
+ }
345
+
346
+ function SidebarSeparator({ className, ...props }: React.ComponentProps<typeof Separator> & SidebarSeparatorBaseProps) {
347
+ return (
348
+ <Separator
349
+ data-slot="sidebar-separator"
350
+ data-sidebar="separator"
351
+ className={cn('bg-sidebar-border mx-2 w-auto', className)}
352
+ {...props}
353
+ />
354
+ );
355
+ }
356
+
357
+ function SidebarContent({ className, ...props }: React.ComponentProps<'div'> & SidebarContentBaseProps) {
358
+ return (
359
+ <div
360
+ data-slot="sidebar-content"
361
+ data-sidebar="content"
362
+ className={cn(
363
+ 'no-scrollbar flex min-h-0 flex-1 flex-col gap-0 overflow-auto group-data-[collapsible=icon]:overflow-hidden',
364
+ className,
365
+ )}
366
+ {...props}
367
+ />
368
+ );
369
+ }
370
+
371
+ function SidebarGroup({ className, ...props }: React.ComponentProps<'div'> & SidebarGroupBaseProps) {
372
+ return (
373
+ <div
374
+ data-slot="sidebar-group"
375
+ data-sidebar="group"
376
+ className={cn('relative flex w-full min-w-0 flex-col p-2', className)}
377
+ {...props}
378
+ />
379
+ );
380
+ }
381
+
382
+ function SidebarGroupLabel({
383
+ className,
384
+ asChild = false,
385
+ ...props
386
+ }: React.ComponentProps<'div'> & SidebarGroupLabelBaseProps) {
387
+ const Comp = asChild ? Slot.Root : 'div';
388
+
389
+ return (
390
+ <Comp
391
+ data-slot="sidebar-group-label"
392
+ data-sidebar="group-label"
393
+ className={cn(
394
+ 'text-sidebar-foreground/70 ring-sidebar-ring flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0 focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0',
395
+ className,
396
+ )}
397
+ {...props}
398
+ />
399
+ );
400
+ }
401
+
402
+ function SidebarGroupAction({
403
+ className,
404
+ asChild = false,
405
+ ...props
406
+ }: React.ComponentProps<'button'> & SidebarGroupActionBaseProps) {
407
+ const Comp = asChild ? Slot.Root : 'button';
408
+
409
+ return (
410
+ <Comp
411
+ data-slot="sidebar-group-action"
412
+ data-sidebar="group-action"
413
+ className={cn(
414
+ 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute end-3 top-3.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform group-data-[collapsible=icon]:hidden after:absolute after:-inset-2 focus-visible:ring-2 md:after:hidden [&>svg]:size-4 [&>svg]:shrink-0',
415
+ className,
416
+ )}
417
+ {...props}
418
+ />
419
+ );
420
+ }
421
+
422
+ function SidebarGroupContent({ className, ...props }: React.ComponentProps<'div'> & SidebarGroupContentBaseProps) {
423
+ return (
424
+ <div
425
+ data-slot="sidebar-group-content"
426
+ data-sidebar="group-content"
427
+ className={cn('w-full text-sm', className)}
428
+ {...props}
429
+ />
430
+ );
431
+ }
432
+
433
+ function SidebarMenu({ className, ...props }: React.ComponentProps<'ul'> & SidebarMenuBaseProps) {
434
+ return (
435
+ <ul
436
+ data-slot="sidebar-menu"
437
+ data-sidebar="menu"
438
+ className={cn('flex w-full min-w-0 flex-col gap-0', className)}
439
+ {...props}
440
+ />
441
+ );
442
+ }
443
+
444
+ function SidebarMenuItem({ className, ...props }: React.ComponentProps<'li'> & SidebarMenuItemBaseProps) {
445
+ return (
446
+ <li
447
+ data-slot="sidebar-menu-item"
448
+ data-sidebar="menu-item"
449
+ className={cn('group/menu-item relative', className)}
450
+ {...props}
451
+ />
452
+ );
453
+ }
454
+
455
+ const sidebarMenuButtonVariants = cva(
456
+ 'peer/menu-button group/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-start text-sm ring-sidebar-ring outline-hidden transition-[width,height,padding] group-has-data-[sidebar=menu-action]/menu-item:pe-8 group-data-[collapsible=icon]:size-8! group-data-[collapsible=icon]:p-2! hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground [&_svg]:size-4 [&_svg]:shrink-0 [&>span:last-child]:truncate',
457
+ {
458
+ variants: {
459
+ variant: {
460
+ default: 'hover:bg-sidebar-accent hover:text-sidebar-accent-foreground',
461
+ outline:
462
+ 'bg-background shadow-[0_0_0_1px_var(--sidebar-border)] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_var(--sidebar-accent)]',
463
+ },
464
+ size: {
465
+ default: 'h-8 text-sm',
466
+ sm: 'h-7 text-xs',
467
+ lg: 'h-12 text-sm group-data-[collapsible=icon]:p-0!',
468
+ },
469
+ },
470
+ defaultVariants: {
471
+ variant: 'default',
472
+ size: 'default',
473
+ },
474
+ },
475
+ );
476
+
477
+ function SidebarMenuButton({
478
+ asChild = false,
479
+ isActive = false,
480
+ variant = 'default',
481
+ size = 'default',
482
+ tooltip,
483
+ className,
484
+ ...props
485
+ }: React.ComponentProps<'button'> & VariantProps<typeof sidebarMenuButtonVariants> & SidebarMenuButtonBaseProps) {
486
+ const Comp = asChild ? Slot.Root : 'button';
487
+ const { isMobile, state } = useSidebar();
488
+
489
+ const button = (
490
+ <Comp
491
+ data-slot="sidebar-menu-button"
492
+ data-sidebar="menu-button"
493
+ data-size={size}
494
+ data-active={isActive}
495
+ className={cn(sidebarMenuButtonVariants({ variant, size }), className)}
496
+ {...props}
497
+ />
498
+ );
499
+
500
+ if (!tooltip) {
501
+ return button;
502
+ }
503
+
504
+ if (typeof tooltip === 'string') {
505
+ tooltip = {
506
+ children: tooltip,
507
+ };
508
+ }
509
+
510
+ return (
511
+ <Tooltip>
512
+ <TooltipTrigger asChild>{button}</TooltipTrigger>
513
+ <TooltipContent side="right" align="center" hidden={state !== 'collapsed' || isMobile} {...tooltip} />
514
+ </Tooltip>
515
+ );
516
+ }
517
+
518
+ function SidebarMenuAction({
519
+ className,
520
+ asChild = false,
521
+ showOnHover = false,
522
+ ...props
523
+ }: React.ComponentProps<'button'> & SidebarMenuActionBaseProps) {
524
+ const Comp = asChild ? Slot.Root : 'button';
525
+
526
+ return (
527
+ <Comp
528
+ data-slot="sidebar-menu-action"
529
+ data-sidebar="menu-action"
530
+ className={cn(
531
+ 'text-sidebar-foreground ring-sidebar-ring peer-hover/menu-button:text-sidebar-accent-foreground hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute end-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform group-data-[collapsible=icon]:hidden peer-data-[size=default]/menu-button:top-1.5 peer-data-[size=lg]/menu-button:top-2.5 peer-data-[size=sm]/menu-button:top-1 after:absolute after:-inset-2 focus-visible:ring-2 md:after:hidden [&>svg]:size-4 [&>svg]:shrink-0',
532
+ showOnHover &&
533
+ 'peer-data-active/menu-button:text-sidebar-accent-foreground group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 aria-expanded:opacity-100 md:opacity-0',
534
+ className,
535
+ )}
536
+ {...props}
537
+ />
538
+ );
539
+ }
540
+
541
+ function SidebarMenuBadge({ className, ...props }: React.ComponentProps<'div'> & SidebarMenuBadgeBaseProps) {
542
+ return (
543
+ <div
544
+ data-slot="sidebar-menu-badge"
545
+ data-sidebar="menu-badge"
546
+ className={cn(
547
+ 'text-sidebar-foreground peer-hover/menu-button:text-sidebar-accent-foreground peer-data-active/menu-button:text-sidebar-accent-foreground pointer-events-none absolute end-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none group-data-[collapsible=icon]:hidden peer-data-[size=default]/menu-button:top-1.5 peer-data-[size=lg]/menu-button:top-2.5 peer-data-[size=sm]/menu-button:top-1',
548
+ className,
549
+ )}
550
+ {...props}
551
+ />
552
+ );
553
+ }
554
+
555
+ function SidebarMenuSkeleton({
556
+ className,
557
+ showIcon = false,
558
+ ...props
559
+ }: React.ComponentProps<'div'> & SidebarMenuSkeletonBaseProps) {
560
+ // Random width between 50 to 90%.
561
+ const [width] = React.useState(() => {
562
+ return `${Math.floor(Math.random() * 40) + 50}%`;
563
+ });
564
+
565
+ return (
566
+ <div
567
+ data-slot="sidebar-menu-skeleton"
568
+ data-sidebar="menu-skeleton"
569
+ className={cn('flex h-8 items-center gap-2 rounded-md px-2', className)}
570
+ {...props}
571
+ >
572
+ {showIcon && <Skeleton className="size-4 rounded-md" data-sidebar="menu-skeleton-icon" />}
573
+ <Skeleton
574
+ className="h-4 max-w-(--skeleton-width) flex-1"
575
+ data-sidebar="menu-skeleton-text"
576
+ style={
577
+ {
578
+ '--skeleton-width': width,
579
+ } as React.CSSProperties
580
+ }
581
+ />
582
+ </div>
583
+ );
584
+ }
585
+
586
+ function SidebarMenuSub({ className, ...props }: React.ComponentProps<'ul'> & SidebarMenuSubBaseProps) {
587
+ return (
588
+ <ul
589
+ data-slot="sidebar-menu-sub"
590
+ data-sidebar="menu-sub"
591
+ className={cn(
592
+ 'border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-s px-2.5 py-0.5 group-data-[collapsible=icon]:hidden rtl:-translate-x-px',
593
+ className,
594
+ )}
595
+ {...props}
596
+ />
597
+ );
598
+ }
599
+
600
+ function SidebarMenuSubItem({ className, ...props }: React.ComponentProps<'li'> & SidebarMenuSubItemBaseProps) {
601
+ return (
602
+ <li
603
+ data-slot="sidebar-menu-sub-item"
604
+ data-sidebar="menu-sub-item"
605
+ className={cn('group/menu-sub-item relative', className)}
606
+ {...props}
607
+ />
608
+ );
609
+ }
610
+
611
+ function SidebarMenuSubButton({
612
+ asChild = false,
613
+ size = 'md',
614
+ isActive = false,
615
+ className,
616
+ ...props
617
+ }: React.ComponentProps<'a'> & SidebarMenuSubButtonBaseProps) {
618
+ const Comp = asChild ? Slot.Root : 'a';
619
+
620
+ return (
621
+ <Comp
622
+ data-slot="sidebar-menu-sub-button"
623
+ data-sidebar="menu-sub-button"
624
+ data-size={size}
625
+ data-active={isActive}
626
+ className={cn(
627
+ 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground active:bg-sidebar-accent active:text-sidebar-accent-foreground data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground [&>svg]:text-sidebar-accent-foreground flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden group-data-[collapsible=icon]:hidden focus-visible:ring-2 disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[size=md]:text-sm data-[size=sm]:text-xs rtl:translate-x-px [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0',
628
+ className,
629
+ )}
630
+ {...props}
631
+ />
632
+ );
633
+ }
634
+
635
+ export {
636
+ Sidebar,
637
+ SidebarContent,
638
+ SidebarFooter,
639
+ SidebarGroup,
640
+ SidebarGroupAction,
641
+ SidebarGroupContent,
642
+ SidebarGroupLabel,
643
+ SidebarHeader,
644
+ SidebarInput,
645
+ SidebarInset,
646
+ SidebarMenu,
647
+ SidebarMenuAction,
648
+ SidebarMenuBadge,
649
+ SidebarMenuButton,
650
+ SidebarMenuItem,
651
+ SidebarMenuSkeleton,
652
+ SidebarMenuSub,
653
+ SidebarMenuSubButton,
654
+ SidebarMenuSubItem,
655
+ SidebarProvider,
656
+ SidebarRail,
657
+ SidebarSeparator,
658
+ SidebarTrigger,
659
+ useSidebar,
660
+ };
package/src/skeleton.tsx CHANGED
@@ -1,11 +1,12 @@
1
- 'use client';
2
- import { SkeletonBaseProps } from '@gv-tech/ui-core';
3
- import * as React from 'react';
4
1
  import { cn } from './lib/utils';
5
2
 
6
- function Skeleton({ className, ...props }: React.HTMLAttributes<HTMLDivElement> & SkeletonBaseProps) {
7
- return <div className={cn('bg-primary/10 animate-pulse rounded-md', className)} {...props} />;
3
+ import type { SkeletonBaseProps } from '@gv-tech/ui-core';
4
+
5
+ function Skeleton({ className, ...props }: React.ComponentProps<'div'>) {
6
+ return <div data-slot="skeleton" className={cn('bg-muted animate-pulse rounded-md', className)} {...props} />;
8
7
  }
9
8
 
10
9
  export { Skeleton };
11
- export type { SkeletonBaseProps as SkeletonProps };
10
+
11
+ // Verify that the component satisfies the ui-core contract
12
+ const _verifySkeletonContract: SkeletonBaseProps = {} as unknown as React.ComponentProps<typeof Skeleton>;