@customafk/lunas-ui 0.0.63 → 0.0.64

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 (449) hide show
  1. package/dist/alert-dialog-BOMy-TmT.js +2 -0
  2. package/dist/alert-dialog-BOMy-TmT.js.map +1 -0
  3. package/dist/alert-dialog-lwTxSl-r.cjs +2 -0
  4. package/dist/alert-dialog-lwTxSl-r.cjs.map +1 -0
  5. package/dist/avatar-BaNIRUku.cjs +2 -0
  6. package/dist/avatar-BaNIRUku.cjs.map +1 -0
  7. package/dist/avatar-DZU7feMQ.js +2 -0
  8. package/dist/avatar-DZU7feMQ.js.map +1 -0
  9. package/dist/badge-6RQPy3Eo.js +2 -0
  10. package/dist/badge-6RQPy3Eo.js.map +1 -0
  11. package/dist/badge-BMXpbMfX.cjs +2 -0
  12. package/dist/badge-BMXpbMfX.cjs.map +1 -0
  13. package/dist/{button-BtvqPQbl.d.cts → button-CS4aajjP.d.ts} +5 -5
  14. package/dist/{button-B_r8XsfH.d.ts → button-De2032Bs.d.cts} +5 -5
  15. package/dist/calendar-BZRNZdsJ.js +2 -0
  16. package/dist/calendar-BZRNZdsJ.js.map +1 -0
  17. package/dist/{calendar-Cd2aQCHB.cjs → calendar-CUDdTiC-.cjs} +2 -2
  18. package/dist/calendar-CUDdTiC-.cjs.map +1 -0
  19. package/dist/cards/simple-card.d.ts +2 -2
  20. package/dist/{command-DewLG5N0.d.ts → command-D7AHVkgQ.d.ts} +12 -12
  21. package/dist/{command-tq_xgJ8Q.d.cts → command-Db5JViIx.d.cts} +12 -12
  22. package/dist/data-display/country.cjs +1 -1
  23. package/dist/data-display/country.js +1 -1
  24. package/dist/data-display/data-list.cjs +1 -1
  25. package/dist/data-display/data-list.js +1 -1
  26. package/dist/data-display/date-tooltip.cjs +1 -1
  27. package/dist/data-display/date-tooltip.js +1 -1
  28. package/dist/data-display/empty.cjs +1 -1
  29. package/dist/data-display/empty.d.ts +2 -2
  30. package/dist/data-display/empty.js +1 -1
  31. package/dist/data-display/name.cjs +1 -1
  32. package/dist/data-display/name.js +1 -1
  33. package/dist/data-display/phone-number.cjs +1 -1
  34. package/dist/data-display/phone-number.js +1 -1
  35. package/dist/data-display/role-badge.cjs +1 -1
  36. package/dist/data-display/role-badge.js +1 -1
  37. package/dist/data-display/statistic.cjs +1 -1
  38. package/dist/data-display/statistic.d.cts +2 -2
  39. package/dist/data-display/statistic.js +1 -1
  40. package/dist/{dialog-DI0dG1nN.d.cts → dialog-CiqPVetj.d.cts} +12 -12
  41. package/dist/{dialog-Ddyl2CZg.d.ts → dialog-yE-2SRfz.d.ts} +12 -12
  42. package/dist/dialogs/confirm-dialog.cjs +1 -1
  43. package/dist/dialogs/confirm-dialog.js +1 -1
  44. package/dist/dialogs/detail-dialog/component/sidebar.cjs +1 -1
  45. package/dist/dialogs/detail-dialog/component/sidebar.d.cts +30 -30
  46. package/dist/dialogs/detail-dialog/component/sidebar.d.ts +30 -30
  47. package/dist/dialogs/detail-dialog/component/sidebar.js +1 -1
  48. package/dist/dialogs/detail-dialog/index.cjs +1 -1
  49. package/dist/dialogs/detail-dialog/index.js +1 -1
  50. package/dist/dialogs/error-dialog.cjs +1 -1
  51. package/dist/dialogs/error-dialog.js +1 -1
  52. package/dist/dialogs/form-dialog.cjs +1 -1
  53. package/dist/dialogs/form-dialog.d.cts +2 -2
  54. package/dist/dialogs/form-dialog.d.ts +2 -2
  55. package/dist/dialogs/form-dialog.js +1 -1
  56. package/dist/drawer-B7OJzlXZ.js +2 -0
  57. package/dist/drawer-B7OJzlXZ.js.map +1 -0
  58. package/dist/drawer-Dh9uXVnU.cjs +2 -0
  59. package/dist/drawer-Dh9uXVnU.cjs.map +1 -0
  60. package/dist/{error-dialog-COyyui94.cjs → error-dialog-BkCaUR7F.cjs} +2 -2
  61. package/dist/{error-dialog-COyyui94.cjs.map → error-dialog-BkCaUR7F.cjs.map} +1 -1
  62. package/dist/{error-dialog-YlSsQqiT.js → error-dialog-D3tnycqF.js} +2 -2
  63. package/dist/{error-dialog-YlSsQqiT.js.map → error-dialog-D3tnycqF.js.map} +1 -1
  64. package/dist/flex-BZHWRUkz.js +2 -0
  65. package/dist/flex-BZHWRUkz.js.map +1 -0
  66. package/dist/flex-DMgD86BT.cjs +2 -0
  67. package/dist/flex-DMgD86BT.cjs.map +1 -0
  68. package/dist/form-CaxhlWxK.cjs +2 -0
  69. package/dist/form-CaxhlWxK.cjs.map +1 -0
  70. package/dist/form-D-gDMD-J.js +2 -0
  71. package/dist/form-D-gDMD-J.js.map +1 -0
  72. package/dist/{form-wrapper-D0-p7R15.cjs → form-wrapper-BUkoh-c7.cjs} +2 -2
  73. package/dist/{form-wrapper-D0-p7R15.cjs.map → form-wrapper-BUkoh-c7.cjs.map} +1 -1
  74. package/dist/{form-wrapper-C4OO_eLu.js → form-wrapper-BbScjpBv.js} +2 -2
  75. package/dist/{form-wrapper-C4OO_eLu.js.map → form-wrapper-BbScjpBv.js.map} +1 -1
  76. package/dist/forms/combobox-field.cjs +1 -1
  77. package/dist/forms/combobox-field.js +1 -1
  78. package/dist/forms/date-field.cjs +1 -1
  79. package/dist/forms/date-field.d.cts +2 -2
  80. package/dist/forms/date-field.d.ts +2 -2
  81. package/dist/forms/date-field.js +1 -1
  82. package/dist/forms/form-wrapper.cjs +1 -1
  83. package/dist/forms/form-wrapper.d.cts +2 -2
  84. package/dist/forms/form-wrapper.d.ts +2 -2
  85. package/dist/forms/form-wrapper.js +1 -1
  86. package/dist/forms/multi-select-field.cjs +1 -1
  87. package/dist/forms/multi-select-field.d.cts +2 -2
  88. package/dist/forms/multi-select-field.d.ts +2 -2
  89. package/dist/forms/multi-select-field.js +1 -1
  90. package/dist/forms/number-field.cjs +1 -1
  91. package/dist/forms/number-field.cjs.map +1 -1
  92. package/dist/forms/number-field.d.cts +2 -2
  93. package/dist/forms/number-field.d.ts +2 -2
  94. package/dist/forms/number-field.js +1 -1
  95. package/dist/forms/number-field.js.map +1 -1
  96. package/dist/forms/password-field.cjs +1 -1
  97. package/dist/forms/password-field.cjs.map +1 -1
  98. package/dist/forms/password-field.d.cts +2 -2
  99. package/dist/forms/password-field.d.ts +2 -2
  100. package/dist/forms/password-field.js +1 -1
  101. package/dist/forms/password-field.js.map +1 -1
  102. package/dist/forms/select-field.cjs +1 -1
  103. package/dist/forms/select-field.d.cts +2 -2
  104. package/dist/forms/select-field.d.ts +2 -2
  105. package/dist/forms/select-field.js +1 -1
  106. package/dist/forms/switch-field.cjs +1 -1
  107. package/dist/forms/switch-field.d.cts +2 -2
  108. package/dist/forms/switch-field.d.ts +2 -2
  109. package/dist/forms/switch-field.js +1 -1
  110. package/dist/forms/text-field.cjs +1 -1
  111. package/dist/forms/text-field.d.cts +2 -2
  112. package/dist/forms/text-field.d.ts +2 -2
  113. package/dist/forms/text-field.js +1 -1
  114. package/dist/forms/textarea-field.cjs +1 -1
  115. package/dist/forms/textarea-field.d.cts +2 -2
  116. package/dist/forms/textarea-field.d.ts +2 -2
  117. package/dist/forms/textarea-field.js +1 -1
  118. package/dist/input-BFZuwsER.js +2 -0
  119. package/dist/input-BFZuwsER.js.map +1 -0
  120. package/dist/{input-B3A9FFIr.d.ts → input-BayoSfCE.d.cts} +3 -4
  121. package/dist/{input-CBmfFkSA.d.cts → input-BjiwI6EW.d.ts} +3 -4
  122. package/dist/input-ERPHY3v4.cjs +2 -0
  123. package/dist/input-ERPHY3v4.cjs.map +1 -0
  124. package/dist/label-BBPPT0-L.cjs +2 -0
  125. package/dist/label-BBPPT0-L.cjs.map +1 -0
  126. package/dist/label-DdpIoRiG.js +2 -0
  127. package/dist/label-DdpIoRiG.js.map +1 -0
  128. package/dist/layouts/app-layout/index.cjs +1 -1
  129. package/dist/layouts/app-layout/index.cjs.map +1 -1
  130. package/dist/layouts/app-layout/index.d.cts +26 -27
  131. package/dist/layouts/app-layout/index.d.ts +37 -38
  132. package/dist/layouts/app-layout/index.js +1 -1
  133. package/dist/layouts/app-layout/index.js.map +1 -1
  134. package/dist/layouts/flex.cjs +1 -1
  135. package/dist/layouts/flex.d.cts +4 -5
  136. package/dist/layouts/flex.d.ts +2 -3
  137. package/dist/layouts/flex.js +1 -1
  138. package/dist/layouts/service-layout/index.cjs +1 -1
  139. package/dist/layouts/service-layout/index.cjs.map +1 -1
  140. package/dist/layouts/service-layout/index.d.cts +28 -13
  141. package/dist/layouts/service-layout/index.d.ts +41 -25
  142. package/dist/layouts/service-layout/index.js +1 -1
  143. package/dist/layouts/service-layout/index.js.map +1 -1
  144. package/dist/multi-select-BAXHYtlU.cjs +2 -0
  145. package/dist/multi-select-BAXHYtlU.cjs.map +1 -0
  146. package/dist/multi-select-oXuLHx0A.js +2 -0
  147. package/dist/multi-select-oXuLHx0A.js.map +1 -0
  148. package/dist/progress-Cet_LGmM.cjs +2 -0
  149. package/dist/progress-Cet_LGmM.cjs.map +1 -0
  150. package/dist/progress-DdINdNdF.js +2 -0
  151. package/dist/progress-DdINdNdF.js.map +1 -0
  152. package/dist/{search-input-BxNMZVG4.js → search-input-B_L6kaz-.js} +2 -2
  153. package/dist/{search-input-BxNMZVG4.js.map → search-input-B_L6kaz-.js.map} +1 -1
  154. package/dist/{search-input-BXAnx2q9.cjs → search-input-DWLfcXEU.cjs} +2 -2
  155. package/dist/{search-input-BXAnx2q9.cjs.map → search-input-DWLfcXEU.cjs.map} +1 -1
  156. package/dist/{separator-DT79vOG-.d.cts → separator-BSmwGEtT.d.cts} +3 -3
  157. package/dist/{separator-Cr_2vFm6.d.ts → separator-zD-G3xIG.d.ts} +3 -3
  158. package/dist/{sidebar-BWhRjoI9.cjs → sidebar-BxGyCuTJ.cjs} +2 -2
  159. package/dist/{sidebar-BWhRjoI9.cjs.map → sidebar-BxGyCuTJ.cjs.map} +1 -1
  160. package/dist/{sidebar-DwA61Am0.js → sidebar-CMWETVDr.js} +2 -2
  161. package/dist/{sidebar-DwA61Am0.js.map → sidebar-CMWETVDr.js.map} +1 -1
  162. package/dist/switch-BPSKvrTw.cjs +2 -0
  163. package/dist/switch-BPSKvrTw.cjs.map +1 -0
  164. package/dist/switch-Crju8DJO.js +2 -0
  165. package/dist/switch-Crju8DJO.js.map +1 -0
  166. package/dist/table/index.cjs +1 -1
  167. package/dist/table/index.cjs.map +1 -1
  168. package/dist/table/index.d.cts +2 -3
  169. package/dist/table/index.d.ts +2 -3
  170. package/dist/table/index.js +1 -1
  171. package/dist/table/index.js.map +1 -1
  172. package/dist/table-CSvLRXlk.cjs +2 -0
  173. package/dist/table-CSvLRXlk.cjs.map +1 -0
  174. package/dist/table-DCmuhHSH.js +2 -0
  175. package/dist/table-DCmuhHSH.js.map +1 -0
  176. package/dist/textarea-BCZiUxv7.js +2 -0
  177. package/dist/textarea-BCZiUxv7.js.map +1 -0
  178. package/dist/textarea-BtACo9UF.cjs +2 -0
  179. package/dist/textarea-BtACo9UF.cjs.map +1 -0
  180. package/dist/{toggle-BAcB5uqb.d.ts → toggle-BtGh6fdx.d.ts} +5 -6
  181. package/dist/{toggle-BXosB_DV.d.cts → toggle-CP8phE7Y.d.cts} +3 -4
  182. package/dist/toggle-D8VezYdr.js +2 -0
  183. package/dist/toggle-D8VezYdr.js.map +1 -0
  184. package/dist/toggle-D_5Xh3Rl.cjs +2 -0
  185. package/dist/toggle-D_5Xh3Rl.cjs.map +1 -0
  186. package/dist/tooltip-CQ8hkJ42.cjs +2 -0
  187. package/dist/tooltip-CQ8hkJ42.cjs.map +1 -0
  188. package/dist/tooltip-CTUSyCdh.js +2 -0
  189. package/dist/tooltip-CTUSyCdh.js.map +1 -0
  190. package/dist/{tooltip-CyEOAlsP.d.ts → tooltip-CamHYf1v.d.ts} +6 -7
  191. package/dist/{tooltip-CJK3asOo.d.cts → tooltip-DLNDOfBF.d.cts} +6 -7
  192. package/dist/typography/paragraph.d.cts +2 -2
  193. package/dist/typography/paragraph.d.ts +2 -2
  194. package/dist/typography/title.d.cts +2 -2
  195. package/dist/typography/title.d.ts +2 -2
  196. package/dist/ui/alert-dialog.cjs +1 -1
  197. package/dist/ui/alert-dialog.d.cts +12 -13
  198. package/dist/ui/alert-dialog.d.ts +12 -13
  199. package/dist/ui/alert-dialog.js +1 -1
  200. package/dist/ui/alert.cjs +1 -1
  201. package/dist/ui/alert.cjs.map +1 -1
  202. package/dist/ui/alert.d.cts +4 -5
  203. package/dist/ui/alert.d.ts +6 -7
  204. package/dist/ui/alert.js +1 -1
  205. package/dist/ui/alert.js.map +1 -1
  206. package/dist/ui/aspect-ratio.cjs +1 -1
  207. package/dist/ui/aspect-ratio.cjs.map +1 -1
  208. package/dist/ui/aspect-ratio.d.cts +2 -3
  209. package/dist/ui/aspect-ratio.d.ts +2 -3
  210. package/dist/ui/aspect-ratio.js +1 -1
  211. package/dist/ui/aspect-ratio.js.map +1 -1
  212. package/dist/ui/avatar.cjs +1 -1
  213. package/dist/ui/avatar.d.cts +4 -5
  214. package/dist/ui/avatar.d.ts +4 -5
  215. package/dist/ui/avatar.js +1 -1
  216. package/dist/ui/badge.cjs +1 -1
  217. package/dist/ui/badge.d.cts +4 -5
  218. package/dist/ui/badge.d.ts +4 -5
  219. package/dist/ui/badge.js +1 -1
  220. package/dist/ui/breadcrumb.cjs +1 -1
  221. package/dist/ui/breadcrumb.cjs.map +1 -1
  222. package/dist/ui/breadcrumb.d.cts +8 -9
  223. package/dist/ui/breadcrumb.d.ts +8 -9
  224. package/dist/ui/breadcrumb.js +1 -1
  225. package/dist/ui/breadcrumb.js.map +1 -1
  226. package/dist/ui/button.d.cts +1 -1
  227. package/dist/ui/button.d.ts +1 -1
  228. package/dist/ui/buttons/upload-image.cjs +1 -1
  229. package/dist/ui/buttons/upload-image.cjs.map +1 -1
  230. package/dist/ui/buttons/upload-image.d.cts +1 -1
  231. package/dist/ui/buttons/upload-image.d.ts +1 -1
  232. package/dist/ui/buttons/upload-image.js +1 -1
  233. package/dist/ui/buttons/upload-image.js.map +1 -1
  234. package/dist/ui/calendar.cjs +1 -1
  235. package/dist/ui/calendar.d.cts +4 -5
  236. package/dist/ui/calendar.d.ts +4 -5
  237. package/dist/ui/calendar.js +1 -1
  238. package/dist/ui/card.d.cts +8 -8
  239. package/dist/ui/card.d.ts +8 -8
  240. package/dist/ui/carousel.cjs +1 -1
  241. package/dist/ui/carousel.cjs.map +1 -1
  242. package/dist/ui/carousel.d.cts +7 -8
  243. package/dist/ui/carousel.d.ts +7 -8
  244. package/dist/ui/carousel.js +1 -1
  245. package/dist/ui/carousel.js.map +1 -1
  246. package/dist/ui/collapsible.cjs +1 -1
  247. package/dist/ui/collapsible.cjs.map +1 -1
  248. package/dist/ui/collapsible.d.cts +4 -5
  249. package/dist/ui/collapsible.d.ts +4 -5
  250. package/dist/ui/collapsible.js +1 -1
  251. package/dist/ui/collapsible.js.map +1 -1
  252. package/dist/ui/command.d.cts +2 -2
  253. package/dist/ui/command.d.ts +2 -2
  254. package/dist/ui/context-menu.cjs +1 -1
  255. package/dist/ui/context-menu.cjs.map +1 -1
  256. package/dist/ui/context-menu.d.cts +16 -17
  257. package/dist/ui/context-menu.d.ts +16 -17
  258. package/dist/ui/context-menu.js +1 -1
  259. package/dist/ui/context-menu.js.map +1 -1
  260. package/dist/ui/dialog.d.cts +1 -1
  261. package/dist/ui/dialog.d.ts +1 -1
  262. package/dist/ui/dropdown-menu.d.cts +16 -16
  263. package/dist/ui/dropdown-menu.d.ts +16 -16
  264. package/dist/ui/file-uploader.cjs +1 -1
  265. package/dist/ui/file-uploader.cjs.map +1 -1
  266. package/dist/ui/file-uploader.d.cts +2 -3
  267. package/dist/ui/file-uploader.d.ts +2 -3
  268. package/dist/ui/file-uploader.js +2 -2
  269. package/dist/ui/file-uploader.js.map +1 -1
  270. package/dist/ui/form.cjs +1 -1
  271. package/dist/ui/form.d.cts +7 -8
  272. package/dist/ui/form.d.ts +7 -8
  273. package/dist/ui/form.js +1 -1
  274. package/dist/ui/hover-card.cjs +1 -1
  275. package/dist/ui/hover-card.cjs.map +1 -1
  276. package/dist/ui/hover-card.d.cts +4 -5
  277. package/dist/ui/hover-card.d.ts +4 -5
  278. package/dist/ui/hover-card.js +1 -1
  279. package/dist/ui/hover-card.js.map +1 -1
  280. package/dist/ui/input-otp.cjs +1 -1
  281. package/dist/ui/input-otp.cjs.map +1 -1
  282. package/dist/ui/input-otp.d.cts +5 -6
  283. package/dist/ui/input-otp.d.ts +5 -6
  284. package/dist/ui/input-otp.js +1 -1
  285. package/dist/ui/input-otp.js.map +1 -1
  286. package/dist/ui/input.cjs +1 -1
  287. package/dist/ui/input.d.cts +1 -1
  288. package/dist/ui/input.d.ts +1 -1
  289. package/dist/ui/input.js +1 -1
  290. package/dist/ui/inputs/search-input.cjs +1 -1
  291. package/dist/ui/inputs/search-input.d.cts +3 -3
  292. package/dist/ui/inputs/search-input.d.ts +3 -3
  293. package/dist/ui/inputs/search-input.js +1 -1
  294. package/dist/ui/label.cjs +1 -1
  295. package/dist/ui/label.d.cts +2 -3
  296. package/dist/ui/label.d.ts +2 -3
  297. package/dist/ui/label.js +1 -1
  298. package/dist/ui/menubar.cjs +1 -1
  299. package/dist/ui/menubar.cjs.map +1 -1
  300. package/dist/ui/menubar.d.cts +17 -18
  301. package/dist/ui/menubar.d.ts +17 -18
  302. package/dist/ui/menubar.js +1 -1
  303. package/dist/ui/menubar.js.map +1 -1
  304. package/dist/ui/multi-select.cjs +1 -1
  305. package/dist/ui/multi-select.d.cts +4 -4
  306. package/dist/ui/multi-select.d.ts +4 -4
  307. package/dist/ui/multi-select.js +1 -1
  308. package/dist/ui/navigation-menu.d.cts +11 -11
  309. package/dist/ui/navigation-menu.d.ts +11 -11
  310. package/dist/ui/pagination.cjs +1 -1
  311. package/dist/ui/pagination.cjs.map +1 -1
  312. package/dist/ui/pagination.d.cts +9 -10
  313. package/dist/ui/pagination.d.ts +9 -10
  314. package/dist/ui/pagination.js +1 -1
  315. package/dist/ui/pagination.js.map +1 -1
  316. package/dist/ui/popover.d.cts +5 -5
  317. package/dist/ui/popover.d.ts +5 -5
  318. package/dist/ui/progress.cjs +1 -1
  319. package/dist/ui/progress.d.cts +2 -3
  320. package/dist/ui/progress.d.ts +2 -3
  321. package/dist/ui/progress.js +1 -1
  322. package/dist/ui/radio-group.cjs +1 -1
  323. package/dist/ui/radio-group.cjs.map +1 -1
  324. package/dist/ui/radio-group.d.cts +3 -4
  325. package/dist/ui/radio-group.d.ts +3 -4
  326. package/dist/ui/radio-group.js +1 -1
  327. package/dist/ui/radio-group.js.map +1 -1
  328. package/dist/ui/resizable.cjs +1 -1
  329. package/dist/ui/resizable.cjs.map +1 -1
  330. package/dist/ui/resizable.d.cts +4 -5
  331. package/dist/ui/resizable.d.ts +4 -5
  332. package/dist/ui/resizable.js +1 -1
  333. package/dist/ui/resizable.js.map +1 -1
  334. package/dist/ui/scroll-area.d.cts +3 -3
  335. package/dist/ui/scroll-area.d.ts +3 -3
  336. package/dist/ui/select.d.cts +11 -11
  337. package/dist/ui/select.d.ts +11 -11
  338. package/dist/ui/separator.d.cts +1 -1
  339. package/dist/ui/separator.d.ts +1 -1
  340. package/dist/ui/sheet.d.cts +9 -9
  341. package/dist/ui/sheet.d.ts +9 -9
  342. package/dist/ui/sidebar.cjs +1 -1
  343. package/dist/ui/sidebar.cjs.map +1 -1
  344. package/dist/ui/sidebar.d.cts +30 -31
  345. package/dist/ui/sidebar.d.ts +30 -31
  346. package/dist/ui/sidebar.js +1 -1
  347. package/dist/ui/sidebar.js.map +1 -1
  348. package/dist/ui/skeleton.d.cts +2 -2
  349. package/dist/ui/skeleton.d.ts +2 -2
  350. package/dist/ui/slider.cjs +1 -1
  351. package/dist/ui/slider.cjs.map +1 -1
  352. package/dist/ui/slider.d.cts +2 -3
  353. package/dist/ui/slider.d.ts +2 -3
  354. package/dist/ui/slider.js +1 -1
  355. package/dist/ui/slider.js.map +1 -1
  356. package/dist/ui/sonner.d.cts +2 -2
  357. package/dist/ui/sonner.d.ts +2 -2
  358. package/dist/ui/switch.cjs +1 -1
  359. package/dist/ui/switch.d.cts +2 -3
  360. package/dist/ui/switch.d.ts +2 -3
  361. package/dist/ui/switch.js +1 -1
  362. package/dist/ui/table.cjs +1 -1
  363. package/dist/ui/table.d.cts +9 -10
  364. package/dist/ui/table.d.ts +9 -10
  365. package/dist/ui/table.js +1 -1
  366. package/dist/ui/tabs.d.cts +5 -5
  367. package/dist/ui/tabs.d.ts +5 -5
  368. package/dist/ui/textarea.cjs +1 -1
  369. package/dist/ui/textarea.d.cts +2 -3
  370. package/dist/ui/textarea.d.ts +2 -3
  371. package/dist/ui/textarea.js +1 -1
  372. package/dist/ui/toggle-group.cjs +1 -1
  373. package/dist/ui/toggle-group.cjs.map +1 -1
  374. package/dist/ui/toggle-group.d.cts +4 -5
  375. package/dist/ui/toggle-group.d.ts +4 -5
  376. package/dist/ui/toggle-group.js +1 -1
  377. package/dist/ui/toggle-group.js.map +1 -1
  378. package/dist/ui/toggle.cjs +1 -1
  379. package/dist/ui/toggle.d.cts +1 -1
  380. package/dist/ui/toggle.d.ts +1 -1
  381. package/dist/ui/toggle.js +1 -1
  382. package/dist/ui/tooltip.cjs +1 -1
  383. package/dist/ui/tooltip.d.cts +1 -1
  384. package/dist/ui/tooltip.d.ts +1 -1
  385. package/dist/ui/tooltip.js +1 -1
  386. package/package.json +2 -2
  387. package/dist/alert-dialog-7AEaiJxA.cjs +0 -2
  388. package/dist/alert-dialog-7AEaiJxA.cjs.map +0 -1
  389. package/dist/alert-dialog-B8Whrlfq.js +0 -2
  390. package/dist/alert-dialog-B8Whrlfq.js.map +0 -1
  391. package/dist/avatar-Bp69hha6.js +0 -2
  392. package/dist/avatar-Bp69hha6.js.map +0 -1
  393. package/dist/avatar-CRQdBYW5.cjs +0 -2
  394. package/dist/avatar-CRQdBYW5.cjs.map +0 -1
  395. package/dist/badge-8wMMxROk.js +0 -2
  396. package/dist/badge-8wMMxROk.js.map +0 -1
  397. package/dist/badge-BnFraaZ1.cjs +0 -2
  398. package/dist/badge-BnFraaZ1.cjs.map +0 -1
  399. package/dist/calendar-BW3whtDD.js +0 -2
  400. package/dist/calendar-BW3whtDD.js.map +0 -1
  401. package/dist/calendar-Cd2aQCHB.cjs.map +0 -1
  402. package/dist/drawer-BbQKog4D.js +0 -2
  403. package/dist/drawer-BbQKog4D.js.map +0 -1
  404. package/dist/drawer-vqMdOZtq.cjs +0 -2
  405. package/dist/drawer-vqMdOZtq.cjs.map +0 -1
  406. package/dist/flex-BxBmZCWh.js +0 -2
  407. package/dist/flex-BxBmZCWh.js.map +0 -1
  408. package/dist/flex-C-4TxUDe.cjs +0 -2
  409. package/dist/flex-C-4TxUDe.cjs.map +0 -1
  410. package/dist/form-B0fOiANW.js +0 -2
  411. package/dist/form-B0fOiANW.js.map +0 -1
  412. package/dist/form-DAwCSzSe.cjs +0 -2
  413. package/dist/form-DAwCSzSe.cjs.map +0 -1
  414. package/dist/input-B0Q1kBoj.js +0 -2
  415. package/dist/input-B0Q1kBoj.js.map +0 -1
  416. package/dist/input-BxXRqpc1.cjs +0 -2
  417. package/dist/input-BxXRqpc1.cjs.map +0 -1
  418. package/dist/label-BbuMrcie.cjs +0 -2
  419. package/dist/label-BbuMrcie.cjs.map +0 -1
  420. package/dist/label-CyaoUND0.js +0 -2
  421. package/dist/label-CyaoUND0.js.map +0 -1
  422. package/dist/multi-select-Bp7nkNEB.js +0 -2
  423. package/dist/multi-select-Bp7nkNEB.js.map +0 -1
  424. package/dist/multi-select-CGe8Mg3n.cjs +0 -2
  425. package/dist/multi-select-CGe8Mg3n.cjs.map +0 -1
  426. package/dist/progress-CBZMOdvp.js +0 -2
  427. package/dist/progress-CBZMOdvp.js.map +0 -1
  428. package/dist/progress-CO0tL2yC.cjs +0 -2
  429. package/dist/progress-CO0tL2yC.cjs.map +0 -1
  430. package/dist/switch-32ewlnXt.js +0 -2
  431. package/dist/switch-32ewlnXt.js.map +0 -1
  432. package/dist/switch-BCOPCdXH.cjs +0 -2
  433. package/dist/switch-BCOPCdXH.cjs.map +0 -1
  434. package/dist/table-6BtDTiv_.cjs +0 -2
  435. package/dist/table-6BtDTiv_.cjs.map +0 -1
  436. package/dist/table-CachGeLA.js +0 -2
  437. package/dist/table-CachGeLA.js.map +0 -1
  438. package/dist/textarea-BEPen5oo.cjs +0 -2
  439. package/dist/textarea-BEPen5oo.cjs.map +0 -1
  440. package/dist/textarea-BI5mw0Vy.js +0 -2
  441. package/dist/textarea-BI5mw0Vy.js.map +0 -1
  442. package/dist/toggle-Cicuy0bA.cjs +0 -2
  443. package/dist/toggle-Cicuy0bA.cjs.map +0 -1
  444. package/dist/toggle-DZbuAtVZ.js +0 -2
  445. package/dist/toggle-DZbuAtVZ.js.map +0 -1
  446. package/dist/tooltip-CN8vvmWA.js +0 -2
  447. package/dist/tooltip-CN8vvmWA.js.map +0 -1
  448. package/dist/tooltip-meYt4lxB.cjs +0 -2
  449. package/dist/tooltip-meYt4lxB.cjs.map +0 -1
