@customafk/lunas-ui 0.0.64 → 0.0.65
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.
- package/dist/{add-new-Dw0uZWxo.js → add-new-BFDOXej7.js} +1 -1
- package/dist/{add-new-Dw0uZWxo.js.map → add-new-BFDOXej7.js.map} +1 -1
- package/dist/{add-new-C2dDiCV3.cjs → add-new-D3b8hc2C.cjs} +1 -1
- package/dist/{add-new-C2dDiCV3.cjs.map → add-new-D3b8hc2C.cjs.map} +1 -1
- package/dist/{alert-dialog-BOMy-TmT.js → alert-dialog-B5dXkMIF.js} +1 -1
- package/dist/{alert-dialog-BOMy-TmT.js.map → alert-dialog-B5dXkMIF.js.map} +1 -1
- package/dist/{alert-dialog-lwTxSl-r.cjs → alert-dialog-D-4wxqLK.cjs} +1 -1
- package/dist/{alert-dialog-lwTxSl-r.cjs.map → alert-dialog-D-4wxqLK.cjs.map} +1 -1
- package/dist/{avatar-BaNIRUku.cjs → avatar-Ch6Lx2oc.cjs} +1 -1
- package/dist/{avatar-BaNIRUku.cjs.map → avatar-Ch6Lx2oc.cjs.map} +1 -1
- package/dist/{avatar-DZU7feMQ.js → avatar-ClIgQDJO.js} +1 -1
- package/dist/{avatar-DZU7feMQ.js.map → avatar-ClIgQDJO.js.map} +1 -1
- package/dist/{button-CS4aajjP.d.ts → button-DUWg-QPz.d.ts} +5 -5
- package/dist/{button-De2032Bs.d.cts → button-st5plaQt.d.cts} +5 -5
- package/dist/{calendar-CUDdTiC-.cjs → calendar-B6F_Lppz.cjs} +1 -1
- package/dist/{calendar-CUDdTiC-.cjs.map → calendar-B6F_Lppz.cjs.map} +1 -1
- package/dist/{calendar-BZRNZdsJ.js → calendar-CXddeN7A.js} +1 -1
- package/dist/{calendar-BZRNZdsJ.js.map → calendar-CXddeN7A.js.map} +1 -1
- package/dist/cards/simple-card.d.cts +2 -2
- package/dist/cards/simple-card.d.ts +2 -2
- package/dist/{command-B9nlrxXh.cjs → command-BNYekOzL.cjs} +2 -2
- package/dist/{command-B9nlrxXh.cjs.map → command-BNYekOzL.cjs.map} +1 -1
- package/dist/{command-D7AHVkgQ.d.ts → command-CL9pytMx.d.cts} +12 -12
- package/dist/{command-DKD5gHi_.js → command-CyWyRcle.js} +2 -2
- package/dist/{command-DKD5gHi_.js.map → command-CyWyRcle.js.map} +1 -1
- package/dist/{command-Db5JViIx.d.cts → command-zikueR7l.d.ts} +12 -12
- package/dist/data-display/empty.d.cts +2 -2
- package/dist/data-display/statistic.d.cts +2 -2
- package/dist/data-display/statistic.d.ts +2 -2
- package/dist/data-display/user.cjs +2 -0
- package/dist/data-display/user.cjs.map +1 -0
- package/dist/data-display/user.d.cts +10 -0
- package/dist/data-display/user.d.ts +10 -0
- package/dist/data-display/user.js +2 -0
- package/dist/data-display/user.js.map +1 -0
- package/dist/{dialog-yE-2SRfz.d.ts → dialog-Dease_8R.d.ts} +12 -12
- package/dist/{dialog-CiqPVetj.d.cts → dialog-oAOedasX.d.cts} +12 -12
- package/dist/{dialog-DbI18XF9.js → dialog-pMHkBJ-w.js} +1 -1
- package/dist/{dialog-DbI18XF9.js.map → dialog-pMHkBJ-w.js.map} +1 -1
- package/dist/{dialog-CGrbU7PO.cjs → dialog-wX27mb8E.cjs} +1 -1
- package/dist/{dialog-CGrbU7PO.cjs.map → dialog-wX27mb8E.cjs.map} +1 -1
- package/dist/dialogs/confirm-dialog.cjs +1 -1
- package/dist/dialogs/confirm-dialog.js +1 -1
- package/dist/dialogs/detail-dialog/component/sidebar.cjs +1 -1
- package/dist/dialogs/detail-dialog/component/sidebar.d.cts +30 -30
- package/dist/dialogs/detail-dialog/component/sidebar.d.ts +30 -30
- package/dist/dialogs/detail-dialog/component/sidebar.js +1 -1
- package/dist/dialogs/detail-dialog/index.cjs +1 -1
- package/dist/dialogs/detail-dialog/index.js +1 -1
- package/dist/dialogs/error-dialog.cjs +1 -1
- package/dist/dialogs/error-dialog.js +1 -1
- package/dist/dialogs/form-dialog.cjs +1 -1
- package/dist/dialogs/form-dialog.d.cts +2 -2
- package/dist/dialogs/form-dialog.d.ts +2 -2
- package/dist/dialogs/form-dialog.js +1 -1
- package/dist/dialogs/loading-dialog.cjs +1 -1
- package/dist/dialogs/loading-dialog.js +1 -1
- package/dist/{drawer-B7OJzlXZ.js → drawer-DnhgwetT.js} +1 -1
- package/dist/{drawer-B7OJzlXZ.js.map → drawer-DnhgwetT.js.map} +1 -1
- package/dist/{drawer-Dh9uXVnU.cjs → drawer-sRfKhXA3.cjs} +1 -1
- package/dist/{drawer-Dh9uXVnU.cjs.map → drawer-sRfKhXA3.cjs.map} +1 -1
- package/dist/{dropdown-menu-Cn96vqMy.js → dropdown-menu-Bj39Rmxd.js} +1 -1
- package/dist/{dropdown-menu-Cn96vqMy.js.map → dropdown-menu-Bj39Rmxd.js.map} +1 -1
- package/dist/{dropdown-menu-BtNJk8EZ.cjs → dropdown-menu-SNcBwTOA.cjs} +1 -1
- package/dist/{dropdown-menu-BtNJk8EZ.cjs.map → dropdown-menu-SNcBwTOA.cjs.map} +1 -1
- package/dist/{error-dialog-D3tnycqF.js → error-dialog-CphiTB4y.js} +2 -2
- package/dist/{error-dialog-D3tnycqF.js.map → error-dialog-CphiTB4y.js.map} +1 -1
- package/dist/{error-dialog-BkCaUR7F.cjs → error-dialog-DGg0x5xF.cjs} +2 -2
- package/dist/{error-dialog-BkCaUR7F.cjs.map → error-dialog-DGg0x5xF.cjs.map} +1 -1
- package/dist/{form-D-gDMD-J.js → form-B-KLKj5u.js} +2 -2
- package/dist/{form-D-gDMD-J.js.map → form-B-KLKj5u.js.map} +1 -1
- package/dist/{form-CaxhlWxK.cjs → form-CtpHZKmh.cjs} +2 -2
- package/dist/{form-CaxhlWxK.cjs.map → form-CtpHZKmh.cjs.map} +1 -1
- package/dist/{form-wrapper-BUkoh-c7.cjs → form-wrapper-C3pU1F5r.cjs} +2 -2
- package/dist/{form-wrapper-BUkoh-c7.cjs.map → form-wrapper-C3pU1F5r.cjs.map} +1 -1
- package/dist/{form-wrapper-BbScjpBv.js → form-wrapper-Deo8gKv5.js} +2 -2
- package/dist/{form-wrapper-BbScjpBv.js.map → form-wrapper-Deo8gKv5.js.map} +1 -1
- package/dist/forms/combobox-field.cjs +1 -1
- package/dist/forms/combobox-field.d.cts +2 -2
- package/dist/forms/combobox-field.d.ts +2 -2
- package/dist/forms/combobox-field.js +1 -1
- package/dist/forms/date-field.cjs +1 -1
- package/dist/forms/date-field.d.ts +2 -2
- package/dist/forms/date-field.js +1 -1
- package/dist/forms/form-wrapper.cjs +1 -1
- package/dist/forms/form-wrapper.d.cts +2 -2
- package/dist/forms/form-wrapper.d.ts +2 -2
- package/dist/forms/form-wrapper.js +1 -1
- package/dist/forms/multi-select-field.cjs +1 -1
- package/dist/forms/multi-select-field.d.cts +2 -2
- package/dist/forms/multi-select-field.d.ts +2 -2
- package/dist/forms/multi-select-field.js +1 -1
- package/dist/forms/number-field.cjs +1 -1
- package/dist/forms/number-field.d.cts +2 -2
- package/dist/forms/number-field.d.ts +2 -2
- package/dist/forms/number-field.js +1 -1
- package/dist/forms/password-field.cjs +1 -1
- package/dist/forms/password-field.d.cts +2 -2
- package/dist/forms/password-field.d.ts +2 -2
- package/dist/forms/password-field.js +1 -1
- package/dist/forms/select-field.cjs +1 -1
- package/dist/forms/select-field.d.cts +2 -2
- package/dist/forms/select-field.d.ts +2 -2
- package/dist/forms/select-field.js +1 -1
- package/dist/forms/switch-field.cjs +1 -1
- package/dist/forms/switch-field.d.cts +2 -2
- package/dist/forms/switch-field.d.ts +2 -2
- package/dist/forms/switch-field.js +1 -1
- package/dist/forms/text-field.cjs +1 -1
- package/dist/forms/text-field.d.cts +2 -2
- package/dist/forms/text-field.d.ts +2 -2
- package/dist/forms/text-field.js +1 -1
- package/dist/forms/textarea-field.cjs +1 -1
- package/dist/forms/textarea-field.d.cts +2 -2
- package/dist/forms/textarea-field.d.ts +2 -2
- package/dist/forms/textarea-field.js +1 -1
- package/dist/{input-BFZuwsER.js → input-BUYJ4_aj.js} +1 -1
- package/dist/{input-BFZuwsER.js.map → input-BUYJ4_aj.js.map} +1 -1
- package/dist/{input-BayoSfCE.d.cts → input-BXxtPvIa.d.cts} +3 -3
- package/dist/{input-BjiwI6EW.d.ts → input-DO3Z69kK.d.ts} +3 -3
- package/dist/{input-ERPHY3v4.cjs → input-DgtTVBtN.cjs} +1 -1
- package/dist/{input-ERPHY3v4.cjs.map → input-DgtTVBtN.cjs.map} +1 -1
- package/dist/{label-BBPPT0-L.cjs → label-BZqk7MPJ.cjs} +1 -1
- package/dist/{label-BBPPT0-L.cjs.map → label-BZqk7MPJ.cjs.map} +1 -1
- package/dist/{label-DdpIoRiG.js → label-HVpeECNr.js} +1 -1
- package/dist/{label-DdpIoRiG.js.map → label-HVpeECNr.js.map} +1 -1
- package/dist/layouts/app-layout/index.d.cts +28 -28
- package/dist/layouts/app-layout/index.d.ts +3 -3
- package/dist/layouts/flex.d.cts +4 -4
- package/dist/layouts/flex.d.ts +2 -2
- package/dist/layouts/service-layout/index.cjs +1 -1
- package/dist/layouts/service-layout/index.cjs.map +1 -1
- package/dist/layouts/service-layout/index.d.cts +15 -15
- package/dist/layouts/service-layout/index.d.ts +3 -3
- package/dist/layouts/service-layout/index.js +1 -1
- package/dist/layouts/service-layout/index.js.map +1 -1
- package/dist/{multi-select-BAXHYtlU.cjs → multi-select-DRKqFg1M.cjs} +2 -2
- package/dist/{multi-select-BAXHYtlU.cjs.map → multi-select-DRKqFg1M.cjs.map} +1 -1
- package/dist/{multi-select-oXuLHx0A.js → multi-select-DyhAPckx.js} +2 -2
- package/dist/{multi-select-oXuLHx0A.js.map → multi-select-DyhAPckx.js.map} +1 -1
- package/dist/{popover-ByL6Igxn.cjs → popover-Bi7GLJT5.cjs} +1 -1
- package/dist/{popover-ByL6Igxn.cjs.map → popover-Bi7GLJT5.cjs.map} +1 -1
- package/dist/{popover-DMt7GPSm.js → popover-CxOK3oy2.js} +1 -1
- package/dist/{popover-DMt7GPSm.js.map → popover-CxOK3oy2.js.map} +1 -1
- package/dist/{refresh-BVSXOk3A.cjs → refresh-CQyFVZx9.cjs} +1 -1
- package/dist/{refresh-BVSXOk3A.cjs.map → refresh-CQyFVZx9.cjs.map} +1 -1
- package/dist/{refresh-CHzDlf3i.js → refresh-CTcKzu_a.js} +1 -1
- package/dist/{refresh-CHzDlf3i.js.map → refresh-CTcKzu_a.js.map} +1 -1
- package/dist/{scroll-area-C4Mg89Qh.js → scroll-area-CqevC_nb.js} +1 -1
- package/dist/{scroll-area-C4Mg89Qh.js.map → scroll-area-CqevC_nb.js.map} +1 -1
- package/dist/{scroll-area-qPdEy4lg.cjs → scroll-area-Dgjr1n1T.cjs} +1 -1
- package/dist/{scroll-area-qPdEy4lg.cjs.map → scroll-area-Dgjr1n1T.cjs.map} +1 -1
- package/dist/{search-input-DWLfcXEU.cjs → search-input-BkhVqB3R.cjs} +2 -2
- package/dist/{search-input-DWLfcXEU.cjs.map → search-input-BkhVqB3R.cjs.map} +1 -1
- package/dist/{search-input-B_L6kaz-.js → search-input-DnYrPBeT.js} +2 -2
- package/dist/{search-input-B_L6kaz-.js.map → search-input-DnYrPBeT.js.map} +1 -1
- package/dist/{select-CijI0HX0.js → select-Cmq5a3Wg.js} +1 -1
- package/dist/{select-CijI0HX0.js.map → select-Cmq5a3Wg.js.map} +1 -1
- package/dist/{select-oxr4KoHx.cjs → select-DAE3Xg7g.cjs} +1 -1
- package/dist/{select-oxr4KoHx.cjs.map → select-DAE3Xg7g.cjs.map} +1 -1
- package/dist/{separator-BSmwGEtT.d.cts → separator-B-TIckT4.d.cts} +3 -3
- package/dist/{separator-zD-G3xIG.d.ts → separator-CO0oTpOK.d.ts} +3 -3
- package/dist/{sidebar-BxGyCuTJ.cjs → sidebar-CROF88rz.cjs} +2 -2
- package/dist/{sidebar-BxGyCuTJ.cjs.map → sidebar-CROF88rz.cjs.map} +1 -1
- package/dist/{sidebar-CMWETVDr.js → sidebar-CrStgrmq.js} +2 -2
- package/dist/{sidebar-CMWETVDr.js.map → sidebar-CrStgrmq.js.map} +1 -1
- package/dist/{switch-BPSKvrTw.cjs → switch-BnHSwQ5T.cjs} +1 -1
- package/dist/{switch-BPSKvrTw.cjs.map → switch-BnHSwQ5T.cjs.map} +1 -1
- package/dist/{switch-Crju8DJO.js → switch-iwm2-R_e.js} +1 -1
- package/dist/{switch-Crju8DJO.js.map → switch-iwm2-R_e.js.map} +1 -1
- package/dist/table/index.cjs +1 -1
- package/dist/table/index.d.cts +2 -2
- package/dist/table/index.d.ts +2 -2
- package/dist/table/index.js +1 -1
- package/dist/{table-CSvLRXlk.cjs → table-CuhHhpgi.cjs} +2 -2
- package/dist/{table-CSvLRXlk.cjs.map → table-CuhHhpgi.cjs.map} +1 -1
- package/dist/{table-DCmuhHSH.js → table-oROsZcz4.js} +2 -2
- package/dist/{table-DCmuhHSH.js.map → table-oROsZcz4.js.map} +1 -1
- package/dist/{textarea-BtACo9UF.cjs → textarea-DK_bNV0u.cjs} +1 -1
- package/dist/{textarea-BtACo9UF.cjs.map → textarea-DK_bNV0u.cjs.map} +1 -1
- package/dist/{textarea-BCZiUxv7.js → textarea-DbNqKCAi.js} +1 -1
- package/dist/{textarea-BCZiUxv7.js.map → textarea-DbNqKCAi.js.map} +1 -1
- package/dist/{title-sD8UJhwY.cjs → title-B51-Oj-Y.cjs} +1 -1
- package/dist/{title-sD8UJhwY.cjs.map → title-B51-Oj-Y.cjs.map} +1 -1
- package/dist/{title-CtD4oOTk.js → title-Cb4SosQb.js} +1 -1
- package/dist/{title-CtD4oOTk.js.map → title-Cb4SosQb.js.map} +1 -1
- package/dist/{toggle-CP8phE7Y.d.cts → toggle-BHyG321X.d.ts} +5 -5
- package/dist/{toggle-BtGh6fdx.d.ts → toggle-DdY6X9AI.d.cts} +4 -4
- package/dist/{tooltip-CamHYf1v.d.ts → tooltip-BURz5fQL.d.ts} +6 -6
- package/dist/{tooltip-DLNDOfBF.d.cts → tooltip-C0_WxGo5.d.cts} +6 -6
- package/dist/typography/paragraph.d.cts +2 -2
- package/dist/typography/paragraph.d.ts +2 -2
- package/dist/typography/title.cjs +1 -1
- package/dist/typography/title.d.cts +2 -2
- package/dist/typography/title.d.ts +2 -2
- package/dist/typography/title.js +1 -1
- package/dist/ui/alert-dialog.cjs +1 -1
- package/dist/ui/alert-dialog.d.cts +12 -12
- package/dist/ui/alert-dialog.d.ts +12 -12
- package/dist/ui/alert-dialog.js +1 -1
- package/dist/ui/alert.d.cts +4 -4
- package/dist/ui/alert.d.ts +6 -6
- package/dist/ui/aspect-ratio.d.cts +2 -2
- package/dist/ui/aspect-ratio.d.ts +2 -2
- package/dist/ui/avatar.cjs +1 -1
- package/dist/ui/avatar.d.cts +4 -4
- package/dist/ui/avatar.d.ts +4 -4
- package/dist/ui/avatar.js +1 -1
- package/dist/ui/badge.d.cts +4 -4
- package/dist/ui/badge.d.ts +4 -4
- package/dist/ui/breadcrumb.d.cts +8 -8
- package/dist/ui/breadcrumb.d.ts +8 -8
- package/dist/ui/button.d.cts +1 -1
- package/dist/ui/button.d.ts +1 -1
- package/dist/ui/buttons/add-new.cjs +1 -1
- package/dist/ui/buttons/add-new.js +1 -1
- package/dist/ui/buttons/refresh.cjs +1 -1
- package/dist/ui/buttons/refresh.js +1 -1
- package/dist/ui/calendar.cjs +1 -1
- package/dist/ui/calendar.d.cts +4 -4
- package/dist/ui/calendar.d.ts +4 -4
- package/dist/ui/calendar.js +1 -1
- package/dist/ui/card.d.cts +8 -8
- package/dist/ui/card.d.ts +8 -8
- package/dist/ui/carousel.d.cts +7 -7
- package/dist/ui/carousel.d.ts +7 -7
- package/dist/ui/collapsible.d.cts +4 -4
- package/dist/ui/collapsible.d.ts +4 -4
- package/dist/ui/command.cjs +1 -1
- package/dist/ui/command.d.cts +2 -2
- package/dist/ui/command.d.ts +2 -2
- package/dist/ui/command.js +1 -1
- package/dist/ui/context-menu.d.cts +16 -16
- package/dist/ui/context-menu.d.ts +16 -16
- package/dist/ui/dialog.cjs +1 -1
- package/dist/ui/dialog.d.cts +1 -1
- package/dist/ui/dialog.d.ts +1 -1
- package/dist/ui/dialog.js +1 -1
- package/dist/ui/dropdown-menu.cjs +1 -1
- package/dist/ui/dropdown-menu.d.cts +16 -16
- package/dist/ui/dropdown-menu.d.ts +16 -16
- package/dist/ui/dropdown-menu.js +1 -1
- package/dist/ui/file-uploader.d.cts +2 -2
- package/dist/ui/file-uploader.d.ts +2 -2
- package/dist/ui/form.cjs +1 -1
- package/dist/ui/form.d.cts +7 -7
- package/dist/ui/form.d.ts +7 -7
- package/dist/ui/form.js +1 -1
- package/dist/ui/hover-card.d.cts +4 -4
- package/dist/ui/hover-card.d.ts +4 -4
- package/dist/ui/input-otp.d.cts +5 -5
- package/dist/ui/input-otp.d.ts +5 -5
- package/dist/ui/input.cjs +1 -1
- package/dist/ui/input.d.cts +1 -1
- package/dist/ui/input.d.ts +1 -1
- package/dist/ui/input.js +1 -1
- package/dist/ui/inputs/search-input.cjs +1 -1
- package/dist/ui/inputs/search-input.d.cts +3 -3
- package/dist/ui/inputs/search-input.d.ts +3 -3
- package/dist/ui/inputs/search-input.js +1 -1
- package/dist/ui/label.cjs +1 -1
- package/dist/ui/label.d.cts +2 -2
- package/dist/ui/label.d.ts +2 -2
- package/dist/ui/label.js +1 -1
- package/dist/ui/menubar.d.cts +17 -17
- package/dist/ui/menubar.d.ts +17 -17
- package/dist/ui/multi-select.cjs +1 -1
- package/dist/ui/multi-select.d.cts +2 -2
- package/dist/ui/multi-select.d.ts +2 -2
- package/dist/ui/multi-select.js +1 -1
- package/dist/ui/navigation-menu.d.cts +11 -11
- package/dist/ui/navigation-menu.d.ts +11 -11
- package/dist/ui/pagination.d.cts +9 -9
- package/dist/ui/pagination.d.ts +9 -9
- package/dist/ui/popover.cjs +1 -1
- package/dist/ui/popover.d.cts +5 -5
- package/dist/ui/popover.d.ts +5 -5
- package/dist/ui/popover.js +1 -1
- package/dist/ui/progress.d.cts +2 -2
- package/dist/ui/progress.d.ts +2 -2
- package/dist/ui/radio-group.d.cts +3 -3
- package/dist/ui/radio-group.d.ts +3 -3
- package/dist/ui/resizable.d.cts +4 -4
- package/dist/ui/resizable.d.ts +4 -4
- package/dist/ui/scroll-area.cjs +1 -1
- package/dist/ui/scroll-area.d.cts +3 -3
- package/dist/ui/scroll-area.d.ts +3 -3
- package/dist/ui/scroll-area.js +1 -1
- package/dist/ui/select.cjs +1 -1
- package/dist/ui/select.d.cts +11 -11
- package/dist/ui/select.d.ts +11 -11
- package/dist/ui/select.js +1 -1
- package/dist/ui/separator.d.cts +1 -1
- package/dist/ui/separator.d.ts +1 -1
- package/dist/ui/sheet.d.cts +9 -9
- package/dist/ui/sheet.d.ts +9 -9
- package/dist/ui/sidebar.cjs +1 -1
- package/dist/ui/sidebar.d.cts +30 -30
- package/dist/ui/sidebar.d.ts +28 -28
- package/dist/ui/sidebar.js +1 -1
- package/dist/ui/skeleton.d.cts +2 -2
- package/dist/ui/skeleton.d.ts +2 -2
- package/dist/ui/slider.d.cts +2 -2
- package/dist/ui/slider.d.ts +2 -2
- package/dist/ui/sonner.d.cts +2 -2
- package/dist/ui/sonner.d.ts +2 -2
- package/dist/ui/switch.cjs +1 -1
- package/dist/ui/switch.d.cts +2 -2
- package/dist/ui/switch.d.ts +2 -2
- package/dist/ui/switch.js +1 -1
- package/dist/ui/table.cjs +1 -1
- package/dist/ui/table.d.cts +9 -9
- package/dist/ui/table.d.ts +9 -9
- package/dist/ui/table.js +1 -1
- package/dist/ui/tabs.d.cts +5 -5
- package/dist/ui/tabs.d.ts +5 -5
- package/dist/ui/textarea.cjs +1 -1
- package/dist/ui/textarea.d.cts +2 -2
- package/dist/ui/textarea.d.ts +2 -2
- package/dist/ui/textarea.js +1 -1
- package/dist/ui/toggle-group.d.cts +4 -4
- package/dist/ui/toggle-group.d.ts +4 -4
- package/dist/ui/toggle.d.cts +1 -1
- package/dist/ui/toggle.d.ts +1 -1
- package/dist/ui/tooltip.d.cts +1 -1
- package/dist/ui/tooltip.d.ts +1 -1
- package/package.json +6 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use client";const e=require(`../chunk-CUT6urMc.cjs`);require(`../label-
|
|
1
|
+
"use client";const e=require(`../chunk-CUT6urMc.cjs`);require(`../label-BZqk7MPJ.cjs`);const t=require(`../form-CtpHZKmh.cjs`),n=require(`../switch-BnHSwQ5T.cjs`),r=e.__toESM(require(`@customafk/react-toolkit/utils`)),i=e.__toESM(require(`react/jsx-runtime`)),a=({name:e,label:a=`Switch Field`,description:o,isShowErrorMsg:s=!1})=>(0,i.jsx)(t.FormField,{name:e,render:({field:e})=>(0,i.jsxs)(`div`,{className:`spage-y-1`,children:[(0,i.jsxs)(t.FormItem,{className:(0,r.cn)(`border-border-weak flex flex-row items-center justify-between rounded-lg border p-3 shadow-xs`),children:[(0,i.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,i.jsx)(t.FormLabel,{className:`cursor-pointer text-sm`,children:a}),o&&(0,i.jsx)(t.FormDescription,{className:`text-xs`,children:o})]}),(0,i.jsx)(t.FormControl,{children:(0,i.jsx)(n.Switch,{checked:e.value,onCheckedChange:e.onChange})})]}),s&&(0,i.jsx)(t.FormMessage,{})]})});exports.SwitchField=a;
|
|
2
2
|
//# sourceMappingURL=switch-field.cjs.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime38 from "react/jsx-runtime";
|
|
2
2
|
import { FieldPath, FieldValues } from "react-hook-form";
|
|
3
3
|
|
|
4
4
|
//#region packages/components/forms/switch-field.d.ts
|
|
@@ -13,7 +13,7 @@ declare const SwitchField: <TFieldValues extends FieldValues = FieldValues>({
|
|
|
13
13
|
label,
|
|
14
14
|
description,
|
|
15
15
|
isShowErrorMsg
|
|
16
|
-
}: Props<TFieldValues>) =>
|
|
16
|
+
}: Props<TFieldValues>) => react_jsx_runtime38.JSX.Element;
|
|
17
17
|
//#endregion
|
|
18
18
|
export { SwitchField };
|
|
19
19
|
//# sourceMappingURL=switch-field.d.cts.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime23 from "react/jsx-runtime";
|
|
2
2
|
import { FieldPath, FieldValues } from "react-hook-form";
|
|
3
3
|
|
|
4
4
|
//#region packages/components/forms/switch-field.d.ts
|
|
@@ -13,7 +13,7 @@ declare const SwitchField: <TFieldValues extends FieldValues = FieldValues>({
|
|
|
13
13
|
label,
|
|
14
14
|
description,
|
|
15
15
|
isShowErrorMsg
|
|
16
|
-
}: Props<TFieldValues>) =>
|
|
16
|
+
}: Props<TFieldValues>) => react_jsx_runtime23.JSX.Element;
|
|
17
17
|
//#endregion
|
|
18
18
|
export { SwitchField };
|
|
19
19
|
//# sourceMappingURL=switch-field.d.ts.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use client";import"../label-
|
|
1
|
+
"use client";import"../label-HVpeECNr.js";import{FormControl as e,FormDescription as t,FormField as n,FormItem as r,FormLabel as i,FormMessage as a}from"../form-B-KLKj5u.js";import{Switch as o}from"../switch-iwm2-R_e.js";import{cn as s}from"@customafk/react-toolkit/utils";import{jsx as c,jsxs as l}from"react/jsx-runtime";const u=({name:u,label:d=`Switch Field`,description:f,isShowErrorMsg:p=!1})=>c(n,{name:u,render:({field:n})=>l(`div`,{className:`spage-y-1`,children:[l(r,{className:s(`border-border-weak flex flex-row items-center justify-between rounded-lg border p-3 shadow-xs`),children:[l(`div`,{className:`space-y-0.5`,children:[c(i,{className:`cursor-pointer text-sm`,children:d}),f&&c(t,{className:`text-xs`,children:f})]}),c(e,{children:c(o,{checked:n.value,onCheckedChange:n.onChange})})]}),p&&c(a,{})]})});export{u as SwitchField};
|
|
2
2
|
//# sourceMappingURL=switch-field.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use client";const e=require(`../chunk-CUT6urMc.cjs`),t=require(`../flex-DMgD86BT.cjs`);require(`../label-
|
|
1
|
+
"use client";const e=require(`../chunk-CUT6urMc.cjs`),t=require(`../flex-DMgD86BT.cjs`);require(`../label-BZqk7MPJ.cjs`);const n=require(`../form-CtpHZKmh.cjs`),r=require(`../input-DgtTVBtN.cjs`),i=e.__toESM(require(`lucide-react`)),a=e.__toESM(require(`@customafk/react-toolkit/utils`)),o=e.__toESM(require(`react/jsx-runtime`)),s=e.__toESM(require(`react`)),c=e.__toESM(require(`react-hook-form`)),l=({name:e,label:l=`Text Field`,placeholder:u=`Enter text here`,isShowLabel:d=!0,isShowClearButton:f=!1,isShowErrorMsg:p=!1,isShowCount:m=!1,description:h,className:g=``,onValueChange:_})=>{let{resetField:v}=n.useFormField(),y=(0,c.useWatch)({name:e}),b=(0,s.useCallback)(()=>{v(e)},[v,e]);return(0,o.jsx)(n.FormField,{name:e,render:({field:e})=>(0,o.jsxs)(n.FormItem,{className:(0,a.cn)(`w-full gap-0`,m||!!h&&`space-y-1`,g),children:[d&&(0,o.jsx)(n.FormLabel,{children:l}),(0,o.jsxs)(`div`,{className:`relative`,children:[(0,o.jsx)(n.FormControl,{children:(0,o.jsx)(r.Input,{...e,placeholder:u,className:(0,a.cn)(`w-full`,f&&`pr-9`),onValueChange:_})}),f&&y&&(0,o.jsx)(`button`,{type:`button`,className:`text-text-positive-weak hover:text-text-positive focus-visible:ring-border absolute inset-y-0 end-0 flex h-full w-8 cursor-pointer items-center justify-center rounded-e-md transition-[color,box-shadow] outline-none focus:z-10 focus-visible:ring-2`,"aria-label":`Clear input`,onClick:b,children:(0,o.jsx)(i.XIcon,{size:14,"aria-hidden":`true`})})]}),(0,o.jsxs)(t.Flex,{width:`full`,padding:`none`,justify:`end`,children:[p&&(0,o.jsx)(n.FormMessage,{className:`grow`}),m&&(0,o.jsxs)(`div`,{className:`text-text-positive-weak text-end text-xs`,children:[y?.length??0,` characters`]})]}),!!h&&(0,o.jsx)(n.FormDescription,{children:h})]})})};exports.TextField=l;
|
|
2
2
|
//# sourceMappingURL=text-field.cjs.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime57 from "react/jsx-runtime";
|
|
2
2
|
import { FieldPath, FieldValues } from "react-hook-form";
|
|
3
3
|
|
|
4
4
|
//#region packages/components/forms/text-field.d.ts
|
|
@@ -25,7 +25,7 @@ declare const TextField: <TFieldValues extends FieldValues = FieldValues>({
|
|
|
25
25
|
description,
|
|
26
26
|
className,
|
|
27
27
|
onValueChange
|
|
28
|
-
}: Props<TFieldValues>) =>
|
|
28
|
+
}: Props<TFieldValues>) => react_jsx_runtime57.JSX.Element;
|
|
29
29
|
//#endregion
|
|
30
30
|
export { TextField };
|
|
31
31
|
//# sourceMappingURL=text-field.d.cts.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime9 from "react/jsx-runtime";
|
|
2
2
|
import { FieldPath, FieldValues } from "react-hook-form";
|
|
3
3
|
|
|
4
4
|
//#region packages/components/forms/text-field.d.ts
|
|
@@ -25,7 +25,7 @@ declare const TextField: <TFieldValues extends FieldValues = FieldValues>({
|
|
|
25
25
|
description,
|
|
26
26
|
className,
|
|
27
27
|
onValueChange
|
|
28
|
-
}: Props<TFieldValues>) =>
|
|
28
|
+
}: Props<TFieldValues>) => react_jsx_runtime9.JSX.Element;
|
|
29
29
|
//#endregion
|
|
30
30
|
export { TextField };
|
|
31
31
|
//# sourceMappingURL=text-field.d.ts.map
|
package/dist/forms/text-field.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use client";import{Flex as e}from"../flex-BZHWRUkz.js";import"../label-
|
|
1
|
+
"use client";import{Flex as e}from"../flex-BZHWRUkz.js";import"../label-HVpeECNr.js";import{FormControl as t,FormDescription as n,FormField as r,FormItem as i,FormLabel as a,FormMessage as o,useFormField as s}from"../form-B-KLKj5u.js";import{Input as c}from"../input-BUYJ4_aj.js";import{XIcon as l}from"lucide-react";import{cn as u}from"@customafk/react-toolkit/utils";import{jsx as d,jsxs as f}from"react/jsx-runtime";import{useCallback as p}from"react";import{useWatch as m}from"react-hook-form";const h=({name:h,label:g=`Text Field`,placeholder:_=`Enter text here`,isShowLabel:v=!0,isShowClearButton:y=!1,isShowErrorMsg:b=!1,isShowCount:x=!1,description:S,className:C=``,onValueChange:w})=>{let{resetField:T}=s(),E=m({name:h}),D=p(()=>{T(h)},[T,h]);return d(r,{name:h,render:({field:r})=>f(i,{className:u(`w-full gap-0`,x||!!S&&`space-y-1`,C),children:[v&&d(a,{children:g}),f(`div`,{className:`relative`,children:[d(t,{children:d(c,{...r,placeholder:_,className:u(`w-full`,y&&`pr-9`),onValueChange:w})}),y&&E&&d(`button`,{type:`button`,className:`text-text-positive-weak hover:text-text-positive focus-visible:ring-border absolute inset-y-0 end-0 flex h-full w-8 cursor-pointer items-center justify-center rounded-e-md transition-[color,box-shadow] outline-none focus:z-10 focus-visible:ring-2`,"aria-label":`Clear input`,onClick:D,children:d(l,{size:14,"aria-hidden":`true`})})]}),f(e,{width:`full`,padding:`none`,justify:`end`,children:[b&&d(o,{className:`grow`}),x&&f(`div`,{className:`text-text-positive-weak text-end text-xs`,children:[E?.length??0,` characters`]})]}),!!S&&d(n,{children:S})]})})};export{h as TextField};
|
|
2
2
|
//# sourceMappingURL=text-field.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use client";const e=require(`../chunk-CUT6urMc.cjs`);require(`../label-
|
|
1
|
+
"use client";const e=require(`../chunk-CUT6urMc.cjs`);require(`../label-BZqk7MPJ.cjs`);const t=require(`../form-CtpHZKmh.cjs`),n=require(`../textarea-DK_bNV0u.cjs`),r=e.__toESM(require(`react/jsx-runtime`)),i=e.__toESM(require(`react-hook-form`)),a=({name:e,label:a=`Textarea Field`,placeholder:o=`Enter text here`,isShowErrorMsg:s=!1,isShowCount:c=!1,description:l,rows:u=3,onValueChange:d})=>{let f=(0,i.useWatch)({name:e});return(0,r.jsx)(t.FormField,{name:e,render:({field:e})=>(0,r.jsxs)(t.FormItem,{className:`w-full`,children:[(0,r.jsx)(t.FormLabel,{children:a}),(0,r.jsx)(t.FormControl,{children:(0,r.jsx)(n.Textarea,{...e,placeholder:o,className:`w-full`,rows:u,onValueChange:d})}),c&&(0,r.jsxs)(`div`,{className:`text-muted-foreground text-end text-xs`,children:[f?.length??0,` characters`]}),!!l&&(0,r.jsx)(t.FormDescription,{children:l}),s&&(0,r.jsx)(t.FormMessage,{})]})})};exports.TextareaField=a;
|
|
2
2
|
//# sourceMappingURL=textarea-field.cjs.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime12 from "react/jsx-runtime";
|
|
2
2
|
import { FieldPath, FieldValues } from "react-hook-form";
|
|
3
3
|
|
|
4
4
|
//#region packages/components/forms/textarea-field.d.ts
|
|
@@ -21,7 +21,7 @@ declare const TextareaField: <TFieldValues extends FieldValues = FieldValues>({
|
|
|
21
21
|
description,
|
|
22
22
|
rows,
|
|
23
23
|
onValueChange
|
|
24
|
-
}: Props<TFieldValues>) =>
|
|
24
|
+
}: Props<TFieldValues>) => react_jsx_runtime12.JSX.Element;
|
|
25
25
|
//#endregion
|
|
26
26
|
export { TextareaField };
|
|
27
27
|
//# sourceMappingURL=textarea-field.d.cts.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime10 from "react/jsx-runtime";
|
|
2
2
|
import { FieldPath, FieldValues } from "react-hook-form";
|
|
3
3
|
|
|
4
4
|
//#region packages/components/forms/textarea-field.d.ts
|
|
@@ -21,7 +21,7 @@ declare const TextareaField: <TFieldValues extends FieldValues = FieldValues>({
|
|
|
21
21
|
description,
|
|
22
22
|
rows,
|
|
23
23
|
onValueChange
|
|
24
|
-
}: Props<TFieldValues>) =>
|
|
24
|
+
}: Props<TFieldValues>) => react_jsx_runtime10.JSX.Element;
|
|
25
25
|
//#endregion
|
|
26
26
|
export { TextareaField };
|
|
27
27
|
//# sourceMappingURL=textarea-field.d.ts.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use client";import"../label-
|
|
1
|
+
"use client";import"../label-HVpeECNr.js";import{FormControl as e,FormDescription as t,FormField as n,FormItem as r,FormLabel as i,FormMessage as a}from"../form-B-KLKj5u.js";import{Textarea as o}from"../textarea-DbNqKCAi.js";import{jsx as s,jsxs as c}from"react/jsx-runtime";import{useWatch as l}from"react-hook-form";const u=({name:u,label:d=`Textarea Field`,placeholder:f=`Enter text here`,isShowErrorMsg:p=!1,isShowCount:m=!1,description:h,rows:g=3,onValueChange:_})=>{let v=l({name:u});return s(n,{name:u,render:({field:n})=>c(r,{className:`w-full`,children:[s(i,{children:d}),s(e,{children:s(o,{...n,placeholder:f,className:`w-full`,rows:g,onValueChange:_})}),m&&c(`div`,{className:`text-muted-foreground text-end text-xs`,children:[v?.length??0,` characters`]}),!!h&&s(t,{children:h}),p&&s(a,{})]})})};export{u as TextareaField};
|
|
2
2
|
//# sourceMappingURL=textarea-field.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import{cn as e}from"@customafk/react-toolkit/utils";import{jsx as t}from"react/jsx-runtime";import{useCallback as n}from"react";function r({className:r,onChange:i,onValueChange:a,...o}){let s=n(e=>{i?.(e),a?.(e.target.value)},[i,a]);return t(`input`,{"data-slot":`input`,className:e(`flex h-9 w-full px-3 py-1`,`border-border-weak shadow-input rounded-md border`,`caret-primary bg-transparent text-sm`,`transition-[color,border,box-shadow] outline-none`,`placeholder:text-text-positive-muted`,`hover:border-border`,`disabled:pointer-events-none`,`disabled:cursor-not-allowed`,`disabled:opacity-50`,`focus-visible:ring-4`,`focus-visible:ring-primary-weak`,`focus-visible:border-primary-strong`,`aria-invalid:ring-danger-muted`,`aria-invalid:border-danger`,r),...o,onChange:s})}export{r as Input};
|
|
2
|
-
//# sourceMappingURL=input-
|
|
2
|
+
//# sourceMappingURL=input-BUYJ4_aj.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"input-
|
|
1
|
+
{"version":3,"file":"input-BUYJ4_aj.js","names":[],"sources":["../packages/components/ui/input.tsx"],"sourcesContent":["'use client'\nimport { useCallback } from 'react'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nfunction Input({\n className,\n onChange,\n onValueChange,\n ...props\n}: React.ComponentProps<'input'> & {\n onValueChange?: (value: string) => void\n}) {\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(e)\n onValueChange?.(e.target.value)\n },\n [onChange, onValueChange],\n )\n return (\n <input\n data-slot=\"input\"\n className={cn(\n 'flex h-9 w-full px-3 py-1',\n 'border-border-weak shadow-input rounded-md border',\n 'caret-primary bg-transparent text-sm',\n 'transition-[color,border,box-shadow] outline-none',\n 'placeholder:text-text-positive-muted',\n 'hover:border-border',\n 'disabled:pointer-events-none',\n 'disabled:cursor-not-allowed',\n 'disabled:opacity-50',\n 'focus-visible:ring-4',\n 'focus-visible:ring-primary-weak',\n 'focus-visible:border-primary-strong',\n 'aria-invalid:ring-danger-muted',\n 'aria-invalid:border-danger',\n className,\n )}\n {...props}\n onChange={handleChange}\n />\n )\n}\n\nexport { Input }\n"],"mappings":"gIAIA,SAAS,EAAM,CACb,YACA,WACA,gBACA,GAAG,GAGF,CACD,IAAM,EAAe,EAClB,GAA2C,CAC1C,IAAW,GACX,IAAgB,EAAE,OAAO,QAE3B,CAAC,EAAU,IAEb,OACE,EAAC,QAAA,CACC,YAAU,QACV,UAAW,EACT,4BACA,oDACA,uCACA,oDACA,uCACA,sBACA,+BACA,8BACA,sBACA,uBACA,kCACA,sCACA,iCACA,6BACA,GAEF,GAAI,EACJ,SAAU"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime58 from "react/jsx-runtime";
|
|
2
2
|
|
|
3
3
|
//#region packages/components/ui/input.d.ts
|
|
4
4
|
declare function Input({
|
|
@@ -8,7 +8,7 @@ declare function Input({
|
|
|
8
8
|
...props
|
|
9
9
|
}: React.ComponentProps<'input'> & {
|
|
10
10
|
onValueChange?: (value: string) => void;
|
|
11
|
-
}):
|
|
11
|
+
}): react_jsx_runtime58.JSX.Element;
|
|
12
12
|
//#endregion
|
|
13
13
|
export { Input };
|
|
14
|
-
//# sourceMappingURL=input-
|
|
14
|
+
//# sourceMappingURL=input-BXxtPvIa.d.cts.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime124 from "react/jsx-runtime";
|
|
2
2
|
|
|
3
3
|
//#region packages/components/ui/input.d.ts
|
|
4
4
|
declare function Input({
|
|
@@ -8,7 +8,7 @@ declare function Input({
|
|
|
8
8
|
...props
|
|
9
9
|
}: React.ComponentProps<'input'> & {
|
|
10
10
|
onValueChange?: (value: string) => void;
|
|
11
|
-
}):
|
|
11
|
+
}): react_jsx_runtime124.JSX.Element;
|
|
12
12
|
//#endregion
|
|
13
13
|
export { Input };
|
|
14
|
-
//# sourceMappingURL=input-
|
|
14
|
+
//# sourceMappingURL=input-DO3Z69kK.d.ts.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
const e=require(`./chunk-CUT6urMc.cjs`),t=e.__toESM(require(`@customafk/react-toolkit/utils`)),n=e.__toESM(require(`react/jsx-runtime`)),r=e.__toESM(require(`react`));function i({className:e,onChange:i,onValueChange:a,...o}){let s=(0,r.useCallback)(e=>{i?.(e),a?.(e.target.value)},[i,a]);return(0,n.jsx)(`input`,{"data-slot":`input`,className:(0,t.cn)(`flex h-9 w-full px-3 py-1`,`border-border-weak shadow-input rounded-md border`,`caret-primary bg-transparent text-sm`,`transition-[color,border,box-shadow] outline-none`,`placeholder:text-text-positive-muted`,`hover:border-border`,`disabled:pointer-events-none`,`disabled:cursor-not-allowed`,`disabled:opacity-50`,`focus-visible:ring-4`,`focus-visible:ring-primary-weak`,`focus-visible:border-primary-strong`,`aria-invalid:ring-danger-muted`,`aria-invalid:border-danger`,e),...o,onChange:s})}Object.defineProperty(exports,`Input`,{enumerable:!0,get:function(){return i}});
|
|
2
|
-
//# sourceMappingURL=input-
|
|
2
|
+
//# sourceMappingURL=input-DgtTVBtN.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"input-
|
|
1
|
+
{"version":3,"file":"input-DgtTVBtN.cjs","names":[],"sources":["../packages/components/ui/input.tsx"],"sourcesContent":["'use client'\nimport { useCallback } from 'react'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nfunction Input({\n className,\n onChange,\n onValueChange,\n ...props\n}: React.ComponentProps<'input'> & {\n onValueChange?: (value: string) => void\n}) {\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(e)\n onValueChange?.(e.target.value)\n },\n [onChange, onValueChange],\n )\n return (\n <input\n data-slot=\"input\"\n className={cn(\n 'flex h-9 w-full px-3 py-1',\n 'border-border-weak shadow-input rounded-md border',\n 'caret-primary bg-transparent text-sm',\n 'transition-[color,border,box-shadow] outline-none',\n 'placeholder:text-text-positive-muted',\n 'hover:border-border',\n 'disabled:pointer-events-none',\n 'disabled:cursor-not-allowed',\n 'disabled:opacity-50',\n 'focus-visible:ring-4',\n 'focus-visible:ring-primary-weak',\n 'focus-visible:border-primary-strong',\n 'aria-invalid:ring-danger-muted',\n 'aria-invalid:border-danger',\n className,\n )}\n {...props}\n onChange={handleChange}\n />\n )\n}\n\nexport { Input }\n"],"mappings":"uKAIA,SAAS,EAAM,CACb,YACA,WACA,gBACA,GAAG,GAGF,CACD,IAAM,GAAA,EAAA,EAAA,aACH,GAA2C,CAC1C,IAAW,GACX,IAAgB,EAAE,OAAO,QAE3B,CAAC,EAAU,IAEb,OACE,EAAA,EAAA,KAAC,QAAA,CACC,YAAU,QACV,WAAA,EAAA,EAAA,IACE,4BACA,oDACA,uCACA,oDACA,uCACA,sBACA,+BACA,8BACA,sBACA,uBACA,kCACA,sCACA,iCACA,6BACA,GAEF,GAAI,EACJ,SAAU"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
const e=require(`./chunk-CUT6urMc.cjs`),t=e.__toESM(require(`@customafk/react-toolkit/utils`)),n=e.__toESM(require(`radix-ui`)),r=e.__toESM(require(`react/jsx-runtime`));function i({className:e,...i}){return(0,r.jsx)(n.Label.Root,{"data-slot":`label`,className:(0,t.cn)(`text-text-positive`,`flex items-center gap-2`,`text-sm leading-none font-medium select-none`,`group-data-[disabled=true]:pointer-events-none`,`group-data-[disabled=true]:opacity-50`,`peer-disabled:cursor-not-allowed`,`peer-disabled:opacity-50`,e),...i})}Object.defineProperty(exports,`Label`,{enumerable:!0,get:function(){return i}});
|
|
2
|
-
//# sourceMappingURL=label-
|
|
2
|
+
//# sourceMappingURL=label-BZqk7MPJ.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"label-
|
|
1
|
+
{"version":3,"file":"label-BZqk7MPJ.cjs","names":["LabelPrimitive"],"sources":["../packages/components/ui/label.tsx"],"sourcesContent":["'use client'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nimport { Label as LabelPrimitive } from 'radix-ui'\n\nfunction Label({ className, ...props }: React.ComponentProps<typeof LabelPrimitive.Root>) {\n return (\n <LabelPrimitive.Root\n data-slot=\"label\"\n className={cn(\n 'text-text-positive',\n 'flex items-center gap-2',\n 'text-sm leading-none font-medium select-none',\n 'group-data-[disabled=true]:pointer-events-none',\n 'group-data-[disabled=true]:opacity-50',\n 'peer-disabled:cursor-not-allowed',\n 'peer-disabled:opacity-50',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport { Label }\n"],"mappings":"0KAKA,SAAS,EAAM,CAAE,YAAW,GAAG,GAA2D,CACxF,OACE,EAAA,EAAA,KAACA,EAAAA,MAAe,KAAA,CACd,YAAU,QACV,WAAA,EAAA,EAAA,IACE,qBACA,0BACA,+CACA,iDACA,wCACA,mCACA,2BACA,GAEF,GAAI"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import{cn as e}from"@customafk/react-toolkit/utils";import{Label as t}from"radix-ui";import{jsx as n}from"react/jsx-runtime";function r({className:r,...i}){return n(t.Root,{"data-slot":`label`,className:e(`text-text-positive`,`flex items-center gap-2`,`text-sm leading-none font-medium select-none`,`group-data-[disabled=true]:pointer-events-none`,`group-data-[disabled=true]:opacity-50`,`peer-disabled:cursor-not-allowed`,`peer-disabled:opacity-50`,r),...i})}export{r as Label};
|
|
2
|
-
//# sourceMappingURL=label-
|
|
2
|
+
//# sourceMappingURL=label-HVpeECNr.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"label-
|
|
1
|
+
{"version":3,"file":"label-HVpeECNr.js","names":["Label","LabelPrimitive"],"sources":["../packages/components/ui/label.tsx"],"sourcesContent":["'use client'\nimport { cn } from '@customafk/react-toolkit/utils'\n\nimport { Label as LabelPrimitive } from 'radix-ui'\n\nfunction Label({ className, ...props }: React.ComponentProps<typeof LabelPrimitive.Root>) {\n return (\n <LabelPrimitive.Root\n data-slot=\"label\"\n className={cn(\n 'text-text-positive',\n 'flex items-center gap-2',\n 'text-sm leading-none font-medium select-none',\n 'group-data-[disabled=true]:pointer-events-none',\n 'group-data-[disabled=true]:opacity-50',\n 'peer-disabled:cursor-not-allowed',\n 'peer-disabled:opacity-50',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport { Label }\n"],"mappings":"6HAKA,SAASA,EAAM,CAAE,YAAW,GAAG,GAA2D,CACxF,OACE,EAACC,EAAe,KAAA,CACd,YAAU,QACV,UAAW,EACT,qBACA,0BACA,+CACA,iDACA,wCACA,mCACA,2BACA,GAEF,GAAI"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Button } from "../../button-
|
|
2
|
-
import { Separator } from "../../separator-
|
|
3
|
-
import { TooltipContent } from "../../tooltip-
|
|
4
|
-
import * as
|
|
5
|
-
import * as
|
|
1
|
+
import { Button } from "../../button-st5plaQt.cjs";
|
|
2
|
+
import { Separator } from "../../separator-B-TIckT4.cjs";
|
|
3
|
+
import { TooltipContent } from "../../tooltip-C0_WxGo5.cjs";
|
|
4
|
+
import * as react_jsx_runtime281 from "react/jsx-runtime";
|
|
5
|
+
import * as class_variance_authority_types8 from "class-variance-authority/types";
|
|
6
6
|
import { VariantProps } from "class-variance-authority";
|
|
7
7
|
|
|
8
8
|
//#region packages/components/layouts/app-layout/sidebar.d.ts
|
|
@@ -28,7 +28,7 @@ declare function SidebarProvider({
|
|
|
28
28
|
defaultOpen?: boolean;
|
|
29
29
|
open?: boolean;
|
|
30
30
|
onOpenChange?: (open: boolean) => void;
|
|
31
|
-
}):
|
|
31
|
+
}): react_jsx_runtime281.JSX.Element;
|
|
32
32
|
declare function Sidebar({
|
|
33
33
|
side,
|
|
34
34
|
variant,
|
|
@@ -40,71 +40,71 @@ declare function Sidebar({
|
|
|
40
40
|
side?: 'left' | 'right';
|
|
41
41
|
variant?: 'sidebar' | 'floating' | 'inset';
|
|
42
42
|
collapsible?: 'offcanvas' | 'icon' | 'none';
|
|
43
|
-
}):
|
|
43
|
+
}): react_jsx_runtime281.JSX.Element;
|
|
44
44
|
declare function AppLayoutSidebarTrigger({
|
|
45
45
|
className,
|
|
46
46
|
onClick,
|
|
47
47
|
...props
|
|
48
|
-
}: React.ComponentProps<typeof Button>):
|
|
48
|
+
}: React.ComponentProps<typeof Button>): react_jsx_runtime281.JSX.Element;
|
|
49
49
|
declare function AppLayoutSidebarRail({
|
|
50
50
|
className,
|
|
51
51
|
...props
|
|
52
|
-
}: React.ComponentProps<'button'>):
|
|
52
|
+
}: React.ComponentProps<'button'>): react_jsx_runtime281.JSX.Element;
|
|
53
53
|
declare function AppLayoutSidebarInset({
|
|
54
54
|
className,
|
|
55
55
|
children,
|
|
56
56
|
...props
|
|
57
|
-
}: React.ComponentProps<'main'>):
|
|
57
|
+
}: React.ComponentProps<'main'>): react_jsx_runtime281.JSX.Element;
|
|
58
58
|
declare function AppLayoutSidebarHeader({
|
|
59
59
|
className,
|
|
60
60
|
...props
|
|
61
|
-
}: React.ComponentProps<'div'>):
|
|
61
|
+
}: React.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
|
|
62
62
|
declare function AppLayoutSidebarFooter({
|
|
63
63
|
className,
|
|
64
64
|
...props
|
|
65
|
-
}: React.ComponentProps<'div'>):
|
|
65
|
+
}: React.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
|
|
66
66
|
declare function AppLayoutSidebarSeparator({
|
|
67
67
|
className,
|
|
68
68
|
...props
|
|
69
|
-
}: React.ComponentProps<typeof Separator>):
|
|
69
|
+
}: React.ComponentProps<typeof Separator>): react_jsx_runtime281.JSX.Element;
|
|
70
70
|
declare function AppLayoutSidebarContent({
|
|
71
71
|
className,
|
|
72
72
|
...props
|
|
73
|
-
}: React.ComponentProps<'div'>):
|
|
73
|
+
}: React.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
|
|
74
74
|
declare function AppLayoutSidebarGroup({
|
|
75
75
|
className,
|
|
76
76
|
...props
|
|
77
|
-
}: React.ComponentProps<'div'>):
|
|
77
|
+
}: React.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
|
|
78
78
|
declare function AppLayoutSidebarGroupLabel({
|
|
79
79
|
className,
|
|
80
80
|
asChild,
|
|
81
81
|
...props
|
|
82
82
|
}: React.ComponentProps<'div'> & {
|
|
83
83
|
asChild?: boolean;
|
|
84
|
-
}):
|
|
84
|
+
}): react_jsx_runtime281.JSX.Element;
|
|
85
85
|
declare function AppLayoutSidebarGroupAction({
|
|
86
86
|
className,
|
|
87
87
|
asChild,
|
|
88
88
|
...props
|
|
89
89
|
}: React.ComponentProps<'button'> & {
|
|
90
90
|
asChild?: boolean;
|
|
91
|
-
}):
|
|
91
|
+
}): react_jsx_runtime281.JSX.Element;
|
|
92
92
|
declare function AppLayoutSidebarGroupContent({
|
|
93
93
|
className,
|
|
94
94
|
...props
|
|
95
|
-
}: React.ComponentProps<'div'>):
|
|
95
|
+
}: React.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
|
|
96
96
|
declare function AppLayoutSidebarMenu({
|
|
97
97
|
className,
|
|
98
98
|
...props
|
|
99
|
-
}: React.ComponentProps<'ul'>):
|
|
99
|
+
}: React.ComponentProps<'ul'>): react_jsx_runtime281.JSX.Element;
|
|
100
100
|
declare function AppLayoutSidebarMenuItem({
|
|
101
101
|
className,
|
|
102
102
|
...props
|
|
103
|
-
}: React.ComponentProps<'li'>):
|
|
103
|
+
}: React.ComponentProps<'li'>): react_jsx_runtime281.JSX.Element;
|
|
104
104
|
declare const sidebarMenuButtonVariants: (props?: ({
|
|
105
105
|
variant?: "default" | "outline" | null | undefined;
|
|
106
106
|
size?: "sm" | "lg" | "default" | null | undefined;
|
|
107
|
-
} &
|
|
107
|
+
} & class_variance_authority_types8.ClassProp) | undefined) => string;
|
|
108
108
|
declare function AppLayoutSidebarMenuButton({
|
|
109
109
|
asChild,
|
|
110
110
|
isActive,
|
|
@@ -117,7 +117,7 @@ declare function AppLayoutSidebarMenuButton({
|
|
|
117
117
|
asChild?: boolean;
|
|
118
118
|
isActive?: boolean;
|
|
119
119
|
tooltip?: string | React.ComponentProps<typeof TooltipContent>;
|
|
120
|
-
} & VariantProps<typeof sidebarMenuButtonVariants>):
|
|
120
|
+
} & VariantProps<typeof sidebarMenuButtonVariants>): react_jsx_runtime281.JSX.Element;
|
|
121
121
|
declare function AppLayoutSidebarMenuAction({
|
|
122
122
|
className,
|
|
123
123
|
asChild,
|
|
@@ -126,26 +126,26 @@ declare function AppLayoutSidebarMenuAction({
|
|
|
126
126
|
}: React.ComponentProps<'button'> & {
|
|
127
127
|
asChild?: boolean;
|
|
128
128
|
showOnHover?: boolean;
|
|
129
|
-
}):
|
|
129
|
+
}): react_jsx_runtime281.JSX.Element;
|
|
130
130
|
declare function AppLayoutSidebarMenuBadge({
|
|
131
131
|
className,
|
|
132
132
|
...props
|
|
133
|
-
}: React.ComponentProps<'div'>):
|
|
133
|
+
}: React.ComponentProps<'div'>): react_jsx_runtime281.JSX.Element;
|
|
134
134
|
declare function AppLayoutSidebarMenuSkeleton({
|
|
135
135
|
className,
|
|
136
136
|
showIcon,
|
|
137
137
|
...props
|
|
138
138
|
}: React.ComponentProps<'div'> & {
|
|
139
139
|
showIcon?: boolean;
|
|
140
|
-
}):
|
|
140
|
+
}): react_jsx_runtime281.JSX.Element;
|
|
141
141
|
declare function AppLayoutSidebarMenuSub({
|
|
142
142
|
className,
|
|
143
143
|
...props
|
|
144
|
-
}: React.ComponentProps<'ul'>):
|
|
144
|
+
}: React.ComponentProps<'ul'>): react_jsx_runtime281.JSX.Element;
|
|
145
145
|
declare function AppLayoutSidebarMenuSubItem({
|
|
146
146
|
className,
|
|
147
147
|
...props
|
|
148
|
-
}: React.ComponentProps<'li'>):
|
|
148
|
+
}: React.ComponentProps<'li'>): react_jsx_runtime281.JSX.Element;
|
|
149
149
|
declare function AppLayoutSidebarMenuSubButton({
|
|
150
150
|
asChild,
|
|
151
151
|
size,
|
|
@@ -156,7 +156,7 @@ declare function AppLayoutSidebarMenuSubButton({
|
|
|
156
156
|
asChild?: boolean;
|
|
157
157
|
size?: 'sm' | 'md';
|
|
158
158
|
isActive?: boolean;
|
|
159
|
-
}):
|
|
159
|
+
}): react_jsx_runtime281.JSX.Element;
|
|
160
160
|
//#endregion
|
|
161
161
|
//#region packages/components/layouts/app-layout/index.d.ts
|
|
162
162
|
declare const AppLayoutWrapper: React.FC<React.PropsWithChildren>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Button } from "../../button-
|
|
2
|
-
import { Separator } from "../../separator-
|
|
3
|
-
import { TooltipContent } from "../../tooltip-
|
|
1
|
+
import { Button } from "../../button-DUWg-QPz.js";
|
|
2
|
+
import { Separator } from "../../separator-CO0oTpOK.js";
|
|
3
|
+
import { TooltipContent } from "../../tooltip-BURz5fQL.js";
|
|
4
4
|
import { VariantProps } from "class-variance-authority";
|
|
5
5
|
import * as react_jsx_runtime259 from "react/jsx-runtime";
|
|
6
6
|
import * as class_variance_authority_types7 from "class-variance-authority/types";
|
package/dist/layouts/flex.d.cts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import * as
|
|
2
|
-
import * as
|
|
1
|
+
import * as react_jsx_runtime26 from "react/jsx-runtime";
|
|
2
|
+
import * as class_variance_authority_types0 from "class-variance-authority/types";
|
|
3
3
|
import { VariantProps } from "class-variance-authority";
|
|
4
4
|
|
|
5
5
|
//#region packages/components/layouts/flex.d.ts
|
|
@@ -12,7 +12,7 @@ declare const flexVariants: (props?: ({
|
|
|
12
12
|
gap?: "xs" | "sm" | "md" | "lg" | "xl" | "none" | null | undefined;
|
|
13
13
|
justify?: "start" | "center" | "end" | "between" | "around" | "evenly" | "stretch" | null | undefined;
|
|
14
14
|
align?: "start" | "center" | "end" | "stretch" | "baseline" | null | undefined;
|
|
15
|
-
} &
|
|
15
|
+
} & class_variance_authority_types0.ClassProp) | undefined) => string;
|
|
16
16
|
type Props = {
|
|
17
17
|
className?: string;
|
|
18
18
|
} & VariantProps<typeof flexVariants>;
|
|
@@ -27,7 +27,7 @@ declare const Flex: ({
|
|
|
27
27
|
align,
|
|
28
28
|
className,
|
|
29
29
|
children
|
|
30
|
-
}: React.PropsWithChildren<Props>) =>
|
|
30
|
+
}: React.PropsWithChildren<Props>) => react_jsx_runtime26.JSX.Element;
|
|
31
31
|
//#endregion
|
|
32
32
|
export { Flex };
|
|
33
33
|
//# sourceMappingURL=flex.d.cts.map
|
package/dist/layouts/flex.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { VariantProps } from "class-variance-authority";
|
|
2
|
-
import * as
|
|
2
|
+
import * as react_jsx_runtime11 from "react/jsx-runtime";
|
|
3
3
|
import * as class_variance_authority_types0 from "class-variance-authority/types";
|
|
4
4
|
|
|
5
5
|
//#region packages/components/layouts/flex.d.ts
|
|
@@ -27,7 +27,7 @@ declare const Flex: ({
|
|
|
27
27
|
align,
|
|
28
28
|
className,
|
|
29
29
|
children
|
|
30
|
-
}: React.PropsWithChildren<Props>) =>
|
|
30
|
+
}: React.PropsWithChildren<Props>) => react_jsx_runtime11.JSX.Element;
|
|
31
31
|
//#endregion
|
|
32
32
|
export { Flex };
|
|
33
33
|
//# sourceMappingURL=flex.d.ts.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../chunk-CUT6urMc.cjs`),t=require(`../../button-119IIVCy.cjs`),n=require(`../../card-RJvu27Ck.cjs`);require(`../../skeleton-CmGSyYRm.cjs`);const r=require(`../../image-Cm4vJeHx.cjs`),i=require(`../../tooltip-CQ8hkJ42.cjs`),a=require(`../../dialog-CGrbU7PO.cjs`),o=require(`../../drawer-Dh9uXVnU.cjs`),s=require(`../../input-ERPHY3v4.cjs`),c=require(`../../dropdown-menu-BtNJk8EZ.cjs`),l=require(`../../scroll-area-qPdEy4lg.cjs`),u=require(`../../avatar-BaNIRUku.cjs`),d=require(`../../separator-JGL-8B0V.cjs`),f=require(`../../sheet-slcLNlWv.cjs`),p=require(`../../tabs-BYS9bv-R.cjs`),m=e.__toESM(require(`lucide-react`)),h=e.__toESM(require(`@customafk/react-toolkit/utils`)),g=e.__toESM(require(`class-variance-authority`)),_=e.__toESM(require(`radix-ui`)),v=e.__toESM(require(`react/jsx-runtime`)),y=e.__toESM(require(`react`)),b=e.__toESM(require(`@customafk/react-toolkit/hooks/useMediaQuery`)),x=e.__toESM(require(`@react-oauth/google`)),S=e.__toESM(require(`@customafk/react-toolkit/hooks/useMobile`)),C=e.__toESM(require(`@customafk/react-toolkit/hooks/useDebounceCallback`)),w=(0,y.createContext)(null),T=()=>{let e=(0,y.useContext)(w);if(!e)throw Error(`useServiceLayoutContext must be used within a ServiceLayoutProvider`);return e},E=({type:e,productUuid:i,variantUuid:a,productName:o,variantName:c,imageUrl:l,optionValue:u,optionTitle:d,quantity:f,price:p})=>{let{onDeletingCart:h,onUpdatingCart:g}=T(),[_,b]=(0,y.useState)(f),[x,S]=(0,y.useState)(!1),w=(0,y.useCallback)(()=>{g?.(a,_,e)},[g,a,_,e]),E=(0,C.useDebounceCallback)(w,500),D=(0,y.useCallback)(e=>{e<1&&(e=1),e>99&&(e=99),b(e)},[]),O=(0,y.useCallback)(async()=>{S(!0),await h?.(i),S(!1)},[i,h]);return(0,y.useEffect)(()=>(_!==f&&E(),()=>{E.cancel()}),[_,f,E]),(0,v.jsxs)(n.Card,{className:`border-border-weak relative mb-3 overflow-x-auto border p-4 shadow-none`,children:[x&&(0,v.jsx)(`div`,{className:`bg-muted-muted/80 absolute inset-0 z-10 flex items-center justify-center`,children:(0,v.jsx)(`div`,{className:`loader-dots`})}),(0,v.jsxs)(n.CardContent,{className:`p-0`,children:[(0,v.jsxs)(t.Button,{variant:`ghost`,size:`icon`,color:`muted`,disabled:x,className:`text-text-positive-weak absolute top-2 right-2 z-10`,onClick:O,children:[(0,v.jsx)(m.Trash2,{className:`h-4 w-4`}),(0,v.jsx)(`span`,{className:`sr-only`,children:`Remove item`})]}),(0,v.jsxs)(`div`,{className:`flex gap-3`,children:[(0,v.jsx)(`div`,{className:`relative size-20 flex-shrink-0`,children:l?(0,v.jsx)(r.Image,{src:l,alt:o,className:`rounded-md border-none shadow-xs`,width:80,height:80}):(0,v.jsx)(`div`,{className:`bg-muted text-muted-foreground flex size-full items-center justify-center text-xs`,children:`No image`})}),(0,v.jsxs)(`div`,{className:`flex flex-1 flex-col`,children:[(0,v.jsx)(`div`,{className:`flex justify-between`,children:(0,v.jsx)(`h3`,{className:`text-text-positive line-clamp-1 text-sm font-medium`,children:o})}),(0,v.jsxs)(`p`,{className:`text-text-positive-weak mb-1 text-xs`,children:[c,d&&` - ${d}: ${u}`]}),(0,v.jsxs)(`div`,{className:`mt-auto flex items-center justify-between`,children:[(0,v.jsxs)(`div`,{className:`flex items-center space-x-1`,children:[(0,v.jsx)(`button`,{disabled:_<=1,className:`border-border active:bg-muted-muted flex size-6 cursor-pointer items-center justify-center rounded-full border transition-all disabled:opacity-60`,onClick:()=>D(_-1),children:(0,v.jsx)(m.Minus,{size:12})}),(0,v.jsx)(s.Input,{value:_,onChange:e=>D(parseInt(e.target.value||`1`)),className:`border-border h-6.5 w-14 rounded-md border p-1 text-center text-sm`,min:1}),(0,v.jsx)(`button`,{disabled:_>=99,className:`border-border active:bg-muted-muted flex size-6 cursor-pointer items-center justify-center rounded-full border transition-all disabled:opacity-60`,onClick:()=>D(_+1),children:(0,v.jsx)(m.Plus,{size:12})})]}),(0,v.jsxs)(`div`,{className:`text-sm font-semibold`,children:[(p*_).toLocaleString(),` ₫`]})]})]})]})]})]})},D=({items:e=[],cartType:n,className:r})=>{let i=e.reduce((e,t)=>e+t.price*t.quantity,0);return e.length===0?(0,v.jsxs)(`div`,{className:(0,h.cn)(`bg-muted-muted flex size-full max-h-80 flex-col items-center justify-center rounded-lg p-8`,r),children:[(0,v.jsx)(`div`,{className:`text-text-positive-weak bg-card shadow-card mb-4 flex size-20 items-center justify-center rounded-full text-5xl`,children:(0,v.jsx)(m.ShoppingBasketIcon,{size:42,strokeWidth:1})}),(0,v.jsxs)(`div`,{className:`flex flex-col space-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive text-center text-base font-semibold`,children:`Giỏ hàng trống`}),(0,v.jsx)(`p`,{className:`text-text-positive-weak mb-4 text-center text-sm`,children:n===`in_stock`?`Thêm sản phẩm có sẵn vào giỏ hàng của bạn!`:`Thêm sản phẩm đặt trước vào giỏ hàng của bạn!`})]})]}):(0,v.jsxs)(`div`,{className:(0,h.cn)(`flex h-full flex-col space-y-4 overflow-y-auto`,r),children:[(0,v.jsx)(l.ScrollArea,{className:`h-full flex-1`,children:e.map(e=>(0,v.jsx)(E,{...e,type:n},`${e.productUuid}-${e.variantUuid}`))}),(0,v.jsxs)(`div`,{className:`flex-0 space-y-3`,children:[(0,v.jsxs)(`div`,{className:`flex justify-between`,children:[(0,v.jsx)(`span`,{className:`text-text-positive-weak text-sm`,children:`Tạm tính:`}),(0,v.jsxs)(`span`,{className:`text-sm`,children:[i.toLocaleString(),` ₫`]})]}),(0,v.jsx)(d.Separator,{}),(0,v.jsxs)(`div`,{className:`flex justify-between`,children:[(0,v.jsx)(`span`,{className:`text-text-positive font-medium`,children:`Tổng cộng:`}),(0,v.jsxs)(`span`,{className:`text-lg font-semibold`,children:[i.toLocaleString(),` ₫`]})]}),(0,v.jsx)(t.Button,{className:`mt-2 w-full`,children:`Thanh toán ngay`}),n===`pre_order`&&(0,v.jsx)(`p`,{className:`text-text-positive-weak text-center text-xs italic`,children:`* Sản phẩm đặt trước sẽ được giao sau khi có hàng`})]})]})},O=(0,y.createContext)(null),k=()=>{let e=(0,y.useContext)(O);if(!e)throw Error(`useSidebar must be used within a SidebarProvider.`);return e},ee=`sidebar_state`,te=3600*24*7,ne=`16rem`,re=`16rem`,ie=`3rem`,ae=`b`;function A({defaultOpen:e=!0,open:t,onOpenChange:n,className:r,style:a,children:o,...s}){let c=(0,S.useIsMobile)(),[l,u]=(0,y.useState)(!1),[d,f]=(0,y.useState)(e),p=t??d,m=(0,y.useCallback)(e=>{let t=typeof e==`function`?e(p):e;n?n(t):f(t),document.cookie=`sidebar_state=${t}; path=/; max-age=604800`},[n,p]),g=(0,y.useCallback)(()=>c?u(e=>!e):m(e=>!e),[c,m,u]);(0,y.useEffect)(()=>{let e=e=>{e.key===`b`&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),g())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[g]);let _=p?`expanded`:`collapsed`,b=(0,y.useMemo)(()=>({state:_,isMobile:c,toggleSidebar:g,open:p,setOpen:m,openMobile:l,setOpenMobile:u}),[_,p,m,c,l,u,g]);return(0,v.jsx)(O.Provider,{value:b,children:(0,v.jsx)(i.TooltipProvider,{delayDuration:0,children:(0,v.jsx)(`div`,{"data-slot":`sidebar-wrapper`,style:{"--sidebar-width":`16rem`,"--sidebar-width-icon":`3rem`,...a},className:(0,h.cn)(`group/sidebar-wrapper`,`has-data-[variant=inset]:bg-sidebar`,`flex h-svh w-full`,r),...s,children:o})})})}function j({side:e=`left`,variant:t=`sidebar`,collapsible:n=`offcanvas`,className:r,children:i,...a}){let{isMobile:o,state:s,openMobile:c,setOpenMobile:l}=k();return n===`none`?(0,v.jsx)(`aside`,{"data-slot":`sidebar`,className:(0,h.cn)(`bg-sidebar`,`text-sidebar-foreground`,`flex h-full w-(--sidebar-width) flex-col`,r),...a,children:i}):o?(0,v.jsx)(f.Sheet,{open:c,onOpenChange:l,...a,children:(0,v.jsxs)(f.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,v.jsxs)(f.SheetHeader,{className:`sr-only`,children:[(0,v.jsx)(f.SheetTitle,{children:`Sidebar`}),(0,v.jsx)(f.SheetDescription,{children:`Displays the mobile sidebar.`})]}),(0,v.jsxs)(`div`,{className:`flex size-full flex-col`,children:[(0,v.jsxs)(`div`,{className:`border-border-weak flex items-center gap-x-2 border-b p-2 pr-4`,children:[(0,v.jsx)(M,{}),(0,v.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,v.jsx)(m.ShoppingCartIcon,{size:20})}),(0,v.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,v.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,v.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),i]})]})}):(0,v.jsxs)(`aside`,{className:`group peer text-sidebar-foreground bg-card hidden md:block`,"data-state":s,"data-collapsible":s===`collapsed`?n:``,"data-variant":t,"data-side":e,"data-slot":`sidebar`,children:[(0,v.jsx)(`div`,{"data-slot":`sidebar-gap`,className:(0,h.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,v.jsx)(`div`,{"data-slot":`sidebar-container`,className:(0,h.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),...a,children:(0,v.jsx)(`div`,{"data-sidebar":`sidebar`,"data-slot":`sidebar-inner`,className:(0,h.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 M({className:e,onClick:n,...r}){let{toggleSidebar:i}=k();return(0,v.jsxs)(t.Button,{"data-sidebar":`trigger`,"data-slot":`sidebar-trigger`,variant:`ghost`,color:`muted`,size:`icon`,className:(0,h.cn)(`size-10 rounded-full`,e),onClick:e=>{n?.(e),i()},...r,children:[(0,v.jsx)(m.MenuIcon,{className:`!size-6`}),(0,v.jsx)(`span`,{className:`sr-only`,children:`Toggle Sidebar`})]})}function N({className:e,children:t,...n}){return(0,v.jsxs)(`main`,{"data-slot":`sidebar-inset`,className:(0,h.cn)(`relative flex w-full flex-1 flex-col`,e),...n,children:[(0,v.jsx)(`div`,{className:`h-(--header-height) w-full sm:h-[calc(var(--header-height)_+_0.5rem)]`}),(0,v.jsx)(`div`,{className:(0,h.cn)(`flex-1 inset-shadow-sm`),children:t})]})}function P({className:e,children:t,...n}){let{open:r}=k();return(0,v.jsxs)(`div`,{"data-slot":`sidebar-footer`,"data-sidebar":`footer`,className:(0,h.cn)(`flex flex-col gap-2 p-2`,e),...n,children:[t,r&&(0,v.jsx)(z,{children:(0,v.jsx)(B,{children:(0,v.jsx)(`p`,{className:`text-muted-foreground text-center text-xs`,children:`Copyright © 2025, Lunas.`})})})]})}function F({className:e,...t}){return(0,v.jsx)(`div`,{"data-slot":`sidebar-content`,"data-sidebar":`content`,className:(0,h.cn)(`flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden`,e),...t})}function I({className:e,...t}){return(0,v.jsx)(`div`,{"data-slot":`sidebar-group`,"data-sidebar":`group`,className:(0,h.cn)(`relative flex w-full min-w-0 flex-col`,e),...t})}function L({className:e,asChild:t=!1,...n}){let r=t?_.Slot.Slot:`div`;return(0,v.jsx)(r,{"data-slot":`sidebar-group-label`,"data-sidebar":`group-label`,className:(0,h.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 R({className:e,...t}){return(0,v.jsx)(`div`,{"data-slot":`sidebar-group-content`,"data-sidebar":`group-content`,className:(0,h.cn)(`w-full text-sm`,e),...t})}function z({className:e,...t}){return(0,v.jsx)(`ul`,{"data-slot":`sidebar-menu`,"data-sidebar":`menu`,className:(0,h.cn)(`flex w-full min-w-0 flex-col gap-1`,e),...t})}function B({className:e,...t}){return(0,v.jsx)(`li`,{"data-slot":`sidebar-menu-item`,"data-sidebar":`menu-item`,className:(0,h.cn)(`group/menu-item relative`,e),...t})}const V=(0,g.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-12!.group-data-[collapsible=icon]:p-3!.group-data-[collapsible=icon]:gap-3!.[&>svg]:size-6.[&>svg]:shrink-0.[&>span:last-child]:truncate`.split(`.`),{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-10 text-sm`,sm:`h-7 text-xs`,lg:`h-12 text-sm group-data-[collapsible=icon]:p-0!`}},defaultVariants:{variant:`default`,size:`default`}});function H({asChild:e=!1,isActive:t=!1,variant:n=`default`,size:r=`default`,tooltip:a,className:o,...s}){let c=e?_.Slot.Slot:`button`,{isMobile:l,state:u}=k(),d=(0,v.jsx)(c,{"data-slot":`sidebar-menu-button`,"data-sidebar":`menu-button`,"data-size":r,"data-active":t,className:(0,h.cn)(V({variant:n,size:r}),o),...s});return a?(typeof a==`string`&&(a={children:a}),(0,v.jsxs)(i.Tooltip,{children:[(0,v.jsx)(i.TooltipTrigger,{asChild:!0,children:d}),(0,v.jsx)(i.TooltipContent,{side:`right`,align:`center`,hidden:u!==`collapsed`||l,...a})]})):d}const U=({isLoggedIn:e=!1,username:t,email:n,inStockCarts:r,orderedCarts:i,onGoogleLoginSuccess:a,onUpdatingCart:o,onDeletingCart:s,onLogout:c,children:l})=>(0,v.jsx)(w.Provider,{value:{isLoggedIn:e,username:t,email:n,inStockCarts:r,orderedCarts:i,onGoogleLoginSuccess:a,onUpdatingCart:o,onDeletingCart:s,onLogout:c},children:l}),W=({children:e})=>(0,v.jsx)(A,{children:e}),G=({userName:e=`Keith Kennedy`,userEmail:n=`k.kennedy@originui.com`,onLogout:r})=>(0,v.jsxs)(c.DropdownMenu,{children:[(0,v.jsx)(c.DropdownMenuTrigger,{asChild:!0,children:(0,v.jsx)(t.Button,{size:`icon`,variant:`ghost`,color:`secondary`,className:`size-10 rounded-full`,children:(0,v.jsxs)(u.Avatar,{className:`size-10`,children:[(0,v.jsx)(u.AvatarImage,{src:``,alt:``}),(0,v.jsx)(u.AvatarFallback,{className:`bg-muted-muted size-full`,children:(0,v.jsx)(m.UserIcon,{})})]})})}),(0,v.jsxs)(c.DropdownMenuContent,{align:`end`,className:`max-w-64`,children:[(0,v.jsxs)(c.DropdownMenuLabel,{className:`flex min-w-0 flex-col`,children:[(0,v.jsx)(`span`,{className:`text-text-positive truncate text-sm font-medium`,children:e}),(0,v.jsx)(`span`,{className:`text-text-positive-weak truncate text-xs font-normal`,children:n})]}),(0,v.jsx)(c.DropdownMenuSeparator,{}),(0,v.jsxs)(c.DropdownMenuItem,{onClick:r,children:[(0,v.jsx)(m.LogOutIcon,{size:16,"aria-hidden":`true`}),(0,v.jsx)(`span`,{className:`text-text-positive`,children:`Logout`})]})]})]}),K=()=>{let{inStockCarts:e=[],orderedCarts:n=[]}=T(),r=e.length,i=n.length,a=r+i;return(0,v.jsxs)(f.Sheet,{children:[(0,v.jsx)(f.SheetTrigger,{asChild:!0,children:(0,v.jsxs)(t.Button,{size:`icon`,variant:`ghost`,color:`secondary`,className:`relative size-10 rounded-full`,children:[(0,v.jsx)(m.ShoppingCartIcon,{}),a>0&&(0,v.jsx)(`span`,{className:`bg-primary text-primary-foreground absolute -top-1 -right-1 flex h-4 min-w-4 items-center justify-center rounded-full px-1 text-xs font-bold`,children:a})]})}),(0,v.jsxs)(f.SheetContent,{className:`w-[95vw] sm:max-w-md`,children:[(0,v.jsx)(f.SheetHeader,{className:`border-border-weak flex-0 border-b pb-3`,children:(0,v.jsxs)(f.SheetTitle,{className:`flex items-center gap-2`,children:[(0,v.jsx)(m.ShoppingBag,{className:`h-5 w-5`}),(0,v.jsx)(`span`,{children:`Giỏ hàng của bạn`}),a>0&&(0,v.jsxs)(`span`,{className:`text-text-positive-weak text-sm font-normal`,children:[`(`,a,` sản phẩm)`]})]})}),(0,v.jsxs)(p.Tabs,{defaultValue:i>0?`pre_order`:`in_stock`,className:`h-full flex-1 overflow-y-auto p-4 pt-0`,children:[(0,v.jsxs)(p.TabsList,{className:`w-full flex-0`,children:[(0,v.jsxs)(p.TabsTrigger,{value:`in_stock`,className:`relative`,children:[`Có sẵn`,r>0&&(0,v.jsxs)(`span`,{children:[`(`,r,`)`]})]}),(0,v.jsxs)(p.TabsTrigger,{value:`pre_order`,className:`relative`,children:[`Đặt trước`,i>0&&(0,v.jsxs)(`span`,{children:[`(`,i,`)`]})]})]}),(0,v.jsx)(p.TabsContent,{value:`pre_order`,className:`flex-1 overflow-y-auto`,children:(0,v.jsx)(D,{items:n,cartType:`pre_order`})}),(0,v.jsx)(p.TabsContent,{value:`in_stock`,className:`flex-1 overflow-y-auto`,children:(0,v.jsx)(D,{items:e,cartType:`in_stock`})})]})]})]})},q=()=>{let{isLoggedIn:e,username:n,email:r,onGoogleLoginSuccess:i,onLogout:s}=T(),c=(0,b.useMediaQuery)(`(min-width: 640px)`),[l,u]=(0,y.useState)(!1);return(0,v.jsxs)(`header`,{className:(0,h.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`),children:[e&&(0,v.jsx)(M,{}),(0,v.jsxs)(`div`,{className:`flex gap-x-2 sm:ml-2.5`,children:[(0,v.jsx)(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg`,children:(0,v.jsx)(m.ShoppingCartIcon,{size:20})}),(0,v.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,v.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,v.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),(0,v.jsxs)(`div`,{className:`flex flex-1 items-center justify-end gap-x-2`,children:[!e&&(0,v.jsxs)(t.Button,{className:`w-8 sm:w-fit`,onClick:()=>u(!0),children:[(0,v.jsx)(m.LogInIcon,{}),(0,v.jsx)(`span`,{className:`sr-only sm:not-sr-only`,children:`Đăng nhập`})]}),e&&(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)(G,{userName:n,userEmail:r,onLogout:s}),(0,v.jsx)(d.Separator,{orientation:`vertical`,className:`min-h-6 w-px`}),(0,v.jsx)(K,{})]})]}),c&&(0,v.jsx)(a.Dialog,{open:l,onOpenChange:u,children:(0,v.jsxs)(a.DialogContent,{showCloseButton:!1,className:`flex flex-col gap-0 border-none p-0 sm:max-w-sm`,children:[(0,v.jsx)(a.DialogHeader,{className:`flex-0 gap-2 p-6`,children:(0,v.jsx)(a.DialogTitle,{className:`text-center`,children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`bg-card size-full flex-1 p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,width:240,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||await i?.(e)}})]})})}),(0,v.jsx)(a.DialogFooter,{className:`p-2`})]})}),!c&&(0,v.jsx)(o.Drawer,{open:l,onOpenChange:u,children:(0,v.jsxs)(o.DrawerContent,{children:[(0,v.jsx)(o.DrawerHeader,{className:`text-left`,children:(0,v.jsx)(o.DrawerTitle,{children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`flex size-full flex-1 flex-col p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||await i?.(e)}})]})})}),(0,v.jsx)(o.DrawerFooter,{})]})})]})},J=({children:e,...t})=>{let{isLoggedIn:n}=T();return n?(0,v.jsx)(j,{variant:`inset`,collapsible:`icon`,...t,children:e}):null},Y=({children:e})=>{let{isLoggedIn:n,onGoogleLoginSuccess:r}=T(),i=(0,b.useMediaQuery)(`(min-width: 640px)`),[s,c]=(0,y.useState)(!1);return n?(0,v.jsx)(N,{children:(0,v.jsx)(`section`,{className:`relative size-full`,children:(0,v.jsx)(`div`,{className:`absolute inset-0 flex flex-col`,children:e})})}):(0,v.jsx)(`div`,{className:`size-full p-4 pt-[calc(var(--header-height)+1.5rem)]`,children:(0,v.jsxs)(`div`,{className:`bg-card shadow-card flex size-full flex-col items-center justify-center gap-6 rounded-lg p-8 text-center`,children:[(0,v.jsx)(`div`,{className:`bg-muted-foreground/10 flex size-20 items-center justify-center rounded-full`,children:(0,v.jsx)(m.LockIcon,{className:`text-primary size-10`})}),(0,v.jsxs)(`div`,{className:`flex max-w-md flex-col gap-2`,children:[(0,v.jsx)(`h2`,{className:`text-2xl font-semibold`,children:`Bạn chưa đăng nhập`}),(0,v.jsx)(`p`,{className:`text-text-positive-weak`,children:`Đăng nhập để khám phá đầy đủ các tính năng của Lunas Store và truy cập vào tài khoản của bạn.`})]}),(0,v.jsxs)(t.Button,{size:`lg`,className:`gap-2`,onClick:()=>c(!0),children:[(0,v.jsx)(m.LogInIcon,{size:18}),(0,v.jsx)(`span`,{children:`Đăng nhập ngay`})]}),i&&(0,v.jsx)(a.Dialog,{open:s,onOpenChange:c,children:(0,v.jsxs)(a.DialogContent,{showCloseButton:!1,className:`flex flex-col gap-0 border-none p-0 sm:max-w-sm`,children:[(0,v.jsx)(a.DialogHeader,{className:`flex-0 gap-2 p-6`,children:(0,v.jsx)(a.DialogTitle,{className:`text-center`,children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`bg-card size-full flex-1 p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,width:240,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||(await r?.(e),c(!1))}})]})})}),(0,v.jsx)(a.DialogFooter,{className:`p-2`})]})}),!i&&(0,v.jsx)(o.Drawer,{open:s,onOpenChange:c,children:(0,v.jsxs)(o.DrawerContent,{children:[(0,v.jsx)(o.DrawerHeader,{className:`text-left`,children:(0,v.jsx)(o.DrawerTitle,{children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`flex size-full flex-1 flex-col p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||(await r?.(e),c(!1))}})]})})}),(0,v.jsx)(o.DrawerFooter,{})]})})]})})},X=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-header`,className:(0,h.cn)(`flex-0 snap-start`,e),children:t}),Z=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-content`,className:(0,h.cn)(`flex w-full flex-1 flex-col gap-4 overflow-y-auto px-2 sm:px-4`,e),children:t}),Q=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-footer`,className:(0,h.cn)(`border-border-weak hidden w-full flex-0 border-t pt-2 sm:flex`,e),children:t}),$=({children:e,className:t})=>(0,v.jsx)(`div`,{"data-slot":`main-group`,className:(0,h.cn)(`flex size-full flex-col gap-4`,t),children:e}),oe=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-group-content`,className:(0,h.cn)(`bg-card shadow-card max-w-8xl size-full flex-1 rounded-md p-4`,e),children:t});exports.ServiceLayoutCartInfo=K,exports.ServiceLayoutHeader=q,exports.ServiceLayoutMain=Y,exports.ServiceLayoutMainContent=Z,exports.ServiceLayoutMainFooter=Q,exports.ServiceLayoutMainGroup=$,exports.ServiceLayoutMainGroupContent=oe,exports.ServiceLayoutMainHeader=X,exports.ServiceLayoutProvider=U,exports.ServiceLayoutSidebar=J,exports.ServiceLayoutSidebarContent=F,exports.ServiceLayoutSidebarFooter=P,exports.ServiceLayoutSidebarGroup=I,exports.ServiceLayoutSidebarGroupContent=R,exports.ServiceLayoutSidebarGroupLabel=L,exports.ServiceLayoutSidebarMenu=z,exports.ServiceLayoutSidebarMenuButton=H,exports.ServiceLayoutSidebarMenuItem=B,exports.ServiceLayoutUserInfo=G,exports.ServiceLayoutWrapper=W;
|
|
1
|
+
const e=require(`../../chunk-CUT6urMc.cjs`),t=require(`../../button-119IIVCy.cjs`),n=require(`../../card-RJvu27Ck.cjs`);require(`../../skeleton-CmGSyYRm.cjs`);const r=require(`../../image-Cm4vJeHx.cjs`),i=require(`../../tooltip-CQ8hkJ42.cjs`),a=require(`../../avatar-Ch6Lx2oc.cjs`),o=require(`../../dialog-wX27mb8E.cjs`),s=require(`../../drawer-sRfKhXA3.cjs`),c=require(`../../input-DgtTVBtN.cjs`),l=require(`../../dropdown-menu-SNcBwTOA.cjs`),u=require(`../../scroll-area-Dgjr1n1T.cjs`),d=require(`../../separator-JGL-8B0V.cjs`),f=require(`../../sheet-slcLNlWv.cjs`),p=require(`../../tabs-BYS9bv-R.cjs`),m=e.__toESM(require(`lucide-react`)),h=e.__toESM(require(`@customafk/react-toolkit/utils`)),g=e.__toESM(require(`class-variance-authority`)),_=e.__toESM(require(`radix-ui`)),v=e.__toESM(require(`react/jsx-runtime`)),y=e.__toESM(require(`react`)),b=e.__toESM(require(`@customafk/react-toolkit/hooks/useMediaQuery`)),x=e.__toESM(require(`@react-oauth/google`)),S=e.__toESM(require(`@customafk/react-toolkit/hooks/useMobile`)),C=e.__toESM(require(`@customafk/react-toolkit/hooks/useDebounceCallback`)),w=(0,y.createContext)(null),T=()=>{let e=(0,y.useContext)(w);if(!e)throw Error(`useServiceLayoutContext must be used within a ServiceLayoutProvider`);return e},E=({type:e,productUuid:i,variantUuid:a,productName:o,variantName:s,imageUrl:l,optionValue:u,optionTitle:d,quantity:f,price:p})=>{let{onDeletingCart:h,onUpdatingCart:g}=T(),[_,b]=(0,y.useState)(f),[x,S]=(0,y.useState)(!1),w=(0,y.useCallback)(()=>{g?.(a,_,e)},[g,a,_,e]),E=(0,C.useDebounceCallback)(w,500),D=(0,y.useCallback)(e=>{e<1&&(e=1),e>99&&(e=99),b(e)},[]),O=(0,y.useCallback)(async()=>{S(!0),await h?.(i),S(!1)},[i,h]);return(0,y.useEffect)(()=>(_!==f&&E(),()=>{E.cancel()}),[_,f,E]),(0,v.jsxs)(n.Card,{className:`border-border-weak relative mb-3 overflow-x-auto border p-4 shadow-none`,children:[x&&(0,v.jsx)(`div`,{className:`bg-muted-muted/80 absolute inset-0 z-10 flex items-center justify-center`,children:(0,v.jsx)(`div`,{className:`loader-dots`})}),(0,v.jsxs)(n.CardContent,{className:`p-0`,children:[(0,v.jsxs)(t.Button,{variant:`ghost`,size:`icon`,color:`muted`,disabled:x,className:`text-text-positive-weak absolute top-2 right-2 z-10`,onClick:O,children:[(0,v.jsx)(m.Trash2,{className:`h-4 w-4`}),(0,v.jsx)(`span`,{className:`sr-only`,children:`Remove item`})]}),(0,v.jsxs)(`div`,{className:`flex gap-3`,children:[(0,v.jsx)(`div`,{className:`relative size-20 flex-shrink-0`,children:l?(0,v.jsx)(r.Image,{src:l,alt:o,className:`rounded-md border-none shadow-xs`,width:80,height:80}):(0,v.jsx)(`div`,{className:`bg-muted text-muted-foreground flex size-full items-center justify-center text-xs`,children:`No image`})}),(0,v.jsxs)(`div`,{className:`flex flex-1 flex-col`,children:[(0,v.jsx)(`div`,{className:`flex justify-between`,children:(0,v.jsx)(`h3`,{className:`text-text-positive line-clamp-1 text-sm font-medium`,children:o})}),(0,v.jsxs)(`p`,{className:`text-text-positive-weak mb-1 text-xs`,children:[s,d&&` - ${d}: ${u}`]}),(0,v.jsxs)(`div`,{className:`mt-auto flex items-center justify-between`,children:[(0,v.jsxs)(`div`,{className:`flex items-center space-x-1`,children:[(0,v.jsx)(`button`,{disabled:_<=1,className:`border-border active:bg-muted-muted flex size-6 cursor-pointer items-center justify-center rounded-full border transition-all disabled:opacity-60`,onClick:()=>D(_-1),children:(0,v.jsx)(m.Minus,{size:12})}),(0,v.jsx)(c.Input,{value:_,onChange:e=>D(parseInt(e.target.value||`1`)),className:`border-border h-6.5 w-14 rounded-md border p-1 text-center text-sm`,min:1}),(0,v.jsx)(`button`,{disabled:_>=99,className:`border-border active:bg-muted-muted flex size-6 cursor-pointer items-center justify-center rounded-full border transition-all disabled:opacity-60`,onClick:()=>D(_+1),children:(0,v.jsx)(m.Plus,{size:12})})]}),(0,v.jsxs)(`div`,{className:`text-sm font-semibold`,children:[(p*_).toLocaleString(),` ₫`]})]})]})]})]})]})},D=({items:e=[],cartType:n,className:r})=>{let i=e.reduce((e,t)=>e+t.price*t.quantity,0);return e.length===0?(0,v.jsxs)(`div`,{className:(0,h.cn)(`bg-muted-muted flex size-full max-h-80 flex-col items-center justify-center rounded-lg p-8`,r),children:[(0,v.jsx)(`div`,{className:`text-text-positive-weak bg-card shadow-card mb-4 flex size-20 items-center justify-center rounded-full text-5xl`,children:(0,v.jsx)(m.ShoppingBasketIcon,{size:42,strokeWidth:1})}),(0,v.jsxs)(`div`,{className:`flex flex-col space-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive text-center text-base font-semibold`,children:`Giỏ hàng trống`}),(0,v.jsx)(`p`,{className:`text-text-positive-weak mb-4 text-center text-sm`,children:n===`in_stock`?`Thêm sản phẩm có sẵn vào giỏ hàng của bạn!`:`Thêm sản phẩm đặt trước vào giỏ hàng của bạn!`})]})]}):(0,v.jsxs)(`div`,{className:(0,h.cn)(`flex h-full flex-col space-y-4 overflow-y-auto`,r),children:[(0,v.jsx)(u.ScrollArea,{className:`h-full flex-1`,children:e.map(e=>(0,v.jsx)(E,{...e,type:n},`${e.productUuid}-${e.variantUuid}`))}),(0,v.jsxs)(`div`,{className:`flex-0 space-y-3`,children:[(0,v.jsxs)(`div`,{className:`flex justify-between`,children:[(0,v.jsx)(`span`,{className:`text-text-positive-weak text-sm`,children:`Tạm tính:`}),(0,v.jsxs)(`span`,{className:`text-sm`,children:[i.toLocaleString(),` ₫`]})]}),(0,v.jsx)(d.Separator,{}),(0,v.jsxs)(`div`,{className:`flex justify-between`,children:[(0,v.jsx)(`span`,{className:`text-text-positive font-medium`,children:`Tổng cộng:`}),(0,v.jsxs)(`span`,{className:`text-lg font-semibold`,children:[i.toLocaleString(),` ₫`]})]}),(0,v.jsx)(t.Button,{className:`mt-2 w-full`,children:`Thanh toán ngay`}),n===`pre_order`&&(0,v.jsx)(`p`,{className:`text-text-positive-weak text-center text-xs italic`,children:`* Sản phẩm đặt trước sẽ được giao sau khi có hàng`})]})]})},O=(0,y.createContext)(null),k=()=>{let e=(0,y.useContext)(O);if(!e)throw Error(`useSidebar must be used within a SidebarProvider.`);return e},ee=`sidebar_state`,te=3600*24*7,ne=`16rem`,re=`16rem`,ie=`3rem`,ae=`b`;function A({defaultOpen:e=!0,open:t,onOpenChange:n,className:r,style:a,children:o,...s}){let c=(0,S.useIsMobile)(),[l,u]=(0,y.useState)(!1),[d,f]=(0,y.useState)(e),p=t??d,m=(0,y.useCallback)(e=>{let t=typeof e==`function`?e(p):e;n?n(t):f(t),document.cookie=`sidebar_state=${t}; path=/; max-age=604800`},[n,p]),g=(0,y.useCallback)(()=>c?u(e=>!e):m(e=>!e),[c,m,u]);(0,y.useEffect)(()=>{let e=e=>{e.key===`b`&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),g())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[g]);let _=p?`expanded`:`collapsed`,b=(0,y.useMemo)(()=>({state:_,isMobile:c,toggleSidebar:g,open:p,setOpen:m,openMobile:l,setOpenMobile:u}),[_,p,m,c,l,u,g]);return(0,v.jsx)(O.Provider,{value:b,children:(0,v.jsx)(i.TooltipProvider,{delayDuration:0,children:(0,v.jsx)(`div`,{"data-slot":`sidebar-wrapper`,style:{"--sidebar-width":`16rem`,"--sidebar-width-icon":`3rem`,...a},className:(0,h.cn)(`group/sidebar-wrapper`,`has-data-[variant=inset]:bg-sidebar`,`flex h-svh w-full`,r),...s,children:o})})})}function j({side:e=`left`,variant:t=`sidebar`,collapsible:n=`offcanvas`,className:r,children:i,...a}){let{isMobile:o,state:s,openMobile:c,setOpenMobile:l}=k();return n===`none`?(0,v.jsx)(`aside`,{"data-slot":`sidebar`,className:(0,h.cn)(`bg-sidebar`,`text-sidebar-foreground`,`flex h-full w-(--sidebar-width) flex-col`,r),...a,children:i}):o?(0,v.jsx)(f.Sheet,{open:c,onOpenChange:l,...a,children:(0,v.jsxs)(f.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,v.jsxs)(f.SheetHeader,{className:`sr-only`,children:[(0,v.jsx)(f.SheetTitle,{children:`Sidebar`}),(0,v.jsx)(f.SheetDescription,{children:`Displays the mobile sidebar.`})]}),(0,v.jsxs)(`div`,{className:`flex size-full flex-col`,children:[(0,v.jsxs)(`div`,{className:`border-border-weak flex items-center gap-x-2 border-b p-2 pr-4`,children:[(0,v.jsx)(M,{}),(0,v.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,v.jsx)(m.ShoppingCartIcon,{size:20})}),(0,v.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,v.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,v.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),i]})]})}):(0,v.jsxs)(`aside`,{className:`group peer text-sidebar-foreground bg-card hidden md:block`,"data-state":s,"data-collapsible":s===`collapsed`?n:``,"data-variant":t,"data-side":e,"data-slot":`sidebar`,children:[(0,v.jsx)(`div`,{"data-slot":`sidebar-gap`,className:(0,h.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,v.jsx)(`div`,{"data-slot":`sidebar-container`,className:(0,h.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),...a,children:(0,v.jsx)(`div`,{"data-sidebar":`sidebar`,"data-slot":`sidebar-inner`,className:(0,h.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 M({className:e,onClick:n,...r}){let{toggleSidebar:i}=k();return(0,v.jsxs)(t.Button,{"data-sidebar":`trigger`,"data-slot":`sidebar-trigger`,variant:`ghost`,color:`muted`,size:`icon`,className:(0,h.cn)(`size-10 rounded-full`,e),onClick:e=>{n?.(e),i()},...r,children:[(0,v.jsx)(m.MenuIcon,{className:`!size-6`}),(0,v.jsx)(`span`,{className:`sr-only`,children:`Toggle Sidebar`})]})}function N({className:e,children:t,...n}){return(0,v.jsxs)(`main`,{"data-slot":`sidebar-inset`,className:(0,h.cn)(`relative flex w-full flex-1 flex-col`,e),...n,children:[(0,v.jsx)(`div`,{className:`h-(--header-height) w-full sm:h-[calc(var(--header-height)_+_0.5rem)]`}),(0,v.jsx)(`div`,{className:(0,h.cn)(`flex-1 inset-shadow-sm`),children:t})]})}function P({className:e,children:t,...n}){let{open:r}=k(),{onLogout:i}=T();return(0,v.jsxs)(`div`,{"data-slot":`sidebar-footer`,"data-sidebar":`footer`,className:(0,h.cn)(`flex flex-col gap-2`,e),...n,children:[t,(0,v.jsxs)(z,{children:[(0,v.jsx)(B,{children:(0,v.jsxs)(H,{className:`border-border border`,onClick:i,children:[(0,v.jsx)(m.LogOutIcon,{className:`text-text-positive-weak`}),`Đăng xuất`]})}),r&&(0,v.jsx)(B,{className:`border-t-border mt-2 border-t`,children:(0,v.jsx)(`p`,{className:`text-muted-foreground pt-2 text-center text-xs`,children:`Copyright © 2025, Lunas.`})})]})]})}function F({className:e,...t}){return(0,v.jsx)(`div`,{"data-slot":`sidebar-content`,"data-sidebar":`content`,className:(0,h.cn)(`flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden`,e),...t})}function I({className:e,...t}){return(0,v.jsx)(`div`,{"data-slot":`sidebar-group`,"data-sidebar":`group`,className:(0,h.cn)(`relative flex w-full min-w-0 flex-col`,e),...t})}function L({className:e,asChild:t=!1,...n}){let r=t?_.Slot.Slot:`div`;return(0,v.jsx)(r,{"data-slot":`sidebar-group-label`,"data-sidebar":`group-label`,className:(0,h.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 R({className:e,...t}){return(0,v.jsx)(`div`,{"data-slot":`sidebar-group-content`,"data-sidebar":`group-content`,className:(0,h.cn)(`w-full text-sm`,e),...t})}function z({className:e,...t}){return(0,v.jsx)(`ul`,{"data-slot":`sidebar-menu`,"data-sidebar":`menu`,className:(0,h.cn)(`flex w-full min-w-0 flex-col gap-1`,e),...t})}function B({className:e,...t}){return(0,v.jsx)(`li`,{"data-slot":`sidebar-menu-item`,"data-sidebar":`menu-item`,className:(0,h.cn)(`group/menu-item relative`,e),...t})}const V=(0,g.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-12!.group-data-[collapsible=icon]:p-3!.group-data-[collapsible=icon]:gap-3!.[&>svg]:size-6.[&>svg]:shrink-0.[&>span:last-child]:truncate`.split(`.`),{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-10 text-sm`,sm:`h-7 text-xs`,lg:`h-12 text-sm group-data-[collapsible=icon]:p-0!`}},defaultVariants:{variant:`default`,size:`default`}});function H({asChild:e=!1,isActive:t=!1,variant:n=`default`,size:r=`default`,tooltip:a,className:o,...s}){let c=e?_.Slot.Slot:`button`,{isMobile:l,state:u}=k(),d=(0,v.jsx)(c,{"data-slot":`sidebar-menu-button`,"data-sidebar":`menu-button`,"data-size":r,"data-active":t,className:(0,h.cn)(V({variant:n,size:r}),o),...s});return a?(typeof a==`string`&&(a={children:a}),(0,v.jsxs)(i.Tooltip,{children:[(0,v.jsx)(i.TooltipTrigger,{asChild:!0,children:d}),(0,v.jsx)(i.TooltipContent,{side:`right`,align:`center`,hidden:u!==`collapsed`||l,...a})]})):d}const U=({isLoggedIn:e=!1,username:t,email:n,inStockCarts:r,orderedCarts:i,onGoogleLoginSuccess:a,onUpdatingCart:o,onDeletingCart:s,onLogout:c,children:l})=>(0,v.jsx)(w.Provider,{value:{isLoggedIn:e,username:t,email:n,inStockCarts:r,orderedCarts:i,onGoogleLoginSuccess:a,onUpdatingCart:o,onDeletingCart:s,onLogout:c},children:l}),W=({children:e})=>(0,v.jsx)(A,{children:e}),G=({userName:e=`Keith Kennedy`,userEmail:n=`k.kennedy@originui.com`,onLogout:r})=>(0,v.jsxs)(l.DropdownMenu,{children:[(0,v.jsx)(l.DropdownMenuTrigger,{asChild:!0,children:(0,v.jsx)(t.Button,{size:`icon`,variant:`ghost`,color:`secondary`,className:`size-10 rounded-full`,children:(0,v.jsxs)(a.Avatar,{className:`size-10`,children:[(0,v.jsx)(a.AvatarImage,{}),(0,v.jsx)(a.AvatarFallback,{className:`bg-muted-muted size-full`,children:(0,v.jsx)(m.UserIcon,{})})]})})}),(0,v.jsxs)(l.DropdownMenuContent,{align:`end`,className:`max-w-64`,children:[(0,v.jsxs)(l.DropdownMenuLabel,{className:`flex min-w-0 flex-col`,children:[(0,v.jsx)(`span`,{className:`text-text-positive truncate text-sm font-medium`,children:e}),(0,v.jsx)(`span`,{className:`text-text-positive-weak truncate text-xs font-normal`,children:n})]}),(0,v.jsx)(l.DropdownMenuSeparator,{}),(0,v.jsxs)(l.DropdownMenuItem,{onClick:r,children:[(0,v.jsx)(m.LogOutIcon,{size:16,"aria-hidden":`true`}),(0,v.jsx)(`span`,{className:`text-text-positive`,children:`Logout`})]})]})]}),K=()=>{let{inStockCarts:e=[],orderedCarts:n=[]}=T(),r=e.length,i=n.length,a=r+i;return(0,v.jsxs)(f.Sheet,{children:[(0,v.jsx)(f.SheetTrigger,{asChild:!0,children:(0,v.jsxs)(t.Button,{size:`icon`,variant:`ghost`,color:`secondary`,className:`relative size-10 rounded-full`,children:[(0,v.jsx)(m.ShoppingCartIcon,{}),a>0&&(0,v.jsx)(`span`,{className:`bg-primary text-primary-foreground absolute -top-1 -right-1 flex h-4 min-w-4 items-center justify-center rounded-full px-1 text-xs font-bold`,children:a})]})}),(0,v.jsxs)(f.SheetContent,{className:`w-[95vw] sm:max-w-md`,children:[(0,v.jsx)(f.SheetHeader,{className:`border-border-weak flex-0 border-b pb-3`,children:(0,v.jsxs)(f.SheetTitle,{className:`flex items-center gap-2`,children:[(0,v.jsx)(m.ShoppingBag,{className:`h-5 w-5`}),(0,v.jsx)(`span`,{children:`Giỏ hàng của bạn`}),a>0&&(0,v.jsxs)(`span`,{className:`text-text-positive-weak text-sm font-normal`,children:[`(`,a,` sản phẩm)`]})]})}),(0,v.jsxs)(p.Tabs,{defaultValue:i>0?`pre_order`:`in_stock`,className:`h-full flex-1 overflow-y-auto p-4 pt-0`,children:[(0,v.jsxs)(p.TabsList,{className:`w-full flex-0`,children:[(0,v.jsxs)(p.TabsTrigger,{value:`in_stock`,className:`relative`,children:[`Có sẵn`,r>0&&(0,v.jsxs)(`span`,{children:[`(`,r,`)`]})]}),(0,v.jsxs)(p.TabsTrigger,{value:`pre_order`,className:`relative`,children:[`Đặt trước`,i>0&&(0,v.jsxs)(`span`,{children:[`(`,i,`)`]})]})]}),(0,v.jsx)(p.TabsContent,{value:`pre_order`,className:`flex-1 overflow-y-auto`,children:(0,v.jsx)(D,{items:n,cartType:`pre_order`})}),(0,v.jsx)(p.TabsContent,{value:`in_stock`,className:`flex-1 overflow-y-auto`,children:(0,v.jsx)(D,{items:e,cartType:`in_stock`})})]})]})]})},q=()=>{let{isLoggedIn:e,username:n,email:r,onGoogleLoginSuccess:i,onLogout:a}=T(),c=(0,b.useMediaQuery)(`(min-width: 640px)`),[l,u]=(0,y.useState)(!1);return(0,v.jsxs)(`header`,{className:(0,h.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`),children:[e&&(0,v.jsx)(M,{}),(0,v.jsxs)(`div`,{className:`flex gap-x-2 sm:ml-2.5`,children:[(0,v.jsx)(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg`,children:(0,v.jsx)(m.ShoppingCartIcon,{size:20})}),(0,v.jsxs)(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[(0,v.jsx)(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),(0,v.jsx)(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),(0,v.jsxs)(`div`,{className:`flex flex-1 items-center justify-end gap-x-2`,children:[!e&&(0,v.jsxs)(t.Button,{className:`w-8 sm:w-fit`,onClick:()=>u(!0),children:[(0,v.jsx)(m.LogInIcon,{}),(0,v.jsx)(`span`,{className:`sr-only sm:not-sr-only`,children:`Đăng nhập`})]}),e&&(0,v.jsxs)(v.Fragment,{children:[(0,v.jsx)(G,{userName:n,userEmail:r,onLogout:a}),(0,v.jsx)(d.Separator,{orientation:`vertical`,className:`min-h-6 w-px`}),(0,v.jsx)(K,{})]})]}),c&&(0,v.jsx)(o.Dialog,{open:l,onOpenChange:u,children:(0,v.jsxs)(o.DialogContent,{showCloseButton:!1,className:`flex flex-col gap-0 border-none p-0 sm:max-w-sm`,children:[(0,v.jsx)(o.DialogHeader,{className:`flex-0 gap-2 p-6`,children:(0,v.jsx)(o.DialogTitle,{className:`text-center`,children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`bg-card size-full flex-1 p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,width:240,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||await i?.(e)}})]})})}),(0,v.jsx)(o.DialogFooter,{className:`p-2`})]})}),!c&&(0,v.jsx)(s.Drawer,{open:l,onOpenChange:u,children:(0,v.jsxs)(s.DrawerContent,{children:[(0,v.jsx)(s.DrawerHeader,{className:`text-left`,children:(0,v.jsx)(s.DrawerTitle,{children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`flex size-full flex-1 flex-col p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||await i?.(e)}})]})})}),(0,v.jsx)(s.DrawerFooter,{})]})})]})},J=({children:e,...t})=>{let{isLoggedIn:n}=T();return n?(0,v.jsx)(j,{variant:`inset`,collapsible:`icon`,...t,children:e}):null},Y=({children:e})=>{let{isLoggedIn:n,onGoogleLoginSuccess:r}=T(),i=(0,b.useMediaQuery)(`(min-width: 640px)`),[a,c]=(0,y.useState)(!1);return n?(0,v.jsx)(N,{children:(0,v.jsx)(`section`,{className:`relative size-full`,children:(0,v.jsx)(`div`,{className:`absolute inset-0 flex flex-col`,children:e})})}):(0,v.jsx)(`div`,{className:`size-full p-4 pt-[calc(var(--header-height)+1.5rem)]`,children:(0,v.jsxs)(`div`,{className:`bg-card shadow-card flex size-full flex-col items-center justify-center gap-6 rounded-lg p-8 text-center`,children:[(0,v.jsx)(`div`,{className:`bg-muted-foreground/10 flex size-20 items-center justify-center rounded-full`,children:(0,v.jsx)(m.LockIcon,{className:`text-primary size-10`})}),(0,v.jsxs)(`div`,{className:`flex max-w-md flex-col gap-2`,children:[(0,v.jsx)(`h2`,{className:`text-2xl font-semibold`,children:`Bạn chưa đăng nhập`}),(0,v.jsx)(`p`,{className:`text-text-positive-weak`,children:`Đăng nhập để khám phá đầy đủ các tính năng của Lunas Store và truy cập vào tài khoản của bạn.`})]}),(0,v.jsxs)(t.Button,{size:`lg`,className:`gap-2`,onClick:()=>c(!0),children:[(0,v.jsx)(m.LogInIcon,{size:18}),(0,v.jsx)(`span`,{children:`Đăng nhập ngay`})]}),i&&(0,v.jsx)(o.Dialog,{open:a,onOpenChange:c,children:(0,v.jsxs)(o.DialogContent,{showCloseButton:!1,className:`flex flex-col gap-0 border-none p-0 sm:max-w-sm`,children:[(0,v.jsx)(o.DialogHeader,{className:`flex-0 gap-2 p-6`,children:(0,v.jsx)(o.DialogTitle,{className:`text-center`,children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`bg-card size-full flex-1 p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,width:240,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||(await r?.(e),c(!1))}})]})})}),(0,v.jsx)(o.DialogFooter,{className:`p-2`})]})}),!i&&(0,v.jsx)(s.Drawer,{open:a,onOpenChange:c,children:(0,v.jsxs)(s.DrawerContent,{children:[(0,v.jsx)(s.DrawerHeader,{className:`text-left`,children:(0,v.jsx)(s.DrawerTitle,{children:`Chào mừng bạn đến với Lunas Store!`})}),(0,v.jsx)(`div`,{className:`flex flex-1 flex-col`,children:(0,v.jsx)(`main`,{className:`flex size-full flex-1 flex-col p-4 pt-0`,children:(0,v.jsxs)(`div`,{className:`flex flex-col items-center gap-y-1`,children:[(0,v.jsx)(`p`,{className:`text-text-positive-weak text-sm`,children:`Đăng nhập với Google`}),(0,v.jsx)(x.GoogleLogin,{size:`large`,theme:`outline`,onSuccess:async e=>{!e.clientId||!e.credential||!e.select_by||(await r?.(e),c(!1))}})]})})}),(0,v.jsx)(s.DrawerFooter,{})]})})]})})},X=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-header`,className:(0,h.cn)(`flex-0 snap-start`,e),children:t}),Z=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-content`,className:(0,h.cn)(`flex w-full flex-1 flex-col gap-4 overflow-y-auto px-2 sm:px-4`,e),children:t}),Q=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-footer`,className:(0,h.cn)(`border-border-weak hidden w-full flex-0 border-t pt-2 sm:flex`,e),children:t}),$=({children:e,className:t})=>(0,v.jsx)(`div`,{"data-slot":`main-group`,className:(0,h.cn)(`flex size-full flex-col gap-4`,t),children:e}),oe=({className:e,children:t})=>(0,v.jsx)(`div`,{"data-slot":`main-group-content`,className:(0,h.cn)(`bg-card shadow-card max-w-8xl size-full flex-1 rounded-md p-4`,e),children:t});exports.ServiceLayoutCartInfo=K,exports.ServiceLayoutHeader=q,exports.ServiceLayoutMain=Y,exports.ServiceLayoutMainContent=Z,exports.ServiceLayoutMainFooter=Q,exports.ServiceLayoutMainGroup=$,exports.ServiceLayoutMainGroupContent=oe,exports.ServiceLayoutMainHeader=X,exports.ServiceLayoutProvider=U,exports.ServiceLayoutSidebar=J,exports.ServiceLayoutSidebarContent=F,exports.ServiceLayoutSidebarFooter=P,exports.ServiceLayoutSidebarGroup=I,exports.ServiceLayoutSidebarGroupContent=R,exports.ServiceLayoutSidebarGroupLabel=L,exports.ServiceLayoutSidebarMenu=z,exports.ServiceLayoutSidebarMenuButton=H,exports.ServiceLayoutSidebarMenuItem=B,exports.ServiceLayoutUserInfo=G,exports.ServiceLayoutWrapper=W;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|