@senitix/ui 0.4.1 → 0.4.3
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/accordion-BcwB0wwz.cjs +2 -0
- package/dist/accordion-BcwB0wwz.cjs.map +1 -0
- package/dist/accordion-BwnJKrKm.js +360 -0
- package/dist/accordion-BwnJKrKm.js.map +1 -0
- package/dist/appointment-scheduler-BoQQO51F.cjs +2 -0
- package/dist/appointment-scheduler-BoQQO51F.cjs.map +1 -0
- package/dist/appointment-scheduler-DHAs-mF_.js +192 -0
- package/dist/appointment-scheduler-DHAs-mF_.js.map +1 -0
- package/dist/arrow-right-CM3nmiZe.js +15 -0
- package/dist/arrow-right-CM3nmiZe.js.map +1 -0
- package/dist/arrow-right-vDxRZOfm.cjs +7 -0
- package/dist/arrow-right-vDxRZOfm.cjs.map +1 -0
- package/dist/avatar-BlEcWE7T.js +191 -0
- package/dist/avatar-BlEcWE7T.js.map +1 -0
- package/dist/avatar-Cl38Ye4J.cjs +2 -0
- package/dist/avatar-Cl38Ye4J.cjs.map +1 -0
- package/dist/badge-BZcdBG5J.cjs +23 -0
- package/dist/badge-BZcdBG5J.cjs.map +1 -0
- package/dist/badge-D0C_rP2l.js +157 -0
- package/dist/badge-D0C_rP2l.js.map +1 -0
- package/dist/button-BP_ug5gP.js +126 -0
- package/dist/button-BP_ug5gP.js.map +1 -0
- package/dist/button-CPuCii0R.cjs +2 -0
- package/dist/button-CPuCii0R.cjs.map +1 -0
- package/dist/{calendar-DgnhzEfp.js → calendar-86qoSnO7.js} +368 -433
- package/dist/calendar-86qoSnO7.js.map +1 -0
- package/dist/{calendar-D3RWU0_G.cjs → calendar-BH-AuyiB.cjs} +2 -2
- package/dist/{calendar-D3RWU0_G.cjs.map → calendar-BH-AuyiB.cjs.map} +1 -1
- package/dist/calendar-CSJ060ym.cjs +2 -0
- package/dist/calendar-CSJ060ym.cjs.map +1 -0
- package/dist/{calendar-CUxm1K7J.js → calendar-JUSWONQ0.js} +2 -2
- package/dist/{calendar-CUxm1K7J.js.map → calendar-JUSWONQ0.js.map} +1 -1
- package/dist/{card-DISL3sPJ.cjs → card-CToWUN1K.cjs} +2 -2
- package/dist/{card-DISL3sPJ.cjs.map → card-CToWUN1K.cjs.map} +1 -1
- package/dist/{card-fId5vof_.js → card-yxbWFvZ1.js} +2 -2
- package/dist/{card-fId5vof_.js.map → card-yxbWFvZ1.js.map} +1 -1
- package/dist/checkbox-BmugT50K.cjs +2 -0
- package/dist/checkbox-BmugT50K.cjs.map +1 -0
- package/dist/{checkbox-BY2zxQVv.js → checkbox-CTa9e4SG.js} +95 -97
- package/dist/checkbox-CTa9e4SG.js.map +1 -0
- package/dist/chevron-left-5h87iFo_.cjs +7 -0
- package/dist/chevron-left-5h87iFo_.cjs.map +1 -0
- package/dist/chevron-left-DD5mQuvf.js +14 -0
- package/dist/chevron-left-DD5mQuvf.js.map +1 -0
- package/dist/{chevron-right-Bxf8i4gi.cjs → chevron-right-D-TdAZ7l.cjs} +2 -2
- package/dist/{chevron-right-Bxf8i4gi.cjs.map → chevron-right-D-TdAZ7l.cjs.map} +1 -1
- package/dist/{chevron-right-BLyGmyaF.js → chevron-right-Di90aqSn.js} +2 -2
- package/dist/{chevron-right-BLyGmyaF.js.map → chevron-right-Di90aqSn.js.map} +1 -1
- package/dist/chevron-up-Bq55Db6X.cjs +7 -0
- package/dist/{chevron-up-C3RClqXD.cjs.map → chevron-up-Bq55Db6X.cjs.map} +1 -1
- package/dist/{chevron-up-BmYZUtrk.js → chevron-up-Dr7EIn9V.js} +2 -2
- package/dist/{chevron-up-BmYZUtrk.js.map → chevron-up-Dr7EIn9V.js.map} +1 -1
- package/dist/clock-BjJE8PGr.js +15 -0
- package/dist/clock-BjJE8PGr.js.map +1 -0
- package/dist/clock-CnxBAA_O.cjs +7 -0
- package/dist/clock-CnxBAA_O.cjs.map +1 -0
- package/dist/command-BEpaOk-5.cjs +2 -0
- package/dist/command-BEpaOk-5.cjs.map +1 -0
- package/dist/command-CYhMM7gX.js +404 -0
- package/dist/command-CYhMM7gX.js.map +1 -0
- package/dist/components/builders/index.cjs.js +2 -0
- package/dist/components/builders/index.cjs.js.map +1 -0
- package/dist/components/builders/index.es.js +42 -0
- package/dist/components/builders/index.es.js.map +1 -0
- package/dist/components/charts/index.cjs.js +1 -1
- package/dist/components/charts/index.es.js +7 -6
- package/dist/components/charts/index.es.js.map +1 -1
- package/dist/components/data-display/index.cjs.js +1 -1
- package/dist/components/data-display/index.es.js +43 -20
- package/dist/components/dnd/index.cjs.js +1 -1
- package/dist/components/dnd/index.es.js +1 -1
- package/dist/components/feedback/index.cjs.js +1 -1
- package/dist/components/feedback/index.es.js +1 -1
- package/dist/components/forms/index.cjs.js +1 -1
- package/dist/components/forms/index.es.js +24 -23
- package/dist/components/forms/index.es.js.map +1 -1
- package/dist/components/layouts/index.cjs.js +1 -1
- package/dist/components/layouts/index.es.js +45 -21
- package/dist/components/messaging/index.cjs.js +2 -0
- package/dist/components/messaging/index.cjs.js.map +1 -0
- package/dist/components/messaging/index.es.js +15 -0
- package/dist/components/messaging/index.es.js.map +1 -0
- package/dist/components/navigation/index.cjs.js +1 -1
- package/dist/components/navigation/index.es.js +1 -1
- package/dist/components/scheduling/index.cjs.js +2 -0
- package/dist/components/scheduling/index.cjs.js.map +1 -0
- package/dist/components/scheduling/index.es.js +6 -0
- package/dist/components/scheduling/index.es.js.map +1 -0
- package/dist/components/ui/index.cjs.js +1 -1
- package/dist/components/ui/index.es.js +168 -158
- package/dist/components/ui/index.es.js.map +1 -1
- package/dist/dialog-Cr9SYCaD.cjs +6 -0
- package/dist/dialog-Cr9SYCaD.cjs.map +1 -0
- package/dist/dialog-MYAx3Qrc.js +387 -0
- package/dist/dialog-MYAx3Qrc.js.map +1 -0
- package/dist/dropdown-menu-CkCCV_tw.js +969 -0
- package/dist/dropdown-menu-CkCCV_tw.js.map +1 -0
- package/dist/dropdown-menu-ejikFvg2.cjs +7 -0
- package/dist/dropdown-menu-ejikFvg2.cjs.map +1 -0
- package/dist/{ellipsis-6eUne95u.js → ellipsis-CKhpjj5H.js} +2 -2
- package/dist/{ellipsis-6eUne95u.js.map → ellipsis-CKhpjj5H.js.map} +1 -1
- package/dist/{ellipsis-DkM3GBF5.cjs → ellipsis-Dk7Wfc4i.cjs} +3 -3
- package/dist/{ellipsis-DkM3GBF5.cjs.map → ellipsis-Dk7Wfc4i.cjs.map} +1 -1
- package/dist/external-link-CGBqsrbm.cjs +7 -0
- package/dist/external-link-CGBqsrbm.cjs.map +1 -0
- package/dist/external-link-UeWW0ty3.js +16 -0
- package/dist/external-link-UeWW0ty3.js.map +1 -0
- package/dist/eye-Cved4eAo.cjs +7 -0
- package/dist/eye-Cved4eAo.cjs.map +1 -0
- package/dist/eye-KdCUpmO8.js +21 -0
- package/dist/eye-KdCUpmO8.js.map +1 -0
- package/dist/{file-Cw_u_aJB.js → file-CHbdXCWO.js} +2 -2
- package/dist/{file-Cw_u_aJB.js.map → file-CHbdXCWO.js.map} +1 -1
- package/dist/{file-Cp5UoYUZ.cjs → file-CqYRamm8.cjs} +3 -3
- package/dist/{file-Cp5UoYUZ.cjs.map → file-CqYRamm8.cjs.map} +1 -1
- package/dist/file-spreadsheet-CpySxI0-.cjs +7 -0
- package/dist/file-spreadsheet-CpySxI0-.cjs.map +1 -0
- package/dist/file-spreadsheet-EqZMR-mM.js +19 -0
- package/dist/file-spreadsheet-EqZMR-mM.js.map +1 -0
- package/dist/form-preview-Bm5xHtkw.js +12075 -0
- package/dist/form-preview-Bm5xHtkw.js.map +1 -0
- package/dist/form-preview-IPEZdspX.cjs +111 -0
- package/dist/form-preview-IPEZdspX.cjs.map +1 -0
- package/dist/full-calendar-4Ut52QNO.cjs +18 -0
- package/dist/full-calendar-4Ut52QNO.cjs.map +1 -0
- package/dist/full-calendar-DD_tBy69.js +2631 -0
- package/dist/full-calendar-DD_tBy69.js.map +1 -0
- package/dist/funnel-chart-Dfj1pOyV.cjs +6 -0
- package/dist/funnel-chart-Dfj1pOyV.cjs.map +1 -0
- package/dist/funnel-chart-o9qcEMgg.js +2952 -0
- package/dist/funnel-chart-o9qcEMgg.js.map +1 -0
- package/dist/global-search-DcBKVaM4.cjs +22 -0
- package/dist/global-search-DcBKVaM4.cjs.map +1 -0
- package/dist/global-search-Dul9CD6-.js +1331 -0
- package/dist/global-search-Dul9CD6-.js.map +1 -0
- package/dist/hooks/index.cjs.js +1 -1
- package/dist/hooks/index.es.js +9 -7
- package/dist/hooks/index.es.js.map +1 -1
- package/dist/{index-DtaLkIY8.js → index-BGUveO6l.js} +84 -79
- package/dist/{index-DtaLkIY8.js.map → index-BGUveO6l.js.map} +1 -1
- package/dist/{index-gVbM3K4f.cjs → index-Bhee6XHk.cjs} +2 -2
- package/dist/{index-gVbM3K4f.cjs.map → index-Bhee6XHk.cjs.map} +1 -1
- package/dist/index-CrSlyWAA.js +1090 -0
- package/dist/index-CrSlyWAA.js.map +1 -0
- package/dist/{index-Dk_Et2WJ.js → index-D8-pHJim.js} +2 -2
- package/dist/{index-Dk_Et2WJ.js.map → index-D8-pHJim.js.map} +1 -1
- package/dist/index-Dy_9oyP3.cjs +2 -0
- package/dist/{index-D2U2F80P.cjs.map → index-Dy_9oyP3.cjs.map} +1 -1
- package/dist/index-hnbbvGmb.cjs +21 -0
- package/dist/index-hnbbvGmb.cjs.map +1 -0
- package/dist/index.cjs.js +1 -1
- package/dist/index.es.js +434 -319
- package/dist/index.es.js.map +1 -1
- package/dist/input-Pfq8fkiV.js +2718 -0
- package/dist/input-Pfq8fkiV.js.map +1 -0
- package/dist/input-UBp7V7li.cjs +52 -0
- package/dist/input-UBp7V7li.cjs.map +1 -0
- package/dist/label-CExiitfO.js +50 -0
- package/dist/label-CExiitfO.js.map +1 -0
- package/dist/label-F0zGAiI2.cjs +2 -0
- package/dist/label-F0zGAiI2.cjs.map +1 -0
- package/dist/loader-circle-CBVYGIRp.js +14 -0
- package/dist/loader-circle-CBVYGIRp.js.map +1 -0
- package/dist/loader-circle-IaJKvYsP.cjs +7 -0
- package/dist/loader-circle-IaJKvYsP.cjs.map +1 -0
- package/dist/locale-provider-BHGNO4j7.js +1786 -0
- package/dist/locale-provider-BHGNO4j7.js.map +1 -0
- package/dist/locale-provider-BScpm-eC.cjs +2 -0
- package/dist/locale-provider-BScpm-eC.cjs.map +1 -0
- package/dist/locale-selector-CRC0VBKl.cjs +12 -0
- package/dist/locale-selector-CRC0VBKl.cjs.map +1 -0
- package/dist/locale-selector-HuzfE0zZ.js +1740 -0
- package/dist/locale-selector-HuzfE0zZ.js.map +1 -0
- package/dist/map-pin-CHh0xl6i.js +46 -0
- package/dist/map-pin-CHh0xl6i.js.map +1 -0
- package/dist/map-pin-DGObSZ40.cjs +17 -0
- package/dist/map-pin-DGObSZ40.cjs.map +1 -0
- package/dist/message-square-B_xLey5D.js +14 -0
- package/dist/message-square-B_xLey5D.js.map +1 -0
- package/dist/message-square-_69ua8rH.cjs +7 -0
- package/dist/message-square-_69ua8rH.cjs.map +1 -0
- package/dist/minus-BUFkTM0k.cjs +7 -0
- package/dist/{minus-C0uyaz70.cjs.map → minus-BUFkTM0k.cjs.map} +1 -1
- package/dist/{minus-CiwV65ZG.js → minus-DJ0tmymW.js} +2 -2
- package/dist/{minus-CiwV65ZG.js.map → minus-DJ0tmymW.js.map} +1 -1
- package/dist/multi-container-CytCGxsc.cjs +7 -0
- package/dist/multi-container-CytCGxsc.cjs.map +1 -0
- package/dist/multi-container-DmkgnCJN.js +799 -0
- package/dist/multi-container-DmkgnCJN.js.map +1 -0
- package/dist/multi-select-Bj_kIDHE.cjs +7 -0
- package/dist/multi-select-Bj_kIDHE.cjs.map +1 -0
- package/dist/multi-select-CPF7w871.js +224 -0
- package/dist/multi-select-CPF7w871.js.map +1 -0
- package/dist/pencil-BJULwaDl.cjs +12 -0
- package/dist/pencil-BJULwaDl.cjs.map +1 -0
- package/dist/pencil-HL0trGIs.js +31 -0
- package/dist/pencil-HL0trGIs.js.map +1 -0
- package/dist/permission-matrix-BRqw2RPb.js +6128 -0
- package/dist/permission-matrix-BRqw2RPb.js.map +1 -0
- package/dist/permission-matrix-CqE8q8Hi.cjs +93 -0
- package/dist/permission-matrix-CqE8q8Hi.cjs.map +1 -0
- package/dist/phone-B0J1dGIE.js +31 -0
- package/dist/phone-B0J1dGIE.js.map +1 -0
- package/dist/phone-DPA6vucM.cjs +12 -0
- package/dist/phone-DPA6vucM.cjs.map +1 -0
- package/dist/plus-Bcuujcqd.cjs +7 -0
- package/dist/{plus-BsV82JJ5.cjs.map → plus-Bcuujcqd.cjs.map} +1 -1
- package/dist/{plus-DxD6rofl.js → plus-D7DMDKb8.js} +2 -2
- package/dist/{plus-DxD6rofl.js.map → plus-D7DMDKb8.js.map} +1 -1
- package/dist/popover-Bba1ELMX.cjs +2 -0
- package/dist/popover-Bba1ELMX.cjs.map +1 -0
- package/dist/popover-CZWAuYUL.js +281 -0
- package/dist/popover-CZWAuYUL.js.map +1 -0
- package/dist/progress-BPpsmZ48.js +218 -0
- package/dist/progress-BPpsmZ48.js.map +1 -0
- package/dist/progress-BrzjVhWG.cjs +22 -0
- package/dist/progress-BrzjVhWG.cjs.map +1 -0
- package/dist/providers/index.cjs.js +1 -1
- package/dist/providers/index.es.js +1 -1
- package/dist/radio-group-B9RM_c7e.js +244 -0
- package/dist/radio-group-B9RM_c7e.js.map +1 -0
- package/dist/radio-group-_n8TTqNQ.cjs +2 -0
- package/dist/radio-group-_n8TTqNQ.cjs.map +1 -0
- package/dist/record-dialog-footer-DbH9A6eA.js +2577 -0
- package/dist/record-dialog-footer-DbH9A6eA.js.map +1 -0
- package/dist/record-dialog-footer-DpDxH5wX.cjs +37 -0
- package/dist/record-dialog-footer-DpDxH5wX.cjs.map +1 -0
- package/dist/scroll-area-CGNbDUBQ.js +889 -0
- package/dist/scroll-area-CGNbDUBQ.js.map +1 -0
- package/dist/scroll-area-HsTSI_58.cjs +22 -0
- package/dist/scroll-area-HsTSI_58.cjs.map +1 -0
- package/dist/select-CEsYpjPi.cjs +2 -0
- package/dist/select-CEsYpjPi.cjs.map +1 -0
- package/dist/{select-BJpZrtep.js → select-Ce2C2acZ.js} +184 -179
- package/dist/select-Ce2C2acZ.js.map +1 -0
- package/dist/send-DIkOd-pu.js +21 -0
- package/dist/send-DIkOd-pu.js.map +1 -0
- package/dist/send-H6HC-rS8.cjs +7 -0
- package/dist/send-H6HC-rS8.cjs.map +1 -0
- package/dist/shared-inbox-Bv0AgLew.js +702 -0
- package/dist/shared-inbox-Bv0AgLew.js.map +1 -0
- package/dist/shared-inbox-DWEKfDX3.cjs +22 -0
- package/dist/shared-inbox-DWEKfDX3.cjs.map +1 -0
- package/dist/sheet-DTimb4SJ.cjs +2 -0
- package/dist/sheet-DTimb4SJ.cjs.map +1 -0
- package/dist/sheet-DgpAPCAp.js +147 -0
- package/dist/sheet-DgpAPCAp.js.map +1 -0
- package/dist/{skeleton-Bl6FAxHT.js → skeleton-C_dwS3_6.js} +2 -2
- package/dist/{skeleton-Bl6FAxHT.js.map → skeleton-C_dwS3_6.js.map} +1 -1
- package/dist/{skeleton-Cb6MWerF.cjs → skeleton-D3YsjVWD.cjs} +2 -2
- package/dist/{skeleton-Cb6MWerF.cjs.map → skeleton-D3YsjVWD.cjs.map} +1 -1
- package/dist/sparkline-chart-BP4bk24J.js +15881 -0
- package/dist/sparkline-chart-BP4bk24J.js.map +1 -0
- package/dist/sparkline-chart-D6SLZVjp.cjs +79 -0
- package/dist/sparkline-chart-D6SLZVjp.cjs.map +1 -0
- package/dist/styles.css +1 -1
- package/dist/switch-AEZvZSRV.cjs +2 -0
- package/dist/switch-AEZvZSRV.cjs.map +1 -0
- package/dist/switch-BF4LLvaU.js +147 -0
- package/dist/switch-BF4LLvaU.js.map +1 -0
- package/dist/table-2-Bn-YjZ9s.cjs +17 -0
- package/dist/table-2-Bn-YjZ9s.cjs.map +1 -0
- package/dist/table-2-C7E_N72K.js +52 -0
- package/dist/table-2-C7E_N72K.js.map +1 -0
- package/dist/textarea-4qZDuQ-C.js +206 -0
- package/dist/textarea-4qZDuQ-C.js.map +1 -0
- package/dist/textarea-Bq_zyt0L.cjs +2 -0
- package/dist/textarea-Bq_zyt0L.cjs.map +1 -0
- package/dist/tooltip-Dd7le9EO.cjs +2 -0
- package/dist/tooltip-Dd7le9EO.cjs.map +1 -0
- package/dist/tooltip-Dee-pNPI.js +338 -0
- package/dist/tooltip-Dee-pNPI.js.map +1 -0
- package/dist/trash-2-B3EP3JfM.js +18 -0
- package/dist/trash-2-B3EP3JfM.js.map +1 -0
- package/dist/trash-2-DWEeKlWT.cjs +7 -0
- package/dist/trash-2-DWEeKlWT.cjs.map +1 -0
- package/dist/{trending-up-BHFXgLWy.js → trending-up-ljWtN4pj.js} +2 -2
- package/dist/{trending-up-BHFXgLWy.js.map → trending-up-ljWtN4pj.js.map} +1 -1
- package/dist/{trending-up-BBjz_E69.cjs → trending-up-mLgmkp--.cjs} +2 -2
- package/dist/{trending-up-BBjz_E69.cjs.map → trending-up-mLgmkp--.cjs.map} +1 -1
- package/dist/upload-2tm-XihE.cjs +7 -0
- package/dist/upload-2tm-XihE.cjs.map +1 -0
- package/dist/upload-C_JDP8O0.js +16 -0
- package/dist/upload-C_JDP8O0.js.map +1 -0
- package/dist/use-controllable-state-3ATd6Fqd.cjs +2 -0
- package/dist/use-controllable-state-3ATd6Fqd.cjs.map +1 -0
- package/dist/use-controllable-state-CEa-Zlq6.js +23 -0
- package/dist/use-controllable-state-CEa-Zlq6.js.map +1 -0
- package/dist/use-formatters-Bb0fX1lW.cjs +2 -0
- package/dist/{use-formatters-CObUgipW.cjs.map → use-formatters-Bb0fX1lW.cjs.map} +1 -1
- package/dist/{use-formatters-Bgj3JA4i.js → use-formatters-xeMS4gdV.js} +1160 -1165
- package/dist/{use-formatters-Bgj3JA4i.js.map → use-formatters-xeMS4gdV.js.map} +1 -1
- package/dist/utils/index.cjs.js +1 -1
- package/dist/utils/index.es.js +1 -1
- package/dist/welcome-card-Ccbl_miQ.js +1007 -0
- package/dist/welcome-card-Ccbl_miQ.js.map +1 -0
- package/dist/welcome-card-D-ShMkaS.cjs +37 -0
- package/dist/welcome-card-D-ShMkaS.cjs.map +1 -0
- package/dist/x-BBkgEhUv.js +15 -0
- package/dist/x-BBkgEhUv.js.map +1 -0
- package/dist/x-D-El5XAY.cjs +7 -0
- package/dist/x-D-El5XAY.cjs.map +1 -0
- package/package.json +20 -2
- package/dist/avatar-BT_SPwFW.cjs +0 -18
- package/dist/avatar-BT_SPwFW.cjs.map +0 -1
- package/dist/avatar-C5-ZWIqT.js +0 -305
- package/dist/avatar-C5-ZWIqT.js.map +0 -1
- package/dist/calendar-BF5drX5u.cjs +0 -12
- package/dist/calendar-BF5drX5u.cjs.map +0 -1
- package/dist/calendar-DgnhzEfp.js.map +0 -1
- package/dist/checkbox-BY2zxQVv.js.map +0 -1
- package/dist/checkbox-CL6u7vL6.cjs +0 -2
- package/dist/checkbox-CL6u7vL6.cjs.map +0 -1
- package/dist/chevron-down-BiUlxZA-.js +0 -14
- package/dist/chevron-down-BiUlxZA-.js.map +0 -1
- package/dist/chevron-down-Ce0kqXiD.cjs +0 -7
- package/dist/chevron-down-Ce0kqXiD.cjs.map +0 -1
- package/dist/chevron-up-C3RClqXD.cjs +0 -7
- package/dist/createLucideIcon-BC8wu-bu.js +0 -80
- package/dist/createLucideIcon-BC8wu-bu.js.map +0 -1
- package/dist/createLucideIcon-Cv8nC2E9.cjs +0 -22
- package/dist/createLucideIcon-Cv8nC2E9.cjs.map +0 -1
- package/dist/filter-tags-DoRzXjuY.cjs +0 -48
- package/dist/filter-tags-DoRzXjuY.cjs.map +0 -1
- package/dist/filter-tags-zEQmRhEU.js +0 -2712
- package/dist/filter-tags-zEQmRhEU.js.map +0 -1
- package/dist/full-calendar-5Z4JSj8g.js +0 -3551
- package/dist/full-calendar-5Z4JSj8g.js.map +0 -1
- package/dist/full-calendar-DjAvCfuE.cjs +0 -23
- package/dist/full-calendar-DjAvCfuE.cjs.map +0 -1
- package/dist/global-search-BbZfc-VL.js +0 -1216
- package/dist/global-search-BbZfc-VL.js.map +0 -1
- package/dist/global-search-Bd74_wPV.cjs +0 -22
- package/dist/global-search-Bd74_wPV.cjs.map +0 -1
- package/dist/index-D2U2F80P.cjs +0 -2
- package/dist/index-DG0KV-sw.cjs +0 -11
- package/dist/index-DG0KV-sw.cjs.map +0 -1
- package/dist/index-XnFSmCuh.js +0 -299
- package/dist/index-XnFSmCuh.js.map +0 -1
- package/dist/input-BgPy-4Qu.js +0 -3658
- package/dist/input-BgPy-4Qu.js.map +0 -1
- package/dist/input-Cfr2WB-P.cjs +0 -47
- package/dist/input-Cfr2WB-P.cjs.map +0 -1
- package/dist/locale-provider-BojNdf1Y.cjs +0 -2
- package/dist/locale-provider-BojNdf1Y.cjs.map +0 -1
- package/dist/locale-provider-DzBeb-X3.js +0 -1013
- package/dist/locale-provider-DzBeb-X3.js.map +0 -1
- package/dist/locale-selector-BD1IWk6X.cjs +0 -22
- package/dist/locale-selector-BD1IWk6X.cjs.map +0 -1
- package/dist/locale-selector-DLRSyVye.js +0 -1772
- package/dist/locale-selector-DLRSyVye.js.map +0 -1
- package/dist/minus-C0uyaz70.cjs +0 -7
- package/dist/multi-container-BZia7HCU.js +0 -748
- package/dist/multi-container-BZia7HCU.js.map +0 -1
- package/dist/multi-container-BdNbgtPZ.cjs +0 -7
- package/dist/multi-container-BdNbgtPZ.cjs.map +0 -1
- package/dist/pipeline-Dh052Dvj.cjs +0 -27
- package/dist/pipeline-Dh052Dvj.cjs.map +0 -1
- package/dist/pipeline-DqWvleNy.js +0 -1076
- package/dist/pipeline-DqWvleNy.js.map +0 -1
- package/dist/plus-BsV82JJ5.cjs +0 -7
- package/dist/popover-BgLxmm1z.cjs +0 -7
- package/dist/popover-BgLxmm1z.cjs.map +0 -1
- package/dist/popover-PI9jbhnS.js +0 -775
- package/dist/popover-PI9jbhnS.js.map +0 -1
- package/dist/progress-CTTt_CP3.js +0 -260
- package/dist/progress-CTTt_CP3.js.map +0 -1
- package/dist/progress-CTWb7X1Q.cjs +0 -37
- package/dist/progress-CTWb7X1Q.cjs.map +0 -1
- package/dist/scroll-area-A3jGu-Ta.js +0 -974
- package/dist/scroll-area-A3jGu-Ta.js.map +0 -1
- package/dist/scroll-area-DzDnWIYJ.cjs +0 -12
- package/dist/scroll-area-DzDnWIYJ.cjs.map +0 -1
- package/dist/select-BJpZrtep.js.map +0 -1
- package/dist/select-Ii8HRuXa.cjs +0 -2
- package/dist/select-Ii8HRuXa.cjs.map +0 -1
- package/dist/separator-BzcDE0Ei.cjs +0 -2
- package/dist/separator-BzcDE0Ei.cjs.map +0 -1
- package/dist/separator-DyarVo1-.js +0 -396
- package/dist/separator-DyarVo1-.js.map +0 -1
- package/dist/sheet-DPSdOoE6.js +0 -84
- package/dist/sheet-DPSdOoE6.js.map +0 -1
- package/dist/sheet-XtjvbEMq.cjs +0 -2
- package/dist/sheet-XtjvbEMq.cjs.map +0 -1
- package/dist/sparkline-chart-CeCDeMNk.cjs +0 -102
- package/dist/sparkline-chart-CeCDeMNk.cjs.map +0 -1
- package/dist/sparkline-chart-DUS4CoW_.js +0 -19787
- package/dist/sparkline-chart-DUS4CoW_.js.map +0 -1
- package/dist/use-formatters-CObUgipW.cjs +0 -2
- package/dist/welcome-card-CNuEa6Ck.cjs +0 -67
- package/dist/welcome-card-CNuEa6Ck.cjs.map +0 -1
- package/dist/welcome-card-Cp6t6G3j.js +0 -1041
- package/dist/welcome-card-Cp6t6G3j.js.map +0 -1
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { jsxs as h, jsx as s } from "react/jsx-runtime";
|
|
2
|
+
import * as x from "react";
|
|
3
|
+
import { c as y } from "./index-BGUveO6l.js";
|
|
4
|
+
import { B as $ } from "./button-BP_ug5gP.js";
|
|
5
|
+
import { u as k } from "./locale-provider-BHGNO4j7.js";
|
|
6
|
+
import { u as C } from "./use-controllable-state-CEa-Zlq6.js";
|
|
7
|
+
import { S as L, a as A } from "./scroll-area-CGNbDUBQ.js";
|
|
8
|
+
import { C as R } from "./chevron-left-DD5mQuvf.js";
|
|
9
|
+
import { C as W } from "./chevron-right-Di90aqSn.js";
|
|
10
|
+
function v(r) {
|
|
11
|
+
const e = r.getFullYear(), c = String(r.getMonth() + 1).padStart(2, "0"), d = String(r.getDate()).padStart(2, "0");
|
|
12
|
+
return `${e}-${c}-${d}`;
|
|
13
|
+
}
|
|
14
|
+
function j(r, e) {
|
|
15
|
+
return `${String(r).padStart(2, "0")}:${String(e).padStart(2, "0")}`;
|
|
16
|
+
}
|
|
17
|
+
function I(r, e, c) {
|
|
18
|
+
const d = [];
|
|
19
|
+
let m = r, n = 0;
|
|
20
|
+
for (; m < e || m === e && n === 0; )
|
|
21
|
+
d.push(j(m, n)), n += c, n >= 60 && (m += Math.floor(n / 60), n = n % 60);
|
|
22
|
+
return d;
|
|
23
|
+
}
|
|
24
|
+
const U = {
|
|
25
|
+
available: "bg-primary/10 hover:bg-primary/20 cursor-pointer border-primary/20",
|
|
26
|
+
booked: "bg-muted border-muted-foreground/20 cursor-default",
|
|
27
|
+
blocked: "bg-muted-foreground/10 border-muted-foreground/10 cursor-not-allowed opacity-60"
|
|
28
|
+
};
|
|
29
|
+
function T({
|
|
30
|
+
slots: r,
|
|
31
|
+
weekStart: e,
|
|
32
|
+
startHour: c,
|
|
33
|
+
endHour: d,
|
|
34
|
+
slotDuration: m,
|
|
35
|
+
onSlotClick: n,
|
|
36
|
+
readOnly: p
|
|
37
|
+
}) {
|
|
38
|
+
const { t: l } = k(), f = x.useMemo(() => [
|
|
39
|
+
l("scheduler.days.mon"),
|
|
40
|
+
l("scheduler.days.tue"),
|
|
41
|
+
l("scheduler.days.wed"),
|
|
42
|
+
l("scheduler.days.thu"),
|
|
43
|
+
l("scheduler.days.fri"),
|
|
44
|
+
l("scheduler.days.sat"),
|
|
45
|
+
l("scheduler.days.sun")
|
|
46
|
+
], [l]), w = x.useMemo(() => {
|
|
47
|
+
const t = [];
|
|
48
|
+
for (let a = 0; a < 7; a++) {
|
|
49
|
+
const u = new Date(e);
|
|
50
|
+
u.setDate(u.getDate() + a), t.push(u);
|
|
51
|
+
}
|
|
52
|
+
return t;
|
|
53
|
+
}, [e]), S = x.useMemo(
|
|
54
|
+
() => I(c, d, m),
|
|
55
|
+
[c, d, m]
|
|
56
|
+
), b = x.useMemo(() => {
|
|
57
|
+
const t = /* @__PURE__ */ new Map();
|
|
58
|
+
for (const a of r)
|
|
59
|
+
t.set(`${a.date}|${a.startTime}`, a);
|
|
60
|
+
return t;
|
|
61
|
+
}, [r]), D = (t) => {
|
|
62
|
+
!t || p || t.status === "available" && (n == null || n(t));
|
|
63
|
+
};
|
|
64
|
+
return /* @__PURE__ */ h(L, { className: "flex-1", children: [
|
|
65
|
+
/* @__PURE__ */ h("table", { className: "w-full min-w-[640px] border-collapse text-xs", children: [
|
|
66
|
+
/* @__PURE__ */ s("thead", { children: /* @__PURE__ */ h("tr", { children: [
|
|
67
|
+
/* @__PURE__ */ s("th", { className: "sticky left-0 z-10 w-16 border-b border-r bg-muted/40 p-2 text-left text-muted-foreground font-medium", children: l("scheduler.time") }),
|
|
68
|
+
w.map((t, a) => {
|
|
69
|
+
const u = v(t) === v(/* @__PURE__ */ new Date());
|
|
70
|
+
return /* @__PURE__ */ h(
|
|
71
|
+
"th",
|
|
72
|
+
{
|
|
73
|
+
className: y(
|
|
74
|
+
"border-b border-r p-2 text-center font-medium",
|
|
75
|
+
u ? "bg-primary/5 text-primary" : "text-muted-foreground"
|
|
76
|
+
),
|
|
77
|
+
children: [
|
|
78
|
+
/* @__PURE__ */ s("div", { className: "text-[11px]", children: f[a] }),
|
|
79
|
+
/* @__PURE__ */ s("div", { className: y("text-sm", u && "font-semibold"), children: t.getDate() })
|
|
80
|
+
]
|
|
81
|
+
},
|
|
82
|
+
a
|
|
83
|
+
);
|
|
84
|
+
})
|
|
85
|
+
] }) }),
|
|
86
|
+
/* @__PURE__ */ s("tbody", { children: S.map((t) => /* @__PURE__ */ h("tr", { children: [
|
|
87
|
+
/* @__PURE__ */ s("td", { className: "sticky left-0 z-10 border-b border-r bg-background px-2 py-1 text-[11px] text-muted-foreground font-mono whitespace-nowrap", children: t }),
|
|
88
|
+
w.map((a, u) => {
|
|
89
|
+
const N = v(a), o = b.get(`${N}|${t}`), g = (o == null ? void 0 : o.status) ?? "blocked";
|
|
90
|
+
return /* @__PURE__ */ s(
|
|
91
|
+
"td",
|
|
92
|
+
{
|
|
93
|
+
className: y(
|
|
94
|
+
"border-b border-r p-0.5 transition-colors"
|
|
95
|
+
),
|
|
96
|
+
children: /* @__PURE__ */ s(
|
|
97
|
+
"button",
|
|
98
|
+
{
|
|
99
|
+
type: "button",
|
|
100
|
+
disabled: p || g !== "available",
|
|
101
|
+
onClick: () => D(o),
|
|
102
|
+
className: y(
|
|
103
|
+
"flex h-8 w-full items-center justify-center rounded-sm border text-[10px] transition-colors",
|
|
104
|
+
U[g]
|
|
105
|
+
),
|
|
106
|
+
"aria-label": o ? `${o.startTime}-${o.endTime} ${g}${o.label ? ": " + o.label : ""}` : `${t} ${l("scheduler.unavailable")}`,
|
|
107
|
+
children: (o == null ? void 0 : o.label) && /* @__PURE__ */ s("span", { className: "truncate px-1", children: o.label })
|
|
108
|
+
}
|
|
109
|
+
)
|
|
110
|
+
},
|
|
111
|
+
u
|
|
112
|
+
);
|
|
113
|
+
})
|
|
114
|
+
] }, t)) })
|
|
115
|
+
] }),
|
|
116
|
+
/* @__PURE__ */ s(A, { orientation: "horizontal" })
|
|
117
|
+
] });
|
|
118
|
+
}
|
|
119
|
+
T.displayName = "SchedulerGrid";
|
|
120
|
+
function M(r) {
|
|
121
|
+
const e = new Date(r), c = e.getDay(), d = c === 0 ? -6 : 1 - c;
|
|
122
|
+
return e.setDate(e.getDate() + d), e.setHours(0, 0, 0, 0), e;
|
|
123
|
+
}
|
|
124
|
+
function Y(r) {
|
|
125
|
+
const e = new Date(r);
|
|
126
|
+
e.setDate(e.getDate() + 6);
|
|
127
|
+
const c = { month: "short", day: "numeric" }, d = r.toLocaleDateString("en-US", c), m = e.getDate(), n = e.getFullYear();
|
|
128
|
+
if (r.getMonth() === e.getMonth())
|
|
129
|
+
return `${d} - ${m}, ${n}`;
|
|
130
|
+
const p = e.toLocaleDateString("en-US", c);
|
|
131
|
+
return `${d} - ${p}, ${n}`;
|
|
132
|
+
}
|
|
133
|
+
function F({
|
|
134
|
+
slots: r,
|
|
135
|
+
weekStart: e,
|
|
136
|
+
defaultWeekStart: c,
|
|
137
|
+
onWeekStartChange: d,
|
|
138
|
+
startHour: m = 8,
|
|
139
|
+
endHour: n = 18,
|
|
140
|
+
slotDuration: p = 30,
|
|
141
|
+
onSlotClick: l,
|
|
142
|
+
onSlotBook: f,
|
|
143
|
+
readOnly: w = !1,
|
|
144
|
+
className: S
|
|
145
|
+
}) {
|
|
146
|
+
const { t: b } = k(), [D, t] = C({
|
|
147
|
+
value: e,
|
|
148
|
+
defaultValue: c ?? M(/* @__PURE__ */ new Date()).toISOString().slice(0, 10),
|
|
149
|
+
onChange: d
|
|
150
|
+
}), a = M(new Date(D)), u = x.useCallback(
|
|
151
|
+
(i) => {
|
|
152
|
+
t(M(i).toISOString().slice(0, 10));
|
|
153
|
+
},
|
|
154
|
+
[t]
|
|
155
|
+
), N = () => u(/* @__PURE__ */ new Date()), o = () => {
|
|
156
|
+
const i = new Date(a);
|
|
157
|
+
i.setDate(i.getDate() - 7), u(i);
|
|
158
|
+
}, g = () => {
|
|
159
|
+
const i = new Date(a);
|
|
160
|
+
i.setDate(i.getDate() + 7), u(i);
|
|
161
|
+
}, z = (i) => {
|
|
162
|
+
l == null || l(i), i.status === "available" && (f == null || f(i));
|
|
163
|
+
};
|
|
164
|
+
return /* @__PURE__ */ h("div", { className: y("flex flex-col overflow-hidden rounded-lg border bg-background", S), children: [
|
|
165
|
+
/* @__PURE__ */ h("div", { className: "flex items-center justify-between border-b px-3 py-2", children: [
|
|
166
|
+
/* @__PURE__ */ h("div", { className: "flex items-center gap-1", children: [
|
|
167
|
+
/* @__PURE__ */ s($, { variant: "outline", size: "sm", className: "h-7 px-2", onClick: o, "aria-label": b("scheduler.previousWeek"), children: /* @__PURE__ */ s(R, { className: "h-4 w-4" }) }),
|
|
168
|
+
/* @__PURE__ */ s($, { variant: "outline", size: "sm", className: "h-7 px-3 text-xs", onClick: N, children: b("scheduler.today") }),
|
|
169
|
+
/* @__PURE__ */ s($, { variant: "outline", size: "sm", className: "h-7 px-2", onClick: g, "aria-label": b("scheduler.nextWeek"), children: /* @__PURE__ */ s(W, { className: "h-4 w-4" }) })
|
|
170
|
+
] }),
|
|
171
|
+
/* @__PURE__ */ s("span", { className: "text-sm font-semibold", children: Y(a) })
|
|
172
|
+
] }),
|
|
173
|
+
/* @__PURE__ */ s(
|
|
174
|
+
T,
|
|
175
|
+
{
|
|
176
|
+
slots: r,
|
|
177
|
+
weekStart: a,
|
|
178
|
+
startHour: m,
|
|
179
|
+
endHour: n,
|
|
180
|
+
slotDuration: p,
|
|
181
|
+
onSlotClick: z,
|
|
182
|
+
readOnly: w
|
|
183
|
+
}
|
|
184
|
+
)
|
|
185
|
+
] });
|
|
186
|
+
}
|
|
187
|
+
F.displayName = "AppointmentScheduler";
|
|
188
|
+
export {
|
|
189
|
+
F as A,
|
|
190
|
+
T as S
|
|
191
|
+
};
|
|
192
|
+
//# sourceMappingURL=appointment-scheduler-DHAs-mF_.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"appointment-scheduler-DHAs-mF_.js","sources":["../src/components/scheduling/appointment-scheduler/scheduler-grid.tsx","../src/components/scheduling/appointment-scheduler/appointment-scheduler.tsx"],"sourcesContent":["import * as React from 'react'\nimport { cn } from '@/utils/cn'\nimport { ScrollArea, ScrollBar } from '@/components/ui/scroll-area'\nimport { useLocale } from '@/providers/locale-provider'\nimport type { TimeSlot, SchedulerProps } from './scheduler-types'\n\ninterface SchedulerGridProps {\n slots: TimeSlot[]\n weekStart: Date\n startHour: number\n endHour: number\n slotDuration: number\n onSlotClick?: SchedulerProps['onSlotClick']\n readOnly?: boolean\n}\n\n/** Format a Date to YYYY-MM-DD. */\nfunction toISODate(d: Date): string {\n const y = d.getFullYear()\n const m = String(d.getMonth() + 1).padStart(2, '0')\n const day = String(d.getDate()).padStart(2, '0')\n return `${y}-${m}-${day}`\n}\n\n/** Format a number as two-digit HH:mm time label. */\nfunction formatTime(hour: number, minute: number): string {\n return `${String(hour).padStart(2, '0')}:${String(minute).padStart(2, '0')}`\n}\n\n/** Generate time row labels based on start/end hour and duration. */\nfunction buildTimeRows(startHour: number, endHour: number, duration: number) {\n const rows: string[] = []\n let h = startHour\n let m = 0\n while (h < endHour || (h === endHour && m === 0)) {\n rows.push(formatTime(h, m))\n m += duration\n if (m >= 60) {\n h += Math.floor(m / 60)\n m = m % 60\n }\n }\n return rows\n}\n\nconst STATUS_STYLES: Record<TimeSlot['status'], string> = {\n available:\n 'bg-primary/10 hover:bg-primary/20 cursor-pointer border-primary/20',\n booked:\n 'bg-muted border-muted-foreground/20 cursor-default',\n blocked:\n 'bg-muted-foreground/10 border-muted-foreground/10 cursor-not-allowed opacity-60',\n}\n\n/**\n * SchedulerGrid -- Weekly time slot grid.\n *\n * 7-day columns x time-slot rows with colour-coded status cells.\n */\nfunction SchedulerGrid({\n slots,\n weekStart,\n startHour,\n endHour,\n slotDuration,\n onSlotClick,\n readOnly,\n}: SchedulerGridProps) {\n const { t } = useLocale()\n\n const dayLabels = React.useMemo(() => [\n t('scheduler.days.mon'),\n t('scheduler.days.tue'),\n t('scheduler.days.wed'),\n t('scheduler.days.thu'),\n t('scheduler.days.fri'),\n t('scheduler.days.sat'),\n t('scheduler.days.sun'),\n ], [t])\n\n const days = React.useMemo(() => {\n const result: Date[] = []\n for (let i = 0; i < 7; i++) {\n const d = new Date(weekStart)\n d.setDate(d.getDate() + i)\n result.push(d)\n }\n return result\n }, [weekStart])\n\n const timeRows = React.useMemo(\n () => buildTimeRows(startHour, endHour, slotDuration),\n [startHour, endHour, slotDuration]\n )\n\n /** Quick lookup: \"date|startTime\" -> slot */\n const slotMap = React.useMemo(() => {\n const map = new Map<string, TimeSlot>()\n for (const s of slots) {\n map.set(`${s.date}|${s.startTime}`, s)\n }\n return map\n }, [slots])\n\n const handleClick = (slot: TimeSlot | undefined) => {\n if (!slot || readOnly) return\n if (slot.status === 'available') {\n onSlotClick?.(slot)\n }\n }\n\n return (\n <ScrollArea className=\"flex-1\">\n <table className=\"w-full min-w-[640px] border-collapse text-xs\">\n <thead>\n <tr>\n {/* Time column header */}\n <th className=\"sticky left-0 z-10 w-16 border-b border-r bg-muted/40 p-2 text-left text-muted-foreground font-medium\">\n {t('scheduler.time')}\n </th>\n {days.map((day, i) => {\n const isToday = toISODate(day) === toISODate(new Date())\n return (\n <th\n key={i}\n className={cn(\n 'border-b border-r p-2 text-center font-medium',\n isToday ? 'bg-primary/5 text-primary' : 'text-muted-foreground'\n )}\n >\n <div className=\"text-[11px]\">{dayLabels[i]}</div>\n <div className={cn('text-sm', isToday && 'font-semibold')}>\n {day.getDate()}\n </div>\n </th>\n )\n })}\n </tr>\n </thead>\n <tbody>\n {timeRows.map((time) => (\n <tr key={time}>\n <td className=\"sticky left-0 z-10 border-b border-r bg-background px-2 py-1 text-[11px] text-muted-foreground font-mono whitespace-nowrap\">\n {time}\n </td>\n {days.map((day, di) => {\n const dateStr = toISODate(day)\n const slot = slotMap.get(`${dateStr}|${time}`)\n const status = slot?.status ?? 'blocked'\n return (\n <td\n key={di}\n className={cn(\n 'border-b border-r p-0.5 transition-colors',\n )}\n >\n <button\n type=\"button\"\n disabled={readOnly || status !== 'available'}\n onClick={() => handleClick(slot)}\n className={cn(\n 'flex h-8 w-full items-center justify-center rounded-sm border text-[10px] transition-colors',\n STATUS_STYLES[status]\n )}\n aria-label={\n slot\n ? `${slot.startTime}-${slot.endTime} ${status}${slot.label ? ': ' + slot.label : ''}`\n : `${time} ${t('scheduler.unavailable')}`\n }\n >\n {slot?.label && (\n <span className=\"truncate px-1\">{slot.label}</span>\n )}\n </button>\n </td>\n )\n })}\n </tr>\n ))}\n </tbody>\n </table>\n <ScrollBar orientation=\"horizontal\" />\n </ScrollArea>\n )\n}\n\nSchedulerGrid.displayName = 'SchedulerGrid'\n\nexport { SchedulerGrid }\n","import * as React from 'react'\nimport { ChevronLeft, ChevronRight } from 'lucide-react'\nimport { cn } from '@/utils/cn'\nimport { Button } from '@/components/ui/button'\nimport { useLocale } from '@/providers/locale-provider'\nimport { useControllableState } from '@/hooks/use-controllable-state'\nimport { SchedulerGrid } from './scheduler-grid'\nimport type { SchedulerProps } from './scheduler-types'\n\n/** Get the Monday of the week that contains `date`. */\nfunction getMonday(date: Date): Date {\n const d = new Date(date)\n const day = d.getDay()\n // Shift so that Monday=0 ... Sunday=6\n const diff = day === 0 ? -6 : 1 - day\n d.setDate(d.getDate() + diff)\n d.setHours(0, 0, 0, 0)\n return d\n}\n\n/** Format a date range for display: \"Jan 6 - 12, 2025\" */\nfunction formatWeekRange(monday: Date): string {\n const sunday = new Date(monday)\n sunday.setDate(sunday.getDate() + 6)\n\n const opts: Intl.DateTimeFormatOptions = { month: 'short', day: 'numeric' }\n const startStr = monday.toLocaleDateString('en-US', opts)\n const endDay = sunday.getDate()\n const year = sunday.getFullYear()\n\n if (monday.getMonth() === sunday.getMonth()) {\n return `${startStr} - ${endDay}, ${year}`\n }\n const endStr = sunday.toLocaleDateString('en-US', opts)\n return `${startStr} - ${endStr}, ${year}`\n}\n\n/**\n * AppointmentScheduler -- Weekly appointment slot grid with navigation.\n *\n * Shows a 7-day view of time slots with prev/next week and \"Today\" buttons.\n *\n * @example\n * ```tsx\n * <AppointmentScheduler\n * slots={slots}\n * startHour={9}\n * endHour={17}\n * slotDuration={30}\n * onSlotClick={(slot) => console.log('clicked', slot)}\n * />\n * ```\n */\nfunction AppointmentScheduler({\n slots,\n weekStart: controlledWeekStart,\n defaultWeekStart,\n onWeekStartChange,\n startHour = 8,\n endHour = 18,\n slotDuration = 30,\n onSlotClick,\n onSlotBook,\n readOnly = false,\n className,\n}: SchedulerProps) {\n const { t } = useLocale()\n const [weekStart, setWeekStart] = useControllableState<string>({\n value: controlledWeekStart,\n defaultValue: defaultWeekStart ?? getMonday(new Date()).toISOString().slice(0, 10),\n onChange: onWeekStartChange,\n })\n\n const monday = getMonday(new Date(weekStart))\n\n const updateWeekStart = React.useCallback(\n (date: Date) => {\n setWeekStart(getMonday(date).toISOString().slice(0, 10))\n },\n [setWeekStart]\n )\n\n const goToday = () => updateWeekStart(new Date())\n const goPrev = () => {\n const d = new Date(monday)\n d.setDate(d.getDate() - 7)\n updateWeekStart(d)\n }\n const goNext = () => {\n const d = new Date(monday)\n d.setDate(d.getDate() + 7)\n updateWeekStart(d)\n }\n\n const handleSlotClick = (slot: typeof slots[number]) => {\n onSlotClick?.(slot)\n if (slot.status === 'available') {\n onSlotBook?.(slot)\n }\n }\n\n return (\n <div className={cn('flex flex-col overflow-hidden rounded-lg border bg-background', className)}>\n {/* Navigation bar */}\n <div className=\"flex items-center justify-between border-b px-3 py-2\">\n <div className=\"flex items-center gap-1\">\n <Button variant=\"outline\" size=\"sm\" className=\"h-7 px-2\" onClick={goPrev} aria-label={t('scheduler.previousWeek')}>\n <ChevronLeft className=\"h-4 w-4\" />\n </Button>\n <Button variant=\"outline\" size=\"sm\" className=\"h-7 px-3 text-xs\" onClick={goToday}>\n {t('scheduler.today')}\n </Button>\n <Button variant=\"outline\" size=\"sm\" className=\"h-7 px-2\" onClick={goNext} aria-label={t('scheduler.nextWeek')}>\n <ChevronRight className=\"h-4 w-4\" />\n </Button>\n </div>\n <span className=\"text-sm font-semibold\">{formatWeekRange(monday)}</span>\n </div>\n\n {/* Grid */}\n <SchedulerGrid\n slots={slots}\n weekStart={monday}\n startHour={startHour}\n endHour={endHour}\n slotDuration={slotDuration}\n onSlotClick={handleSlotClick}\n readOnly={readOnly}\n />\n </div>\n )\n}\n\nAppointmentScheduler.displayName = 'AppointmentScheduler'\n\nexport { AppointmentScheduler }\n"],"names":["toISODate","d","y","m","day","formatTime","hour","minute","buildTimeRows","startHour","endHour","duration","rows","h","STATUS_STYLES","SchedulerGrid","slots","weekStart","slotDuration","onSlotClick","readOnly","t","useLocale","dayLabels","React","days","result","i","timeRows","slotMap","map","s","handleClick","slot","jsxs","ScrollArea","jsx","isToday","cn","time","di","dateStr","status","ScrollBar","getMonday","date","diff","formatWeekRange","monday","sunday","opts","startStr","endDay","year","endStr","AppointmentScheduler","controlledWeekStart","defaultWeekStart","onWeekStartChange","onSlotBook","className","setWeekStart","useControllableState","updateWeekStart","goToday","goPrev","goNext","handleSlotClick","Button","ChevronLeft","ChevronRight"],"mappings":";;;;;;;;;AAiBA,SAASA,EAAUC,GAAiB;AAClC,QAAMC,IAAID,EAAE,YAAA,GACNE,IAAI,OAAOF,EAAE,SAAA,IAAa,CAAC,EAAE,SAAS,GAAG,GAAG,GAC5CG,IAAM,OAAOH,EAAE,QAAA,CAAS,EAAE,SAAS,GAAG,GAAG;AAC/C,SAAO,GAAGC,CAAC,IAAIC,CAAC,IAAIC,CAAG;AACzB;AAGA,SAASC,EAAWC,GAAcC,GAAwB;AACxD,SAAO,GAAG,OAAOD,CAAI,EAAE,SAAS,GAAG,GAAG,CAAC,IAAI,OAAOC,CAAM,EAAE,SAAS,GAAG,GAAG,CAAC;AAC5E;AAGA,SAASC,EAAcC,GAAmBC,GAAiBC,GAAkB;AAC3E,QAAMC,IAAiB,CAAA;AACvB,MAAIC,IAAIJ,GACJN,IAAI;AACR,SAAOU,IAAIH,KAAYG,MAAMH,KAAWP,MAAM;AAC5C,IAAAS,EAAK,KAAKP,EAAWQ,GAAGV,CAAC,CAAC,GAC1BA,KAAKQ,GACDR,KAAK,OACPU,KAAK,KAAK,MAAMV,IAAI,EAAE,GACtBA,IAAIA,IAAI;AAGZ,SAAOS;AACT;AAEA,MAAME,IAAoD;AAAA,EACxD,WACE;AAAA,EACF,QACE;AAAA,EACF,SACE;AACJ;AAOA,SAASC,EAAc;AAAA,EACrB,OAAAC;AAAA,EACA,WAAAC;AAAA,EACA,WAAAR;AAAA,EACA,SAAAC;AAAA,EACA,cAAAQ;AAAA,EACA,aAAAC;AAAA,EACA,UAAAC;AACF,GAAuB;AACrB,QAAM,EAAE,GAAAC,EAAA,IAAMC,EAAA,GAERC,IAAYC,EAAM,QAAQ,MAAM;AAAA,IACpCH,EAAE,oBAAoB;AAAA,IACtBA,EAAE,oBAAoB;AAAA,IACtBA,EAAE,oBAAoB;AAAA,IACtBA,EAAE,oBAAoB;AAAA,IACtBA,EAAE,oBAAoB;AAAA,IACtBA,EAAE,oBAAoB;AAAA,IACtBA,EAAE,oBAAoB;AAAA,EAAA,GACrB,CAACA,CAAC,CAAC,GAEAI,IAAOD,EAAM,QAAQ,MAAM;AAC/B,UAAME,IAAiB,CAAA;AACvB,aAASC,IAAI,GAAGA,IAAI,GAAGA,KAAK;AAC1B,YAAM1B,IAAI,IAAI,KAAKgB,CAAS;AAC5B,MAAAhB,EAAE,QAAQA,EAAE,QAAA,IAAY0B,CAAC,GACzBD,EAAO,KAAKzB,CAAC;AAAA,IACf;AACA,WAAOyB;AAAA,EACT,GAAG,CAACT,CAAS,CAAC,GAERW,IAAWJ,EAAM;AAAA,IACrB,MAAMhB,EAAcC,GAAWC,GAASQ,CAAY;AAAA,IACpD,CAACT,GAAWC,GAASQ,CAAY;AAAA,EAAA,GAI7BW,IAAUL,EAAM,QAAQ,MAAM;AAClC,UAAMM,wBAAU,IAAA;AAChB,eAAWC,KAAKf;AACd,MAAAc,EAAI,IAAI,GAAGC,EAAE,IAAI,IAAIA,EAAE,SAAS,IAAIA,CAAC;AAEvC,WAAOD;AAAA,EACT,GAAG,CAACd,CAAK,CAAC,GAEJgB,IAAc,CAACC,MAA+B;AAClD,IAAI,CAACA,KAAQb,KACTa,EAAK,WAAW,gBAClBd,KAAA,QAAAA,EAAcc;AAAA,EAElB;AAEA,SACE,gBAAAC,EAACC,GAAA,EAAW,WAAU,UACpB,UAAA;AAAA,IAAA,gBAAAD,EAAC,SAAA,EAAM,WAAU,gDACf,UAAA;AAAA,MAAA,gBAAAE,EAAC,SAAA,EACC,4BAAC,MAAA,EAEC,UAAA;AAAA,QAAA,gBAAAA,EAAC,MAAA,EAAG,WAAU,yGACX,UAAAf,EAAE,gBAAgB,GACrB;AAAA,QACCI,EAAK,IAAI,CAACrB,GAAKuB,MAAM;AACpB,gBAAMU,IAAUrC,EAAUI,CAAG,MAAMJ,EAAU,oBAAI,MAAM;AACvD,iBACE,gBAAAkC;AAAA,YAAC;AAAA,YAAA;AAAA,cAEC,WAAWI;AAAA,gBACT;AAAA,gBACAD,IAAU,8BAA8B;AAAA,cAAA;AAAA,cAG1C,UAAA;AAAA,gBAAA,gBAAAD,EAAC,OAAA,EAAI,WAAU,eAAe,UAAAb,EAAUI,CAAC,GAAE;AAAA,gBAC3C,gBAAAS,EAAC,OAAA,EAAI,WAAWE,EAAG,WAAWD,KAAW,eAAe,GACrD,UAAAjC,EAAI,QAAA,EAAQ,CACf;AAAA,cAAA;AAAA,YAAA;AAAA,YATKuB;AAAA,UAAA;AAAA,QAYX,CAAC;AAAA,MAAA,EAAA,CACH,EAAA,CACF;AAAA,wBACC,SAAA,EACE,UAAAC,EAAS,IAAI,CAACW,wBACZ,MAAA,EACC,UAAA;AAAA,QAAA,gBAAAH,EAAC,MAAA,EAAG,WAAU,8HACX,UAAAG,GACH;AAAA,QACCd,EAAK,IAAI,CAACrB,GAAKoC,MAAO;AACrB,gBAAMC,IAAUzC,EAAUI,CAAG,GACvB6B,IAAOJ,EAAQ,IAAI,GAAGY,CAAO,IAAIF,CAAI,EAAE,GACvCG,KAAST,KAAA,gBAAAA,EAAM,WAAU;AAC/B,iBACE,gBAAAG;AAAA,YAAC;AAAA,YAAA;AAAA,cAEC,WAAWE;AAAA,gBACT;AAAA,cAAA;AAAA,cAGF,UAAA,gBAAAF;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC,MAAK;AAAA,kBACL,UAAUhB,KAAYsB,MAAW;AAAA,kBACjC,SAAS,MAAMV,EAAYC,CAAI;AAAA,kBAC/B,WAAWK;AAAA,oBACT;AAAA,oBACAxB,EAAc4B,CAAM;AAAA,kBAAA;AAAA,kBAEtB,cACET,IACI,GAAGA,EAAK,SAAS,IAAIA,EAAK,OAAO,IAAIS,CAAM,GAAGT,EAAK,QAAQ,OAAOA,EAAK,QAAQ,EAAE,KACjF,GAAGM,CAAI,IAAIlB,EAAE,uBAAuB,CAAC;AAAA,kBAG1C,kCAAM,UACL,gBAAAe,EAAC,UAAK,WAAU,iBAAiB,YAAK,MAAA,CAAM;AAAA,gBAAA;AAAA,cAAA;AAAA,YAEhD;AAAA,YAtBKI;AAAA,UAAA;AAAA,QAyBX,CAAC;AAAA,MAAA,EAAA,GAnCMD,CAoCT,CACD,EAAA,CACH;AAAA,IAAA,GACF;AAAA,IACA,gBAAAH,EAACO,GAAA,EAAU,aAAY,aAAA,CAAa;AAAA,EAAA,GACtC;AAEJ;AAEA5B,EAAc,cAAc;AChL5B,SAAS6B,EAAUC,GAAkB;AACnC,QAAM5C,IAAI,IAAI,KAAK4C,CAAI,GACjBzC,IAAMH,EAAE,OAAA,GAER6C,IAAO1C,MAAQ,IAAI,KAAK,IAAIA;AAClC,SAAAH,EAAE,QAAQA,EAAE,QAAA,IAAY6C,CAAI,GAC5B7C,EAAE,SAAS,GAAG,GAAG,GAAG,CAAC,GACdA;AACT;AAGA,SAAS8C,EAAgBC,GAAsB;AAC7C,QAAMC,IAAS,IAAI,KAAKD,CAAM;AAC9B,EAAAC,EAAO,QAAQA,EAAO,QAAA,IAAY,CAAC;AAEnC,QAAMC,IAAmC,EAAE,OAAO,SAAS,KAAK,UAAA,GAC1DC,IAAWH,EAAO,mBAAmB,SAASE,CAAI,GAClDE,IAASH,EAAO,QAAA,GAChBI,IAAOJ,EAAO,YAAA;AAEpB,MAAID,EAAO,SAAA,MAAeC,EAAO;AAC/B,WAAO,GAAGE,CAAQ,MAAMC,CAAM,KAAKC,CAAI;AAEzC,QAAMC,IAASL,EAAO,mBAAmB,SAASC,CAAI;AACtD,SAAO,GAAGC,CAAQ,MAAMG,CAAM,KAAKD,CAAI;AACzC;AAkBA,SAASE,EAAqB;AAAA,EAC5B,OAAAvC;AAAA,EACA,WAAWwC;AAAA,EACX,kBAAAC;AAAA,EACA,mBAAAC;AAAA,EACA,WAAAjD,IAAY;AAAA,EACZ,SAAAC,IAAU;AAAA,EACV,cAAAQ,IAAe;AAAA,EACf,aAAAC;AAAA,EACA,YAAAwC;AAAA,EACA,UAAAvC,IAAW;AAAA,EACX,WAAAwC;AACF,GAAmB;AACjB,QAAM,EAAE,GAAAvC,EAAA,IAAMC,EAAA,GACR,CAACL,GAAW4C,CAAY,IAAIC,EAA6B;AAAA,IAC7D,OAAON;AAAA,IACP,cAAcC,KAAoBb,EAAU,oBAAI,KAAA,CAAM,EAAE,cAAc,MAAM,GAAG,EAAE;AAAA,IACjF,UAAUc;AAAA,EAAA,CACX,GAEKV,IAASJ,EAAU,IAAI,KAAK3B,CAAS,CAAC,GAEtC8C,IAAkBvC,EAAM;AAAA,IAC5B,CAACqB,MAAe;AACd,MAAAgB,EAAajB,EAAUC,CAAI,EAAE,YAAA,EAAc,MAAM,GAAG,EAAE,CAAC;AAAA,IACzD;AAAA,IACA,CAACgB,CAAY;AAAA,EAAA,GAGTG,IAAU,MAAMD,EAAgB,oBAAI,MAAM,GAC1CE,IAAS,MAAM;AACnB,UAAMhE,IAAI,IAAI,KAAK+C,CAAM;AACzB,IAAA/C,EAAE,QAAQA,EAAE,QAAA,IAAY,CAAC,GACzB8D,EAAgB9D,CAAC;AAAA,EACnB,GACMiE,IAAS,MAAM;AACnB,UAAMjE,IAAI,IAAI,KAAK+C,CAAM;AACzB,IAAA/C,EAAE,QAAQA,EAAE,QAAA,IAAY,CAAC,GACzB8D,EAAgB9D,CAAC;AAAA,EACnB,GAEMkE,IAAkB,CAAClC,MAA+B;AACtD,IAAAd,KAAA,QAAAA,EAAcc,IACVA,EAAK,WAAW,gBAClB0B,KAAA,QAAAA,EAAa1B;AAAA,EAEjB;AAEA,2BACG,OAAA,EAAI,WAAWK,EAAG,iEAAiEsB,CAAS,GAE3F,UAAA;AAAA,IAAA,gBAAA1B,EAAC,OAAA,EAAI,WAAU,wDACb,UAAA;AAAA,MAAA,gBAAAA,EAAC,OAAA,EAAI,WAAU,2BACb,UAAA;AAAA,QAAA,gBAAAE,EAACgC,KAAO,SAAQ,WAAU,MAAK,MAAK,WAAU,YAAW,SAASH,GAAQ,cAAY5C,EAAE,wBAAwB,GAC9G,4BAACgD,GAAA,EAAY,WAAU,WAAU,GACnC;AAAA,QACA,gBAAAjC,EAACgC,GAAA,EAAO,SAAQ,WAAU,MAAK,MAAK,WAAU,oBAAmB,SAASJ,GACvE,UAAA3C,EAAE,iBAAiB,EAAA,CACtB;AAAA,0BACC+C,GAAA,EAAO,SAAQ,WAAU,MAAK,MAAK,WAAU,YAAW,SAASF,GAAQ,cAAY7C,EAAE,oBAAoB,GAC1G,4BAACiD,GAAA,EAAa,WAAU,WAAU,EAAA,CACpC;AAAA,MAAA,GACF;AAAA,wBACC,QAAA,EAAK,WAAU,yBAAyB,UAAAvB,EAAgBC,CAAM,EAAA,CAAE;AAAA,IAAA,GACnE;AAAA,IAGA,gBAAAZ;AAAA,MAACrB;AAAA,MAAA;AAAA,QACC,OAAAC;AAAA,QACA,WAAWgC;AAAA,QACX,WAAAvC;AAAA,QACA,SAAAC;AAAA,QACA,cAAAQ;AAAA,QACA,aAAaiD;AAAA,QACb,UAAA/C;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,GACF;AAEJ;AAEAmC,EAAqB,cAAc;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { c as r } from "./scroll-area-CGNbDUBQ.js";
|
|
2
|
+
/**
|
|
3
|
+
* @license lucide-react v0.441.0 - ISC
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the ISC license.
|
|
6
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
const o = r("ArrowRight", [
|
|
9
|
+
["path", { d: "M5 12h14", key: "1ays0h" }],
|
|
10
|
+
["path", { d: "m12 5 7 7-7 7", key: "xquz4c" }]
|
|
11
|
+
]);
|
|
12
|
+
export {
|
|
13
|
+
o as A
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=arrow-right-CM3nmiZe.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arrow-right-CM3nmiZe.js","sources":["../node_modules/lucide-react/dist/esm/icons/arrow-right.js"],"sourcesContent":["/**\n * @license lucide-react v0.441.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst ArrowRight = createLucideIcon(\"ArrowRight\", [\n [\"path\", { d: \"M5 12h14\", key: \"1ays0h\" }],\n [\"path\", { d: \"m12 5 7 7-7 7\", key: \"xquz4c\" }]\n]);\n\nexport { ArrowRight as default };\n//# sourceMappingURL=arrow-right.js.map\n"],"names":["ArrowRight","createLucideIcon"],"mappings":";AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASK,MAACA,IAAaC,EAAiB,cAAc;AAAA,EAChD,CAAC,QAAQ,EAAE,GAAG,YAAY,KAAK,SAAQ,CAAE;AAAA,EACzC,CAAC,QAAQ,EAAE,GAAG,iBAAiB,KAAK,SAAQ,CAAE;AAChD,CAAC;","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";const r=require("./scroll-area-HsTSI_58.cjs");/**
|
|
2
|
+
* @license lucide-react v0.441.0 - ISC
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the ISC license.
|
|
5
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/const t=r.createLucideIcon("ArrowRight",[["path",{d:"M5 12h14",key:"1ays0h"}],["path",{d:"m12 5 7 7-7 7",key:"xquz4c"}]]);exports.ArrowRight=t;
|
|
7
|
+
//# sourceMappingURL=arrow-right-vDxRZOfm.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arrow-right-vDxRZOfm.cjs","sources":["../node_modules/lucide-react/dist/esm/icons/arrow-right.js"],"sourcesContent":["/**\n * @license lucide-react v0.441.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst ArrowRight = createLucideIcon(\"ArrowRight\", [\n [\"path\", { d: \"M5 12h14\", key: \"1ays0h\" }],\n [\"path\", { d: \"m12 5 7 7-7 7\", key: \"xquz4c\" }]\n]);\n\nexport { ArrowRight as default };\n//# sourceMappingURL=arrow-right.js.map\n"],"names":["ArrowRight","createLucideIcon"],"mappings":"2DAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GASK,MAACA,EAAaC,EAAAA,iBAAiB,aAAc,CAChD,CAAC,OAAQ,CAAE,EAAG,WAAY,IAAK,QAAQ,CAAE,EACzC,CAAC,OAAQ,CAAE,EAAG,gBAAiB,IAAK,QAAQ,CAAE,CAChD,CAAC","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { jsx as l } from "react/jsx-runtime";
|
|
2
|
+
import * as u from "react";
|
|
3
|
+
import { j as M, h as x } from "./scroll-area-CGNbDUBQ.js";
|
|
4
|
+
import "react-dom";
|
|
5
|
+
import { a as F } from "./button-BP_ug5gP.js";
|
|
6
|
+
import { s as j } from "./badge-D0C_rP2l.js";
|
|
7
|
+
import { c as w } from "./index-BGUveO6l.js";
|
|
8
|
+
function H(e, t = []) {
|
|
9
|
+
let a = [];
|
|
10
|
+
function o(r, i) {
|
|
11
|
+
const n = u.createContext(i);
|
|
12
|
+
n.displayName = r + "Context";
|
|
13
|
+
const c = a.length;
|
|
14
|
+
a = [...a, i];
|
|
15
|
+
const d = (f) => {
|
|
16
|
+
var y;
|
|
17
|
+
const { scope: m, children: S, ...p } = f, g = ((y = m == null ? void 0 : m[e]) == null ? void 0 : y[c]) || n, k = u.useMemo(() => p, Object.values(p));
|
|
18
|
+
return /* @__PURE__ */ l(g.Provider, { value: k, children: S });
|
|
19
|
+
};
|
|
20
|
+
d.displayName = r + "Provider";
|
|
21
|
+
function v(f, m) {
|
|
22
|
+
var g;
|
|
23
|
+
const S = ((g = m == null ? void 0 : m[e]) == null ? void 0 : g[c]) || n, p = u.useContext(S);
|
|
24
|
+
if (p) return p;
|
|
25
|
+
if (i !== void 0) return i;
|
|
26
|
+
throw new Error(`\`${f}\` must be used within \`${r}\``);
|
|
27
|
+
}
|
|
28
|
+
return [d, v];
|
|
29
|
+
}
|
|
30
|
+
const s = () => {
|
|
31
|
+
const r = a.map((i) => u.createContext(i));
|
|
32
|
+
return function(n) {
|
|
33
|
+
const c = (n == null ? void 0 : n[e]) || r;
|
|
34
|
+
return u.useMemo(
|
|
35
|
+
() => ({ [`__scope${e}`]: { ...n, [e]: c } }),
|
|
36
|
+
[n, c]
|
|
37
|
+
);
|
|
38
|
+
};
|
|
39
|
+
};
|
|
40
|
+
return s.scopeName = e, [o, T(s, ...t)];
|
|
41
|
+
}
|
|
42
|
+
function T(...e) {
|
|
43
|
+
const t = e[0];
|
|
44
|
+
if (e.length === 1) return t;
|
|
45
|
+
const a = () => {
|
|
46
|
+
const o = e.map((s) => ({
|
|
47
|
+
useScope: s(),
|
|
48
|
+
scopeName: s.scopeName
|
|
49
|
+
}));
|
|
50
|
+
return function(r) {
|
|
51
|
+
const i = o.reduce((n, { useScope: c, scopeName: d }) => {
|
|
52
|
+
const f = c(r)[`__scope${d}`];
|
|
53
|
+
return { ...n, ...f };
|
|
54
|
+
}, {});
|
|
55
|
+
return u.useMemo(() => ({ [`__scope${t.scopeName}`]: i }), [i]);
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
return a.scopeName = t.scopeName, a;
|
|
59
|
+
}
|
|
60
|
+
var B = [
|
|
61
|
+
"a",
|
|
62
|
+
"button",
|
|
63
|
+
"div",
|
|
64
|
+
"form",
|
|
65
|
+
"h2",
|
|
66
|
+
"h3",
|
|
67
|
+
"img",
|
|
68
|
+
"input",
|
|
69
|
+
"label",
|
|
70
|
+
"li",
|
|
71
|
+
"nav",
|
|
72
|
+
"ol",
|
|
73
|
+
"p",
|
|
74
|
+
"select",
|
|
75
|
+
"span",
|
|
76
|
+
"svg",
|
|
77
|
+
"ul"
|
|
78
|
+
], A = B.reduce((e, t) => {
|
|
79
|
+
const a = F(`Primitive.${t}`), o = u.forwardRef((s, r) => {
|
|
80
|
+
const { asChild: i, ...n } = s, c = i ? a : t;
|
|
81
|
+
return typeof window < "u" && (window[Symbol.for("radix-ui")] = !0), /* @__PURE__ */ l(c, { ...n, ref: r });
|
|
82
|
+
});
|
|
83
|
+
return o.displayName = `Primitive.${t}`, { ...e, [t]: o };
|
|
84
|
+
}, {});
|
|
85
|
+
function q() {
|
|
86
|
+
return j.useSyncExternalStore(
|
|
87
|
+
D,
|
|
88
|
+
() => !0,
|
|
89
|
+
() => !1
|
|
90
|
+
);
|
|
91
|
+
}
|
|
92
|
+
function D() {
|
|
93
|
+
return () => {
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
var h = "Avatar", [G] = H(h), [K, L] = G(h), N = u.forwardRef(
|
|
97
|
+
(e, t) => {
|
|
98
|
+
const { __scopeAvatar: a, ...o } = e, [s, r] = u.useState("idle");
|
|
99
|
+
return /* @__PURE__ */ l(
|
|
100
|
+
K,
|
|
101
|
+
{
|
|
102
|
+
scope: a,
|
|
103
|
+
imageLoadingStatus: s,
|
|
104
|
+
onImageLoadingStatusChange: r,
|
|
105
|
+
children: /* @__PURE__ */ l(A.span, { ...o, ref: t })
|
|
106
|
+
}
|
|
107
|
+
);
|
|
108
|
+
}
|
|
109
|
+
);
|
|
110
|
+
N.displayName = h;
|
|
111
|
+
var b = "AvatarImage", E = u.forwardRef(
|
|
112
|
+
(e, t) => {
|
|
113
|
+
const { __scopeAvatar: a, src: o, onLoadingStatusChange: s = () => {
|
|
114
|
+
}, ...r } = e, i = L(b, a), n = O(o, r), c = M((d) => {
|
|
115
|
+
s(d), i.onImageLoadingStatusChange(d);
|
|
116
|
+
});
|
|
117
|
+
return x(() => {
|
|
118
|
+
n !== "idle" && c(n);
|
|
119
|
+
}, [n, c]), n === "loaded" ? /* @__PURE__ */ l(A.img, { ...r, ref: t, src: o }) : null;
|
|
120
|
+
}
|
|
121
|
+
);
|
|
122
|
+
E.displayName = b;
|
|
123
|
+
var R = "AvatarFallback", _ = u.forwardRef(
|
|
124
|
+
(e, t) => {
|
|
125
|
+
const { __scopeAvatar: a, delayMs: o, ...s } = e, r = L(R, a), [i, n] = u.useState(o === void 0);
|
|
126
|
+
return u.useEffect(() => {
|
|
127
|
+
if (o !== void 0) {
|
|
128
|
+
const c = window.setTimeout(() => n(!0), o);
|
|
129
|
+
return () => window.clearTimeout(c);
|
|
130
|
+
}
|
|
131
|
+
}, [o]), i && r.imageLoadingStatus !== "loaded" ? /* @__PURE__ */ l(A.span, { ...s, ref: t }) : null;
|
|
132
|
+
}
|
|
133
|
+
);
|
|
134
|
+
_.displayName = R;
|
|
135
|
+
function C(e, t) {
|
|
136
|
+
return e ? t ? (e.src !== t && (e.src = t), e.complete && e.naturalWidth > 0 ? "loaded" : "loading") : "error" : "idle";
|
|
137
|
+
}
|
|
138
|
+
function O(e, { referrerPolicy: t, crossOrigin: a }) {
|
|
139
|
+
const o = q(), s = u.useRef(null), r = o ? (s.current || (s.current = new window.Image()), s.current) : null, [i, n] = u.useState(
|
|
140
|
+
() => C(r, e)
|
|
141
|
+
);
|
|
142
|
+
return x(() => {
|
|
143
|
+
n(C(r, e));
|
|
144
|
+
}, [r, e]), x(() => {
|
|
145
|
+
const c = (f) => () => {
|
|
146
|
+
n(f);
|
|
147
|
+
};
|
|
148
|
+
if (!r) return;
|
|
149
|
+
const d = c("loaded"), v = c("error");
|
|
150
|
+
return r.addEventListener("load", d), r.addEventListener("error", v), t && (r.referrerPolicy = t), typeof a == "string" && (r.crossOrigin = a), () => {
|
|
151
|
+
r.removeEventListener("load", d), r.removeEventListener("error", v);
|
|
152
|
+
};
|
|
153
|
+
}, [r, a, t]), i;
|
|
154
|
+
}
|
|
155
|
+
var I = N, P = E, $ = _;
|
|
156
|
+
const V = u.forwardRef(({ className: e, ...t }, a) => /* @__PURE__ */ l(
|
|
157
|
+
I,
|
|
158
|
+
{
|
|
159
|
+
ref: a,
|
|
160
|
+
className: w("relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full", e),
|
|
161
|
+
...t
|
|
162
|
+
}
|
|
163
|
+
));
|
|
164
|
+
V.displayName = I.displayName;
|
|
165
|
+
const W = u.forwardRef(({ className: e, ...t }, a) => /* @__PURE__ */ l(
|
|
166
|
+
P,
|
|
167
|
+
{
|
|
168
|
+
ref: a,
|
|
169
|
+
className: w("aspect-square h-full w-full", e),
|
|
170
|
+
...t
|
|
171
|
+
}
|
|
172
|
+
));
|
|
173
|
+
W.displayName = P.displayName;
|
|
174
|
+
const z = u.forwardRef(({ className: e, ...t }, a) => /* @__PURE__ */ l(
|
|
175
|
+
$,
|
|
176
|
+
{
|
|
177
|
+
ref: a,
|
|
178
|
+
className: w(
|
|
179
|
+
"flex h-full w-full items-center justify-center rounded-full bg-muted",
|
|
180
|
+
e
|
|
181
|
+
),
|
|
182
|
+
...t
|
|
183
|
+
}
|
|
184
|
+
));
|
|
185
|
+
z.displayName = $.displayName;
|
|
186
|
+
export {
|
|
187
|
+
V as A,
|
|
188
|
+
W as a,
|
|
189
|
+
z as b
|
|
190
|
+
};
|
|
191
|
+
//# sourceMappingURL=avatar-BlEcWE7T.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar-BlEcWE7T.js","sources":["../node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-use-is-hydrated/dist/index.mjs","../node_modules/@radix-ui/react-avatar/dist/index.mjs","../src/components/ui/avatar.tsx"],"sourcesContent":["// src/create-context.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createContext2(rootComponentName, defaultContext) {\n const Context = React.createContext(defaultContext);\n Context.displayName = rootComponentName + \"Context\";\n const Provider = (props) => {\n const { children, ...context } = props;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName) {\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n}\nfunction createContextScope(scopeName, createContextScopeDeps = []) {\n let defaultContexts = [];\n function createContext3(rootComponentName, defaultContext) {\n const BaseContext = React.createContext(defaultContext);\n BaseContext.displayName = rootComponentName + \"Context\";\n const index = defaultContexts.length;\n defaultContexts = [...defaultContexts, defaultContext];\n const Provider = (props) => {\n const { scope, children, ...context } = props;\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName, scope) {\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n }\n const createScope = () => {\n const scopeContexts = defaultContexts.map((defaultContext) => {\n return React.createContext(defaultContext);\n });\n return function useScope(scope) {\n const contexts = scope?.[scopeName] || scopeContexts;\n return React.useMemo(\n () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),\n [scope, contexts]\n );\n };\n };\n createScope.scopeName = scopeName;\n return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];\n}\nfunction composeContextScopes(...scopes) {\n const baseScope = scopes[0];\n if (scopes.length === 1) return baseScope;\n const createScope = () => {\n const scopeHooks = scopes.map((createScope2) => ({\n useScope: createScope2(),\n scopeName: createScope2.scopeName\n }));\n return function useComposedScopes(overrideScopes) {\n const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {\n const scopeProps = useScope(overrideScopes);\n const currentScope = scopeProps[`__scope${scopeName}`];\n return { ...nextScopes2, ...currentScope };\n }, {});\n return React.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);\n };\n };\n createScope.scopeName = baseScope.scopeName;\n return createScope;\n}\nexport {\n createContext2 as createContext,\n createContextScope\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","// src/use-is-hydrated.tsx\nimport { useSyncExternalStore } from \"use-sync-external-store/shim\";\nfunction useIsHydrated() {\n return useSyncExternalStore(\n subscribe,\n () => true,\n () => false\n );\n}\nfunction subscribe() {\n return () => {\n };\n}\nexport {\n useIsHydrated\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/avatar.tsx\nimport * as React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useIsHydrated } from \"@radix-ui/react-use-is-hydrated\";\nimport { jsx } from \"react/jsx-runtime\";\nvar AVATAR_NAME = \"Avatar\";\nvar [createAvatarContext, createAvatarScope] = createContextScope(AVATAR_NAME);\nvar [AvatarProvider, useAvatarContext] = createAvatarContext(AVATAR_NAME);\nvar Avatar = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, ...avatarProps } = props;\n const [imageLoadingStatus, setImageLoadingStatus] = React.useState(\"idle\");\n return /* @__PURE__ */ jsx(\n AvatarProvider,\n {\n scope: __scopeAvatar,\n imageLoadingStatus,\n onImageLoadingStatusChange: setImageLoadingStatus,\n children: /* @__PURE__ */ jsx(Primitive.span, { ...avatarProps, ref: forwardedRef })\n }\n );\n }\n);\nAvatar.displayName = AVATAR_NAME;\nvar IMAGE_NAME = \"AvatarImage\";\nvar AvatarImage = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, src, onLoadingStatusChange = () => {\n }, ...imageProps } = props;\n const context = useAvatarContext(IMAGE_NAME, __scopeAvatar);\n const imageLoadingStatus = useImageLoadingStatus(src, imageProps);\n const handleLoadingStatusChange = useCallbackRef((status) => {\n onLoadingStatusChange(status);\n context.onImageLoadingStatusChange(status);\n });\n useLayoutEffect(() => {\n if (imageLoadingStatus !== \"idle\") {\n handleLoadingStatusChange(imageLoadingStatus);\n }\n }, [imageLoadingStatus, handleLoadingStatusChange]);\n return imageLoadingStatus === \"loaded\" ? /* @__PURE__ */ jsx(Primitive.img, { ...imageProps, ref: forwardedRef, src }) : null;\n }\n);\nAvatarImage.displayName = IMAGE_NAME;\nvar FALLBACK_NAME = \"AvatarFallback\";\nvar AvatarFallback = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, delayMs, ...fallbackProps } = props;\n const context = useAvatarContext(FALLBACK_NAME, __scopeAvatar);\n const [canRender, setCanRender] = React.useState(delayMs === void 0);\n React.useEffect(() => {\n if (delayMs !== void 0) {\n const timerId = window.setTimeout(() => setCanRender(true), delayMs);\n return () => window.clearTimeout(timerId);\n }\n }, [delayMs]);\n return canRender && context.imageLoadingStatus !== \"loaded\" ? /* @__PURE__ */ jsx(Primitive.span, { ...fallbackProps, ref: forwardedRef }) : null;\n }\n);\nAvatarFallback.displayName = FALLBACK_NAME;\nfunction resolveLoadingStatus(image, src) {\n if (!image) {\n return \"idle\";\n }\n if (!src) {\n return \"error\";\n }\n if (image.src !== src) {\n image.src = src;\n }\n return image.complete && image.naturalWidth > 0 ? \"loaded\" : \"loading\";\n}\nfunction useImageLoadingStatus(src, { referrerPolicy, crossOrigin }) {\n const isHydrated = useIsHydrated();\n const imageRef = React.useRef(null);\n const image = (() => {\n if (!isHydrated) return null;\n if (!imageRef.current) {\n imageRef.current = new window.Image();\n }\n return imageRef.current;\n })();\n const [loadingStatus, setLoadingStatus] = React.useState(\n () => resolveLoadingStatus(image, src)\n );\n useLayoutEffect(() => {\n setLoadingStatus(resolveLoadingStatus(image, src));\n }, [image, src]);\n useLayoutEffect(() => {\n const updateStatus = (status) => () => {\n setLoadingStatus(status);\n };\n if (!image) return;\n const handleLoad = updateStatus(\"loaded\");\n const handleError = updateStatus(\"error\");\n image.addEventListener(\"load\", handleLoad);\n image.addEventListener(\"error\", handleError);\n if (referrerPolicy) {\n image.referrerPolicy = referrerPolicy;\n }\n if (typeof crossOrigin === \"string\") {\n image.crossOrigin = crossOrigin;\n }\n return () => {\n image.removeEventListener(\"load\", handleLoad);\n image.removeEventListener(\"error\", handleError);\n };\n }, [image, crossOrigin, referrerPolicy]);\n return loadingStatus;\n}\nvar Root = Avatar;\nvar Image = AvatarImage;\nvar Fallback = AvatarFallback;\nexport {\n Avatar,\n AvatarFallback,\n AvatarImage,\n Fallback,\n Image,\n Root,\n createAvatarScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from 'react'\nimport * as AvatarPrimitive from '@radix-ui/react-avatar'\nimport { cn } from '@/utils/cn'\n\nconst Avatar = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Root>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Root\n ref={ref}\n className={cn('relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full', className)}\n {...props}\n />\n))\nAvatar.displayName = AvatarPrimitive.Root.displayName\n\nconst AvatarImage = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Image>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Image>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Image\n ref={ref}\n className={cn('aspect-square h-full w-full', className)}\n {...props}\n />\n))\nAvatarImage.displayName = AvatarPrimitive.Image.displayName\n\nconst AvatarFallback = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Fallback>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Fallback>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Fallback\n ref={ref}\n className={cn(\n 'flex h-full w-full items-center justify-center rounded-full bg-muted',\n className\n )}\n {...props}\n />\n))\nAvatarFallback.displayName = AvatarPrimitive.Fallback.displayName\n\nexport { Avatar, AvatarImage, AvatarFallback }\n"],"names":["createContextScope","scopeName","createContextScopeDeps","defaultContexts","createContext3","rootComponentName","defaultContext","BaseContext","React","index","Provider","props","scope","children","context","Context","_a","value","jsx","useContext2","consumerName","createScope","scopeContexts","contexts","composeContextScopes","scopes","baseScope","scopeHooks","createScope2","overrideScopes","nextScopes","nextScopes2","useScope","currentScope","NODES","Primitive","primitive","node","Slot","createSlot","Node","forwardedRef","asChild","primitiveProps","Comp","useIsHydrated","useSyncExternalStore","subscribe","AVATAR_NAME","createAvatarContext","AvatarProvider","useAvatarContext","Avatar","__scopeAvatar","avatarProps","imageLoadingStatus","setImageLoadingStatus","IMAGE_NAME","AvatarImage","src","onLoadingStatusChange","imageProps","useImageLoadingStatus","handleLoadingStatusChange","useCallbackRef","status","useLayoutEffect","FALLBACK_NAME","AvatarFallback","delayMs","fallbackProps","canRender","setCanRender","timerId","resolveLoadingStatus","image","referrerPolicy","crossOrigin","isHydrated","imageRef","loadingStatus","setLoadingStatus","updateStatus","handleLoad","handleError","Root","Image","Fallback","className","ref","AvatarPrimitive.Root","cn","AvatarPrimitive.Image","AvatarPrimitive.Fallback"],"mappings":"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","x_google_ignoreList":[0,1,2,3]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";const d=require("react/jsx-runtime"),F=require("react"),x=require("./scroll-area-HsTSI_58.cjs");require("react-dom");const O=require("./button-CPuCii0R.cjs"),T=require("./badge-BZcdBG5J.cjs"),A=require("./index-Dy_9oyP3.cjs");function D(e){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const r in e)if(r!=="default"){const o=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,o.get?o:{enumerable:!0,get:()=>e[r]})}}return t.default=e,Object.freeze(t)}const c=D(F);function H(e,t=[]){let r=[];function o(a,u){const n=c.createContext(u);n.displayName=a+"Context";const i=r.length;r=[...r,u];const l=f=>{var b;const{scope:v,children:S,...p}=f,g=((b=v==null?void 0:v[e])==null?void 0:b[i])||n,q=c.useMemo(()=>p,Object.values(p));return d.jsx(g.Provider,{value:q,children:S})};l.displayName=a+"Provider";function m(f,v){var g;const S=((g=v==null?void 0:v[e])==null?void 0:g[i])||n,p=c.useContext(S);if(p)return p;if(u!==void 0)return u;throw new Error(`\`${f}\` must be used within \`${a}\``)}return[l,m]}const s=()=>{const a=r.map(u=>c.createContext(u));return function(n){const i=(n==null?void 0:n[e])||a;return c.useMemo(()=>({[`__scope${e}`]:{...n,[e]:i}}),[n,i])}};return s.scopeName=e,[o,B(s,...t)]}function B(...e){const t=e[0];if(e.length===1)return t;const r=()=>{const o=e.map(s=>({useScope:s(),scopeName:s.scopeName}));return function(a){const u=o.reduce((n,{useScope:i,scopeName:l})=>{const f=i(a)[`__scope${l}`];return{...n,...f}},{});return c.useMemo(()=>({[`__scope${t.scopeName}`]:u}),[u])}};return r.scopeName=t.scopeName,r}var z=["a","button","div","form","h2","h3","img","input","label","li","nav","ol","p","select","span","svg","ul"],w=z.reduce((e,t)=>{const r=O.createSlot(`Primitive.${t}`),o=c.forwardRef((s,a)=>{const{asChild:u,...n}=s,i=u?r:t;return typeof window<"u"&&(window[Symbol.for("radix-ui")]=!0),d.jsx(i,{...n,ref:a})});return o.displayName=`Primitive.${t}`,{...e,[t]:o}},{});function G(){return T.shimExports.useSyncExternalStore(K,()=>!0,()=>!1)}function K(){return()=>{}}var y="Avatar",[V]=H(y),[W,L]=V(y),C=c.forwardRef((e,t)=>{const{__scopeAvatar:r,...o}=e,[s,a]=c.useState("idle");return d.jsx(W,{scope:r,imageLoadingStatus:s,onImageLoadingStatusChange:a,children:d.jsx(w.span,{...o,ref:t})})});C.displayName=y;var N="AvatarImage",_=c.forwardRef((e,t)=>{const{__scopeAvatar:r,src:o,onLoadingStatusChange:s=()=>{},...a}=e,u=L(N,r),n=J(o,a),i=x.useCallbackRef(l=>{s(l),u.onImageLoadingStatusChange(l)});return x.useLayoutEffect2(()=>{n!=="idle"&&i(n)},[n,i]),n==="loaded"?d.jsx(w.img,{...a,ref:t,src:o}):null});_.displayName=N;var E="AvatarFallback",R=c.forwardRef((e,t)=>{const{__scopeAvatar:r,delayMs:o,...s}=e,a=L(E,r),[u,n]=c.useState(o===void 0);return c.useEffect(()=>{if(o!==void 0){const i=window.setTimeout(()=>n(!0),o);return()=>window.clearTimeout(i)}},[o]),u&&a.imageLoadingStatus!=="loaded"?d.jsx(w.span,{...s,ref:t}):null});R.displayName=E;function h(e,t){return e?t?(e.src!==t&&(e.src=t),e.complete&&e.naturalWidth>0?"loaded":"loading"):"error":"idle"}function J(e,{referrerPolicy:t,crossOrigin:r}){const o=G(),s=c.useRef(null),a=o?(s.current||(s.current=new window.Image),s.current):null,[u,n]=c.useState(()=>h(a,e));return x.useLayoutEffect2(()=>{n(h(a,e))},[a,e]),x.useLayoutEffect2(()=>{const i=f=>()=>{n(f)};if(!a)return;const l=i("loaded"),m=i("error");return a.addEventListener("load",l),a.addEventListener("error",m),t&&(a.referrerPolicy=t),typeof r=="string"&&(a.crossOrigin=r),()=>{a.removeEventListener("load",l),a.removeEventListener("error",m)}},[a,r,t]),u}var j=C,P=_,I=R;const k=c.forwardRef(({className:e,...t},r)=>d.jsx(j,{ref:r,className:A.cn("relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full",e),...t}));k.displayName=j.displayName;const $=c.forwardRef(({className:e,...t},r)=>d.jsx(P,{ref:r,className:A.cn("aspect-square h-full w-full",e),...t}));$.displayName=P.displayName;const M=c.forwardRef(({className:e,...t},r)=>d.jsx(I,{ref:r,className:A.cn("flex h-full w-full items-center justify-center rounded-full bg-muted",e),...t}));M.displayName=I.displayName;exports.Avatar=k;exports.AvatarFallback=M;exports.AvatarImage=$;
|
|
2
|
+
//# sourceMappingURL=avatar-Cl38Ye4J.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar-Cl38Ye4J.cjs","sources":["../node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-use-is-hydrated/dist/index.mjs","../node_modules/@radix-ui/react-avatar/dist/index.mjs","../src/components/ui/avatar.tsx"],"sourcesContent":["// src/create-context.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createContext2(rootComponentName, defaultContext) {\n const Context = React.createContext(defaultContext);\n Context.displayName = rootComponentName + \"Context\";\n const Provider = (props) => {\n const { children, ...context } = props;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName) {\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n}\nfunction createContextScope(scopeName, createContextScopeDeps = []) {\n let defaultContexts = [];\n function createContext3(rootComponentName, defaultContext) {\n const BaseContext = React.createContext(defaultContext);\n BaseContext.displayName = rootComponentName + \"Context\";\n const index = defaultContexts.length;\n defaultContexts = [...defaultContexts, defaultContext];\n const Provider = (props) => {\n const { scope, children, ...context } = props;\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName, scope) {\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n }\n const createScope = () => {\n const scopeContexts = defaultContexts.map((defaultContext) => {\n return React.createContext(defaultContext);\n });\n return function useScope(scope) {\n const contexts = scope?.[scopeName] || scopeContexts;\n return React.useMemo(\n () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),\n [scope, contexts]\n );\n };\n };\n createScope.scopeName = scopeName;\n return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];\n}\nfunction composeContextScopes(...scopes) {\n const baseScope = scopes[0];\n if (scopes.length === 1) return baseScope;\n const createScope = () => {\n const scopeHooks = scopes.map((createScope2) => ({\n useScope: createScope2(),\n scopeName: createScope2.scopeName\n }));\n return function useComposedScopes(overrideScopes) {\n const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {\n const scopeProps = useScope(overrideScopes);\n const currentScope = scopeProps[`__scope${scopeName}`];\n return { ...nextScopes2, ...currentScope };\n }, {});\n return React.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);\n };\n };\n createScope.scopeName = baseScope.scopeName;\n return createScope;\n}\nexport {\n createContext2 as createContext,\n createContextScope\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","// src/use-is-hydrated.tsx\nimport { useSyncExternalStore } from \"use-sync-external-store/shim\";\nfunction useIsHydrated() {\n return useSyncExternalStore(\n subscribe,\n () => true,\n () => false\n );\n}\nfunction subscribe() {\n return () => {\n };\n}\nexport {\n useIsHydrated\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/avatar.tsx\nimport * as React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useIsHydrated } from \"@radix-ui/react-use-is-hydrated\";\nimport { jsx } from \"react/jsx-runtime\";\nvar AVATAR_NAME = \"Avatar\";\nvar [createAvatarContext, createAvatarScope] = createContextScope(AVATAR_NAME);\nvar [AvatarProvider, useAvatarContext] = createAvatarContext(AVATAR_NAME);\nvar Avatar = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, ...avatarProps } = props;\n const [imageLoadingStatus, setImageLoadingStatus] = React.useState(\"idle\");\n return /* @__PURE__ */ jsx(\n AvatarProvider,\n {\n scope: __scopeAvatar,\n imageLoadingStatus,\n onImageLoadingStatusChange: setImageLoadingStatus,\n children: /* @__PURE__ */ jsx(Primitive.span, { ...avatarProps, ref: forwardedRef })\n }\n );\n }\n);\nAvatar.displayName = AVATAR_NAME;\nvar IMAGE_NAME = \"AvatarImage\";\nvar AvatarImage = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, src, onLoadingStatusChange = () => {\n }, ...imageProps } = props;\n const context = useAvatarContext(IMAGE_NAME, __scopeAvatar);\n const imageLoadingStatus = useImageLoadingStatus(src, imageProps);\n const handleLoadingStatusChange = useCallbackRef((status) => {\n onLoadingStatusChange(status);\n context.onImageLoadingStatusChange(status);\n });\n useLayoutEffect(() => {\n if (imageLoadingStatus !== \"idle\") {\n handleLoadingStatusChange(imageLoadingStatus);\n }\n }, [imageLoadingStatus, handleLoadingStatusChange]);\n return imageLoadingStatus === \"loaded\" ? /* @__PURE__ */ jsx(Primitive.img, { ...imageProps, ref: forwardedRef, src }) : null;\n }\n);\nAvatarImage.displayName = IMAGE_NAME;\nvar FALLBACK_NAME = \"AvatarFallback\";\nvar AvatarFallback = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, delayMs, ...fallbackProps } = props;\n const context = useAvatarContext(FALLBACK_NAME, __scopeAvatar);\n const [canRender, setCanRender] = React.useState(delayMs === void 0);\n React.useEffect(() => {\n if (delayMs !== void 0) {\n const timerId = window.setTimeout(() => setCanRender(true), delayMs);\n return () => window.clearTimeout(timerId);\n }\n }, [delayMs]);\n return canRender && context.imageLoadingStatus !== \"loaded\" ? /* @__PURE__ */ jsx(Primitive.span, { ...fallbackProps, ref: forwardedRef }) : null;\n }\n);\nAvatarFallback.displayName = FALLBACK_NAME;\nfunction resolveLoadingStatus(image, src) {\n if (!image) {\n return \"idle\";\n }\n if (!src) {\n return \"error\";\n }\n if (image.src !== src) {\n image.src = src;\n }\n return image.complete && image.naturalWidth > 0 ? \"loaded\" : \"loading\";\n}\nfunction useImageLoadingStatus(src, { referrerPolicy, crossOrigin }) {\n const isHydrated = useIsHydrated();\n const imageRef = React.useRef(null);\n const image = (() => {\n if (!isHydrated) return null;\n if (!imageRef.current) {\n imageRef.current = new window.Image();\n }\n return imageRef.current;\n })();\n const [loadingStatus, setLoadingStatus] = React.useState(\n () => resolveLoadingStatus(image, src)\n );\n useLayoutEffect(() => {\n setLoadingStatus(resolveLoadingStatus(image, src));\n }, [image, src]);\n useLayoutEffect(() => {\n const updateStatus = (status) => () => {\n setLoadingStatus(status);\n };\n if (!image) return;\n const handleLoad = updateStatus(\"loaded\");\n const handleError = updateStatus(\"error\");\n image.addEventListener(\"load\", handleLoad);\n image.addEventListener(\"error\", handleError);\n if (referrerPolicy) {\n image.referrerPolicy = referrerPolicy;\n }\n if (typeof crossOrigin === \"string\") {\n image.crossOrigin = crossOrigin;\n }\n return () => {\n image.removeEventListener(\"load\", handleLoad);\n image.removeEventListener(\"error\", handleError);\n };\n }, [image, crossOrigin, referrerPolicy]);\n return loadingStatus;\n}\nvar Root = Avatar;\nvar Image = AvatarImage;\nvar Fallback = AvatarFallback;\nexport {\n Avatar,\n AvatarFallback,\n AvatarImage,\n Fallback,\n Image,\n Root,\n createAvatarScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from 'react'\nimport * as AvatarPrimitive from '@radix-ui/react-avatar'\nimport { cn } from '@/utils/cn'\n\nconst Avatar = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Root>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Root\n ref={ref}\n className={cn('relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full', className)}\n {...props}\n />\n))\nAvatar.displayName = AvatarPrimitive.Root.displayName\n\nconst AvatarImage = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Image>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Image>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Image\n ref={ref}\n className={cn('aspect-square h-full w-full', className)}\n {...props}\n />\n))\nAvatarImage.displayName = AvatarPrimitive.Image.displayName\n\nconst AvatarFallback = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Fallback>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Fallback>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Fallback\n ref={ref}\n className={cn(\n 'flex h-full w-full items-center justify-center rounded-full bg-muted',\n className\n )}\n {...props}\n />\n))\nAvatarFallback.displayName = AvatarPrimitive.Fallback.displayName\n\nexport { Avatar, AvatarImage, AvatarFallback }\n"],"names":["createContextScope","scopeName","createContextScopeDeps","defaultContexts","createContext3","rootComponentName","defaultContext","BaseContext","React","index","Provider","props","scope","children","context","Context","_a","value","jsx","useContext2","consumerName","createScope","scopeContexts","contexts","composeContextScopes","scopes","baseScope","scopeHooks","createScope2","overrideScopes","nextScopes","nextScopes2","useScope","currentScope","NODES","Primitive","primitive","node","Slot","createSlot","Node","forwardedRef","asChild","primitiveProps","Comp","useIsHydrated","useSyncExternalStore","subscribe","AVATAR_NAME","createAvatarContext","AvatarProvider","useAvatarContext","Avatar","__scopeAvatar","avatarProps","imageLoadingStatus","setImageLoadingStatus","IMAGE_NAME","AvatarImage","src","onLoadingStatusChange","imageProps","useImageLoadingStatus","handleLoadingStatusChange","useCallbackRef","status","useLayoutEffect","FALLBACK_NAME","AvatarFallback","delayMs","fallbackProps","canRender","setCanRender","timerId","resolveLoadingStatus","image","referrerPolicy","crossOrigin","isHydrated","imageRef","loadingStatus","setLoadingStatus","updateStatus","handleLoad","handleError","Root","Image","Fallback","className","ref","AvatarPrimitive.Root","cn","AvatarPrimitive.Image","AvatarPrimitive.Fallback"],"mappings":"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","x_google_ignoreList":[0,1,2,3]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";const L=require("./scroll-area-HsTSI_58.cjs"),x=require("react"),T=require("react/jsx-runtime"),A=require("./button-CPuCii0R.cjs"),R=require("./index-Dy_9oyP3.cjs");/**
|
|
2
|
+
* @license lucide-react v0.441.0 - ISC
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the ISC license.
|
|
5
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/const D=L.createLucideIcon("Check",[["path",{d:"M20 6 9 17l-5-5",key:"1gmf2c"}]]);var O={exports:{}},g={};/**
|
|
7
|
+
* @license React
|
|
8
|
+
* use-sync-external-store-shim.production.js
|
|
9
|
+
*
|
|
10
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
11
|
+
*
|
|
12
|
+
* This source code is licensed under the MIT license found in the
|
|
13
|
+
* LICENSE file in the root directory of this source tree.
|
|
14
|
+
*/var m;function V(){if(m)return g;m=1;var u=x;function d(t,o){return t===o&&(t!==0||1/t===1/o)||t!==t&&o!==o}var c=typeof Object.is=="function"?Object.is:d,v=u.useState,a=u.useEffect,l=u.useLayoutEffect,p=u.useDebugValue;function _(t,o){var e=o(),r=v({inst:{value:e,getSnapshot:o}}),n=r[0].inst,s=r[1];return l(function(){n.value=e,n.getSnapshot=o,f(n)&&s({inst:n})},[t,e,o]),a(function(){return f(n)&&s({inst:n}),t(function(){f(n)&&s({inst:n})})},[t]),p(e),e}function f(t){var o=t.getSnapshot;t=t.value;try{var e=o();return!c(t,e)}catch{return!0}}function h(t,o){return o()}var S=typeof window>"u"||typeof window.document>"u"||typeof window.document.createElement>"u"?h:_;return g.useSyncExternalStore=u.useSyncExternalStore!==void 0?u.useSyncExternalStore:S,g}var y={};/**
|
|
15
|
+
* @license React
|
|
16
|
+
* use-sync-external-store-shim.development.js
|
|
17
|
+
*
|
|
18
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
19
|
+
*
|
|
20
|
+
* This source code is licensed under the MIT license found in the
|
|
21
|
+
* LICENSE file in the root directory of this source tree.
|
|
22
|
+
*/var b;function C(){return b||(b=1,process.env.NODE_ENV!=="production"&&function(){function u(e,r){return e===r&&(e!==0||1/e===1/r)||e!==e&&r!==r}function d(e,r){S||a.startTransition===void 0||(S=!0,console.error("You are using an outdated, pre-release alpha of React 18 that does not support useSyncExternalStore. The use-sync-external-store shim will not work correctly. Upgrade to a newer pre-release."));var n=r();if(!t){var s=r();l(n,s)||(console.error("The result of getSnapshot should be cached to avoid an infinite loop"),t=!0)}s=p({inst:{value:n,getSnapshot:r}});var i=s[0].inst,E=s[1];return f(function(){i.value=n,i.getSnapshot=r,c(i)&&E({inst:i})},[e,n,r]),_(function(){return c(i)&&E({inst:i}),e(function(){c(i)&&E({inst:i})})},[e]),h(n),n}function c(e){var r=e.getSnapshot;e=e.value;try{var n=r();return!l(e,n)}catch{return!0}}function v(e,r){return r()}typeof __REACT_DEVTOOLS_GLOBAL_HOOK__<"u"&&typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart=="function"&&__REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(Error());var a=x,l=typeof Object.is=="function"?Object.is:u,p=a.useState,_=a.useEffect,f=a.useLayoutEffect,h=a.useDebugValue,S=!1,t=!1,o=typeof window>"u"||typeof window.document>"u"||typeof window.document.createElement>"u"?v:d;y.useSyncExternalStore=a.useSyncExternalStore!==void 0?a.useSyncExternalStore:o,typeof __REACT_DEVTOOLS_GLOBAL_HOOK__<"u"&&typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop=="function"&&__REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(Error())}()),y}process.env.NODE_ENV==="production"?O.exports=V():O.exports=C();var q=O.exports;const w=A.cva("inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-all duration-200 focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring/50",{variants:{variant:{default:"border-transparent bg-primary text-primary-foreground hover:bg-primary/80 hover:shadow-sm",secondary:"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",destructive:"border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80 hover:shadow-sm",outline:"text-foreground hover:bg-muted",success:"border-transparent bg-success text-success-foreground hover:bg-success/80 hover:shadow-sm",warning:"border-transparent bg-warning text-warning-foreground hover:bg-warning/80 hover:shadow-sm",info:"border-transparent bg-info text-info-foreground hover:bg-info/80 hover:shadow-sm"}},defaultVariants:{variant:"default"}});function G({className:u,variant:d,...c}){return T.jsx("div",{className:R.cn(w({variant:d}),u),...c})}exports.Badge=G;exports.Check=D;exports.badgeVariants=w;exports.shimExports=q;
|
|
23
|
+
//# sourceMappingURL=badge-BZcdBG5J.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"badge-BZcdBG5J.cjs","sources":["../node_modules/lucide-react/dist/esm/icons/check.js","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js","../node_modules/use-sync-external-store/shim/index.js","../src/components/ui/badge.tsx"],"sourcesContent":["/**\n * @license lucide-react v0.441.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst Check = createLucideIcon(\"Check\", [[\"path\", { d: \"M20 6 9 17l-5-5\", key: \"1gmf2c\" }]]);\n\nexport { Check as default };\n//# sourceMappingURL=check.js.map\n","/**\n * @license React\n * use-sync-external-store-shim.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar React = require(\"react\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue;\nfunction useSyncExternalStore$2(subscribe, getSnapshot) {\n var value = getSnapshot(),\n _useState = useState({ inst: { value: value, getSnapshot: getSnapshot } }),\n inst = _useState[0].inst,\n forceUpdate = _useState[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n}\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n}\nfunction useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n}\nvar shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\nexports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n","/**\n * @license React\n * use-sync-external-store-shim.development.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\n\"production\" !== process.env.NODE_ENV &&\n (function () {\n function is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n }\n function useSyncExternalStore$2(subscribe, getSnapshot) {\n didWarnOld18Alpha ||\n void 0 === React.startTransition ||\n ((didWarnOld18Alpha = !0),\n console.error(\n \"You are using an outdated, pre-release alpha of React 18 that does not support useSyncExternalStore. The use-sync-external-store shim will not work correctly. Upgrade to a newer pre-release.\"\n ));\n var value = getSnapshot();\n if (!didWarnUncachedGetSnapshot) {\n var cachedValue = getSnapshot();\n objectIs(value, cachedValue) ||\n (console.error(\n \"The result of getSnapshot should be cached to avoid an infinite loop\"\n ),\n (didWarnUncachedGetSnapshot = !0));\n }\n cachedValue = useState({\n inst: { value: value, getSnapshot: getSnapshot }\n });\n var inst = cachedValue[0].inst,\n forceUpdate = cachedValue[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n }\n function checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n }\n function useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n }\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(Error());\n var React = require(\"react\"),\n objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue,\n didWarnOld18Alpha = !1,\n didWarnUncachedGetSnapshot = !1,\n shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\n exports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(Error());\n })();\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","import * as React from 'react'\nimport { cva, type VariantProps } from 'class-variance-authority'\nimport { cn } from '@/utils/cn'\n\nconst badgeVariants = cva(\n 'inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-all duration-200 focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring/50',\n {\n variants: {\n variant: {\n default: 'border-transparent bg-primary text-primary-foreground hover:bg-primary/80 hover:shadow-sm',\n secondary:\n 'border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80',\n destructive:\n 'border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80 hover:shadow-sm',\n outline: 'text-foreground hover:bg-muted',\n success: 'border-transparent bg-success text-success-foreground hover:bg-success/80 hover:shadow-sm',\n warning: 'border-transparent bg-warning text-warning-foreground hover:bg-warning/80 hover:shadow-sm',\n info: 'border-transparent bg-info text-info-foreground hover:bg-info/80 hover:shadow-sm',\n },\n },\n defaultVariants: {\n variant: 'default',\n },\n }\n)\n\nexport interface BadgeProps\n extends React.HTMLAttributes<HTMLDivElement>,\n VariantProps<typeof badgeVariants> {}\n\nfunction Badge({ className, variant, ...props }: BadgeProps) {\n return <div className={cn(badgeVariants({ variant }), className)} {...props} />\n}\n\nexport { Badge, badgeVariants }\n"],"names":["Check","createLucideIcon","React","require$$0","is","x","y","objectIs","useState","useEffect","useLayoutEffect","useDebugValue","useSyncExternalStore$2","subscribe","getSnapshot","value","_useState","inst","forceUpdate","checkIfSnapshotChanged","latestGetSnapshot","nextValue","useSyncExternalStore$1","shim","useSyncExternalStoreShim_production","didWarnOld18Alpha","didWarnUncachedGetSnapshot","cachedValue","useSyncExternalStoreShim_development","shimModule","require$$1","badgeVariants","cva","Badge","className","variant","props","jsx","cn"],"mappings":"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","x_google_ignoreList":[0,1,2,3]}
|