@@ -1,2 +1,2 @@
1
- "use client";const e=require(`../../chunk-CUT6urMc.cjs`),t=require(`../../button-119IIVCy.cjs`),n=require(`../../skeleton-CmGSyYRm.cjs`),r=require(`../../tooltip-meYt4lxB.cjs`),i=require(`../../separator-JGL-8B0V.cjs`),a=require(`../../sheet-slcLNlWv.cjs`),o=e.__toESM(require(`lucide-react`)),s=e.__toESM(require(`@customafk/react-toolkit/utils`)),c=e.__toESM(require(`class-variance-authority`)),l=e.__toESM(require(`radix-ui`)),u=e.__toESM(require(`react/jsx-runtime`)),d=e.__toESM(require(`react`)),f=e.__toESM(require(`@customafk/react-toolkit/hooks/useMobile`)),p=`sidebar_state`,m=3600*24*7,h=`16rem`,g=`16rem`,_=`3rem`,v=`b`,y=d.default.createContext(null);function b(){let e=d.default.useContext(y);if(!e)throw Error(`useSidebar must be used within a SidebarProvider.`);return e}function x({defaultOpen:e=!0,open:t,onOpenChange:n,className:i,style:a,children:o,...c}){let l=(0,f.useIsMobile)(),[p,m]=d.default.useState(!1),[h,g]=d.default.useState(e),_=t??h,v=d.default.useCallback(e=>{let t=typeof e==`function`?e(_):e;n?n(t):g(t),document.cookie=`sidebar_state=${t}; path=/; max-age=604800`},[n,_]),b=d.default.useCallback(()=>l?m(e=>!e):v(e=>!e),[l,v,m]);d.default.useEffect(()=>{let e=e=>{e.key===`b`&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),b())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[b]);let x=_?`expanded`:`collapsed`,S=d.default.useMemo(()=>({state:x,isMobile:l,toggleSidebar:b,open:_,setOpen:v,openMobile:p,setOpenMobile:m}),[x,_,v,l,p,m,b]);return(0,u.jsx)(y.Provider,{value:S,children:(0,u.jsx)(r.TooltipProvider,{delayDuration:0,children:(0,u.jsx)(`div`,{"data-slot":`sidebar-wrapper`,style:{"--sidebar-width":`16rem`,"--sidebar-width-icon":`3rem`,...a},className:(0,s.cn)(`group/sidebar-wrapper`,`has-data-[variant=inset]:bg-sidebar`,`flex h-svh w-full`,i),...c,children:o})})})}function S({side:e=`left`,variant:t=`sidebar`,collapsible:n=`offcanvas`,className:r,children:i,...c}){let{isMobile:l,state:d,openMobile:f,setOpenMobile:p}=b();return n===`none`?(0,u.jsx)(`aside`,{"data-slot":`sidebar`,className:(0,s.cn)(`bg-sidebar`,`text-sidebar-foreground`,`flex h-full w-(--sidebar-width) flex-col`,r),...c,children:i}):l?(0,u.jsx)(a.Sheet,{open:f,onOpenChange:p,...c,children:(0,u.jsxs)(a.SheetContent,{"data-sidebar":`sidebar`,"data-slot":`sidebar`,"data-mobile":`true`,className:`bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden`,style:{"--sidebar-width":`16rem`},side:e,children:[(0,u.jsxs)(a.SheetHeader,{className:`sr-only`,children:[(0,u.jsx)(a.SheetTitle,{children:`Sidebar`}),(0,u.jsx)(a.SheetDescription,{children:`Displays the mobile sidebar.`})]}),(0,u.jsxs)(`div`,{className:`flex size-full flex-col`,children:[(0,u.jsxs)(`div`,{className:`border-border-weak flex items-center gap-x-2 border-b p-2 pr-4`,children:[(0,u.jsx)(C,{}),(0,u.jsx)(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground ml-2 flex aspect-square size-8 items-center justify-center rounded-lg`,children:(0,u.jsx)(o.ShoppingCartIcon,{size:20})}),(0,u.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,u.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,u.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),i]})]})}):(0,u.jsxs)(`aside`,{className:`group peer text-sidebar-foreground bg-card hidden md:block`,"data-state":d,"data-collapsible":d===`collapsed`?n:``,"data-variant":t,"data-side":e,"data-slot":`sidebar`,children:[(0,u.jsx)(`div`,{"data-slot":`sidebar-gap`,className:(0,s.cn)(`relative`,`bg-transparent`,`transition-[width] duration-200 ease-linear`,`h-(--header-height) w-(--sidebar-width)`,`sm:h-[calc(var(--header-height) + 0.5rem)]`,`group-data-[collapsible=offcanvas]:w-0`,`group-data-[side=right]:rotate-180`,t===`floating`||t===`inset`?`group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon)`)}),(0,u.jsx)(`div`,{"data-slot":`sidebar-container`,className:(0,s.cn)(`hidden md:flex`,`shadow-nav fixed inset-y-0 top-14 z-10`,`h-[calc(100svh-3.5rem)] w-(--sidebar-width)`,`transition-[left,right,width] duration-200 ease-linear`,e===`left`&&`left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]`,e===`right`&&`right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]`,t===`floating`||t===`inset`?`p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l`,r),...c,children:(0,u.jsx)(`div`,{"data-sidebar":`sidebar`,"data-slot":`sidebar-inner`,className:(0,s.cn)(`flex size-full flex-col`,`group-data-[variant=floating]:rounded-lg`,`group-data-[variant=floating]:border`,`group-data-[variant=floating]:border-sidebar-border`,`group-data-[variant=floating]:shadow-sm`),children:i})})]})}function C({className:e,onClick:n,...r}){let{toggleSidebar:i}=b();return(0,u.jsxs)(t.Button,{"data-sidebar":`trigger`,"data-slot":`sidebar-trigger`,variant:`ghost`,color:`muted`,size:`icon`,className:(0,s.cn)(`size-10 rounded-full`,e),onClick:e=>{n?.(e),i()},...r,children:[(0,u.jsx)(o.MenuIcon,{className:`!size-6`}),(0,u.jsx)(`span`,{className:`sr-only`,children:`Toggle Sidebar`})]})}function w({className:e,...t}){let{toggleSidebar:n}=b();return(0,u.jsx)(`button`,{"data-sidebar":`rail`,"data-slot":`sidebar-rail`,"aria-label":`Toggle Sidebar`,tabIndex:-1,onClick:n,title:`Toggle Sidebar`,className:(0,s.cn)(`absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex`,`after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]`,`group-data-[side=left]:-right-4`,`group-data-[side=right]:left-0`,`in-data-[side=left]:cursor-w-resize`,`in-data-[side=right]:cursor-e-resize`,`hover:after:bg-sidebar-border`,`hover:group-data-[collapsible=offcanvas]:bg-sidebar`,`group-data-[collapsible=offcanvas]:translate-x-0`,`group-data-[collapsible=offcanvas]:after:left-full`,`[[data-side=left][data-state=collapsed]_&]:cursor-e-resize`,`[[data-side=right][data-state=collapsed]_&]:cursor-w-resize`,`[[data-side=left][data-collapsible=offcanvas]_&]:-right-2`,`[[data-side=right][data-collapsible=offcanvas]_&]:-left-2`,e),...t})}function T({className:e,children:t,...n}){return(0,u.jsxs)(`main`,{"data-slot":`sidebar-inset`,className:(0,s.cn)(`relative flex w-full flex-1 flex-col`,e),...n,children:[(0,u.jsx)(`div`,{className:`h-(--header-height) w-full sm:h-[calc(var(--header-height)_+_0.5rem)]`}),(0,u.jsx)(`div`,{className:(0,s.cn)(`flex-1 inset-shadow-sm`),children:t})]})}function E({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-header`,"data-sidebar":`header`,className:(0,s.cn)(`flex flex-col gap-2 p-2`,e),...t})}function D({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-footer`,"data-sidebar":`footer`,className:(0,s.cn)(`flex flex-col gap-2 p-2`,e),...t})}function O({className:e,...t}){return(0,u.jsx)(i.Separator,{"data-slot":`sidebar-separator`,"data-sidebar":`separator`,className:(0,s.cn)(`bg-sidebar-border mx-2 w-auto`,e),...t})}function k({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-content`,"data-sidebar":`content`,className:(0,s.cn)(`flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden`,e),...t})}function A({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-group`,"data-sidebar":`group`,className:(0,s.cn)(`relative flex w-full min-w-0 flex-col p-2`,e),...t})}function j({className:e,asChild:t=!1,...n}){let r=t?l.Slot.Slot:`div`;return(0,u.jsx)(r,{"data-slot":`sidebar-group-label`,"data-sidebar":`group-label`,className:(0,s.cn)(`flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2`,`text-sidebar-foreground/70`,`ring-sidebar-ring`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`group-data-[collapsible=icon]:-mt-8`,`group-data-[collapsible=icon]:opacity-0`,e),...n})}function M({className:e,asChild:t=!1,...n}){let r=t?l.Slot.Slot:`button`;return(0,u.jsx)(r,{"data-slot":`sidebar-group-action`,"data-sidebar":`group-action`,className:(0,s.cn)(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`group-data-[collapsible=icon]:hidden`,e),...n})}function N({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-group-content`,"data-sidebar":`group-content`,className:(0,s.cn)(`w-full text-sm`,e),...t})}function P({className:e,...t}){return(0,u.jsx)(`ul`,{"data-slot":`sidebar-menu`,"data-sidebar":`menu`,className:(0,s.cn)(`flex w-full min-w-0 flex-col gap-1`,e),...t})}function F({className:e,...t}){return(0,u.jsx)(`li`,{"data-slot":`sidebar-menu-item`,"data-sidebar":`menu-item`,className:(0,s.cn)(`group/menu-item relative`,e),...t})}const I=(0,c.cva)([`peer/menu-button`,`cursor-pointer`,`flex w-full items-center gap-2`,`overflow-hidden rounded-md p-2 outline-hidden`,`text-left truncate`,`transition-[color,width,height,padding]`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`active:bg-sidebar-accent`,`active:text-sidebar-accent-foreground`,`disabled:pointer-events-none`,`disabled:opacity-50`,`group-has-data-[sidebar=menu-action]/menu-item:pr-8`,`aria-disabled:pointer-events-none`,`aria-disabled:opacity-50`,`data-[active=true]:bg-sidebar-primary-muted`,`data-[active=true]:font-medium`,`data-[active=true]:text-sidebar-primary`,`data-[state=open]:hover:bg-sidebar-accent`,`data-[state=open]:hover:text-sidebar-accent-foreground`,`group-data-[collapsible=icon]:size-8!`,`group-data-[collapsible=icon]:p-2!`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>span:last-child]:truncate`],{variants:{variant:{default:`hover:bg-sidebar-accent/60 hover:text-sidebar-accent-foreground/80`,outline:`bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]`},size:{default:`h-8 text-sm`,sm:`h-7 text-xs`,lg:`h-12 text-sm group-data-[collapsible=icon]:p-0!`}},defaultVariants:{variant:`default`,size:`default`}});function L({asChild:e=!1,isActive:t=!1,variant:n=`default`,size:i=`default`,tooltip:a,className:o,...c}){let d=e?l.Slot.Slot:`button`,{isMobile:f,state:p}=b(),m=(0,u.jsx)(d,{"data-slot":`sidebar-menu-button`,"data-sidebar":`menu-button`,"data-size":i,"data-active":t,className:(0,s.cn)(I({variant:n,size:i}),o),...c});return a?(typeof a==`string`&&(a={children:a}),(0,u.jsxs)(r.Tooltip,{children:[(0,u.jsx)(r.TooltipTrigger,{asChild:!0,children:m}),(0,u.jsx)(r.TooltipContent,{side:`right`,align:`center`,hidden:p!==`collapsed`||f,...a})]})):m}function R({className:e,asChild:t=!1,showOnHover:n=!1,...r}){let i=t?l.Slot.Slot:`button`;return(0,u.jsx)(i,{"data-slot":`sidebar-menu-action`,"data-sidebar":`menu-action`,className:(0,s.cn)(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,n&&`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,n&&`group-focus-within/menu-item:opacity-100`,n&&`group-hover/menu-item:opacity-100`,n&&`data-[state=open]:opacity-100 md:opacity-0`,e),...r})}function z({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-menu-badge`,"data-sidebar":`menu-badge`,className:(0,s.cn)(`text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none`,`peer-hover/menu-button:text-sidebar-accent-foreground`,`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,e),...t})}function B({className:e,showIcon:t=!1,...r}){let i=d.default.useMemo(()=>`${Math.floor(Math.random()*40)+50}%`,[]);return(0,u.jsxs)(`div`,{"data-slot":`sidebar-menu-skeleton`,"data-sidebar":`menu-skeleton`,className:(0,s.cn)(`flex h-8 items-center gap-2 rounded-md px-2`,e),...r,children:[t&&(0,u.jsx)(n.Skeleton,{className:`size-4 rounded-md`,"data-sidebar":`menu-skeleton-icon`}),(0,u.jsx)(n.Skeleton,{className:`h-4 max-w-(--skeleton-width) flex-1`,"data-sidebar":`menu-skeleton-text`,style:{"--skeleton-width":i}})]})}function V({className:e,...t}){return(0,u.jsx)(`ul`,{"data-slot":`sidebar-menu-sub`,"data-sidebar":`menu-sub`,className:(0,s.cn)(`border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5`,`group-data-[collapsible=icon]:hidden`,e),...t})}function H({className:e,...t}){return(0,u.jsx)(`li`,{"data-slot":`sidebar-menu-sub-item`,"data-sidebar":`menu-sub-item`,className:(0,s.cn)(`group/menu-sub-item relative`,e),...t})}function U({asChild:e=!1,size:t=`md`,isActive:n=!1,className:r,...i}){let a=e?l.Slot.Slot:`a`;return(0,u.jsx)(a,{"data-slot":`sidebar-menu-sub-button`,"data-sidebar":`menu-sub-button`,"data-size":t,"data-active":n,className:(0,s.cn)(`text-sidebar-foreground`,`ring-sidebar-ring`,`flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden`,`focus-visible:ring-2`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`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`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>svg]:text-sidebar-accent-foreground`,`[&>span:last-child]:truncate`,`data-[active=true]:bg-sidebar-accent`,`data-[active=true]:text-sidebar-accent-foreground`,t===`sm`&&`text-xs`,t===`md`&&`text-sm`,`group-data-[collapsible=icon]:hidden`,r),...i})}const W=({children:e})=>(0,u.jsx)(x,{children:e}),G=({children:e})=>(0,u.jsxs)(`header`,{className:(0,s.cn)(`bg-card`,`h-(--header-height)`,`sm:h-[calc(var(--header-height)_+_0.5rem)]`,`sm:px-4 sm:pr-6`,`absolute inset-x-0 top-0 z-20 gap-2 px-2 pr-4.5`,`shadow-nav flex items-center`,`transition-[width,height] ease-linear`,`group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)`,`sm:group-has-data-[collapsible=icon]/sidebar-wrapper:h-[calc(var(--header-height)_+_0.5rem)]`),children:[(0,u.jsx)(C,{}),(0,u.jsxs)(`div`,{className:`flex gap-x-2 sm:ml-2.5`,children:[(0,u.jsx)(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg`,children:(0,u.jsx)(o.ShoppingCartIcon,{size:20})}),(0,u.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,u.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,u.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),(0,u.jsx)(`div`,{className:`flex flex-1 items-center justify-end`,children:e})]}),K=({children:e,...t})=>(0,u.jsx)(S,{variant:`inset`,collapsible:`icon`,...t,children:e}),q=({children:e})=>(0,u.jsx)(T,{children:(0,u.jsx)(`section`,{className:`relative size-full`,children:(0,u.jsx)(`div`,{className:`absolute inset-0 flex flex-col`,children:e})})}),J=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-header`,className:(0,s.cn)(`flex-0 snap-start`,e),children:t}),Y=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-content`,className:(0,s.cn)(`flex w-full flex-1 snap-y flex-col gap-4 overflow-y-auto px-2 sm:px-4`,e),children:t}),X=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-footer`,className:(0,s.cn)(`border-border-weak hidden w-full flex-0 border-t pt-2 sm:flex`,e),children:t}),Z=({children:e,className:t})=>(0,u.jsx)(`div`,{"data-slot":`main-group`,className:(0,s.cn)(`flex size-full flex-col gap-4`,t),children:e}),Q=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-group-content`,className:(0,s.cn)(`bg-card shadow-card size-full max-w-5xl flex-1 snap-start snap-always scroll-mt-4 rounded-md p-4`,e),children:t});exports.AppLayoutHeader=G,exports.AppLayoutMain=q,exports.AppLayoutMainContent=Y,exports.AppLayoutMainFooter=X,exports.AppLayoutMainGroup=Z,exports.AppLayoutMainGroupContent=Q,exports.AppLayoutMainHeader=J,exports.AppLayoutSidebar=K,exports.AppLayoutSidebarContent=k,exports.AppLayoutSidebarFooter=D,exports.AppLayoutSidebarGroup=A,exports.AppLayoutSidebarGroupAction=M,exports.AppLayoutSidebarGroupContent=N,exports.AppLayoutSidebarGroupLabel=j,exports.AppLayoutSidebarHeader=E,exports.AppLayoutSidebarInset=T,exports.AppLayoutSidebarMenu=P,exports.AppLayoutSidebarMenuAction=R,exports.AppLayoutSidebarMenuBadge=z,exports.AppLayoutSidebarMenuButton=L,exports.AppLayoutSidebarMenuItem=F,exports.AppLayoutSidebarMenuSkeleton=B,exports.AppLayoutSidebarMenuSub=V,exports.AppLayoutSidebarMenuSubButton=U,exports.AppLayoutSidebarMenuSubItem=H,exports.AppLayoutSidebarRail=w,exports.AppLayoutSidebarSeparator=O,exports.AppLayoutSidebarTrigger=C,exports.AppLayoutWrapper=W,exports.Sidebar=S,exports.SidebarProvider=x,exports.useSidebar=b;
1
+ "use client";const e=require(`../../chunk-CUT6urMc.cjs`),t=require(`../../button-119IIVCy.cjs`),n=require(`../../skeleton-CmGSyYRm.cjs`),r=require(`../../tooltip-CQ8hkJ42.cjs`),i=require(`../../separator-JGL-8B0V.cjs`),a=require(`../../sheet-slcLNlWv.cjs`),o=e.__toESM(require(`lucide-react`)),s=e.__toESM(require(`@customafk/react-toolkit/utils`)),c=e.__toESM(require(`class-variance-authority`)),l=e.__toESM(require(`radix-ui`)),u=e.__toESM(require(`react/jsx-runtime`)),d=e.__toESM(require(`react`)),f=e.__toESM(require(`@customafk/react-toolkit/hooks/useMobile`)),p=`sidebar_state`,m=3600*24*7,h=`16rem`,g=`16rem`,_=`3rem`,v=`b`,y=(0,d.createContext)(null);function b(){let e=(0,d.useContext)(y);if(!e)throw Error(`useSidebar must be used within a SidebarProvider.`);return e}function x({defaultOpen:e=!0,open:t,onOpenChange:n,className:i,style:a,children:o,...c}){let l=(0,f.useIsMobile)(),[p,m]=(0,d.useState)(!1),[h,g]=(0,d.useState)(e),_=t??h,v=(0,d.useCallback)(e=>{let t=typeof e==`function`?e(_):e;n?n(t):g(t),document.cookie=`sidebar_state=${t}; path=/; max-age=604800`},[n,_]),b=(0,d.useCallback)(()=>l?m(e=>!e):v(e=>!e),[l,v,m]);(0,d.useEffect)(()=>{let e=e=>{e.key===`b`&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),b())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[b]);let x=_?`expanded`:`collapsed`,S=(0,d.useMemo)(()=>({state:x,isMobile:l,toggleSidebar:b,open:_,setOpen:v,openMobile:p,setOpenMobile:m}),[x,_,v,l,p,m,b]);return(0,u.jsx)(y.Provider,{value:S,children:(0,u.jsx)(r.TooltipProvider,{delayDuration:0,children:(0,u.jsx)(`div`,{"data-slot":`sidebar-wrapper`,style:{"--sidebar-width":`16rem`,"--sidebar-width-icon":`3rem`,...a},className:(0,s.cn)(`group/sidebar-wrapper`,`has-data-[variant=inset]:bg-sidebar`,`flex h-svh w-full`,i),...c,children:o})})})}function S({side:e=`left`,variant:t=`sidebar`,collapsible:n=`offcanvas`,className:r,children:i,...c}){let{isMobile:l,state:d,openMobile:f,setOpenMobile:p}=b();return n===`none`?(0,u.jsx)(`aside`,{"data-slot":`sidebar`,className:(0,s.cn)(`bg-sidebar`,`text-sidebar-foreground`,`flex h-full w-(--sidebar-width) flex-col`,r),...c,children:i}):l?(0,u.jsx)(a.Sheet,{open:f,onOpenChange:p,...c,children:(0,u.jsxs)(a.SheetContent,{"data-sidebar":`sidebar`,"data-slot":`sidebar`,"data-mobile":`true`,className:`bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden`,style:{"--sidebar-width":`16rem`},side:e,children:[(0,u.jsxs)(a.SheetHeader,{className:`sr-only`,children:[(0,u.jsx)(a.SheetTitle,{children:`Sidebar`}),(0,u.jsx)(a.SheetDescription,{children:`Displays the mobile sidebar.`})]}),(0,u.jsxs)(`div`,{className:`flex size-full flex-col`,children:[(0,u.jsxs)(`div`,{className:`border-border-weak flex items-center gap-x-2 border-b p-2 pr-4`,children:[(0,u.jsx)(C,{}),(0,u.jsx)(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground ml-2 flex aspect-square size-8 items-center justify-center rounded-lg`,children:(0,u.jsx)(o.ShoppingCartIcon,{size:20})}),(0,u.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,u.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,u.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),i]})]})}):(0,u.jsxs)(`aside`,{className:`group peer text-sidebar-foreground bg-card hidden md:block`,"data-state":d,"data-collapsible":d===`collapsed`?n:``,"data-variant":t,"data-side":e,"data-slot":`sidebar`,children:[(0,u.jsx)(`div`,{"data-slot":`sidebar-gap`,className:(0,s.cn)(`relative`,`bg-transparent`,`transition-[width] duration-200 ease-linear`,`h-(--header-height) w-(--sidebar-width)`,`sm:h-[calc(var(--header-height) + 0.5rem)]`,`group-data-[collapsible=offcanvas]:w-0`,`group-data-[side=right]:rotate-180`,t===`floating`||t===`inset`?`group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon)`)}),(0,u.jsx)(`div`,{"data-slot":`sidebar-container`,className:(0,s.cn)(`hidden md:flex`,`shadow-nav fixed inset-y-0 top-14 z-10`,`h-[calc(100svh-3.5rem)] w-(--sidebar-width)`,`transition-[left,right,width] duration-200 ease-linear`,e===`left`&&`left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]`,e===`right`&&`right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]`,t===`floating`||t===`inset`?`p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l`,r),...c,children:(0,u.jsx)(`div`,{"data-sidebar":`sidebar`,"data-slot":`sidebar-inner`,className:(0,s.cn)(`flex size-full flex-col`,`group-data-[variant=floating]:rounded-lg`,`group-data-[variant=floating]:border`,`group-data-[variant=floating]:border-sidebar-border`,`group-data-[variant=floating]:shadow-sm`),children:i})})]})}function C({className:e,onClick:n,...r}){let{toggleSidebar:i}=b();return(0,u.jsxs)(t.Button,{"data-sidebar":`trigger`,"data-slot":`sidebar-trigger`,variant:`ghost`,color:`muted`,size:`icon`,className:(0,s.cn)(`size-10 rounded-full`,e),onClick:e=>{n?.(e),i()},...r,children:[(0,u.jsx)(o.MenuIcon,{className:`!size-6`}),(0,u.jsx)(`span`,{className:`sr-only`,children:`Toggle Sidebar`})]})}function w({className:e,...t}){let{toggleSidebar:n}=b();return(0,u.jsx)(`button`,{"data-sidebar":`rail`,"data-slot":`sidebar-rail`,"aria-label":`Toggle Sidebar`,tabIndex:-1,onClick:n,title:`Toggle Sidebar`,className:(0,s.cn)(`absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex`,`after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]`,`group-data-[side=left]:-right-4`,`group-data-[side=right]:left-0`,`in-data-[side=left]:cursor-w-resize`,`in-data-[side=right]:cursor-e-resize`,`hover:after:bg-sidebar-border`,`hover:group-data-[collapsible=offcanvas]:bg-sidebar`,`group-data-[collapsible=offcanvas]:translate-x-0`,`group-data-[collapsible=offcanvas]:after:left-full`,`[[data-side=left][data-state=collapsed]_&]:cursor-e-resize`,`[[data-side=right][data-state=collapsed]_&]:cursor-w-resize`,`[[data-side=left][data-collapsible=offcanvas]_&]:-right-2`,`[[data-side=right][data-collapsible=offcanvas]_&]:-left-2`,e),...t})}function T({className:e,children:t,...n}){return(0,u.jsxs)(`main`,{"data-slot":`sidebar-inset`,className:(0,s.cn)(`relative flex w-full flex-1 flex-col`,e),...n,children:[(0,u.jsx)(`div`,{className:`h-(--header-height) w-full sm:h-[calc(var(--header-height)_+_0.5rem)]`}),(0,u.jsx)(`div`,{className:(0,s.cn)(`flex-1 inset-shadow-sm`),children:t})]})}function E({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-header`,"data-sidebar":`header`,className:(0,s.cn)(`flex flex-col gap-2 p-2`,e),...t})}function D({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-footer`,"data-sidebar":`footer`,className:(0,s.cn)(`flex flex-col gap-2 p-2`,e),...t})}function O({className:e,...t}){return(0,u.jsx)(i.Separator,{"data-slot":`sidebar-separator`,"data-sidebar":`separator`,className:(0,s.cn)(`bg-sidebar-border mx-2 w-auto`,e),...t})}function k({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-content`,"data-sidebar":`content`,className:(0,s.cn)(`flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden`,e),...t})}function A({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-group`,"data-sidebar":`group`,className:(0,s.cn)(`relative flex w-full min-w-0 flex-col p-2`,e),...t})}function j({className:e,asChild:t=!1,...n}){let r=t?l.Slot.Slot:`div`;return(0,u.jsx)(r,{"data-slot":`sidebar-group-label`,"data-sidebar":`group-label`,className:(0,s.cn)(`flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2`,`text-sidebar-foreground/70`,`ring-sidebar-ring`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`group-data-[collapsible=icon]:-mt-8`,`group-data-[collapsible=icon]:opacity-0`,e),...n})}function M({className:e,asChild:t=!1,...n}){let r=t?l.Slot.Slot:`button`;return(0,u.jsx)(r,{"data-slot":`sidebar-group-action`,"data-sidebar":`group-action`,className:(0,s.cn)(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`group-data-[collapsible=icon]:hidden`,e),...n})}function N({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-group-content`,"data-sidebar":`group-content`,className:(0,s.cn)(`w-full text-sm`,e),...t})}function P({className:e,...t}){return(0,u.jsx)(`ul`,{"data-slot":`sidebar-menu`,"data-sidebar":`menu`,className:(0,s.cn)(`flex w-full min-w-0 flex-col gap-1`,e),...t})}function F({className:e,...t}){return(0,u.jsx)(`li`,{"data-slot":`sidebar-menu-item`,"data-sidebar":`menu-item`,className:(0,s.cn)(`group/menu-item relative`,e),...t})}const I=(0,c.cva)([`peer/menu-button`,`cursor-pointer`,`flex w-full items-center gap-2`,`overflow-hidden rounded-md p-2 outline-hidden`,`text-left truncate`,`transition-[color,width,height,padding]`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`active:bg-sidebar-accent`,`active:text-sidebar-accent-foreground`,`disabled:pointer-events-none`,`disabled:opacity-50`,`group-has-data-[sidebar=menu-action]/menu-item:pr-8`,`aria-disabled:pointer-events-none`,`aria-disabled:opacity-50`,`data-[active=true]:bg-sidebar-primary-muted`,`data-[active=true]:font-medium`,`data-[active=true]:text-sidebar-primary`,`data-[state=open]:hover:bg-sidebar-accent`,`data-[state=open]:hover:text-sidebar-accent-foreground`,`group-data-[collapsible=icon]:size-8!`,`group-data-[collapsible=icon]:p-2!`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>span:last-child]:truncate`],{variants:{variant:{default:`hover:bg-sidebar-accent/60 hover:text-sidebar-accent-foreground/80`,outline:`bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]`},size:{default:`h-8 text-sm`,sm:`h-7 text-xs`,lg:`h-12 text-sm group-data-[collapsible=icon]:p-0!`}},defaultVariants:{variant:`default`,size:`default`}});function L({asChild:e=!1,isActive:t=!1,variant:n=`default`,size:i=`default`,tooltip:a,className:o,...c}){let d=e?l.Slot.Slot:`button`,{isMobile:f,state:p}=b(),m=(0,u.jsx)(d,{"data-slot":`sidebar-menu-button`,"data-sidebar":`menu-button`,"data-size":i,"data-active":t,className:(0,s.cn)(I({variant:n,size:i}),o),...c});return a?(typeof a==`string`&&(a={children:a}),(0,u.jsxs)(r.Tooltip,{children:[(0,u.jsx)(r.TooltipTrigger,{asChild:!0,children:m}),(0,u.jsx)(r.TooltipContent,{side:`right`,align:`center`,hidden:p!==`collapsed`||f,...a})]})):m}function R({className:e,asChild:t=!1,showOnHover:n=!1,...r}){let i=t?l.Slot.Slot:`button`;return(0,u.jsx)(i,{"data-slot":`sidebar-menu-action`,"data-sidebar":`menu-action`,className:(0,s.cn)(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,n&&`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,n&&`group-focus-within/menu-item:opacity-100`,n&&`group-hover/menu-item:opacity-100`,n&&`data-[state=open]:opacity-100 md:opacity-0`,e),...r})}function z({className:e,...t}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-menu-badge`,"data-sidebar":`menu-badge`,className:(0,s.cn)(`text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none`,`peer-hover/menu-button:text-sidebar-accent-foreground`,`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,e),...t})}function B({className:e,showIcon:t=!1,...r}){let i=(0,d.useMemo)(()=>`${Math.floor(Math.random()*40)+50}%`,[]);return(0,u.jsxs)(`div`,{"data-slot":`sidebar-menu-skeleton`,"data-sidebar":`menu-skeleton`,className:(0,s.cn)(`flex h-8 items-center gap-2 rounded-md px-2`,e),...r,children:[t&&(0,u.jsx)(n.Skeleton,{className:`size-4 rounded-md`,"data-sidebar":`menu-skeleton-icon`}),(0,u.jsx)(n.Skeleton,{className:`h-4 max-w-(--skeleton-width) flex-1`,"data-sidebar":`menu-skeleton-text`,style:{"--skeleton-width":i}})]})}function V({className:e,...t}){return(0,u.jsx)(`ul`,{"data-slot":`sidebar-menu-sub`,"data-sidebar":`menu-sub`,className:(0,s.cn)(`border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5`,`group-data-[collapsible=icon]:hidden`,e),...t})}function H({className:e,...t}){return(0,u.jsx)(`li`,{"data-slot":`sidebar-menu-sub-item`,"data-sidebar":`menu-sub-item`,className:(0,s.cn)(`group/menu-sub-item relative`,e),...t})}function U({asChild:e=!1,size:t=`md`,isActive:n=!1,className:r,...i}){let a=e?l.Slot.Slot:`a`;return(0,u.jsx)(a,{"data-slot":`sidebar-menu-sub-button`,"data-sidebar":`menu-sub-button`,"data-size":t,"data-active":n,className:(0,s.cn)(`text-sidebar-foreground`,`ring-sidebar-ring`,`flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden`,`focus-visible:ring-2`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`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`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>svg]:text-sidebar-accent-foreground`,`[&>span:last-child]:truncate`,`data-[active=true]:bg-sidebar-accent`,`data-[active=true]:text-sidebar-accent-foreground`,t===`sm`&&`text-xs`,t===`md`&&`text-sm`,`group-data-[collapsible=icon]:hidden`,r),...i})}const W=({children:e})=>(0,u.jsx)(x,{children:e}),G=({children:e})=>(0,u.jsxs)(`header`,{className:(0,s.cn)(`bg-card`,`h-(--header-height)`,`sm:h-[calc(var(--header-height)_+_0.5rem)]`,`sm:px-4 sm:pr-6`,`absolute inset-x-0 top-0 z-20 gap-2 px-2 pr-4.5`,`shadow-nav flex items-center`,`transition-[width,height] ease-linear`,`group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)`,`sm:group-has-data-[collapsible=icon]/sidebar-wrapper:h-[calc(var(--header-height)_+_0.5rem)]`),children:[(0,u.jsx)(C,{}),(0,u.jsxs)(`div`,{className:`flex gap-x-2 sm:ml-2.5`,children:[(0,u.jsx)(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg`,children:(0,u.jsx)(o.ShoppingCartIcon,{size:20})}),(0,u.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,u.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,u.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),(0,u.jsx)(`div`,{className:`flex flex-1 items-center justify-end`,children:e})]}),K=({children:e,...t})=>(0,u.jsx)(S,{variant:`inset`,collapsible:`icon`,...t,children:e}),q=({children:e})=>(0,u.jsx)(T,{children:(0,u.jsx)(`section`,{className:`relative size-full`,children:(0,u.jsx)(`div`,{className:`absolute inset-0 flex flex-col`,children:e})})}),J=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-header`,className:(0,s.cn)(`flex-0 snap-start`,e),children:t}),Y=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-content`,className:(0,s.cn)(`flex w-full flex-1 snap-y flex-col gap-4 overflow-y-auto px-2 sm:px-4`,e),children:t}),X=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-footer`,className:(0,s.cn)(`border-border-weak hidden w-full flex-0 border-t pt-2 sm:flex`,e),children:t}),Z=({children:e,className:t})=>(0,u.jsx)(`div`,{"data-slot":`main-group`,className:(0,s.cn)(`flex size-full flex-col gap-4`,t),children:e}),Q=({className:e,children:t})=>(0,u.jsx)(`div`,{"data-slot":`main-group-content`,className:(0,s.cn)(`bg-card shadow-card size-full max-w-5xl flex-1 snap-start snap-always scroll-mt-4 rounded-md p-4`,e),children:t});exports.AppLayoutHeader=G,exports.AppLayoutMain=q,exports.AppLayoutMainContent=Y,exports.AppLayoutMainFooter=X,exports.AppLayoutMainGroup=Z,exports.AppLayoutMainGroupContent=Q,exports.AppLayoutMainHeader=J,exports.AppLayoutSidebar=K,exports.AppLayoutSidebarContent=k,exports.AppLayoutSidebarFooter=D,exports.AppLayoutSidebarGroup=A,exports.AppLayoutSidebarGroupAction=M,exports.AppLayoutSidebarGroupContent=N,exports.AppLayoutSidebarGroupLabel=j,exports.AppLayoutSidebarHeader=E,exports.AppLayoutSidebarInset=T,exports.AppLayoutSidebarMenu=P,exports.AppLayoutSidebarMenuAction=R,exports.AppLayoutSidebarMenuBadge=z,exports.AppLayoutSidebarMenuButton=L,exports.AppLayoutSidebarMenuItem=F,exports.AppLayoutSidebarMenuSkeleton=B,exports.AppLayoutSidebarMenuSub=V,exports.AppLayoutSidebarMenuSubButton=U,exports.AppLayoutSidebarMenuSubItem=H,exports.AppLayoutSidebarRail=w,exports.AppLayoutSidebarSeparator=O,exports.AppLayoutSidebarTrigger=C,exports.AppLayoutWrapper=W,exports.Sidebar=S,exports.SidebarProvider=x,exports.useSidebar=b;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":["React","open","TooltipProvider","Sheet","SheetContent","SheetHeader","SheetTitle","SheetDescription","ShoppingCartIcon","Button","MenuIcon","Separator","SlotPrimitive","Tooltip","TooltipTrigger","TooltipContent","Skeleton","AppLayoutWrapper: React.FC<React.PropsWithChildren>","AppLayoutHeader: React.FC<React.PropsWithChildren>","ShoppingCartIcon","AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>>","AppLayoutMain: React.FC<React.PropsWithChildren>","AppLayoutMainHeader: React.FC<React.PropsWithChildren & { className?: string }>","AppLayoutMainContent: React.FC<React.PropsWithChildren & { className?: string }>","AppLayoutMainFooter: React.FC<React.PropsWithChildren & { className?: string }>","AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>>","AppLayoutMainGroupContent: React.FC<React.PropsWithChildren & { className?: string }>"],"sources":["../../../packages/components/layouts/app-layout/sidebar.tsx","../../../packages/components/layouts/app-layout/index.tsx"],"sourcesContent":["import React from 'react'\nimport { useIsMobile } from '@customafk/react-toolkit/hooks/useMobile'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nimport { MenuIcon, ShoppingCartIcon } from 'lucide-react'\n\nimport { Button } from '@/components/ui/button'\nimport { Separator } from '@/components/ui/separator'\nimport { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle } from '@/components/ui/sheet'\nimport { Skeleton } from '@/components/ui/skeleton'\nimport { TooltipProvider } from '@/components/ui/tooltip'\nimport { Tooltip, TooltipContent, TooltipTrigger } from '@/components/ui/tooltip'\n\nimport { cva, type VariantProps } from 'class-variance-authority'\nimport { Slot as SlotPrimitive } from 'radix-ui'\n\nconst SIDEBAR_COOKIE_NAME = 'sidebar_state'\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7\nconst SIDEBAR_WIDTH = '16rem'\nconst SIDEBAR_WIDTH_MOBILE = '16rem'\nconst SIDEBAR_WIDTH_ICON = '3rem'\nconst SIDEBAR_KEYBOARD_SHORTCUT = 'b'\n\ntype SidebarContextProps = {\n state: 'expanded' | 'collapsed'\n open: boolean\n setOpen: (open: boolean) => void\n openMobile: boolean\n setOpenMobile: (open: boolean) => void\n isMobile: boolean\n toggleSidebar: () => void\n}\n\nconst SidebarContext = React.createContext<SidebarContextProps | null>(null)\n\nfunction useSidebar() {\n const context = React.useContext(SidebarContext)\n if (!context) {\n throw new Error('useSidebar must be used within a SidebarProvider.')\n }\n\n return context\n}\n\nfunction SidebarProvider({\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n defaultOpen?: boolean\n open?: boolean\n onOpenChange?: (open: boolean) => void\n}) {\n const isMobile = useIsMobile()\n const [openMobile, setOpenMobile] = React.useState(false)\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = React.useState(defaultOpen)\n const open = openProp ?? _open\n const setOpen = React.useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === 'function' ? value(open) : value\n if (setOpenProp) {\n setOpenProp(openState)\n } else {\n _setOpen(openState)\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open],\n )\n\n // Helper to toggle the sidebar.\n const toggleSidebar = React.useCallback(() => {\n return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\n // Adds a keyboard shortcut to toggle the sidebar.\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === SIDEBAR_KEYBOARD_SHORTCUT && (event.metaKey || event.ctrlKey)) {\n event.preventDefault()\n toggleSidebar()\n }\n }\n\n window.addEventListener('keydown', handleKeyDown)\n return () => window.removeEventListener('keydown', handleKeyDown)\n }, [toggleSidebar])\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? 'expanded' : 'collapsed'\n\n const contextValue = React.useMemo<SidebarContextProps>(\n () => ({\n state,\n isMobile,\n\n toggleSidebar,\n\n open,\n setOpen,\n\n openMobile,\n setOpenMobile,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar],\n )\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n data-slot=\"sidebar-wrapper\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH,\n '--sidebar-width-icon': SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn('group/sidebar-wrapper', 'has-data-[variant=inset]:bg-sidebar', 'flex h-svh w-full', className)}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n )\n}\n\nfunction Sidebar({\n side = 'left',\n variant = 'sidebar',\n collapsible = 'offcanvas',\n className,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n side?: 'left' | 'right'\n variant?: 'sidebar' | 'floating' | 'inset'\n collapsible?: 'offcanvas' | 'icon' | 'none'\n}) {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === 'none') {\n return (\n <aside data-slot=\"sidebar\" className={cn('bg-sidebar', 'text-sidebar-foreground', 'flex h-full w-(--sidebar-width) flex-col', className)} {...props}>\n {children}\n </aside>\n )\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar\"\n data-mobile=\"true\"\n className=\"bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex size-full flex-col\">\n <div className=\"border-border-weak flex items-center gap-x-2 border-b p-2 pr-4\">\n <AppLayoutSidebarTrigger />\n <div className=\"bg-sidebar-primary text-sidebar-primary-foreground ml-2 flex aspect-square size-8 items-center justify-center rounded-lg\">\n <ShoppingCartIcon size={20} />\n </div>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-medium\">Lunas Store</span>\n <span className=\"truncate text-xs\">Established 2023</span>\n </div>\n </div>\n {children}\n </div>\n </SheetContent>\n </Sheet>\n )\n }\n\n return (\n <aside\n className=\"group peer text-sidebar-foreground bg-card hidden md:block\"\n data-state={state}\n data-collapsible={state === 'collapsed' ? collapsible : ''}\n data-variant={variant}\n data-side={side}\n data-slot=\"sidebar\"\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n data-slot=\"sidebar-gap\"\n className={cn(\n 'relative',\n 'bg-transparent',\n 'transition-[width] duration-200 ease-linear',\n 'h-(--header-height) w-(--sidebar-width)',\n 'sm:h-[calc(var(--header-height) + 0.5rem)]',\n 'group-data-[collapsible=offcanvas]:w-0',\n 'group-data-[side=right]:rotate-180',\n variant === 'floating' || variant === 'inset'\n ? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',\n )}\n />\n <div\n data-slot=\"sidebar-container\"\n className={cn(\n 'hidden md:flex',\n 'shadow-nav fixed inset-y-0 top-14 z-10',\n 'h-[calc(100svh-3.5rem)] w-(--sidebar-width)',\n 'transition-[left,right,width] duration-200 ease-linear',\n side === 'left' && 'left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]',\n side === 'right' && 'right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]',\n // Adjust the padding for floating and inset variants.\n variant === 'floating' || variant === 'inset'\n ? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l',\n className,\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar-inner\"\n className={cn(\n 'flex size-full flex-col',\n 'group-data-[variant=floating]:rounded-lg',\n 'group-data-[variant=floating]:border',\n 'group-data-[variant=floating]:border-sidebar-border',\n 'group-data-[variant=floating]:shadow-sm',\n )}\n >\n {children}\n </div>\n </div>\n </aside>\n )\n}\n\nfunction AppLayoutSidebarTrigger({ className, onClick, ...props }: React.ComponentProps<typeof Button>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <Button\n data-sidebar=\"trigger\"\n data-slot=\"sidebar-trigger\"\n variant=\"ghost\"\n color=\"muted\"\n size=\"icon\"\n className={cn('size-10 rounded-full', className)}\n onClick={(event) => {\n onClick?.(event)\n toggleSidebar()\n }}\n {...props}\n >\n <MenuIcon className=\"!size-6\" />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n )\n}\n\nfunction AppLayoutSidebarRail({ className, ...props }: React.ComponentProps<'button'>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <button\n data-sidebar=\"rail\"\n data-slot=\"sidebar-rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onClick={toggleSidebar}\n title=\"Toggle Sidebar\"\n className={cn(\n 'absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex',\n 'after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]',\n 'group-data-[side=left]:-right-4',\n 'group-data-[side=right]:left-0',\n 'in-data-[side=left]:cursor-w-resize',\n 'in-data-[side=right]:cursor-e-resize',\n 'hover:after:bg-sidebar-border',\n 'hover:group-data-[collapsible=offcanvas]:bg-sidebar',\n 'group-data-[collapsible=offcanvas]:translate-x-0',\n 'group-data-[collapsible=offcanvas]:after:left-full',\n '[[data-side=left][data-state=collapsed]_&]:cursor-e-resize',\n '[[data-side=right][data-state=collapsed]_&]:cursor-w-resize',\n '[[data-side=left][data-collapsible=offcanvas]_&]:-right-2',\n '[[data-side=right][data-collapsible=offcanvas]_&]:-left-2',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarInset({ className, children, ...props }: React.ComponentProps<'main'>) {\n return (\n <main data-slot=\"sidebar-inset\" className={cn('relative flex w-full flex-1 flex-col', className)} {...props}>\n <div className=\"h-(--header-height) w-full sm:h-[calc(var(--header-height)_+_0.5rem)]\" />\n <div className={cn('flex-1 inset-shadow-sm')}>{children}</div>\n </main>\n )\n}\n\nfunction AppLayoutSidebarHeader({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-header\" data-sidebar=\"header\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarFooter({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-footer\" data-sidebar=\"footer\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarSeparator({ className, ...props }: React.ComponentProps<typeof Separator>) {\n return <Separator data-slot=\"sidebar-separator\" data-sidebar=\"separator\" className={cn('bg-sidebar-border mx-2 w-auto', className)} {...props} />\n}\n\nfunction AppLayoutSidebarContent({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-content\"\n data-sidebar=\"content\"\n className={cn('flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden', className)}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroup({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group\" data-sidebar=\"group\" className={cn('relative flex w-full min-w-0 flex-col p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarGroupLabel({ className, asChild = false, ...props }: React.ComponentProps<'div'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'div'\n\n return (\n <Comp\n data-slot=\"sidebar-group-label\"\n data-sidebar=\"group-label\"\n className={cn(\n 'flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2',\n 'text-sidebar-foreground/70',\n 'ring-sidebar-ring',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n 'group-data-[collapsible=icon]:-mt-8',\n 'group-data-[collapsible=icon]:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroupAction({ className, asChild = false, ...props }: React.ComponentProps<'button'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-group-action\"\n data-sidebar=\"group-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroupContent({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group-content\" data-sidebar=\"group-content\" className={cn('w-full text-sm', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenu({ className, ...props }: React.ComponentProps<'ul'>) {\n return <ul data-slot=\"sidebar-menu\" data-sidebar=\"menu\" className={cn('flex w-full min-w-0 flex-col gap-1', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenuItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-item\" data-sidebar=\"menu-item\" className={cn('group/menu-item relative', className)} {...props} />\n}\n\nconst sidebarMenuButtonVariants = cva(\n [\n 'peer/menu-button',\n 'cursor-pointer',\n 'flex w-full items-center gap-2',\n 'overflow-hidden rounded-md p-2 outline-hidden',\n 'text-left truncate',\n 'transition-[color,width,height,padding]',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'group-has-data-[sidebar=menu-action]/menu-item:pr-8',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n 'data-[active=true]:bg-sidebar-primary-muted',\n 'data-[active=true]:font-medium',\n 'data-[active=true]:text-sidebar-primary',\n 'data-[state=open]:hover:bg-sidebar-accent',\n 'data-[state=open]:hover:text-sidebar-accent-foreground',\n 'group-data-[collapsible=icon]:size-8!',\n 'group-data-[collapsible=icon]:p-2!',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n '[&>span:last-child]:truncate',\n ],\n {\n variants: {\n variant: {\n default: 'hover:bg-sidebar-accent/60 hover:text-sidebar-accent-foreground/80',\n outline:\n 'bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]',\n },\n size: {\n default: 'h-8 text-sm',\n sm: 'h-7 text-xs',\n lg: 'h-12 text-sm group-data-[collapsible=icon]:p-0!',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n },\n)\n\nfunction AppLayoutSidebarMenuButton({\n asChild = false,\n isActive = false,\n variant = 'default',\n size = 'default',\n tooltip,\n className,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n isActive?: boolean\n tooltip?: string | React.ComponentProps<typeof TooltipContent>\n} & VariantProps<typeof sidebarMenuButtonVariants>) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n const { isMobile, state } = useSidebar()\n\n const button = (\n <Comp\n data-slot=\"sidebar-menu-button\"\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n )\n\n if (!tooltip) {\n return button\n }\n\n if (typeof tooltip === 'string') {\n tooltip = {\n children: tooltip,\n }\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent side=\"right\" align=\"center\" hidden={state !== 'collapsed' || isMobile} {...tooltip} />\n </Tooltip>\n )\n}\n\nfunction AppLayoutSidebarMenuAction({\n className,\n asChild = false,\n showOnHover = false,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n showOnHover?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-action\"\n data-sidebar=\"menu-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n showOnHover && 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n showOnHover && 'group-focus-within/menu-item:opacity-100',\n showOnHover && 'group-hover/menu-item:opacity-100',\n showOnHover && 'data-[state=open]:opacity-100 md:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuBadge({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-menu-badge\"\n data-sidebar=\"menu-badge\"\n className={cn(\n 'text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none',\n 'peer-hover/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuSkeleton({\n className,\n showIcon = false,\n ...props\n}: React.ComponentProps<'div'> & {\n showIcon?: boolean\n}) {\n // Random width between 50 to 90%.\n const width = React.useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`\n }, [])\n\n return (\n <div data-slot=\"sidebar-menu-skeleton\" data-sidebar=\"menu-skeleton\" className={cn('flex h-8 items-center gap-2 rounded-md px-2', className)} {...props}>\n {showIcon && <Skeleton className=\"size-4 rounded-md\" data-sidebar=\"menu-skeleton-icon\" />}\n <Skeleton\n className=\"h-4 max-w-(--skeleton-width) flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n '--skeleton-width': width,\n } as React.CSSProperties\n }\n />\n </div>\n )\n}\n\nfunction AppLayoutSidebarMenuSub({ className, ...props }: React.ComponentProps<'ul'>) {\n return (\n <ul\n data-slot=\"sidebar-menu-sub\"\n data-sidebar=\"menu-sub\"\n className={cn(\n 'border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuSubItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-sub-item\" data-sidebar=\"menu-sub-item\" className={cn('group/menu-sub-item relative', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenuSubButton({\n asChild = false,\n size = 'md',\n isActive = false,\n className,\n ...props\n}: React.ComponentProps<'a'> & {\n asChild?: boolean\n size?: 'sm' | 'md'\n isActive?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'a'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-sub-button\"\n data-sidebar=\"menu-sub-button\"\n data-size={size}\n data-active={isActive}\n className={cn(\n 'text-sidebar-foreground',\n 'ring-sidebar-ring',\n 'flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden',\n 'focus-visible:ring-2',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n '[&>svg]:text-sidebar-accent-foreground',\n '[&>span:last-child]:truncate',\n 'data-[active=true]:bg-sidebar-accent',\n 'data-[active=true]:text-sidebar-accent-foreground',\n size === 'sm' && 'text-xs',\n size === 'md' && 'text-sm',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport {\n AppLayoutSidebarContent,\n AppLayoutSidebarFooter,\n AppLayoutSidebarGroup,\n AppLayoutSidebarGroupAction,\n AppLayoutSidebarGroupContent,\n AppLayoutSidebarGroupLabel,\n AppLayoutSidebarHeader,\n AppLayoutSidebarInset,\n AppLayoutSidebarMenu,\n AppLayoutSidebarMenuAction,\n AppLayoutSidebarMenuBadge,\n AppLayoutSidebarMenuButton,\n AppLayoutSidebarMenuItem,\n AppLayoutSidebarMenuSkeleton,\n AppLayoutSidebarMenuSub,\n AppLayoutSidebarMenuSubButton,\n AppLayoutSidebarMenuSubItem,\n AppLayoutSidebarRail,\n AppLayoutSidebarSeparator,\n AppLayoutSidebarTrigger,\n Sidebar,\n SidebarProvider,\n // eslint-disable-next-line react-refresh/only-export-components\n useSidebar,\n}\n","'use client'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nimport { ShoppingCartIcon } from 'lucide-react'\n\nimport { AppLayoutSidebarInset, AppLayoutSidebarTrigger, Sidebar, SidebarProvider } from './sidebar'\n\n// eslint-disable-next-line react-refresh/only-export-components\nexport * from './sidebar'\n\nexport const AppLayoutWrapper: React.FC<React.PropsWithChildren> = ({ children }) => {\n return <SidebarProvider>{children}</SidebarProvider>\n}\n\nexport const AppLayoutHeader: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <header\n className={cn(\n 'bg-card',\n 'h-(--header-height)',\n 'sm:h-[calc(var(--header-height)_+_0.5rem)]',\n 'sm:px-4 sm:pr-6',\n 'absolute inset-x-0 top-0 z-20 gap-2 px-2 pr-4.5',\n 'shadow-nav flex items-center',\n 'transition-[width,height] ease-linear',\n 'group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)',\n 'sm:group-has-data-[collapsible=icon]/sidebar-wrapper:h-[calc(var(--header-height)_+_0.5rem)]',\n )}\n >\n <AppLayoutSidebarTrigger />\n\n <div className=\"flex gap-x-2 sm:ml-2.5\">\n <div className=\"bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg\">\n <ShoppingCartIcon size={20} />\n </div>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-medium\">Lunas Store</span>\n <span className=\"truncate text-xs\">Established 2023</span>\n </div>\n </div>\n\n <div className=\"flex flex-1 items-center justify-end\">{children}</div>\n </header>\n )\n}\n\nexport const AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>> = ({ children, ...props }) => {\n return (\n <Sidebar variant=\"inset\" collapsible=\"icon\" {...props}>\n {children}\n </Sidebar>\n )\n}\n\nexport const AppLayoutMain: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <AppLayoutSidebarInset>\n <section className=\"relative size-full\">\n <div className=\"absolute inset-0 flex flex-col\">{children}</div>\n </section>\n </AppLayoutSidebarInset>\n )\n}\nexport const AppLayoutMainHeader: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div data-slot=\"main-header\" className={cn('flex-0 snap-start', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainContent: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div data-slot=\"main-content\" className={cn('flex w-full flex-1 snap-y flex-col gap-4 overflow-y-auto px-2 sm:px-4', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainFooter: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div data-slot=\"main-footer\" className={cn('border-border-weak hidden w-full flex-0 border-t pt-2 sm:flex', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>> = ({ children, className }) => {\n return (\n <div data-slot=\"main-group\" className={cn('flex size-full flex-col gap-4', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainGroupContent: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div\n data-slot=\"main-group-content\"\n className={cn('bg-card shadow-card size-full max-w-5xl flex-1 snap-start snap-always scroll-mt-4 rounded-md p-4', className)}\n >\n {children}\n </div>\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","names":["open","TooltipProvider","Sheet","SheetContent","SheetHeader","SheetTitle","SheetDescription","ShoppingCartIcon","Button","MenuIcon","Separator","SlotPrimitive","Tooltip","TooltipTrigger","TooltipContent","Skeleton","AppLayoutWrapper: React.FC<React.PropsWithChildren>","AppLayoutHeader: React.FC<React.PropsWithChildren>","ShoppingCartIcon","AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>>","AppLayoutMain: React.FC<React.PropsWithChildren>","AppLayoutMainHeader: React.FC<React.PropsWithChildren & { className?: string }>","AppLayoutMainContent: React.FC<React.PropsWithChildren & { className?: string }>","AppLayoutMainFooter: React.FC<React.PropsWithChildren & { className?: string }>","AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>>","AppLayoutMainGroupContent: React.FC<React.PropsWithChildren & { className?: string }>"],"sources":["../../../packages/components/layouts/app-layout/sidebar.tsx","../../../packages/components/layouts/app-layout/index.tsx"],"sourcesContent":["import { createContext, useCallback, useContext, useEffect, useMemo, useState } from 'react'\nimport { useIsMobile } from '@customafk/react-toolkit/hooks/useMobile'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nimport { MenuIcon, ShoppingCartIcon } from 'lucide-react'\n\nimport { Button } from '@/components/ui/button'\nimport { Separator } from '@/components/ui/separator'\nimport { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle } from '@/components/ui/sheet'\nimport { Skeleton } from '@/components/ui/skeleton'\nimport { TooltipProvider } from '@/components/ui/tooltip'\nimport { Tooltip, TooltipContent, TooltipTrigger } from '@/components/ui/tooltip'\n\nimport { cva, type VariantProps } from 'class-variance-authority'\nimport { Slot as SlotPrimitive } from 'radix-ui'\n\nconst SIDEBAR_COOKIE_NAME = 'sidebar_state'\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7\nconst SIDEBAR_WIDTH = '16rem'\nconst SIDEBAR_WIDTH_MOBILE = '16rem'\nconst SIDEBAR_WIDTH_ICON = '3rem'\nconst SIDEBAR_KEYBOARD_SHORTCUT = 'b'\n\ntype SidebarContextProps = {\n state: 'expanded' | 'collapsed'\n open: boolean\n setOpen: (open: boolean) => void\n openMobile: boolean\n setOpenMobile: (open: boolean) => void\n isMobile: boolean\n toggleSidebar: () => void\n}\n\nconst SidebarContext = createContext<SidebarContextProps | null>(null)\n\nfunction useSidebar() {\n const context = useContext(SidebarContext)\n if (!context) {\n throw new Error('useSidebar must be used within a SidebarProvider.')\n }\n\n return context\n}\n\nfunction SidebarProvider({\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n defaultOpen?: boolean\n open?: boolean\n onOpenChange?: (open: boolean) => void\n}) {\n const isMobile = useIsMobile()\n const [openMobile, setOpenMobile] = useState(false)\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = useState(defaultOpen)\n const open = openProp ?? _open\n const setOpen = useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === 'function' ? value(open) : value\n if (setOpenProp) {\n setOpenProp(openState)\n } else {\n _setOpen(openState)\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open],\n )\n\n // Helper to toggle the sidebar.\n const toggleSidebar = useCallback(() => {\n return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\n // Adds a keyboard shortcut to toggle the sidebar.\n useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === SIDEBAR_KEYBOARD_SHORTCUT && (event.metaKey || event.ctrlKey)) {\n event.preventDefault()\n toggleSidebar()\n }\n }\n\n window.addEventListener('keydown', handleKeyDown)\n return () => window.removeEventListener('keydown', handleKeyDown)\n }, [toggleSidebar])\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? 'expanded' : 'collapsed'\n\n const contextValue = useMemo<SidebarContextProps>(\n () => ({\n state,\n isMobile,\n\n toggleSidebar,\n\n open,\n setOpen,\n\n openMobile,\n setOpenMobile,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar],\n )\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n data-slot=\"sidebar-wrapper\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH,\n '--sidebar-width-icon': SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn('group/sidebar-wrapper', 'has-data-[variant=inset]:bg-sidebar', 'flex h-svh w-full', className)}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n )\n}\n\nfunction Sidebar({\n side = 'left',\n variant = 'sidebar',\n collapsible = 'offcanvas',\n className,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n side?: 'left' | 'right'\n variant?: 'sidebar' | 'floating' | 'inset'\n collapsible?: 'offcanvas' | 'icon' | 'none'\n}) {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === 'none') {\n return (\n <aside data-slot=\"sidebar\" className={cn('bg-sidebar', 'text-sidebar-foreground', 'flex h-full w-(--sidebar-width) flex-col', className)} {...props}>\n {children}\n </aside>\n )\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar\"\n data-mobile=\"true\"\n className=\"bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex size-full flex-col\">\n <div className=\"border-border-weak flex items-center gap-x-2 border-b p-2 pr-4\">\n <AppLayoutSidebarTrigger />\n <div className=\"bg-sidebar-primary text-sidebar-primary-foreground ml-2 flex aspect-square size-8 items-center justify-center rounded-lg\">\n <ShoppingCartIcon size={20} />\n </div>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-medium\">Lunas Store</span>\n <span className=\"truncate text-xs\">Established 2023</span>\n </div>\n </div>\n {children}\n </div>\n </SheetContent>\n </Sheet>\n )\n }\n\n return (\n <aside\n className=\"group peer text-sidebar-foreground bg-card hidden md:block\"\n data-state={state}\n data-collapsible={state === 'collapsed' ? collapsible : ''}\n data-variant={variant}\n data-side={side}\n data-slot=\"sidebar\"\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n data-slot=\"sidebar-gap\"\n className={cn(\n 'relative',\n 'bg-transparent',\n 'transition-[width] duration-200 ease-linear',\n 'h-(--header-height) w-(--sidebar-width)',\n 'sm:h-[calc(var(--header-height) + 0.5rem)]',\n 'group-data-[collapsible=offcanvas]:w-0',\n 'group-data-[side=right]:rotate-180',\n variant === 'floating' || variant === 'inset'\n ? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',\n )}\n />\n <div\n data-slot=\"sidebar-container\"\n className={cn(\n 'hidden md:flex',\n 'shadow-nav fixed inset-y-0 top-14 z-10',\n 'h-[calc(100svh-3.5rem)] w-(--sidebar-width)',\n 'transition-[left,right,width] duration-200 ease-linear',\n side === 'left' && 'left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]',\n side === 'right' && 'right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]',\n // Adjust the padding for floating and inset variants.\n variant === 'floating' || variant === 'inset'\n ? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l',\n className,\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar-inner\"\n className={cn(\n 'flex size-full flex-col',\n 'group-data-[variant=floating]:rounded-lg',\n 'group-data-[variant=floating]:border',\n 'group-data-[variant=floating]:border-sidebar-border',\n 'group-data-[variant=floating]:shadow-sm',\n )}\n >\n {children}\n </div>\n </div>\n </aside>\n )\n}\n\nfunction AppLayoutSidebarTrigger({ className, onClick, ...props }: React.ComponentProps<typeof Button>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <Button\n data-sidebar=\"trigger\"\n data-slot=\"sidebar-trigger\"\n variant=\"ghost\"\n color=\"muted\"\n size=\"icon\"\n className={cn('size-10 rounded-full', className)}\n onClick={(event) => {\n onClick?.(event)\n toggleSidebar()\n }}\n {...props}\n >\n <MenuIcon className=\"!size-6\" />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n )\n}\n\nfunction AppLayoutSidebarRail({ className, ...props }: React.ComponentProps<'button'>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <button\n data-sidebar=\"rail\"\n data-slot=\"sidebar-rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onClick={toggleSidebar}\n title=\"Toggle Sidebar\"\n className={cn(\n 'absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex',\n 'after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]',\n 'group-data-[side=left]:-right-4',\n 'group-data-[side=right]:left-0',\n 'in-data-[side=left]:cursor-w-resize',\n 'in-data-[side=right]:cursor-e-resize',\n 'hover:after:bg-sidebar-border',\n 'hover:group-data-[collapsible=offcanvas]:bg-sidebar',\n 'group-data-[collapsible=offcanvas]:translate-x-0',\n 'group-data-[collapsible=offcanvas]:after:left-full',\n '[[data-side=left][data-state=collapsed]_&]:cursor-e-resize',\n '[[data-side=right][data-state=collapsed]_&]:cursor-w-resize',\n '[[data-side=left][data-collapsible=offcanvas]_&]:-right-2',\n '[[data-side=right][data-collapsible=offcanvas]_&]:-left-2',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarInset({ className, children, ...props }: React.ComponentProps<'main'>) {\n return (\n <main data-slot=\"sidebar-inset\" className={cn('relative flex w-full flex-1 flex-col', className)} {...props}>\n <div className=\"h-(--header-height) w-full sm:h-[calc(var(--header-height)_+_0.5rem)]\" />\n <div className={cn('flex-1 inset-shadow-sm')}>{children}</div>\n </main>\n )\n}\n\nfunction AppLayoutSidebarHeader({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-header\" data-sidebar=\"header\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarFooter({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-footer\" data-sidebar=\"footer\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarSeparator({ className, ...props }: React.ComponentProps<typeof Separator>) {\n return <Separator data-slot=\"sidebar-separator\" data-sidebar=\"separator\" className={cn('bg-sidebar-border mx-2 w-auto', className)} {...props} />\n}\n\nfunction AppLayoutSidebarContent({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-content\"\n data-sidebar=\"content\"\n className={cn('flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden', className)}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroup({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group\" data-sidebar=\"group\" className={cn('relative flex w-full min-w-0 flex-col p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarGroupLabel({ className, asChild = false, ...props }: React.ComponentProps<'div'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'div'\n\n return (\n <Comp\n data-slot=\"sidebar-group-label\"\n data-sidebar=\"group-label\"\n className={cn(\n 'flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2',\n 'text-sidebar-foreground/70',\n 'ring-sidebar-ring',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n 'group-data-[collapsible=icon]:-mt-8',\n 'group-data-[collapsible=icon]:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroupAction({ className, asChild = false, ...props }: React.ComponentProps<'button'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-group-action\"\n data-sidebar=\"group-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroupContent({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group-content\" data-sidebar=\"group-content\" className={cn('w-full text-sm', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenu({ className, ...props }: React.ComponentProps<'ul'>) {\n return <ul data-slot=\"sidebar-menu\" data-sidebar=\"menu\" className={cn('flex w-full min-w-0 flex-col gap-1', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenuItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-item\" data-sidebar=\"menu-item\" className={cn('group/menu-item relative', className)} {...props} />\n}\n\nconst sidebarMenuButtonVariants = cva(\n [\n 'peer/menu-button',\n 'cursor-pointer',\n 'flex w-full items-center gap-2',\n 'overflow-hidden rounded-md p-2 outline-hidden',\n 'text-left truncate',\n 'transition-[color,width,height,padding]',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'group-has-data-[sidebar=menu-action]/menu-item:pr-8',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n 'data-[active=true]:bg-sidebar-primary-muted',\n 'data-[active=true]:font-medium',\n 'data-[active=true]:text-sidebar-primary',\n 'data-[state=open]:hover:bg-sidebar-accent',\n 'data-[state=open]:hover:text-sidebar-accent-foreground',\n 'group-data-[collapsible=icon]:size-8!',\n 'group-data-[collapsible=icon]:p-2!',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n '[&>span:last-child]:truncate',\n ],\n {\n variants: {\n variant: {\n default: 'hover:bg-sidebar-accent/60 hover:text-sidebar-accent-foreground/80',\n outline:\n 'bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]',\n },\n size: {\n default: 'h-8 text-sm',\n sm: 'h-7 text-xs',\n lg: 'h-12 text-sm group-data-[collapsible=icon]:p-0!',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n },\n)\n\nfunction AppLayoutSidebarMenuButton({\n asChild = false,\n isActive = false,\n variant = 'default',\n size = 'default',\n tooltip,\n className,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n isActive?: boolean\n tooltip?: string | React.ComponentProps<typeof TooltipContent>\n} & VariantProps<typeof sidebarMenuButtonVariants>) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n const { isMobile, state } = useSidebar()\n\n const button = (\n <Comp\n data-slot=\"sidebar-menu-button\"\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n )\n\n if (!tooltip) {\n return button\n }\n\n if (typeof tooltip === 'string') {\n tooltip = {\n children: tooltip,\n }\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent side=\"right\" align=\"center\" hidden={state !== 'collapsed' || isMobile} {...tooltip} />\n </Tooltip>\n )\n}\n\nfunction AppLayoutSidebarMenuAction({\n className,\n asChild = false,\n showOnHover = false,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n showOnHover?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-action\"\n data-sidebar=\"menu-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n showOnHover && 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n showOnHover && 'group-focus-within/menu-item:opacity-100',\n showOnHover && 'group-hover/menu-item:opacity-100',\n showOnHover && 'data-[state=open]:opacity-100 md:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuBadge({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-menu-badge\"\n data-sidebar=\"menu-badge\"\n className={cn(\n 'text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none',\n 'peer-hover/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuSkeleton({\n className,\n showIcon = false,\n ...props\n}: React.ComponentProps<'div'> & {\n showIcon?: boolean\n}) {\n // Random width between 50 to 90%.\n const width = useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`\n }, [])\n\n return (\n <div data-slot=\"sidebar-menu-skeleton\" data-sidebar=\"menu-skeleton\" className={cn('flex h-8 items-center gap-2 rounded-md px-2', className)} {...props}>\n {showIcon && <Skeleton className=\"size-4 rounded-md\" data-sidebar=\"menu-skeleton-icon\" />}\n <Skeleton\n className=\"h-4 max-w-(--skeleton-width) flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n '--skeleton-width': width,\n } as React.CSSProperties\n }\n />\n </div>\n )\n}\n\nfunction AppLayoutSidebarMenuSub({ className, ...props }: React.ComponentProps<'ul'>) {\n return (\n <ul\n data-slot=\"sidebar-menu-sub\"\n data-sidebar=\"menu-sub\"\n className={cn(\n 'border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuSubItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-sub-item\" data-sidebar=\"menu-sub-item\" className={cn('group/menu-sub-item relative', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenuSubButton({\n asChild = false,\n size = 'md',\n isActive = false,\n className,\n ...props\n}: React.ComponentProps<'a'> & {\n asChild?: boolean\n size?: 'sm' | 'md'\n isActive?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'a'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-sub-button\"\n data-sidebar=\"menu-sub-button\"\n data-size={size}\n data-active={isActive}\n className={cn(\n 'text-sidebar-foreground',\n 'ring-sidebar-ring',\n 'flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden',\n 'focus-visible:ring-2',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n '[&>svg]:text-sidebar-accent-foreground',\n '[&>span:last-child]:truncate',\n 'data-[active=true]:bg-sidebar-accent',\n 'data-[active=true]:text-sidebar-accent-foreground',\n size === 'sm' && 'text-xs',\n size === 'md' && 'text-sm',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport {\n AppLayoutSidebarContent,\n AppLayoutSidebarFooter,\n AppLayoutSidebarGroup,\n AppLayoutSidebarGroupAction,\n AppLayoutSidebarGroupContent,\n AppLayoutSidebarGroupLabel,\n AppLayoutSidebarHeader,\n AppLayoutSidebarInset,\n AppLayoutSidebarMenu,\n AppLayoutSidebarMenuAction,\n AppLayoutSidebarMenuBadge,\n AppLayoutSidebarMenuButton,\n AppLayoutSidebarMenuItem,\n AppLayoutSidebarMenuSkeleton,\n AppLayoutSidebarMenuSub,\n AppLayoutSidebarMenuSubButton,\n AppLayoutSidebarMenuSubItem,\n AppLayoutSidebarRail,\n AppLayoutSidebarSeparator,\n AppLayoutSidebarTrigger,\n Sidebar,\n SidebarProvider,\n // eslint-disable-next-line react-refresh/only-export-components\n useSidebar,\n}\n","'use client'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nimport { ShoppingCartIcon } from 'lucide-react'\n\nimport { AppLayoutSidebarInset, AppLayoutSidebarTrigger, Sidebar, SidebarProvider } from './sidebar'\n\n// eslint-disable-next-line react-refresh/only-export-components\nexport * from './sidebar'\n\nexport const AppLayoutWrapper: React.FC<React.PropsWithChildren> = ({ children }) => {\n return <SidebarProvider>{children}</SidebarProvider>\n}\n\nexport const AppLayoutHeader: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <header\n className={cn(\n 'bg-card',\n 'h-(--header-height)',\n 'sm:h-[calc(var(--header-height)_+_0.5rem)]',\n 'sm:px-4 sm:pr-6',\n 'absolute inset-x-0 top-0 z-20 gap-2 px-2 pr-4.5',\n 'shadow-nav flex items-center',\n 'transition-[width,height] ease-linear',\n 'group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)',\n 'sm:group-has-data-[collapsible=icon]/sidebar-wrapper:h-[calc(var(--header-height)_+_0.5rem)]',\n )}\n >\n <AppLayoutSidebarTrigger />\n\n <div className=\"flex gap-x-2 sm:ml-2.5\">\n <div className=\"bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg\">\n <ShoppingCartIcon size={20} />\n </div>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-medium\">Lunas Store</span>\n <span className=\"truncate text-xs\">Established 2023</span>\n </div>\n </div>\n\n <div className=\"flex flex-1 items-center justify-end\">{children}</div>\n </header>\n )\n}\n\nexport const AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>> = ({ children, ...props }) => {\n return (\n <Sidebar variant=\"inset\" collapsible=\"icon\" {...props}>\n {children}\n </Sidebar>\n )\n}\n\nexport const AppLayoutMain: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <AppLayoutSidebarInset>\n <section className=\"relative size-full\">\n <div className=\"absolute inset-0 flex flex-col\">{children}</div>\n </section>\n </AppLayoutSidebarInset>\n )\n}\nexport const AppLayoutMainHeader: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div data-slot=\"main-header\" className={cn('flex-0 snap-start', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainContent: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div data-slot=\"main-content\" className={cn('flex w-full flex-1 snap-y flex-col gap-4 overflow-y-auto px-2 sm:px-4', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainFooter: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div data-slot=\"main-footer\" className={cn('border-border-weak hidden w-full flex-0 border-t pt-2 sm:flex', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>> = ({ children, className }) => {\n return (\n <div data-slot=\"main-group\" className={cn('flex size-full flex-col gap-4', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainGroupContent: React.FC<React.PropsWithChildren & { className?: string }> = ({ className, children }) => {\n return (\n <div\n data-slot=\"main-group-content\"\n className={cn('bg-card shadow-card size-full max-w-5xl flex-1 snap-start snap-always scroll-mt-4 rounded-md p-4', className)}\n >\n {children}\n </div>\n )\n}\n"],"mappings":"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"}
@@ -1,8 +1,7 @@
1
- import { Button } from "../../button-BtvqPQbl.cjs";
2
- import { Separator } from "../../separator-DT79vOG-.cjs";
3
- import { TooltipContent } from "../../tooltip-CJK3asOo.cjs";
1
+ import { Button } from "../../button-De2032Bs.cjs";
2
+ import { Separator } from "../../separator-BSmwGEtT.cjs";
3
+ import { TooltipContent } from "../../tooltip-DLNDOfBF.cjs";
4
4
  import * as react_jsx_runtime259 from "react/jsx-runtime";
