@alfadocs/ui-kit 0.1.4 → 0.1.6
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/README.md +26 -0
- package/dist/_chunks/{agenda-card-C_hQGErS.js → agenda-card-DIWDvWum.js} +10 -10
- package/dist/_chunks/agenda-card-DIWDvWum.js.map +1 -0
- package/dist/_chunks/{agenda-tray-CBaVMJLO.js → agenda-tray-BqQZwiHc.js} +5 -5
- package/dist/_chunks/{agenda-tray-CBaVMJLO.js.map → agenda-tray-BqQZwiHc.js.map} +1 -1
- package/dist/_chunks/{ai-prompt-input-K94oVLG2.js → ai-prompt-input-CI27KmZ1.js} +4 -4
- package/dist/_chunks/ai-prompt-input-CI27KmZ1.js.map +1 -0
- package/dist/_chunks/{alert-rOM4EG0P.js → alert-BlOUMkXj.js} +39 -39
- package/dist/_chunks/alert-BlOUMkXj.js.map +1 -0
- package/dist/_chunks/{audio-recorder-Cn8z2zC9.js → audio-recorder-B-8SKgKn.js} +5 -5
- package/dist/_chunks/{audio-recorder-Cn8z2zC9.js.map → audio-recorder-B-8SKgKn.js.map} +1 -1
- package/dist/_chunks/{autocomplete.agent-DRrp-Rsx.js → autocomplete.agent-DqOy0_1P.js} +31 -31
- package/dist/_chunks/autocomplete.agent-DqOy0_1P.js.map +1 -0
- package/dist/_chunks/{avatar-Biffh-_H.js → avatar-Dcr6XuDQ.js} +19 -19
- package/dist/_chunks/avatar-Dcr6XuDQ.js.map +1 -0
- package/dist/_chunks/{balance-cell-renderer-CiyezQhi.js → balance-cell-renderer-BRWt3neo.js} +166 -166
- package/dist/_chunks/balance-cell-renderer-BRWt3neo.js.map +1 -0
- package/dist/_chunks/breadcrumb-D6xpsP7n.js +293 -0
- package/dist/_chunks/breadcrumb-D6xpsP7n.js.map +1 -0
- package/dist/_chunks/{button-7dTew-IV.js → button-7mLWcMp_.js} +9 -9
- package/dist/_chunks/{button-7dTew-IV.js.map → button-7mLWcMp_.js.map} +1 -1
- package/dist/_chunks/{calendar-BkDeDTaX.js → calendar-nGEgelJs.js} +100 -100
- package/dist/_chunks/calendar-nGEgelJs.js.map +1 -0
- package/dist/_chunks/{chat-input-xiBIujMv.js → chat-input-DsIrWM4f.js} +2 -2
- package/dist/_chunks/{chat-input-xiBIujMv.js.map → chat-input-DsIrWM4f.js.map} +1 -1
- package/dist/_chunks/{chat-message-BtxUyugB.js → chat-message-ByouZpPP.js} +3 -3
- package/dist/_chunks/{chat-message-BtxUyugB.js.map → chat-message-ByouZpPP.js.map} +1 -1
- package/dist/_chunks/{checkbox-Ni6C_KJg.js → checkbox-DNK4qS2_.js} +13 -13
- package/dist/_chunks/checkbox-DNK4qS2_.js.map +1 -0
- package/dist/_chunks/{checkbox-group-BFZ4oN5t.js → checkbox-group-CWpGZEF6.js} +13 -13
- package/dist/_chunks/checkbox-group-CWpGZEF6.js.map +1 -0
- package/dist/_chunks/{collapsible-fFMqzpdL.js → collapsible-D4LOdLxp.js} +18 -18
- package/dist/_chunks/collapsible-D4LOdLxp.js.map +1 -0
- package/dist/_chunks/{color-picker-Cl3KdjJd.js → color-picker-e9PmpaGH.js} +161 -161
- package/dist/_chunks/color-picker-e9PmpaGH.js.map +1 -0
- package/dist/_chunks/{combobox.agent-DjdivI3X.js → combobox.agent-ByobCLJ_.js} +28 -28
- package/dist/_chunks/combobox.agent-ByobCLJ_.js.map +1 -0
- package/dist/_chunks/{command-palette.agent-BUjzr2ET.js → command-palette.agent-js2rxgeR.js} +117 -117
- package/dist/_chunks/command-palette.agent-js2rxgeR.js.map +1 -0
- package/dist/_chunks/{description-list-C_1NX8P3.js → description-list-DvJbp6Yg.js} +2 -2
- package/dist/_chunks/{description-list-C_1NX8P3.js.map → description-list-DvJbp6Yg.js.map} +1 -1
- package/dist/_chunks/{dialog.agent-C2lP9H0h.js → dialog.agent-DEG_fVzG.js} +42 -42
- package/dist/_chunks/dialog.agent-DEG_fVzG.js.map +1 -0
- package/dist/_chunks/{dropdown-menu-2HgU1Emf.js → dropdown-menu-JNo66A-j.js} +2 -2
- package/dist/_chunks/dropdown-menu-JNo66A-j.js.map +1 -0
- package/dist/_chunks/{empty-state-BHrItOiE.js → empty-state-DQPtRp2b.js} +2 -2
- package/dist/_chunks/{empty-state-BHrItOiE.js.map → empty-state-DQPtRp2b.js.map} +1 -1
- package/dist/_chunks/{file-upload.agent-LlC0W468.js → file-upload.agent-B9AN82LA.js} +2 -2
- package/dist/_chunks/{file-upload.agent-LlC0W468.js.map → file-upload.agent-B9AN82LA.js.map} +1 -1
- package/dist/_chunks/{freemium-paywall-Dr9aOtOC.js → freemium-paywall-CkefGLM_.js} +4 -4
- package/dist/_chunks/{freemium-paywall-Dr9aOtOC.js.map → freemium-paywall-CkefGLM_.js.map} +1 -1
- package/dist/_chunks/{header-BpU9U-1X.js → header-BGn1mRp8.js} +2 -2
- package/dist/_chunks/{header-BpU9U-1X.js.map → header-BGn1mRp8.js.map} +1 -1
- package/dist/_chunks/{icon-button-CNjWCD1X.js → icon-button-Wnnde5lc.js} +6 -6
- package/dist/_chunks/icon-button-Wnnde5lc.js.map +1 -0
- package/dist/_chunks/input-surface-u4QB0lxe.js +32 -0
- package/dist/_chunks/input-surface-u4QB0lxe.js.map +1 -0
- package/dist/_chunks/{key-value-pair-C9hpjC_B.js → key-value-pair-JRFS9Xrh.js} +10 -10
- package/dist/_chunks/key-value-pair-JRFS9Xrh.js.map +1 -0
- package/dist/_chunks/{leo-sidebar-CNjZqljo.js → leo-sidebar-Bh3dPDTQ.js} +64 -64
- package/dist/_chunks/leo-sidebar-Bh3dPDTQ.js.map +1 -0
- package/dist/_chunks/{message-card-CZzNO4ov.js → message-card-qAp2-WQK.js} +12 -12
- package/dist/_chunks/message-card-qAp2-WQK.js.map +1 -0
- package/dist/_chunks/{message-tray-BWbjXW3F.js → message-tray-VaLpQU5t.js} +5 -5
- package/dist/_chunks/{message-tray-BWbjXW3F.js.map → message-tray-VaLpQU5t.js.map} +1 -1
- package/dist/_chunks/{multi-select.agent-BSGEW10d.js → multi-select.agent-CNsyW3n9.js} +66 -66
- package/dist/_chunks/multi-select.agent-CNsyW3n9.js.map +1 -0
- package/dist/_chunks/navigation-menu-EVFau1O2.js +180 -0
- package/dist/_chunks/navigation-menu-EVFau1O2.js.map +1 -0
- package/dist/_chunks/{notification-card-DgW-vVg-.js → notification-card-BF2_veHy.js} +11 -11
- package/dist/_chunks/notification-card-BF2_veHy.js.map +1 -0
- package/dist/_chunks/{notification-tray-CKUgl2jc.js → notification-tray-Bq-08ReD.js} +5 -5
- package/dist/_chunks/{notification-tray-CKUgl2jc.js.map → notification-tray-Bq-08ReD.js.map} +1 -1
- package/dist/_chunks/{number-input-BPPhekLu.js → number-input-DjpT_RXJ.js} +46 -46
- package/dist/_chunks/number-input-DjpT_RXJ.js.map +1 -0
- package/dist/_chunks/pagination.agent-oEaqmtx5.js +380 -0
- package/dist/_chunks/pagination.agent-oEaqmtx5.js.map +1 -0
- package/dist/_chunks/{password-input-DAT5HQth.js → password-input-DJDVznWH.js} +5 -5
- package/dist/_chunks/password-input-DJDVznWH.js.map +1 -0
- package/dist/_chunks/{patient-shell-BzHhg6uA.js → patient-shell-DP54y6rc.js} +5 -5
- package/dist/_chunks/{patient-shell-BzHhg6uA.js.map → patient-shell-DP54y6rc.js.map} +1 -1
- package/dist/_chunks/{payment-form-YlxrCpZQ.js → payment-form-hcl-gGrp.js} +2 -2
- package/dist/_chunks/{payment-form-YlxrCpZQ.js.map → payment-form-hcl-gGrp.js.map} +1 -1
- package/dist/_chunks/{pdf-viewer.agent-sMned5Xn.js → pdf-viewer.agent-CfIHhcHx.js} +3 -3
- package/dist/_chunks/{pdf-viewer.agent-sMned5Xn.js.map → pdf-viewer.agent-CfIHhcHx.js.map} +1 -1
- package/dist/_chunks/{phone-input-BuRe5PyI.js → phone-input-DE_39q65.js} +103 -103
- package/dist/_chunks/phone-input-DE_39q65.js.map +1 -0
- package/dist/_chunks/{popover-Ds1iOdiv.js → popover-DvAtFOi-.js} +2 -2
- package/dist/_chunks/{popover-Ds1iOdiv.js.map → popover-DvAtFOi-.js.map} +1 -1
- package/dist/_chunks/{privacy-lock-up2ervfF.js → privacy-lock-DS6QRo2N.js} +3 -3
- package/dist/_chunks/{privacy-lock-up2ervfF.js.map → privacy-lock-DS6QRo2N.js.map} +1 -1
- package/dist/_chunks/{progress-D4ELgHG3.js → progress-B4Of_pzz.js} +57 -57
- package/dist/_chunks/progress-B4Of_pzz.js.map +1 -0
- package/dist/_chunks/{radio-XSSNX3Af.js → radio-cs8N1wJi.js} +29 -29
- package/dist/_chunks/radio-cs8N1wJi.js.map +1 -0
- package/dist/_chunks/{radio-group-DBrUOPcy.js → radio-group-BIUbpWml.js} +3 -3
- package/dist/_chunks/radio-group-BIUbpWml.js.map +1 -0
- package/dist/_chunks/{scroll-area-HIq0hJyJ.js → scroll-area-DLr5w9Dd.js} +9 -9
- package/dist/_chunks/scroll-area-DLr5w9Dd.js.map +1 -0
- package/dist/_chunks/{search-bar-9Zbew4yM.js → search-bar-fcGqDFW3.js} +30 -30
- package/dist/_chunks/{search-bar-9Zbew4yM.js.map → search-bar-fcGqDFW3.js.map} +1 -1
- package/dist/_chunks/{search-input-CtkWITO2.js → search-input-BVMCONyN.js} +2 -2
- package/dist/_chunks/{search-input-CtkWITO2.js.map → search-input-BVMCONyN.js.map} +1 -1
- package/dist/_chunks/{select-DdAOtomN.js → select-IY_JQa-F.js} +50 -50
- package/dist/_chunks/select-IY_JQa-F.js.map +1 -0
- package/dist/_chunks/{sheet-D7GRhnWw.js → sheet-BhNpLHc9.js} +8 -8
- package/dist/_chunks/sheet-BhNpLHc9.js.map +1 -0
- package/dist/_chunks/{sidebar-Dc2ffrbf.js → sidebar-OVzwN3jE.js} +294 -294
- package/dist/_chunks/sidebar-OVzwN3jE.js.map +1 -0
- package/dist/_chunks/{sign-in-with-alfadocs-button-BotwPDcW.js → sign-in-with-alfadocs-button-BN_FPGHT.js} +2 -2
- package/dist/_chunks/{sign-in-with-alfadocs-button-BotwPDcW.js.map → sign-in-with-alfadocs-button-BN_FPGHT.js.map} +1 -1
- package/dist/_chunks/{skeleton-DAdPFx9d.js → skeleton-dtqyF09N.js} +8 -8
- package/dist/_chunks/skeleton-dtqyF09N.js.map +1 -0
- package/dist/_chunks/{slot-grid-WHc5A8-z.js → slot-grid-D_l5VsHG.js} +5 -5
- package/dist/_chunks/{slot-grid-WHc5A8-z.js.map → slot-grid-D_l5VsHG.js.map} +1 -1
- package/dist/_chunks/{stepper-accordion-2_7Pw0tC.js → stepper-accordion-CGog0JSF.js} +64 -64
- package/dist/_chunks/stepper-accordion-CGog0JSF.js.map +1 -0
- package/dist/_chunks/{stepper-calendar-CWZcFgt_.js → stepper-calendar-_fLOAjus.js} +7 -7
- package/dist/_chunks/{stepper-calendar-CWZcFgt_.js.map → stepper-calendar-_fLOAjus.js.map} +1 -1
- package/dist/_chunks/{switch-DhSORO9C.js → switch-aN2EYxHh.js} +4 -4
- package/dist/_chunks/switch-aN2EYxHh.js.map +1 -0
- package/dist/_chunks/{tabs.agent-BtaNGxRh.js → tabs.agent-BpbVA-Zh.js} +55 -55
- package/dist/_chunks/tabs.agent-BpbVA-Zh.js.map +1 -0
- package/dist/_chunks/{tag--uLKOb9f.js → tag-BqidXKo3.js} +2 -2
- package/dist/_chunks/tag-BqidXKo3.js.map +1 -0
- package/dist/_chunks/{task-card-BeSuntXP.js → task-card-yW7tKlG4.js} +17 -17
- package/dist/_chunks/task-card-yW7tKlG4.js.map +1 -0
- package/dist/_chunks/{task-tray-pRk6u8Ik.js → task-tray-BzahI5FQ.js} +5 -5
- package/dist/_chunks/{task-tray-pRk6u8Ik.js.map → task-tray-BzahI5FQ.js.map} +1 -1
- package/dist/_chunks/{text-area-xf9-6iDf.js → text-area-DmKSd2DG.js} +2 -2
- package/dist/_chunks/text-area-DmKSd2DG.js.map +1 -0
- package/dist/_chunks/{text-input-exh7VD7D.js → text-input-CRHvl5zk.js} +19 -19
- package/dist/_chunks/text-input-CRHvl5zk.js.map +1 -0
- package/dist/_chunks/{theme-toggle-CJgA6G24.js → theme-toggle-COHFwO2H.js} +4 -4
- package/dist/_chunks/{theme-toggle-CJgA6G24.js.map → theme-toggle-COHFwO2H.js.map} +1 -1
- package/dist/_chunks/{timeline-DIueH4TJ.js → timeline-RgAIzpMd.js} +2 -2
- package/dist/_chunks/{timeline-DIueH4TJ.js.map → timeline-RgAIzpMd.js.map} +1 -1
- package/dist/_chunks/{toast-q0SlabGr.js → toast-lOhJDKOH.js} +12 -12
- package/dist/_chunks/{toast-q0SlabGr.js.map → toast-lOhJDKOH.js.map} +1 -1
- package/dist/_chunks/{transcript-panel-DFnhbrlQ.js → transcript-panel-CNbVGG9L.js} +59 -59
- package/dist/_chunks/transcript-panel-CNbVGG9L.js.map +1 -0
- package/dist/_chunks/{visually-hidden-BlkhaZWe.js → visually-hidden-Bw7vBHLm.js} +6 -6
- package/dist/_chunks/{visually-hidden-BlkhaZWe.js.map → visually-hidden-Bw7vBHLm.js.map} +1 -1
- package/dist/_chunks/{warning-stack-DCmO0R07.js → warning-stack-8Pa3pekh.js} +24 -24
- package/dist/_chunks/warning-stack-8Pa3pekh.js.map +1 -0
- package/dist/_chunks/{workflow-map-CAM6Uy_J.js → workflow-map-DGJwVcO-.js} +106 -106
- package/dist/_chunks/workflow-map-DGJwVcO-.js.map +1 -0
- package/dist/agent-catalog.json +1 -1
- package/dist/components/_shared/input-surface.d.ts +11 -11
- package/dist/components/agenda-card/index.js +1 -1
- package/dist/components/agenda-tray/index.js +1 -1
- package/dist/components/ai-prompt-input/index.js +1 -1
- package/dist/components/alert/index.js +1 -1
- package/dist/components/audio-recorder/index.js +1 -1
- package/dist/components/autocomplete/index.js +1 -1
- package/dist/components/avatar/index.js +1 -1
- package/dist/components/breadcrumb/index.js +1 -1
- package/dist/components/button/index.js +2 -2
- package/dist/components/calendar/index.js +1 -1
- package/dist/components/chat-input/index.js +1 -1
- package/dist/components/chat-message/index.js +1 -1
- package/dist/components/checkbox/index.js +1 -1
- package/dist/components/checkbox-group/index.js +1 -1
- package/dist/components/collapsible/index.js +1 -1
- package/dist/components/color-picker/index.js +1 -1
- package/dist/components/combobox/index.js +1 -1
- package/dist/components/command-palette/index.js +1 -1
- package/dist/components/data-table/index.js +1 -1
- package/dist/components/description-list/index.js +1 -1
- package/dist/components/dialog/index.js +1 -1
- package/dist/components/dropdown-menu/index.js +1 -1
- package/dist/components/empty-state/index.js +1 -1
- package/dist/components/file-upload/index.js +1 -1
- package/dist/components/freemium-paywall/index.js +1 -1
- package/dist/components/header/index.js +1 -1
- package/dist/components/icon-button/index.js +1 -1
- package/dist/components/key-value-pair/index.js +1 -1
- package/dist/components/message-card/index.js +1 -1
- package/dist/components/message-tray/index.js +1 -1
- package/dist/components/multi-select/index.js +1 -1
- package/dist/components/navigation-menu/index.js +1 -1
- package/dist/components/notification-card/index.js +1 -1
- package/dist/components/notification-tray/index.js +1 -1
- package/dist/components/number-input/index.js +1 -1
- package/dist/components/pagination/index.js +1 -1
- package/dist/components/password-input/index.js +1 -1
- package/dist/components/payment-form/index.js +1 -1
- package/dist/components/pdf-viewer/index.js +1 -1
- package/dist/components/phone-input/index.js +1 -1
- package/dist/components/popover/index.js +1 -1
- package/dist/components/privacy-lock/index.js +1 -1
- package/dist/components/progress/index.js +1 -1
- package/dist/components/radio/index.js +1 -1
- package/dist/components/radio-group/index.js +2 -2
- package/dist/components/scroll-area/index.js +1 -1
- package/dist/components/search-bar/index.js +1 -1
- package/dist/components/search-input/index.js +1 -1
- package/dist/components/select/index.js +1 -1
- package/dist/components/sheet/index.js +1 -1
- package/dist/components/sidebar/index.js +1 -1
- package/dist/components/sign-in-with-alfadocs-button/index.js +1 -1
- package/dist/components/skeleton/index.js +1 -1
- package/dist/components/slot-grid/index.js +1 -1
- package/dist/components/stepper-accordion/index.js +1 -1
- package/dist/components/stepper-calendar/index.js +1 -1
- package/dist/components/switch/index.js +1 -1
- package/dist/components/tabs/index.js +1 -1
- package/dist/components/tag/index.js +1 -1
- package/dist/components/task-card/index.js +1 -1
- package/dist/components/task-tray/index.js +1 -1
- package/dist/components/text-area/index.js +1 -1
- package/dist/components/text-input/index.js +1 -1
- package/dist/components/theme-toggle/index.js +1 -1
- package/dist/components/timeline/index.js +1 -1
- package/dist/components/toast/index.js +1 -1
- package/dist/components/transcript-panel/index.js +1 -1
- package/dist/components/visually-hidden/index.js +1 -1
- package/dist/components/warning-stack/index.js +1 -1
- package/dist/components/workflow/index.js +1 -1
- package/dist/index.js +72 -72
- package/dist/patterns/leo-assistant/index.js +1 -1
- package/dist/patterns/leo-assistant/leo-sidebar.d.ts.map +1 -1
- package/dist/patterns/patient-shell/index.js +1 -1
- package/dist/tokens.css +1 -1
- package/package.json +1 -1
- package/dist/_chunks/agenda-card-C_hQGErS.js.map +0 -1
- package/dist/_chunks/ai-prompt-input-K94oVLG2.js.map +0 -1
- package/dist/_chunks/alert-rOM4EG0P.js.map +0 -1
- package/dist/_chunks/autocomplete.agent-DRrp-Rsx.js.map +0 -1
- package/dist/_chunks/avatar-Biffh-_H.js.map +0 -1
- package/dist/_chunks/balance-cell-renderer-CiyezQhi.js.map +0 -1
- package/dist/_chunks/breadcrumb-CcZovmIq.js +0 -293
- package/dist/_chunks/breadcrumb-CcZovmIq.js.map +0 -1
- package/dist/_chunks/calendar-BkDeDTaX.js.map +0 -1
- package/dist/_chunks/checkbox-Ni6C_KJg.js.map +0 -1
- package/dist/_chunks/checkbox-group-BFZ4oN5t.js.map +0 -1
- package/dist/_chunks/collapsible-fFMqzpdL.js.map +0 -1
- package/dist/_chunks/color-picker-Cl3KdjJd.js.map +0 -1
- package/dist/_chunks/combobox.agent-DjdivI3X.js.map +0 -1
- package/dist/_chunks/command-palette.agent-BUjzr2ET.js.map +0 -1
- package/dist/_chunks/dialog.agent-C2lP9H0h.js.map +0 -1
- package/dist/_chunks/dropdown-menu-2HgU1Emf.js.map +0 -1
- package/dist/_chunks/icon-button-CNjWCD1X.js.map +0 -1
- package/dist/_chunks/input-surface-D5OMCB1W.js +0 -32
- package/dist/_chunks/input-surface-D5OMCB1W.js.map +0 -1
- package/dist/_chunks/key-value-pair-C9hpjC_B.js.map +0 -1
- package/dist/_chunks/leo-sidebar-CNjZqljo.js.map +0 -1
- package/dist/_chunks/message-card-CZzNO4ov.js.map +0 -1
- package/dist/_chunks/multi-select.agent-BSGEW10d.js.map +0 -1
- package/dist/_chunks/navigation-menu-DxOMvrKM.js +0 -180
- package/dist/_chunks/navigation-menu-DxOMvrKM.js.map +0 -1
- package/dist/_chunks/notification-card-DgW-vVg-.js.map +0 -1
- package/dist/_chunks/number-input-BPPhekLu.js.map +0 -1
- package/dist/_chunks/pagination.agent-CmA0Ocr5.js +0 -380
- package/dist/_chunks/pagination.agent-CmA0Ocr5.js.map +0 -1
- package/dist/_chunks/password-input-DAT5HQth.js.map +0 -1
- package/dist/_chunks/phone-input-BuRe5PyI.js.map +0 -1
- package/dist/_chunks/progress-D4ELgHG3.js.map +0 -1
- package/dist/_chunks/radio-XSSNX3Af.js.map +0 -1
- package/dist/_chunks/radio-group-DBrUOPcy.js.map +0 -1
- package/dist/_chunks/scroll-area-HIq0hJyJ.js.map +0 -1
- package/dist/_chunks/select-DdAOtomN.js.map +0 -1
- package/dist/_chunks/sheet-D7GRhnWw.js.map +0 -1
- package/dist/_chunks/sidebar-Dc2ffrbf.js.map +0 -1
- package/dist/_chunks/skeleton-DAdPFx9d.js.map +0 -1
- package/dist/_chunks/stepper-accordion-2_7Pw0tC.js.map +0 -1
- package/dist/_chunks/switch-DhSORO9C.js.map +0 -1
- package/dist/_chunks/tabs.agent-BtaNGxRh.js.map +0 -1
- package/dist/_chunks/tag--uLKOb9f.js.map +0 -1
- package/dist/_chunks/task-card-BeSuntXP.js.map +0 -1
- package/dist/_chunks/text-area-xf9-6iDf.js.map +0 -1
- package/dist/_chunks/text-input-exh7VD7D.js.map +0 -1
- package/dist/_chunks/transcript-panel-DFnhbrlQ.js.map +0 -1
- package/dist/_chunks/warning-stack-DCmO0R07.js.map +0 -1
- package/dist/_chunks/workflow-map-CAM6Uy_J.js.map +0 -1
|
@@ -5,29 +5,29 @@ import { useTranslation as ve } from "react-i18next";
|
|
|
5
5
|
import { u as ge } from "./form-field-context-94LwgYTQ.js";
|
|
6
6
|
import { C as Ne } from "./chevron-down-BX_NP2Yh.js";
|
|
7
7
|
import { C as he } from "./chevron-up-zOEDrmBB.js";
|
|
8
|
-
function we(
|
|
8
|
+
function we(i) {
|
|
9
9
|
let r = "";
|
|
10
|
-
for (const a of
|
|
10
|
+
for (const a of i) {
|
|
11
11
|
const t = a.codePointAt(0);
|
|
12
12
|
t !== void 0 && (t >= 1632 && t <= 1641 ? r += String.fromCodePoint(48 + (t - 1632)) : t >= 1776 && t <= 1785 ? r += String.fromCodePoint(48 + (t - 1776)) : r += a);
|
|
13
13
|
}
|
|
14
14
|
return r;
|
|
15
15
|
}
|
|
16
|
-
function ye(
|
|
16
|
+
function ye(i, r, a) {
|
|
17
17
|
return ce(() => {
|
|
18
18
|
var S, C;
|
|
19
|
-
const t = new Intl.NumberFormat(
|
|
19
|
+
const t = new Intl.NumberFormat(i).formatToParts(1234.5), d = ((S = t.find((u) => u.type === "decimal")) == null ? void 0 : S.value) ?? ".", F = ((C = t.find((u) => u.type === "group")) == null ? void 0 : C.value) ?? ",", c = r === "currency" ? new Intl.NumberFormat(i, {
|
|
20
20
|
style: "currency",
|
|
21
21
|
currency: a ?? "USD"
|
|
22
|
-
}) : r === "percentage" ? new Intl.NumberFormat(
|
|
22
|
+
}) : r === "percentage" ? new Intl.NumberFormat(i, {
|
|
23
23
|
style: "percent",
|
|
24
24
|
maximumFractionDigits: 4
|
|
25
|
-
}) : r === "integer" ? new Intl.NumberFormat(
|
|
26
|
-
if (!
|
|
27
|
-
const M = we(
|
|
25
|
+
}) : r === "integer" ? new Intl.NumberFormat(i, { maximumFractionDigits: 0 }) : new Intl.NumberFormat(i, { maximumFractionDigits: 10 }), T = (u) => Number.isFinite(u) ? c.format(u) : "", P = (u) => {
|
|
26
|
+
if (!u) return NaN;
|
|
27
|
+
const M = we(u), v = M.trim(), w = v.startsWith("-") || v.startsWith("−");
|
|
28
28
|
let l = "";
|
|
29
29
|
for (const g of M)
|
|
30
|
-
g >= "0" && g <= "9" ? l += g : g ===
|
|
30
|
+
g >= "0" && g <= "9" ? l += g : g === d && (l += ".");
|
|
31
31
|
if (!l || l === ".") return NaN;
|
|
32
32
|
let f = Number(l);
|
|
33
33
|
return Number.isFinite(f) ? (w && (f = -f), r === "percentage" && (f = f / 100), f) : NaN;
|
|
@@ -37,22 +37,22 @@ function ye(s, r, a) {
|
|
|
37
37
|
b = "numeric";
|
|
38
38
|
else if (r === "currency")
|
|
39
39
|
try {
|
|
40
|
-
const { maximumFractionDigits:
|
|
40
|
+
const { maximumFractionDigits: u } = new Intl.NumberFormat(i, {
|
|
41
41
|
style: "currency",
|
|
42
42
|
currency: a ?? "USD"
|
|
43
43
|
}).resolvedOptions();
|
|
44
|
-
b =
|
|
44
|
+
b = u === 0 ? "numeric" : "decimal";
|
|
45
45
|
} catch {
|
|
46
46
|
b = "decimal";
|
|
47
47
|
}
|
|
48
48
|
return {
|
|
49
49
|
format: T,
|
|
50
50
|
parse: P,
|
|
51
|
-
decimalSeparator:
|
|
51
|
+
decimalSeparator: d,
|
|
52
52
|
groupingSeparator: F,
|
|
53
53
|
inputMode: b
|
|
54
54
|
};
|
|
55
|
-
}, [
|
|
55
|
+
}, [i, r, a]);
|
|
56
56
|
}
|
|
57
57
|
const De = be(
|
|
58
58
|
[
|
|
@@ -78,29 +78,29 @@ const De = be(
|
|
|
78
78
|
defaultVariants: { size: "md", tone: "default" }
|
|
79
79
|
}
|
|
80
80
|
), H = [
|
|
81
|
-
"inline-flex items-center justify-center",
|
|
82
|
-
"h-full shrink-0",
|
|
83
|
-
"text-muted-foreground hover:text-foreground",
|
|
84
|
-
"transition-colors duration-[var(--animation-duration)] motion-reduce:transition-none",
|
|
85
|
-
"disabled:cursor-not-allowed disabled:opacity-50"
|
|
81
|
+
"ds:inline-flex ds:items-center ds:justify-center",
|
|
82
|
+
"ds:h-full ds:shrink-0",
|
|
83
|
+
"ds:text-muted-foreground ds:hover:text-foreground",
|
|
84
|
+
"ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none",
|
|
85
|
+
"ds:disabled:cursor-not-allowed ds:disabled:opacity-50"
|
|
86
86
|
].join(" "), xe = () => typeof navigator < "u" && navigator.language ? navigator.language : "en-US";
|
|
87
|
-
function Ie(
|
|
88
|
-
if (!Number.isFinite(
|
|
89
|
-
const r = String(
|
|
87
|
+
function Ie(i) {
|
|
88
|
+
if (!Number.isFinite(i)) return 0;
|
|
89
|
+
const r = String(i), a = r.indexOf(".");
|
|
90
90
|
return a === -1 ? 0 : r.length - a - 1;
|
|
91
91
|
}
|
|
92
|
-
function Fe(
|
|
93
|
-
if (r <= 0 || !Number.isFinite(r)) return
|
|
92
|
+
function Fe(i, r) {
|
|
93
|
+
if (r <= 0 || !Number.isFinite(r)) return i;
|
|
94
94
|
const t = 10 ** Ie(r);
|
|
95
|
-
return Math.round(
|
|
95
|
+
return Math.round(i * t) / t;
|
|
96
96
|
}
|
|
97
97
|
const Se = fe(
|
|
98
98
|
({
|
|
99
|
-
value:
|
|
99
|
+
value: i,
|
|
100
100
|
defaultValue: r,
|
|
101
101
|
onChange: a,
|
|
102
102
|
min: t,
|
|
103
|
-
max:
|
|
103
|
+
max: d,
|
|
104
104
|
step: F = 1,
|
|
105
105
|
mode: c = "integer",
|
|
106
106
|
currency: T,
|
|
@@ -108,16 +108,16 @@ const Se = fe(
|
|
|
108
108
|
size: b = "md",
|
|
109
109
|
tone: S,
|
|
110
110
|
className: C,
|
|
111
|
-
id:
|
|
111
|
+
id: u,
|
|
112
112
|
disabled: M,
|
|
113
113
|
onFocus: v,
|
|
114
114
|
onBlur: w,
|
|
115
115
|
onKeyDown: l,
|
|
116
116
|
...f
|
|
117
117
|
}, g) => {
|
|
118
|
-
const { t: A } = ve(), y = ge(), G =
|
|
118
|
+
const { t: A } = ve(), y = ge(), G = u ?? y.id, z = !!(y.disabled || M), J = P ?? xe(), j = ye(J, c, T), { decimalSeparator: E, format: k, parse: L } = j, R = i !== void 0, [Q, X] = B(
|
|
119
119
|
r ?? null
|
|
120
|
-
),
|
|
120
|
+
), s = R ? i ?? null : Q, U = $(
|
|
121
121
|
(e) => {
|
|
122
122
|
const n = c === "percentage" ? e * 100 : e;
|
|
123
123
|
return (Number.isInteger(n) ? String(n) : n.toString()).replace(".", E);
|
|
@@ -127,16 +127,16 @@ const Se = fe(
|
|
|
127
127
|
(e) => e == null || Number.isNaN(e) ? "" : k(e),
|
|
128
128
|
[k]
|
|
129
129
|
), [V, m] = B(
|
|
130
|
-
() => p(
|
|
130
|
+
() => p(s)
|
|
131
131
|
), D = me(!1), [Y, x] = B(!1);
|
|
132
132
|
pe(() => {
|
|
133
|
-
D.current || m(p(
|
|
134
|
-
}, [
|
|
135
|
-
const Z = Y ||
|
|
133
|
+
D.current || m(p(s));
|
|
134
|
+
}, [s, p]);
|
|
135
|
+
const Z = Y || s !== null && (t !== void 0 && s < t || d !== void 0 && s > d), q = y.invalid || Z, _ = q ? "error" : S ?? "default", N = (e) => {
|
|
136
136
|
R || X(e), a == null || a(e);
|
|
137
137
|
}, h = (e) => {
|
|
138
|
-
let o = (
|
|
139
|
-
t !== void 0 && (o = Math.max(t, o)),
|
|
138
|
+
let o = (s ?? 0) + F * e;
|
|
139
|
+
t !== void 0 && (o = Math.max(t, o)), d !== void 0 && (o = Math.min(d, o)), o = Fe(o, F), N(o), x(!1), m(
|
|
140
140
|
D.current ? U(o) : p(o)
|
|
141
141
|
);
|
|
142
142
|
}, O = (e) => {
|
|
@@ -146,7 +146,7 @@ const Se = fe(
|
|
|
146
146
|
}, K = (e) => {
|
|
147
147
|
if (l == null || l(e), e.defaultPrevented || z) return;
|
|
148
148
|
const { key: n, shiftKey: o } = e;
|
|
149
|
-
n === "ArrowUp" ? (e.preventDefault(), h(o ? 10 : 1)) : n === "ArrowDown" ? (e.preventDefault(), h(o ? -10 : -1)) : n === "PageUp" ? (e.preventDefault(), h(100)) : n === "PageDown" ? (e.preventDefault(), h(-100)) : n === "Home" && t !== void 0 ? (e.preventDefault(), O(t)) : n === "End" &&
|
|
149
|
+
n === "ArrowUp" ? (e.preventDefault(), h(o ? 10 : 1)) : n === "ArrowDown" ? (e.preventDefault(), h(o ? -10 : -1)) : n === "PageUp" ? (e.preventDefault(), h(100)) : n === "PageDown" ? (e.preventDefault(), h(-100)) : n === "Home" && t !== void 0 ? (e.preventDefault(), O(t)) : n === "End" && d !== void 0 && (e.preventDefault(), O(d));
|
|
150
150
|
}, ee = (e) => {
|
|
151
151
|
const n = e.target.value;
|
|
152
152
|
if (m(n), n.trim() === "") {
|
|
@@ -156,7 +156,7 @@ const Se = fe(
|
|
|
156
156
|
const o = L(n);
|
|
157
157
|
Number.isNaN(o) || N(o);
|
|
158
158
|
}, te = (e) => {
|
|
159
|
-
v == null || v(e), D.current = !0,
|
|
159
|
+
v == null || v(e), D.current = !0, s != null && m(U(s));
|
|
160
160
|
}, re = (e) => {
|
|
161
161
|
if (w == null || w(e), D.current = !1, V.trim() === "") {
|
|
162
162
|
N(null), x(!1), m("");
|
|
@@ -164,14 +164,14 @@ const Se = fe(
|
|
|
164
164
|
}
|
|
165
165
|
const n = L(V);
|
|
166
166
|
if (Number.isNaN(n)) {
|
|
167
|
-
m(p(
|
|
167
|
+
m(p(s));
|
|
168
168
|
return;
|
|
169
169
|
}
|
|
170
|
-
const o = t !== void 0 && n < t ||
|
|
170
|
+
const o = t !== void 0 && n < t || d !== void 0 && n > d;
|
|
171
171
|
x(o), N(n), m(p(n));
|
|
172
172
|
}, W = (e) => {
|
|
173
173
|
e.preventDefault();
|
|
174
|
-
}, ne = () => h(1),
|
|
174
|
+
}, ne = () => h(1), se = () => h(-1), ie = z || t !== void 0 && s !== null && s <= t, oe = z || d !== void 0 && s !== null && s >= d, ae = s ?? void 0, de = (c === "currency" || c === "percentage") && s !== null && s !== null ? k(s) : void 0, ue = j.inputMode === "numeric" ? "[0-9]*" : void 0;
|
|
175
175
|
return /* @__PURE__ */ le(
|
|
176
176
|
"div",
|
|
177
177
|
{
|
|
@@ -189,9 +189,9 @@ const Se = fe(
|
|
|
189
189
|
type: "button",
|
|
190
190
|
tabIndex: -1,
|
|
191
191
|
"aria-label": A("ui.inputs.number.decrement", "Decrement"),
|
|
192
|
-
onClick:
|
|
192
|
+
onClick: se,
|
|
193
193
|
onMouseDown: W,
|
|
194
|
-
disabled:
|
|
194
|
+
disabled: ie,
|
|
195
195
|
className: `${H} ds:ps-2 ds:pe-1`,
|
|
196
196
|
children: /* @__PURE__ */ I(Ne, { "aria-hidden": "true", className: "ds:size-4" })
|
|
197
197
|
}
|
|
@@ -204,14 +204,14 @@ const Se = fe(
|
|
|
204
204
|
type: "text",
|
|
205
205
|
role: "spinbutton",
|
|
206
206
|
inputMode: j.inputMode,
|
|
207
|
-
pattern:
|
|
207
|
+
pattern: ue,
|
|
208
208
|
autoComplete: "off",
|
|
209
209
|
value: V,
|
|
210
210
|
disabled: z,
|
|
211
211
|
"aria-valuemin": t,
|
|
212
|
-
"aria-valuemax":
|
|
212
|
+
"aria-valuemax": d,
|
|
213
213
|
"aria-valuenow": ae,
|
|
214
|
-
"aria-valuetext":
|
|
214
|
+
"aria-valuetext": de,
|
|
215
215
|
"aria-invalid": q || void 0,
|
|
216
216
|
"aria-required": y.required || void 0,
|
|
217
217
|
"aria-describedby": y.describedBy || void 0,
|
|
@@ -246,4 +246,4 @@ export {
|
|
|
246
246
|
Se as N,
|
|
247
247
|
ye as u
|
|
248
248
|
};
|
|
249
|
-
//# sourceMappingURL=number-input-
|
|
249
|
+
//# sourceMappingURL=number-input-DjpT_RXJ.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"number-input-DjpT_RXJ.js","sources":["../../src/components/number-input/use-locale-number.ts","../../src/components/number-input/number-input.tsx"],"sourcesContent":["import { useMemo } from 'react';\n\nexport type NumberInputMode = 'integer' | 'decimal' | 'currency' | 'percentage';\n\nexport interface LocaleNumber {\n /** Format a JS number for display (e.g. `1234.5` → `1.234,5` in de-DE). */\n format: (value: number) => string;\n /** Parse a locale-formatted string back to a JS number. Returns `NaN` for invalid input. */\n parse: (text: string) => number;\n /** The decimal separator for this locale (e.g. `.` or `,`). */\n decimalSeparator: string;\n /** The grouping separator for this locale (e.g. `,` or `.` or ` `). */\n groupingSeparator: string;\n /** The correct `inputMode` for the virtual keyboard. */\n inputMode: 'numeric' | 'decimal';\n}\n\nfunction normalizeDigits(text: string): string {\n let result = '';\n for (const ch of text) {\n const code = ch.codePointAt(0);\n if (code === undefined) continue;\n if (code >= 0x0660 && code <= 0x0669) {\n result += String.fromCodePoint(0x30 + (code - 0x0660));\n } else if (code >= 0x06f0 && code <= 0x06f9) {\n result += String.fromCodePoint(0x30 + (code - 0x06f0));\n } else {\n result += ch;\n }\n }\n return result;\n}\n\nexport function useLocaleNumber(\n locale: string,\n mode: NumberInputMode,\n currency?: string,\n): LocaleNumber {\n return useMemo(() => {\n const parts = new Intl.NumberFormat(locale).formatToParts(1234.5);\n const decimalSeparator =\n parts.find((p) => p.type === 'decimal')?.value ?? '.';\n const groupingSeparator =\n parts.find((p) => p.type === 'group')?.value ?? ',';\n\n const displayFormatter: Intl.NumberFormat = (() => {\n if (mode === 'currency') {\n return new Intl.NumberFormat(locale, {\n style: 'currency',\n currency: currency ?? 'USD',\n });\n }\n if (mode === 'percentage') {\n return new Intl.NumberFormat(locale, {\n style: 'percent',\n maximumFractionDigits: 4,\n });\n }\n if (mode === 'integer') {\n return new Intl.NumberFormat(locale, { maximumFractionDigits: 0 });\n }\n return new Intl.NumberFormat(locale, { maximumFractionDigits: 10 });\n })();\n\n const format = (value: number): string => {\n if (!Number.isFinite(value)) return '';\n return displayFormatter.format(value);\n };\n\n const parse = (text: string): number => {\n if (!text) return NaN;\n const normalized = normalizeDigits(text);\n const trimmed = normalized.trim();\n const hasMinus =\n trimmed.startsWith('-') || trimmed.startsWith('\\u2212');\n\n let cleaned = '';\n for (const ch of normalized) {\n if (ch >= '0' && ch <= '9') {\n cleaned += ch;\n } else if (ch === decimalSeparator) {\n cleaned += '.';\n }\n }\n if (!cleaned || cleaned === '.') return NaN;\n\n let n = Number(cleaned);\n if (!Number.isFinite(n)) return NaN;\n if (hasMinus) n = -n;\n if (mode === 'percentage') n = n / 100;\n return n;\n };\n\n let inputMode: 'numeric' | 'decimal' = 'decimal';\n if (mode === 'integer') {\n inputMode = 'numeric';\n } else if (mode === 'currency') {\n try {\n const { maximumFractionDigits } = new Intl.NumberFormat(locale, {\n style: 'currency',\n currency: currency ?? 'USD',\n }).resolvedOptions();\n inputMode = maximumFractionDigits === 0 ? 'numeric' : 'decimal';\n } catch {\n inputMode = 'decimal';\n }\n }\n\n return {\n format,\n parse,\n decimalSeparator,\n groupingSeparator,\n inputMode,\n };\n }, [locale, mode, currency]);\n}\n","import {\n forwardRef,\n useCallback,\n useEffect,\n useRef,\n useState,\n type ChangeEvent,\n type FocusEvent,\n type InputHTMLAttributes,\n type KeyboardEvent,\n type MouseEvent,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { ChevronDown, ChevronUp } from 'lucide-react';\nimport { useFormField } from '../form-field/form-field-context';\nimport {\n useLocaleNumber,\n type NumberInputMode,\n} from './use-locale-number';\n\nconst numberInputVariants = cva(\n [\n 'ds:flex ds:items-center ds:w-full ds:rounded-[var(--radius-sm)]',\n 'ds:border ds:bg-background ds:text-foreground',\n 'ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n 'ds:focus-within:outline-[length:var(--focus-ring-width)] ds:focus-within:outline-solid',\n 'ds:focus-within:outline-ring ds:focus-within:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:has-[:disabled]:cursor-not-allowed ds:has-[:disabled]:opacity-50',\n ].join(' '),\n {\n variants: {\n size: {\n sm: 'ds:h-8 ds:text-[length:var(--font-size-sm)]',\n md: 'ds:h-[var(--min-target-size)] ds:text-[length:var(--font-size-base)]',\n lg: 'ds:h-12 ds:text-[length:var(--font-size-lg)]',\n },\n tone: {\n default: 'ds:border-border',\n error: 'ds:border-destructive ds:focus-within:outline-destructive',\n },\n },\n defaultVariants: { size: 'md', tone: 'default' },\n },\n);\n\nconst spinnerButton = [\n 'ds:inline-flex ds:items-center ds:justify-center',\n 'ds:h-full ds:shrink-0',\n 'ds:text-muted-foreground ds:hover:text-foreground',\n 'ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n 'ds:disabled:cursor-not-allowed ds:disabled:opacity-50',\n].join(' ');\n\nexport type { NumberInputMode };\n\nexport interface NumberInputProps\n extends Omit<\n InputHTMLAttributes<HTMLInputElement>,\n 'type' | 'onChange' | 'value' | 'defaultValue' | 'size'\n >,\n VariantProps<typeof numberInputVariants> {\n /** Current numeric value (controlled). */\n value?: number | null;\n /** Initial value (uncontrolled). */\n defaultValue?: number;\n /** Fires with the parsed number (not a string). `null` when the field is empty. */\n onChange?: (value: number | null) => void;\n /** Minimum allowed value. Maps to `aria-valuemin`. */\n min?: number;\n /** Maximum allowed value. Maps to `aria-valuemax`. */\n max?: number;\n /** Increment step. Defaults to `1`. */\n step?: number;\n /** Display/parse mode. Defaults to `'integer'`. */\n mode?: NumberInputMode;\n /** ISO 4217 currency code, required when `mode='currency'`. */\n currency?: string;\n /** BCP 47 locale. Defaults to `navigator.language` or `'en-US'`. */\n locale?: string;\n /** Size variant. */\n size?: 'sm' | 'md' | 'lg';\n /** Additional class names on the wrapper. */\n className?: string;\n}\n\nconst resolveDefaultLocale = (): string => {\n if (typeof navigator !== 'undefined' && navigator.language) {\n return navigator.language;\n }\n return 'en-US';\n};\n\nfunction decimalPlaces(n: number): number {\n if (!Number.isFinite(n)) return 0;\n const s = String(n);\n const dot = s.indexOf('.');\n if (dot === -1) return 0;\n return s.length - dot - 1;\n}\n\nfunction roundToStep(value: number, step: number): number {\n if (step <= 0 || !Number.isFinite(step)) return value;\n const precision = decimalPlaces(step);\n const factor = 10 ** precision;\n return Math.round(value * factor) / factor;\n}\n\nexport const NumberInput = forwardRef<HTMLInputElement, NumberInputProps>(\n (\n {\n value,\n defaultValue,\n onChange,\n min,\n max,\n step = 1,\n mode = 'integer',\n currency,\n locale,\n size = 'md',\n tone,\n className,\n id,\n disabled,\n onFocus,\n onBlur,\n onKeyDown,\n ...rest\n },\n ref,\n ) => {\n const { t } = useTranslation();\n const ctx = useFormField();\n const inputId = id ?? ctx.id;\n const effectiveDisabled = Boolean(ctx.disabled || disabled);\n\n const resolvedLocale = locale ?? resolveDefaultLocale();\n const localeNumber = useLocaleNumber(resolvedLocale, mode, currency);\n const { decimalSeparator, format: localeFormat, parse: localeParse } =\n localeNumber;\n\n const isControlled = value !== undefined;\n const [internalValue, setInternalValue] = useState<number | null>(\n defaultValue ?? null,\n );\n const currentValue: number | null = isControlled\n ? (value ?? null)\n : internalValue;\n\n const formatForEdit = useCallback(\n (n: number): string => {\n const displayed = mode === 'percentage' ? n * 100 : n;\n const raw = Number.isInteger(displayed)\n ? String(displayed)\n : displayed.toString();\n return raw.replace('.', decimalSeparator);\n },\n [mode, decimalSeparator],\n );\n\n const formatCurrent = useCallback(\n (n: number | null | undefined): string =>\n n === null || n === undefined || Number.isNaN(n) ? '' : localeFormat(n),\n [localeFormat],\n );\n\n const [inputText, setInputText] = useState<string>(() =>\n formatCurrent(currentValue),\n );\n const isFocusedRef = useRef(false);\n const [crossedBounds, setCrossedBounds] = useState(false);\n\n useEffect(() => {\n if (!isFocusedRef.current) {\n setInputText(formatCurrent(currentValue));\n }\n }, [currentValue, formatCurrent]);\n\n const computedInvalid =\n crossedBounds ||\n (currentValue !== null &&\n ((min !== undefined && currentValue < min) ||\n (max !== undefined && currentValue > max)));\n const ariaInvalid = ctx.invalid || computedInvalid;\n const effectiveTone: 'default' | 'error' = ariaInvalid\n ? 'error'\n : tone ?? 'default';\n\n const commitValue = (next: number | null) => {\n if (!isControlled) setInternalValue(next);\n onChange?.(next);\n };\n\n const applyDelta = (multiplier: number) => {\n const base = currentValue ?? 0;\n let next = base + step * multiplier;\n if (min !== undefined) next = Math.max(min, next);\n if (max !== undefined) next = Math.min(max, next);\n next = roundToStep(next, step);\n commitValue(next);\n setCrossedBounds(false);\n setInputText(\n isFocusedRef.current ? formatForEdit(next) : formatCurrent(next),\n );\n };\n\n const jumpTo = (target: number) => {\n commitValue(target);\n setCrossedBounds(false);\n setInputText(\n isFocusedRef.current ? formatForEdit(target) : formatCurrent(target),\n );\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {\n onKeyDown?.(event);\n if (event.defaultPrevented) return;\n if (effectiveDisabled) return;\n\n const { key, shiftKey } = event;\n if (key === 'ArrowUp') {\n event.preventDefault();\n applyDelta(shiftKey ? 10 : 1);\n } else if (key === 'ArrowDown') {\n event.preventDefault();\n applyDelta(shiftKey ? -10 : -1);\n } else if (key === 'PageUp') {\n event.preventDefault();\n applyDelta(100);\n } else if (key === 'PageDown') {\n event.preventDefault();\n applyDelta(-100);\n } else if (key === 'Home' && min !== undefined) {\n event.preventDefault();\n jumpTo(min);\n } else if (key === 'End' && max !== undefined) {\n event.preventDefault();\n jumpTo(max);\n }\n };\n\n const handleInputChange = (event: ChangeEvent<HTMLInputElement>) => {\n const text = event.target.value;\n setInputText(text);\n if (text.trim() === '') {\n commitValue(null);\n setCrossedBounds(false);\n return;\n }\n const parsed = localeParse(text);\n if (!Number.isNaN(parsed)) {\n commitValue(parsed);\n }\n };\n\n const handleFocus = (event: FocusEvent<HTMLInputElement>) => {\n onFocus?.(event);\n isFocusedRef.current = true;\n if (currentValue !== null && currentValue !== undefined) {\n setInputText(formatForEdit(currentValue));\n }\n };\n\n const handleBlur = (event: FocusEvent<HTMLInputElement>) => {\n onBlur?.(event);\n isFocusedRef.current = false;\n\n if (inputText.trim() === '') {\n commitValue(null);\n setCrossedBounds(false);\n setInputText('');\n return;\n }\n const parsed = localeParse(inputText);\n if (Number.isNaN(parsed)) {\n setInputText(formatCurrent(currentValue));\n return;\n }\n const crossed =\n (min !== undefined && parsed < min) ||\n (max !== undefined && parsed > max);\n setCrossedBounds(crossed);\n commitValue(parsed);\n setInputText(formatCurrent(parsed));\n };\n\n const preventButtonBlur = (event: MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n };\n\n const handleIncrement = () => applyDelta(1);\n const handleDecrement = () => applyDelta(-1);\n\n const decrementDisabled =\n effectiveDisabled ||\n (min !== undefined && currentValue !== null && currentValue <= min);\n const incrementDisabled =\n effectiveDisabled ||\n (max !== undefined && currentValue !== null && currentValue >= max);\n\n const valueNow = currentValue ?? undefined;\n const valueTextNeeded =\n (mode === 'currency' || mode === 'percentage') && currentValue !== null;\n const valueText =\n valueTextNeeded && currentValue !== null\n ? localeFormat(currentValue)\n : undefined;\n\n const patternAttr =\n localeNumber.inputMode === 'numeric' ? '[0-9]*' : undefined;\n\n return (\n <div\n className={numberInputVariants({\n size,\n tone: effectiveTone,\n className,\n })}\n data-component=\"number-input\"\n data-mode={mode}\n >\n <button\n type=\"button\"\n tabIndex={-1}\n aria-label={t('ui.inputs.number.decrement', 'Decrement')}\n onClick={handleDecrement}\n onMouseDown={preventButtonBlur}\n disabled={decrementDisabled}\n className={`${spinnerButton} ds:ps-2 ds:pe-1`}\n >\n <ChevronDown aria-hidden=\"true\" className=\"ds:size-4\" />\n </button>\n <input\n ref={ref}\n id={inputId}\n type=\"text\"\n role=\"spinbutton\"\n inputMode={localeNumber.inputMode}\n pattern={patternAttr}\n autoComplete=\"off\"\n value={inputText}\n disabled={effectiveDisabled}\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={valueNow}\n aria-valuetext={valueText}\n aria-invalid={ariaInvalid || undefined}\n aria-required={ctx.required || undefined}\n aria-describedby={ctx.describedBy || undefined}\n onChange={handleInputChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n className=\"ds:flex-1 ds:w-full ds:min-w-0 ds:bg-transparent ds:outline-none ds:ps-2 ds:pe-2 ds:text-start ds:tabular-nums ds:disabled:cursor-not-allowed\"\n {...rest}\n />\n <button\n type=\"button\"\n tabIndex={-1}\n aria-label={t('ui.inputs.number.increment', 'Increment')}\n onClick={handleIncrement}\n onMouseDown={preventButtonBlur}\n disabled={incrementDisabled}\n className={`${spinnerButton} ds:ps-1 ds:pe-2`}\n >\n <ChevronUp aria-hidden=\"true\" className=\"ds:size-4\" />\n </button>\n </div>\n );\n },\n);\n\nNumberInput.displayName = 'NumberInput';\n"],"names":["normalizeDigits","text","result","ch","code","useLocaleNumber","locale","mode","currency","useMemo","parts","decimalSeparator","_a","p","groupingSeparator","_b","displayFormatter","format","value","parse","normalized","trimmed","hasMinus","cleaned","n","inputMode","maximumFractionDigits","numberInputVariants","cva","spinnerButton","resolveDefaultLocale","decimalPlaces","s","dot","roundToStep","step","factor","NumberInput","forwardRef","defaultValue","onChange","min","max","size","tone","className","id","disabled","onFocus","onBlur","onKeyDown","rest","ref","t","useTranslation","ctx","useFormField","inputId","effectiveDisabled","resolvedLocale","localeNumber","localeFormat","localeParse","isControlled","internalValue","setInternalValue","useState","currentValue","formatForEdit","useCallback","displayed","formatCurrent","inputText","setInputText","isFocusedRef","useRef","crossedBounds","setCrossedBounds","useEffect","computedInvalid","ariaInvalid","effectiveTone","commitValue","next","applyDelta","multiplier","jumpTo","target","handleKeyDown","event","key","shiftKey","handleInputChange","parsed","handleFocus","handleBlur","crossed","preventButtonBlur","handleIncrement","handleDecrement","decrementDisabled","incrementDisabled","valueNow","valueText","patternAttr","jsxs","jsx","ChevronDown","ChevronUp"],"mappings":"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"}
|
|
@@ -0,0 +1,380 @@
|
|
|
1
|
+
import { jsxs as g, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as m, useState as K, useEffect as O, useCallback as R, useMemo as Q, useId as W } from "react";
|
|
3
|
+
import * as c from "@radix-ui/react-select";
|
|
4
|
+
import { c as X } from "./index-D2ZczOXr.js";
|
|
5
|
+
import { useTranslation as x } from "react-i18next";
|
|
6
|
+
import { E as Y } from "./ellipsis-rgGdiK_9.js";
|
|
7
|
+
import { C as S } from "./chevron-right-BrpYejk0.js";
|
|
8
|
+
import { C as Z } from "./chevron-left-CX1jqD2M.js";
|
|
9
|
+
import { C as D, a as ss } from "./chevrons-right-d9MwesPG.js";
|
|
10
|
+
import { C as es } from "./check-DPdL_Sm7.js";
|
|
11
|
+
const as = [
|
|
12
|
+
"ds:inline-flex ds:items-center ds:justify-center",
|
|
13
|
+
"ds:rounded-[var(--radius-sm)]",
|
|
14
|
+
"ds:border ds:border-transparent",
|
|
15
|
+
"ds:font-[var(--font-weight-medium)]",
|
|
16
|
+
"ds:text-[var(--foreground)]",
|
|
17
|
+
"ds:select-none",
|
|
18
|
+
"ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none",
|
|
19
|
+
"ds:hover:bg-[var(--muted)]/20",
|
|
20
|
+
"ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid",
|
|
21
|
+
"ds:focus-visible:outline-[var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]",
|
|
22
|
+
"ds:disabled:cursor-not-allowed ds:disabled:opacity-50",
|
|
23
|
+
"ds:aria-disabled:cursor-not-allowed ds:aria-disabled:opacity-50"
|
|
24
|
+
].join(" "), j = X(as, {
|
|
25
|
+
variants: {
|
|
26
|
+
size: {
|
|
27
|
+
sm: "ds:min-w-[var(--min-target-size)] ds:min-h-[var(--min-target-size)] ds:text-[length:var(--font-size-sm)] ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)]",
|
|
28
|
+
md: "ds:min-w-[var(--min-target-size)] ds:min-h-[var(--min-target-size)] ds:text-[length:var(--font-size-base)] ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]",
|
|
29
|
+
lg: "ds:min-w-[3rem] ds:min-h-[3rem] ds:text-[length:var(--font-size-lg)] ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]"
|
|
30
|
+
},
|
|
31
|
+
active: {
|
|
32
|
+
true: "ds:bg-[var(--primary)] ds:text-[var(--primary-foreground)] ds:font-[var(--font-weight-bold)] ds:outline ds:outline-1 ds:outline-[var(--primary)] ds:hover:bg-[var(--primary-hover)]",
|
|
33
|
+
false: ""
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
defaultVariants: { size: "md", active: !1 }
|
|
37
|
+
});
|
|
38
|
+
function w(n, a) {
|
|
39
|
+
const i = [];
|
|
40
|
+
for (let s = n; s <= a; s++) i.push(s);
|
|
41
|
+
return i;
|
|
42
|
+
}
|
|
43
|
+
function is(n, a, i = 1, s = 1) {
|
|
44
|
+
if (a <= 0) return [];
|
|
45
|
+
if (i = Math.max(0, i), s = Math.max(1, s), s * 2 + i * 2 + 3 >= a) return w(1, a);
|
|
46
|
+
const r = w(1, s), t = w(a - s + 1, a), p = Math.max(
|
|
47
|
+
Math.min(n - i, a - s - i * 2 - 1),
|
|
48
|
+
s + 2
|
|
49
|
+
), f = Math.min(
|
|
50
|
+
Math.max(n + i, s + i * 2 + 2),
|
|
51
|
+
t[0] - 2
|
|
52
|
+
), l = [...r];
|
|
53
|
+
return p > s + 2 ? l.push("ellipsis-start") : s + 1 < a - s && l.push(s + 1), l.push(...w(p, f)), f < a - s - 1 ? l.push("ellipsis-end") : a - s > s && l.push(a - s), l.push(...t), l;
|
|
54
|
+
}
|
|
55
|
+
const ns = m(
|
|
56
|
+
({
|
|
57
|
+
totalPages: n,
|
|
58
|
+
page: a,
|
|
59
|
+
defaultPage: i = 1,
|
|
60
|
+
onPageChange: s,
|
|
61
|
+
siblingCount: d = 1,
|
|
62
|
+
boundaryCount: r = 1,
|
|
63
|
+
size: t = "md",
|
|
64
|
+
showEndpoints: p = !1,
|
|
65
|
+
align: f = "center",
|
|
66
|
+
pageSize: l,
|
|
67
|
+
useLocaleDigits: I = !1,
|
|
68
|
+
locale: M,
|
|
69
|
+
className: H,
|
|
70
|
+
...U
|
|
71
|
+
}, _) => {
|
|
72
|
+
const { t: P, i18n: k } = x(), h = a !== void 0, [q, C] = K(i), v = h ? a : q;
|
|
73
|
+
O(() => {
|
|
74
|
+
h && i !== 1 && console.warn(
|
|
75
|
+
"[Pagination] Both `page` and `defaultPage` were supplied. The `page` prop wins; remove `defaultPage` for controlled usage."
|
|
76
|
+
);
|
|
77
|
+
}, [h, i]);
|
|
78
|
+
const b = R(
|
|
79
|
+
(o) => {
|
|
80
|
+
const N = Math.min(Math.max(o, 1), Math.max(1, n));
|
|
81
|
+
h || C(N), s == null || s(N);
|
|
82
|
+
},
|
|
83
|
+
[h, s, n]
|
|
84
|
+
), E = R(
|
|
85
|
+
(o) => {
|
|
86
|
+
if (!I) return String(o);
|
|
87
|
+
try {
|
|
88
|
+
return new Intl.NumberFormat(M ?? k.language).format(o);
|
|
89
|
+
} catch {
|
|
90
|
+
return String(o);
|
|
91
|
+
}
|
|
92
|
+
},
|
|
93
|
+
[k.language, M, I]
|
|
94
|
+
), G = Q(
|
|
95
|
+
() => is(v, n, d, r),
|
|
96
|
+
[v, n, d, r]
|
|
97
|
+
), B = v <= 1, L = v >= n, J = f === "start" ? "ds:justify-start" : f === "end" ? "ds:justify-end" : "ds:justify-center";
|
|
98
|
+
return /* @__PURE__ */ g(
|
|
99
|
+
"nav",
|
|
100
|
+
{
|
|
101
|
+
ref: _,
|
|
102
|
+
"aria-label": P("ui.navigation.pagination.label"),
|
|
103
|
+
"data-component": "pagination",
|
|
104
|
+
className: [
|
|
105
|
+
"ds:flex ds:items-center",
|
|
106
|
+
J,
|
|
107
|
+
"ds:gap-[var(--spacing-sm)]",
|
|
108
|
+
"ds:flex-wrap",
|
|
109
|
+
H ?? ""
|
|
110
|
+
].filter(Boolean).join(" "),
|
|
111
|
+
...U,
|
|
112
|
+
children: [
|
|
113
|
+
/* @__PURE__ */ g(T, { size: t, children: [
|
|
114
|
+
p ? /* @__PURE__ */ e(u, { children: /* @__PURE__ */ e(
|
|
115
|
+
y,
|
|
116
|
+
{
|
|
117
|
+
type: "first",
|
|
118
|
+
size: t,
|
|
119
|
+
disabled: B,
|
|
120
|
+
onClick: () => b(1)
|
|
121
|
+
}
|
|
122
|
+
) }) : null,
|
|
123
|
+
/* @__PURE__ */ e(u, { children: /* @__PURE__ */ e(
|
|
124
|
+
F,
|
|
125
|
+
{
|
|
126
|
+
size: t,
|
|
127
|
+
disabled: B,
|
|
128
|
+
onClick: () => b(v - 1)
|
|
129
|
+
}
|
|
130
|
+
) }),
|
|
131
|
+
G.map((o, N) => o === "ellipsis-start" || o === "ellipsis-end" ? /* @__PURE__ */ e(u, { children: /* @__PURE__ */ e(A, {}) }, `e-${N}`) : /* @__PURE__ */ e(u, { children: /* @__PURE__ */ e(
|
|
132
|
+
V,
|
|
133
|
+
{
|
|
134
|
+
size: t,
|
|
135
|
+
isActive: o === v,
|
|
136
|
+
"aria-label": P("ui.navigation.pagination.pageN", { n: o }),
|
|
137
|
+
onClick: () => b(o),
|
|
138
|
+
children: E(o)
|
|
139
|
+
}
|
|
140
|
+
) }, `p-${o}`)),
|
|
141
|
+
/* @__PURE__ */ e(u, { children: /* @__PURE__ */ e(
|
|
142
|
+
$,
|
|
143
|
+
{
|
|
144
|
+
size: t,
|
|
145
|
+
disabled: L,
|
|
146
|
+
onClick: () => b(v + 1)
|
|
147
|
+
}
|
|
148
|
+
) }),
|
|
149
|
+
p ? /* @__PURE__ */ e(u, { children: /* @__PURE__ */ e(
|
|
150
|
+
y,
|
|
151
|
+
{
|
|
152
|
+
type: "last",
|
|
153
|
+
size: t,
|
|
154
|
+
disabled: L,
|
|
155
|
+
onClick: () => b(n)
|
|
156
|
+
}
|
|
157
|
+
) }) : null
|
|
158
|
+
] }),
|
|
159
|
+
l ? /* @__PURE__ */ e(
|
|
160
|
+
os,
|
|
161
|
+
{
|
|
162
|
+
size: t,
|
|
163
|
+
value: l.value,
|
|
164
|
+
options: l.options ?? [10, 25, 50, 100],
|
|
165
|
+
onChange: l.onChange,
|
|
166
|
+
formatNumber: E
|
|
167
|
+
}
|
|
168
|
+
) : null
|
|
169
|
+
]
|
|
170
|
+
}
|
|
171
|
+
);
|
|
172
|
+
}
|
|
173
|
+
);
|
|
174
|
+
ns.displayName = "Pagination";
|
|
175
|
+
const T = m(
|
|
176
|
+
({ children: n, className: a, ...i }, s) => /* @__PURE__ */ e(
|
|
177
|
+
"ul",
|
|
178
|
+
{
|
|
179
|
+
ref: s,
|
|
180
|
+
className: [
|
|
181
|
+
"ds:flex ds:items-center",
|
|
182
|
+
"ds:gap-[var(--spacing-xs)]",
|
|
183
|
+
"ds:m-0 ds:ps-0",
|
|
184
|
+
"ds:list-none",
|
|
185
|
+
a ?? ""
|
|
186
|
+
].filter(Boolean).join(" "),
|
|
187
|
+
...i,
|
|
188
|
+
children: n
|
|
189
|
+
}
|
|
190
|
+
)
|
|
191
|
+
);
|
|
192
|
+
T.displayName = "PaginationList";
|
|
193
|
+
const u = m(
|
|
194
|
+
({ children: n, className: a, ...i }, s) => /* @__PURE__ */ e("li", { ref: s, className: a, ...i, children: n })
|
|
195
|
+
);
|
|
196
|
+
u.displayName = "PaginationItem";
|
|
197
|
+
const V = m(
|
|
198
|
+
({ isActive: n = !1, size: a = "md", className: i, children: s, ...d }, r) => /* @__PURE__ */ e(
|
|
199
|
+
"button",
|
|
200
|
+
{
|
|
201
|
+
ref: r,
|
|
202
|
+
type: "button",
|
|
203
|
+
"aria-current": n ? "page" : void 0,
|
|
204
|
+
className: j({
|
|
205
|
+
size: a,
|
|
206
|
+
active: n,
|
|
207
|
+
className: i
|
|
208
|
+
}),
|
|
209
|
+
...d,
|
|
210
|
+
children: s
|
|
211
|
+
}
|
|
212
|
+
)
|
|
213
|
+
);
|
|
214
|
+
V.displayName = "PaginationLink";
|
|
215
|
+
const z = "ds:size-4 ds:rtl:-scale-x-100", F = m(
|
|
216
|
+
({ size: n = "md", disabled: a, onClick: i }, s) => {
|
|
217
|
+
const { t: d } = x(), r = d("ui.navigation.pagination.previous");
|
|
218
|
+
return /* @__PURE__ */ e(
|
|
219
|
+
"button",
|
|
220
|
+
{
|
|
221
|
+
ref: s,
|
|
222
|
+
type: "button",
|
|
223
|
+
"aria-label": r,
|
|
224
|
+
"aria-disabled": a || void 0,
|
|
225
|
+
disabled: a,
|
|
226
|
+
onClick: i,
|
|
227
|
+
className: j({ size: n }),
|
|
228
|
+
children: /* @__PURE__ */ e(Z, { "aria-hidden": "true", className: z })
|
|
229
|
+
}
|
|
230
|
+
);
|
|
231
|
+
}
|
|
232
|
+
);
|
|
233
|
+
F.displayName = "PaginationPrevious";
|
|
234
|
+
const $ = m(
|
|
235
|
+
({ size: n = "md", disabled: a, onClick: i }, s) => {
|
|
236
|
+
const { t: d } = x(), r = d("ui.navigation.pagination.next");
|
|
237
|
+
return /* @__PURE__ */ e(
|
|
238
|
+
"button",
|
|
239
|
+
{
|
|
240
|
+
ref: s,
|
|
241
|
+
type: "button",
|
|
242
|
+
"aria-label": r,
|
|
243
|
+
"aria-disabled": a || void 0,
|
|
244
|
+
disabled: a,
|
|
245
|
+
onClick: i,
|
|
246
|
+
className: j({ size: n }),
|
|
247
|
+
children: /* @__PURE__ */ e(S, { "aria-hidden": "true", className: z })
|
|
248
|
+
}
|
|
249
|
+
);
|
|
250
|
+
}
|
|
251
|
+
);
|
|
252
|
+
$.displayName = "PaginationNext";
|
|
253
|
+
const y = m(
|
|
254
|
+
({ type: n, size: a = "md", disabled: i, onClick: s }, d) => {
|
|
255
|
+
const { t: r } = x(), t = r(n === "first" ? "ui.navigation.pagination.first" : "ui.navigation.pagination.last"), p = n === "first" ? D : ss;
|
|
256
|
+
return /* @__PURE__ */ e(
|
|
257
|
+
"button",
|
|
258
|
+
{
|
|
259
|
+
ref: d,
|
|
260
|
+
type: "button",
|
|
261
|
+
"aria-label": t,
|
|
262
|
+
"aria-disabled": i || void 0,
|
|
263
|
+
disabled: i,
|
|
264
|
+
onClick: s,
|
|
265
|
+
className: j({ size: a }),
|
|
266
|
+
children: /* @__PURE__ */ e(p, { "aria-hidden": "true", className: z })
|
|
267
|
+
}
|
|
268
|
+
);
|
|
269
|
+
}
|
|
270
|
+
);
|
|
271
|
+
y.displayName = "PaginationEndpoint";
|
|
272
|
+
const A = m(
|
|
273
|
+
({ className: n, ...a }, i) => /* @__PURE__ */ e(
|
|
274
|
+
"span",
|
|
275
|
+
{
|
|
276
|
+
ref: i,
|
|
277
|
+
"aria-hidden": "true",
|
|
278
|
+
role: "presentation",
|
|
279
|
+
className: [
|
|
280
|
+
"ds:inline-flex ds:items-center ds:justify-center",
|
|
281
|
+
"ds:min-w-[var(--min-target-size)] ds:min-h-[var(--min-target-size)]",
|
|
282
|
+
"ds:text-[var(--muted-foreground)]",
|
|
283
|
+
n ?? ""
|
|
284
|
+
].filter(Boolean).join(" "),
|
|
285
|
+
...a,
|
|
286
|
+
children: /* @__PURE__ */ e(Y, { "aria-hidden": "true", className: "ds:size-4" })
|
|
287
|
+
}
|
|
288
|
+
)
|
|
289
|
+
);
|
|
290
|
+
A.displayName = "PaginationEllipsis";
|
|
291
|
+
const ts = [
|
|
292
|
+
"ds:inline-flex ds:items-center ds:justify-between ds:gap-[var(--spacing-xs)]",
|
|
293
|
+
"ds:rounded-[var(--radius-sm)] ds:border ds:border-[var(--border)] ds:bg-[var(--background)]",
|
|
294
|
+
"ds:text-[var(--foreground)]",
|
|
295
|
+
"ds:min-h-[var(--min-target-size)] ds:min-w-[6rem]",
|
|
296
|
+
"ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]",
|
|
297
|
+
"ds:text-[var(--font-size-sm)]",
|
|
298
|
+
"ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid",
|
|
299
|
+
"ds:focus-visible:outline-[var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]"
|
|
300
|
+
].join(" "), rs = [
|
|
301
|
+
"ds:z-[var(--z-dropdown)] ds:overflow-hidden",
|
|
302
|
+
"ds:rounded-[var(--radius-md)] ds:border ds:border-[var(--border)]",
|
|
303
|
+
"ds:bg-[var(--background)] ds:text-[var(--foreground)]",
|
|
304
|
+
"ds:shadow-[var(--shadow-lg)]",
|
|
305
|
+
"ds:animate-in ds:fade-in ds:zoom-in-95 ds:motion-reduce:animate-none"
|
|
306
|
+
].join(" "), ds = [
|
|
307
|
+
"ds:relative ds:flex ds:cursor-pointer ds:items-center",
|
|
308
|
+
"ds:min-h-[var(--min-target-size)]",
|
|
309
|
+
"ds:ps-[var(--spacing-xl)] ds:pe-[var(--spacing-sm)]",
|
|
310
|
+
"ds:rounded-[var(--radius-sm)]",
|
|
311
|
+
"ds:text-[var(--foreground)] ds:outline-none ds:select-none",
|
|
312
|
+
"ds:data-[highlighted]:bg-[var(--muted)]/20",
|
|
313
|
+
"ds:data-[disabled]:pointer-events-none ds:data-[disabled]:opacity-50"
|
|
314
|
+
].join(" ");
|
|
315
|
+
function os({ value: n, options: a, onChange: i, formatNumber: s }) {
|
|
316
|
+
const { t: d } = x(), r = W();
|
|
317
|
+
return /* @__PURE__ */ g("div", { className: "ds:flex ds:items-center ds:gap-[var(--spacing-sm)]", children: [
|
|
318
|
+
/* @__PURE__ */ e(
|
|
319
|
+
"span",
|
|
320
|
+
{
|
|
321
|
+
id: r,
|
|
322
|
+
className: "type-label ds:text-[var(--muted-foreground)]",
|
|
323
|
+
children: d("ui.navigation.pagination.rowsPerPage")
|
|
324
|
+
}
|
|
325
|
+
),
|
|
326
|
+
/* @__PURE__ */ g(
|
|
327
|
+
c.Root,
|
|
328
|
+
{
|
|
329
|
+
value: String(n),
|
|
330
|
+
onValueChange: (t) => i(Number(t)),
|
|
331
|
+
children: [
|
|
332
|
+
/* @__PURE__ */ g(
|
|
333
|
+
c.Trigger,
|
|
334
|
+
{
|
|
335
|
+
"aria-labelledby": r,
|
|
336
|
+
className: ts,
|
|
337
|
+
children: [
|
|
338
|
+
/* @__PURE__ */ e(c.Value, {}),
|
|
339
|
+
/* @__PURE__ */ e(c.Icon, { asChild: !0, children: /* @__PURE__ */ e(S, { "aria-hidden": "true", className: "ds:size-3 ds:rotate-90" }) })
|
|
340
|
+
]
|
|
341
|
+
}
|
|
342
|
+
),
|
|
343
|
+
/* @__PURE__ */ e(c.Portal, { children: /* @__PURE__ */ e(c.Content, { className: rs, position: "popper", children: /* @__PURE__ */ e(c.Viewport, { className: "ds:p-[var(--spacing-xs)]", children: a.map((t) => /* @__PURE__ */ g(
|
|
344
|
+
c.Item,
|
|
345
|
+
{
|
|
346
|
+
value: String(t),
|
|
347
|
+
className: ds,
|
|
348
|
+
children: [
|
|
349
|
+
/* @__PURE__ */ e(c.ItemIndicator, { className: "ds:absolute ds:inline-flex ds:items-center ds:justify-center ds:start-[var(--spacing-sm)]", children: /* @__PURE__ */ e(es, { "aria-hidden": "true", className: "ds:size-3.5" }) }),
|
|
350
|
+
/* @__PURE__ */ e(c.ItemText, { children: s(t) })
|
|
351
|
+
]
|
|
352
|
+
},
|
|
353
|
+
t
|
|
354
|
+
)) }) }) })
|
|
355
|
+
]
|
|
356
|
+
}
|
|
357
|
+
)
|
|
358
|
+
] });
|
|
359
|
+
}
|
|
360
|
+
const bs = {
|
|
361
|
+
id: "pagination",
|
|
362
|
+
capabilities: ["paginate", "range_navigate"],
|
|
363
|
+
state: {},
|
|
364
|
+
actions: {},
|
|
365
|
+
domHooks: {
|
|
366
|
+
root: { attr: "data-component", value: "pagination" }
|
|
367
|
+
}
|
|
368
|
+
};
|
|
369
|
+
export {
|
|
370
|
+
ns as P,
|
|
371
|
+
A as a,
|
|
372
|
+
u as b,
|
|
373
|
+
V as c,
|
|
374
|
+
T as d,
|
|
375
|
+
$ as e,
|
|
376
|
+
F as f,
|
|
377
|
+
is as g,
|
|
378
|
+
bs as p
|
|
379
|
+
};
|
|
380
|
+
//# sourceMappingURL=pagination.agent-oEaqmtx5.js.map
|