5
- import React$1 from "react";
6
5
  import * as class_variance_authority_types7 from "class-variance-authority/types";
7
6
  import { VariantProps } from "class-variance-authority";
8
7
 
@@ -25,7 +24,7 @@ declare function SidebarProvider({
25
24
  style,
26
25
  children,
27
26
  ...props
28
- }: React$1.ComponentProps<'div'> & {
27
+ }: React.ComponentProps<'div'> & {
29
28
  defaultOpen?: boolean;
30
29
  open?: boolean;
31
30
  onOpenChange?: (open: boolean) => void;
@@ -37,7 +36,7 @@ declare function Sidebar({
37
36
  className,
38
37
  children,
39
38
  ...props
40
- }: React$1.ComponentProps<'div'> & {
39
+ }: React.ComponentProps<'div'> & {
41
40
  side?: 'left' | 'right';
42
41
  variant?: 'sidebar' | 'floating' | 'inset';
43
42
  collapsible?: 'offcanvas' | 'icon' | 'none';
@@ -46,62 +45,62 @@ declare function AppLayoutSidebarTrigger({
46
45
  className,
47
46
  onClick,
48
47
  ...props
49
- }: React$1.ComponentProps<typeof Button>): react_jsx_runtime259.JSX.Element;
48
+ }: React.ComponentProps<typeof Button>): react_jsx_runtime259.JSX.Element;
50
49
  declare function AppLayoutSidebarRail({
51
50
  className,
52
51
  ...props
53
- }: React$1.ComponentProps<'button'>): react_jsx_runtime259.JSX.Element;
52
+ }: React.ComponentProps<'button'>): react_jsx_runtime259.JSX.Element;
54
53
  declare function AppLayoutSidebarInset({
55
54
  className,
56
55
  children,
57
56
  ...props
58
- }: React$1.ComponentProps<'main'>): react_jsx_runtime259.JSX.Element;
57
+ }: React.ComponentProps<'main'>): react_jsx_runtime259.JSX.Element;
59
58
  declare function AppLayoutSidebarHeader({
60
59
  className,
61
60
  ...props
62
- }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
61
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
63
62
  declare function AppLayoutSidebarFooter({
64
63
  className,
65
64
  ...props
66
- }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
65
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
67
66
  declare function AppLayoutSidebarSeparator({
68
67
  className,
69
68
  ...props
70
- }: React$1.ComponentProps<typeof Separator>): react_jsx_runtime259.JSX.Element;
69
+ }: React.ComponentProps<typeof Separator>): react_jsx_runtime259.JSX.Element;
71
70
  declare function AppLayoutSidebarContent({
72
71
  className,
73
72
  ...props
74
- }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
73
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
75
74
  declare function AppLayoutSidebarGroup({
76
75
  className,
77
76
  ...props
78
- }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
77
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
79
78
  declare function AppLayoutSidebarGroupLabel({
80
79
  className,
81
80
  asChild,
82
81
  ...props
83
- }: React$1.ComponentProps<'div'> & {
82
+ }: React.ComponentProps<'div'> & {
84
83
  asChild?: boolean;
85
84
  }): react_jsx_runtime259.JSX.Element;
86
85
  declare function AppLayoutSidebarGroupAction({
87
86
  className,
88
87
  asChild,
89
88
  ...props
90
- }: React$1.ComponentProps<'button'> & {
89
+ }: React.ComponentProps<'button'> & {
91
90
  asChild?: boolean;
92
91
  }): react_jsx_runtime259.JSX.Element;
93
92
  declare function AppLayoutSidebarGroupContent({
94
93
  className,
95
94
  ...props
96
- }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
95
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
97
96
  declare function AppLayoutSidebarMenu({
98
97
  className,
99
98
  ...props
100
- }: React$1.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
99
+ }: React.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
101
100
  declare function AppLayoutSidebarMenuItem({
102
101
  className,
103
102
  ...props
104
- }: React$1.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
103
+ }: React.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
105
104
  declare const sidebarMenuButtonVariants: (props?: ({
106
105
  variant?: "default" | "outline" | null | undefined;
107
106
  size?: "sm" | "lg" | "default" | null | undefined;
@@ -114,46 +113,46 @@ declare function AppLayoutSidebarMenuButton({
114
113
  tooltip,
115
114
  className,
116
115
  ...props
117
- }: React$1.ComponentProps<'button'> & {
116
+ }: React.ComponentProps<'button'> & {
118
117
  asChild?: boolean;
119
118
  isActive?: boolean;
120
- tooltip?: string | React$1.ComponentProps<typeof TooltipContent>;
119
+ tooltip?: string | React.ComponentProps<typeof TooltipContent>;
121
120
  } & VariantProps<typeof sidebarMenuButtonVariants>): react_jsx_runtime259.JSX.Element;
122
121
  declare function AppLayoutSidebarMenuAction({
123
122
  className,
124
123
  asChild,
125
124
  showOnHover,
126
125
  ...props
127
- }: React$1.ComponentProps<'button'> & {
126
+ }: React.ComponentProps<'button'> & {
128
127
  asChild?: boolean;
129
128
  showOnHover?: boolean;
130
129
  }): react_jsx_runtime259.JSX.Element;
131
130
  declare function AppLayoutSidebarMenuBadge({
132
131
  className,
133
132
  ...props
134
- }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
133
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
135
134
  declare function AppLayoutSidebarMenuSkeleton({
136
135
  className,
137
136
  showIcon,
138
137
  ...props
139
- }: React$1.ComponentProps<'div'> & {
138
+ }: React.ComponentProps<'div'> & {
140
139
  showIcon?: boolean;
141
140
  }): react_jsx_runtime259.JSX.Element;
142
141
  declare function AppLayoutSidebarMenuSub({
143
142
  className,
144
143
  ...props
145
- }: React$1.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
144
+ }: React.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
146
145
  declare function AppLayoutSidebarMenuSubItem({
147
146
  className,
148
147
  ...props
149
- }: React$1.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
148
+ }: React.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
150
149
  declare function AppLayoutSidebarMenuSubButton({
151
150
  asChild,
152
151
  size,
153
152
  isActive,
154
153
  className,
155
154
  ...props
156
- }: React$1.ComponentProps<'a'> & {
155
+ }: React.ComponentProps<'a'> & {
157
156
  asChild?: boolean;
158
157
  size?: 'sm' | 'md';
159
158
  isActive?: boolean;
@@ -1,10 +1,9 @@
1
- import { Button } from "../../button-B_r8XsfH.js";
2
- import { Separator } from "../../separator-Cr_2vFm6.js";
3
- import { TooltipContent } from "../../tooltip-CyEOAlsP.js";
1
+ import { Button } from "../../button-CS4aajjP.js";
2
+ import { Separator } from "../../separator-zD-G3xIG.js";
3
+ import { TooltipContent } from "../../tooltip-CamHYf1v.js";
4
4
  import { VariantProps } from "class-variance-authority";
5
- import * as react_jsx_runtime281 from "react/jsx-runtime";
6
- import React$1 from "react";
7
- import * as class_variance_authority_types8 from "class-variance-authority/types";
5
+ import * as react_jsx_runtime259 from "react/jsx-runtime";
6
+ import * as class_variance_authority_types7 from "class-variance-authority/types";
8
7
 
9
8
  //#region packages/components/layouts/app-layout/sidebar.d.ts
10
9
  type SidebarContextProps = {
@@ -25,11 +24,11 @@ declare function SidebarProvider({
25
24
  style,
26
25
  children,
27
26
  ...props
28
- }: React$1.ComponentProps<'div'> & {
27
+ }: React.ComponentProps<'div'> & {
29
28
  defaultOpen?: boolean;
30
29
  open?: boolean;
31
30
  onOpenChange?: (open: boolean) => void;
32
- }): react_jsx_runtime281.JSX.Element;
31
+ }): react_jsx_runtime259.JSX.Element;
33
32
  declare function Sidebar({
34
33
  side,
35
34
  variant,
@@ -37,75 +36,75 @@ declare function Sidebar({
37
36
  className,
38
37
  children,
39
38
  ...props
40
- }: React$1.ComponentProps<'div'> & {
39
+ }: React.ComponentProps<'div'> & {
41
40
  side?: 'left' | 'right';
42
41
  variant?: 'sidebar' | 'floating' | 'inset';
43
42
  collapsible?: 'offcanvas' | 'icon' | 'none';
44
- }): react_jsx_runtime281.JSX.Element;
43
+ }): react_jsx_runtime259.JSX.Element;
45
44
  declare function AppLayoutSidebarTrigger({
46
45
  className,
47
46
  onClick,
48
47
  ...props
49
- }: React$1.ComponentProps<typeof Button>): react_jsx_runtime281.JSX.Element;
48
+ }: React.ComponentProps<typeof Button>): react_jsx_runtime259.JSX.Element;
50
49
  declare function AppLayoutSidebarRail({
51
50
  className,
52
51
  ...props
53
- }: React$1.ComponentProps<'button'>): react_jsx_runtime281.JSX.Element;
52
+ }: React.ComponentProps<'button'>): react_jsx_runtime259.JSX.Element;
54
53
  declare function AppLayoutSidebarInset({
55
54
  className,
56
55
  children,
57
56
  ...props
58
- }: React$1.ComponentProps<'main'>): react_jsx_runtime281.JSX.Element;
57
+ }: React.ComponentProps<'main'>): react_jsx_runtime259.JSX.Element;
59
58
  declare function AppLayoutSidebarHeader({
60
59
  className,
61
60
  ...props
62
- }: React$1.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
61
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
63
62
  declare function AppLayoutSidebarFooter({
64
63
  className,
65
64
  ...props
66
- }: React$1.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
65
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
67
66
  declare function AppLayoutSidebarSeparator({
68
67
  className,
69
68
  ...props
70
- }: React$1.ComponentProps<typeof Separator>): react_jsx_runtime281.JSX.Element;
69
+ }: React.ComponentProps<typeof Separator>): react_jsx_runtime259.JSX.Element;
71
70
  declare function AppLayoutSidebarContent({
72
71
  className,
73
72
  ...props
74
- }: React$1.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
73
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
75
74
  declare function AppLayoutSidebarGroup({
76
75
  className,
77
76
  ...props
78
- }: React$1.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
77
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
79
78
  declare function AppLayoutSidebarGroupLabel({
80
79
  className,
81
80
  asChild,
82
81
  ...props
83
- }: React$1.ComponentProps<'div'> & {
82
+ }: React.ComponentProps<'div'> & {
84
83
  asChild?: boolean;
85
- }): react_jsx_runtime281.JSX.Element;
84
+ }): react_jsx_runtime259.JSX.Element;
86
85
  declare function AppLayoutSidebarGroupAction({
87
86
  className,
88
87
  asChild,
89
88
  ...props
90
- }: React$1.ComponentProps<'button'> & {
89
+ }: React.ComponentProps<'button'> & {
91
90
  asChild?: boolean;
92
- }): react_jsx_runtime281.JSX.Element;
91
+ }): react_jsx_runtime259.JSX.Element;
93
92
  declare function AppLayoutSidebarGroupContent({
94
93
  className,
95
94
  ...props
96
- }: React$1.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
95
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
97
96
  declare function AppLayoutSidebarMenu({
98
97
  className,
99
98
  ...props
100
- }: React$1.ComponentProps<'ul'>): react_jsx_runtime281.JSX.Element;
99
+ }: React.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
101
100
  declare function AppLayoutSidebarMenuItem({
102
101
  className,
103
102
  ...props
104
- }: React$1.ComponentProps<'li'>): react_jsx_runtime281.JSX.Element;
103
+ }: React.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
105
104
  declare const sidebarMenuButtonVariants: (props?: ({
106
105
  variant?: "default" | "outline" | null | undefined;
107
106
  size?: "sm" | "lg" | "default" | null | undefined;
108
- } & class_variance_authority_types8.ClassProp) | undefined) => string;
107
+ } & class_variance_authority_types7.ClassProp) | undefined) => string;
109
108
  declare function AppLayoutSidebarMenuButton({
110
109
  asChild,
111
110
  isActive,
@@ -114,50 +113,50 @@ declare function AppLayoutSidebarMenuButton({
114
113
  tooltip,
115
114
  className,
116
115
  ...props
117
- }: React$1.ComponentProps<'button'> & {
116
+ }: React.ComponentProps<'button'> & {
118
117
  asChild?: boolean;
119
118
  isActive?: boolean;
120
- tooltip?: string | React$1.ComponentProps<typeof TooltipContent>;
121
- } & VariantProps<typeof sidebarMenuButtonVariants>): react_jsx_runtime281.JSX.Element;
119
+ tooltip?: string | React.ComponentProps<typeof TooltipContent>;
120
+ } & VariantProps<typeof sidebarMenuButtonVariants>): react_jsx_runtime259.JSX.Element;
122
121
  declare function AppLayoutSidebarMenuAction({
123
122
  className,
124
123
  asChild,
125
124
  showOnHover,
126
125
  ...props
127
- }: React$1.ComponentProps<'button'> & {
126
+ }: React.ComponentProps<'button'> & {
128
127
  asChild?: boolean;
129
128
  showOnHover?: boolean;
130
- }): react_jsx_runtime281.JSX.Element;
129
+ }): react_jsx_runtime259.JSX.Element;
131
130
  declare function AppLayoutSidebarMenuBadge({
132
131
  className,
133
132
  ...props
134
- }: React$1.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
133
+ }: React.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
135
134
  declare function AppLayoutSidebarMenuSkeleton({
136
135
  className,
137
136
  showIcon,
138
137
  ...props
139
- }: React$1.ComponentProps<'div'> & {
138
+ }: React.ComponentProps<'div'> & {
140
139
  showIcon?: boolean;
141
- }): react_jsx_runtime281.JSX.Element;
140
+ }): react_jsx_runtime259.JSX.Element;
142
141
  declare function AppLayoutSidebarMenuSub({
143
142
  className,
144
143
  ...props
145
- }: React$1.ComponentProps<'ul'>): react_jsx_runtime281.JSX.Element;
144
+ }: React.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
146
145
  declare function AppLayoutSidebarMenuSubItem({
147
146
  className,
148
147
  ...props
149
- }: React$1.ComponentProps<'li'>): react_jsx_runtime281.JSX.Element;
148
+ }: React.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
150
149
  declare function AppLayoutSidebarMenuSubButton({
151
150
  asChild,
152
151
  size,
153
152
  isActive,
154
153
  className,
155
154
  ...props
156
- }: React$1.ComponentProps<'a'> & {
155
+ }: React.ComponentProps<'a'> & {
157
156
  asChild?: boolean;
158
157
  size?: 'sm' | 'md';
159
158
  isActive?: boolean;
160
- }): react_jsx_runtime281.JSX.Element;
159
+ }): react_jsx_runtime259.JSX.Element;
161
160
  //#endregion
162
161
  //#region packages/components/layouts/app-layout/index.d.ts
163
162
  declare const AppLayoutWrapper: React.FC<React.PropsWithChildren>;