@bigbinary/neeto-atoms 1.0.36 → 1.0.38
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-DVMgPBum.js +45 -0
- package/dist/{Accordion-Ch9S_qd3.js.map → Accordion-DVMgPBum.js.map} +1 -1
- package/dist/Alert-bS5M631u.js +150 -0
- package/dist/{Alert-CayTuRLW.js.map → Alert-bS5M631u.js.map} +1 -1
- package/dist/Avatar-CJq2rlgk.js +71 -0
- package/dist/{Avatar-D5YGlXVF.js.map → Avatar-CJq2rlgk.js.map} +1 -1
- package/dist/Badge-DC6zxOwS.js +131 -0
- package/dist/{Badge-Bj3ajrWB.js.map → Badge-DC6zxOwS.js.map} +1 -1
- package/dist/Button-BCWJgHDy.js +193 -0
- package/dist/Button-BCWJgHDy.js.map +1 -0
- package/dist/{Calendar-gPWbQa_c.js → Calendar-CjOBwDbx.js} +181 -72
- package/dist/{Calendar-gPWbQa_c.js.map → Calendar-CjOBwDbx.js.map} +1 -1
- package/dist/{Callout-CTr3dhBe.js → Callout-ClNFeMbn.js} +36 -22
- package/dist/{Callout-CTr3dhBe.js.map → Callout-ClNFeMbn.js.map} +1 -1
- package/dist/Checkbox-C_Rd2-8Z.js +75 -0
- package/dist/{Checkbox-zCxgcZiC.js.map → Checkbox-C_Rd2-8Z.js.map} +1 -1
- package/dist/ColorPicker-D7Y1gZNn.js +437 -0
- package/dist/ColorPicker-D7Y1gZNn.js.map +1 -0
- package/dist/{DataTable-BpMBsz5i.js → DataTable-CEA8czNL.js} +1024 -641
- package/dist/DataTable-CEA8czNL.js.map +1 -0
- package/dist/{DatePicker-B7SYjsog.js → DatePicker-IrQUHqdL.js} +509 -267
- package/dist/{DatePicker-B7SYjsog.js.map → DatePicker-IrQUHqdL.js.map} +1 -1
- package/dist/Dialog-BOcBeB8v.js +147 -0
- package/dist/{Dialog-BURSzxaP.js.map → Dialog-BOcBeB8v.js.map} +1 -1
- package/dist/{DirectionProvider-DGYDg_He.js → DirectionProvider-weqLz_BJ.js} +2 -2
- package/dist/{DirectionProvider-DGYDg_He.js.map → DirectionProvider-weqLz_BJ.js.map} +1 -1
- package/dist/Empty-fV1Yplri.js +75 -0
- package/dist/{Empty-zyL2ZsHX.js.map → Empty-fV1Yplri.js.map} +1 -1
- package/dist/Input-xjYQfsaz.js +222 -0
- package/dist/{Input-C1gcv9o2.js.map → Input-xjYQfsaz.js.map} +1 -1
- package/dist/Kbd-CJOM9x4C.js +41 -0
- package/dist/{Kbd-EqbC0bua.js.map → Kbd-CJOM9x4C.js.map} +1 -1
- package/dist/Label-CrCRic4I.js +87 -0
- package/dist/{Label-DAFESZOG.js.map → Label-CrCRic4I.js.map} +1 -1
- package/dist/MultiEmailInput-L-QJg0hh.js +262 -0
- package/dist/MultiEmailInput-L-QJg0hh.js.map +1 -0
- package/dist/Pagination-C_X9kgc8.js +103 -0
- package/dist/{Pagination-DSc9yXPy.js.map → Pagination-C_X9kgc8.js.map} +1 -1
- package/dist/Popover-Cco_6txS.js +131 -0
- package/dist/{Popover-Dmq-xK_a.js.map → Popover-Cco_6txS.js.map} +1 -1
- package/dist/Progress-DURemsl_.js +18 -0
- package/dist/{Progress-B9NlUm6e.js.map → Progress-DURemsl_.js.map} +1 -1
- package/dist/RadioGroup-BTemSonO.js +106 -0
- package/dist/{RadioGroup-BNeYQAoT.js.map → RadioGroup-BTemSonO.js.map} +1 -1
- package/dist/Select-o0yJaN0P.js +1059 -0
- package/dist/Select-o0yJaN0P.js.map +1 -0
- package/dist/SelectFieldWrapper-CiBARDsn.js +74 -0
- package/dist/{SelectFieldWrapper-BJzq9aCY.js.map → SelectFieldWrapper-CiBARDsn.js.map} +1 -1
- package/dist/Sheet-DVoy6if3.js +158 -0
- package/dist/{Sheet-B99vGwLH.js.map → Sheet-DVoy6if3.js.map} +1 -1
- package/dist/Slider-DNcH5X7b.js +65 -0
- package/dist/{Slider-BCQXhs0Q.js.map → Slider-DNcH5X7b.js.map} +1 -1
- package/dist/Spinner-DgV3mILN.js +26 -0
- package/dist/{Spinner-C8HSac-2.js.map → Spinner-DgV3mILN.js.map} +1 -1
- package/dist/Stepper-7OpfOfas.js +109 -0
- package/dist/{Stepper-BoGkmkY0.js.map → Stepper-7OpfOfas.js.map} +1 -1
- package/dist/Switch-OAB7pfNn.js +82 -0
- package/dist/{Switch-B83TGxJ_.js.map → Switch-OAB7pfNn.js.map} +1 -1
- package/dist/Tabs-DTbbJITd.js +64 -0
- package/dist/{Tabs-DWfKnl3S.js.map → Tabs-DTbbJITd.js.map} +1 -1
- package/dist/Textarea-B2Uhx-Yy.js +181 -0
- package/dist/{Textarea-C0z50h0N.js.map → Textarea-B2Uhx-Yy.js.map} +1 -1
- package/dist/TimePicker-BzlF3JWj.js +278 -0
- package/dist/TimePicker-BzlF3JWj.js.map +1 -0
- package/dist/TimePickerPanel-CgEbjExH.js +425 -0
- package/dist/TimePickerPanel-CgEbjExH.js.map +1 -0
- package/dist/Toastr-BimwuEnS.js +95 -0
- package/dist/{Toastr-DYqpSaMd.js.map → Toastr-BimwuEnS.js.map} +1 -1
- package/dist/Tooltip-CA3irJ2q.js +88 -0
- package/dist/{Tooltip-3ZzQyaDV.js.map → Tooltip-CA3irJ2q.js.map} +1 -1
- package/dist/{TranslationProvider-Ba9rn47H.js → TranslationProvider-BvRvUsPS.js} +20 -17
- package/dist/{TranslationProvider-Ba9rn47H.js.map → TranslationProvider-BvRvUsPS.js.map} +1 -1
- package/dist/{Tree-C7r10UY5.js → Tree-BlzjThRi.js} +515 -322
- package/dist/Tree-BlzjThRi.js.map +1 -0
- package/dist/TreeSelect-Dk299XMv.js +335 -0
- package/dist/TreeSelect-Dk299XMv.js.map +1 -0
- package/dist/Typography-CiQzW5Fy.js +97 -0
- package/dist/{Typography-ClPJbLjP.js.map → Typography-CiQzW5Fy.js.map} +1 -1
- package/dist/button-CrEMzWKw.js +67 -0
- package/dist/{button-D6uWDFCs.js.map → button-CrEMzWKw.js.map} +1 -1
- package/dist/cjs/Accordion-D75SDnkY.js +51 -0
- package/dist/cjs/Accordion-D75SDnkY.js.map +1 -0
- package/dist/cjs/Alert-_TPuVqa5.js +152 -0
- package/dist/cjs/Alert-_TPuVqa5.js.map +1 -0
- package/dist/cjs/Avatar-nG7vhAUS.js +73 -0
- package/dist/cjs/Avatar-nG7vhAUS.js.map +1 -0
- package/dist/cjs/Badge-Dz_Kb49L.js +133 -0
- package/dist/cjs/Badge-Dz_Kb49L.js.map +1 -0
- package/dist/cjs/Button-BlNtYr1w.js +195 -0
- package/dist/cjs/Button-BlNtYr1w.js.map +1 -0
- package/dist/cjs/{Calendar-jVF8fRaS.js → Calendar-02KiUZTT.js} +181 -72
- package/dist/cjs/Calendar-02KiUZTT.js.map +1 -0
- package/dist/cjs/{Callout-CVNpjTde.js → Callout-_XBx1JHL.js} +36 -22
- package/dist/cjs/Callout-_XBx1JHL.js.map +1 -0
- package/dist/cjs/Checkbox-CxqWOvFN.js +77 -0
- package/dist/cjs/Checkbox-CxqWOvFN.js.map +1 -0
- package/dist/cjs/ColorPicker-Co1Gffsu.js +439 -0
- package/dist/cjs/ColorPicker-Co1Gffsu.js.map +1 -0
- package/dist/cjs/{DataTable-BynOh4Bs.js → DataTable-DRGW8JVP.js} +1024 -641
- package/dist/cjs/DataTable-DRGW8JVP.js.map +1 -0
- package/dist/cjs/{DatePicker-C0BwxIh8.js → DatePicker-DdTclP8E.js} +508 -266
- package/dist/cjs/DatePicker-DdTclP8E.js.map +1 -0
- package/dist/cjs/Dialog-CBSuKeu_.js +149 -0
- package/dist/cjs/Dialog-CBSuKeu_.js.map +1 -0
- package/dist/cjs/{DirectionProvider-Bec-6U8p.js → DirectionProvider-BTtE4FcN.js} +2 -2
- package/dist/cjs/DirectionProvider-BTtE4FcN.js.map +1 -0
- package/dist/cjs/Empty-DqmmPlPJ.js +77 -0
- package/dist/cjs/Empty-DqmmPlPJ.js.map +1 -0
- package/dist/cjs/Input-CpuJXazH.js +224 -0
- package/dist/cjs/Input-CpuJXazH.js.map +1 -0
- package/dist/cjs/Kbd-D2nELu5m.js +43 -0
- package/dist/cjs/Kbd-D2nELu5m.js.map +1 -0
- package/dist/cjs/Label-DFkiC2Jk.js +89 -0
- package/dist/cjs/Label-DFkiC2Jk.js.map +1 -0
- package/dist/cjs/MultiEmailInput-CPXODFvs.js +264 -0
- package/dist/cjs/MultiEmailInput-CPXODFvs.js.map +1 -0
- package/dist/cjs/Pagination-DeWfLAq5.js +105 -0
- package/dist/cjs/Pagination-DeWfLAq5.js.map +1 -0
- package/dist/cjs/Popover-Br9hkU5i.js +137 -0
- package/dist/cjs/Popover-Br9hkU5i.js.map +1 -0
- package/dist/cjs/Progress-yBpMAzIU.js +20 -0
- package/dist/cjs/Progress-yBpMAzIU.js.map +1 -0
- package/dist/cjs/RadioGroup-CkKlLHnR.js +108 -0
- package/dist/cjs/RadioGroup-CkKlLHnR.js.map +1 -0
- package/dist/cjs/Select-DbfPhEu0.js +1065 -0
- package/dist/cjs/Select-DbfPhEu0.js.map +1 -0
- package/dist/cjs/SelectFieldWrapper-DKkizQNM.js +76 -0
- package/dist/cjs/SelectFieldWrapper-DKkizQNM.js.map +1 -0
- package/dist/cjs/Sheet-mJ7pJHrn.js +160 -0
- package/dist/cjs/Sheet-mJ7pJHrn.js.map +1 -0
- package/dist/cjs/Slider-ICf2eQ6p.js +67 -0
- package/dist/cjs/Slider-ICf2eQ6p.js.map +1 -0
- package/dist/cjs/Spinner-DzNBz8al.js +28 -0
- package/dist/cjs/Spinner-DzNBz8al.js.map +1 -0
- package/dist/cjs/Stepper-DZb25oBH.js +115 -0
- package/dist/cjs/Stepper-DZb25oBH.js.map +1 -0
- package/dist/cjs/Switch-BTkncHw2.js +84 -0
- package/dist/cjs/Switch-BTkncHw2.js.map +1 -0
- package/dist/cjs/Tabs-YPRmLtUM.js +66 -0
- package/dist/cjs/Tabs-YPRmLtUM.js.map +1 -0
- package/dist/cjs/Textarea-yWv-66yX.js +183 -0
- package/dist/cjs/Textarea-yWv-66yX.js.map +1 -0
- package/dist/cjs/TimePicker-Cwwa1DD8.js +280 -0
- package/dist/cjs/TimePicker-Cwwa1DD8.js.map +1 -0
- package/dist/cjs/TimePickerPanel-CAdLD7qW.js +434 -0
- package/dist/cjs/TimePickerPanel-CAdLD7qW.js.map +1 -0
- package/dist/cjs/Toastr-DYWd66L7.js +97 -0
- package/dist/cjs/Toastr-DYWd66L7.js.map +1 -0
- package/dist/cjs/Tooltip-Dph_R3Ct.js +94 -0
- package/dist/cjs/Tooltip-Dph_R3Ct.js.map +1 -0
- package/dist/cjs/{TranslationProvider-DBZHXmzX.js → TranslationProvider-Dh5_Fzzk.js} +20 -17
- package/dist/cjs/TranslationProvider-Dh5_Fzzk.js.map +1 -0
- package/dist/cjs/{Tree-BPd0DuLh.js → Tree-DAyVPLnJ.js} +515 -322
- package/dist/cjs/Tree-DAyVPLnJ.js.map +1 -0
- package/dist/cjs/TreeSelect-Cmm5yYq3.js +337 -0
- package/dist/cjs/TreeSelect-Cmm5yYq3.js.map +1 -0
- package/dist/cjs/Typography-UyaYuppP.js +100 -0
- package/dist/cjs/Typography-UyaYuppP.js.map +1 -0
- package/dist/cjs/button-CMl9rLXi.js +90 -0
- package/dist/cjs/button-CMl9rLXi.js.map +1 -0
- package/dist/cjs/components/Accordion.js +2 -2
- package/dist/cjs/components/Alert.js +10 -10
- package/dist/cjs/components/Avatar.js +3 -3
- package/dist/cjs/components/Badge.js +4 -4
- package/dist/cjs/components/Button.js +6 -6
- package/dist/cjs/components/Callout.js +4 -4
- package/dist/cjs/components/Checkbox.js +5 -5
- package/dist/cjs/components/ColorPicker.js +5 -5
- package/dist/cjs/components/DataTable.js +15 -15
- package/dist/cjs/components/DatePicker.js +9 -9
- package/dist/cjs/components/Dialog.js +7 -7
- package/dist/cjs/components/DirectionProvider.js +1 -1
- package/dist/cjs/components/DropdownMenu.js +320 -92
- package/dist/cjs/components/DropdownMenu.js.map +1 -1
- package/dist/cjs/components/Empty.js +16 -16
- package/dist/cjs/components/Input.js +9 -9
- package/dist/cjs/components/Kbd.js +3 -3
- package/dist/cjs/components/Label.js +12 -12
- package/dist/cjs/components/MultiEmailInput.js +5 -5
- package/dist/cjs/components/Pagination.js +4 -4
- package/dist/cjs/components/Popover.js +6 -6
- package/dist/cjs/components/Progress.js +2 -2
- package/dist/cjs/components/RadioGroup.js +5 -5
- package/dist/cjs/components/Select.js +10 -10
- package/dist/cjs/components/Sheet.js +7 -7
- package/dist/cjs/components/Slider.js +5 -5
- package/dist/cjs/components/Spinner.js +2 -2
- package/dist/cjs/components/Stepper.js +2 -2
- package/dist/cjs/components/Switch.js +3 -3
- package/dist/cjs/components/Tabs.js +4 -4
- package/dist/cjs/components/Textarea.js +6 -6
- package/dist/cjs/components/TimePicker.js +8 -8
- package/dist/cjs/components/Toastr.js +1 -1
- package/dist/cjs/components/Tooltip.js +3 -3
- package/dist/cjs/components/TranslationProvider.js +1 -1
- package/dist/cjs/components/Tree.js +3 -3
- package/dist/cjs/components/TreeSelect.js +8 -8
- package/dist/cjs/components/Typography.js +3 -3
- package/dist/cjs/components/index.js +80 -80
- package/dist/cjs/dialog-Cs1qH5xA.js +161 -0
- package/dist/cjs/dialog-Cs1qH5xA.js.map +1 -0
- package/dist/cjs/formik/ActionBlock.js +56 -12
- package/dist/cjs/formik/ActionBlock.js.map +1 -1
- package/dist/cjs/formik/BlockNavigation.js +150 -79
- package/dist/cjs/formik/BlockNavigation.js.map +1 -1
- package/dist/cjs/formik/Button.js +20 -9
- package/dist/cjs/formik/Button.js.map +1 -1
- package/dist/cjs/formik/Checkbox.js +33 -15
- package/dist/cjs/formik/Checkbox.js.map +1 -1
- package/dist/cjs/formik/Form.js +105 -74
- package/dist/cjs/formik/Form.js.map +1 -1
- package/dist/cjs/formik/Input.js +32 -22
- package/dist/cjs/formik/Input.js.map +1 -1
- package/dist/cjs/formik/MultiEmailInput.js +23 -13
- package/dist/cjs/formik/MultiEmailInput.js.map +1 -1
- package/dist/cjs/formik/RadioGroup.js +33 -15
- package/dist/cjs/formik/RadioGroup.js.map +1 -1
- package/dist/cjs/formik/Select.js +29 -28
- package/dist/cjs/formik/Select.js.map +1 -1
- package/dist/cjs/formik/Slider.js +31 -13
- package/dist/cjs/formik/Slider.js.map +1 -1
- package/dist/cjs/formik/Switch.js +28 -13
- package/dist/cjs/formik/Switch.js.map +1 -1
- package/dist/cjs/formik/Textarea.js +29 -19
- package/dist/cjs/formik/Textarea.js.map +1 -1
- package/dist/cjs/formik/TreeSelect.js +26 -15
- package/dist/cjs/formik/TreeSelect.js.map +1 -1
- package/dist/cjs/formik/index.js +26 -26
- package/dist/cjs/{index-BLGrl3PF.js → index-BTsnrFFc.js} +2 -2
- package/dist/cjs/{index-BLGrl3PF.js.map → index-BTsnrFFc.js.map} +1 -1
- package/dist/cjs/{index-ChSOMM8b.js → index-CS_WSHYi.js} +54 -54
- package/dist/cjs/index-CS_WSHYi.js.map +1 -0
- package/dist/cjs/{index-D1SiRLYs.js → index-DbA93GP3.js} +2 -2
- package/dist/cjs/{index-D1SiRLYs.js.map → index-DbA93GP3.js.map} +1 -1
- package/dist/cjs/{index-BZhTddX0.js → index-vioSzJOw.js} +2 -2
- package/dist/cjs/{index-BZhTddX0.js.map → index-vioSzJOw.js.map} +1 -1
- package/dist/cjs/index.js +306 -300
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/input-BlyvDsZ5.js +22 -0
- package/dist/cjs/input-BlyvDsZ5.js.map +1 -0
- package/dist/cjs/input-group-8TZFHzVl.js +147 -0
- package/dist/cjs/input-group-8TZFHzVl.js.map +1 -0
- package/dist/cjs/{label-Bdc9ytTI.js → label-DJ7KkKYy.js} +17 -4
- package/dist/cjs/label-DJ7KkKYy.js.map +1 -0
- package/dist/cjs/primitives/Accordion.js +76 -13
- package/dist/cjs/primitives/Accordion.js.map +1 -1
- package/dist/cjs/primitives/Alert.js +65 -20
- package/dist/cjs/primitives/Alert.js.map +1 -1
- package/dist/cjs/primitives/AlertDialog.js +176 -41
- package/dist/cjs/primitives/AlertDialog.js.map +1 -1
- package/dist/cjs/primitives/AspectRatio.js +5 -3
- package/dist/cjs/primitives/AspectRatio.js.map +1 -1
- package/dist/cjs/primitives/Avatar.js +94 -17
- package/dist/cjs/primitives/Avatar.js.map +1 -1
- package/dist/cjs/primitives/Badge.js +99 -69
- package/dist/cjs/primitives/Badge.js.map +1 -1
- package/dist/cjs/primitives/Breadcrumb.js +103 -21
- package/dist/cjs/primitives/Breadcrumb.js.map +1 -1
- package/dist/cjs/primitives/Button.js +4 -4
- package/dist/cjs/primitives/Button.js.map +1 -1
- package/dist/cjs/primitives/ButtonGroup.js +65 -21
- package/dist/cjs/primitives/ButtonGroup.js.map +1 -1
- package/dist/cjs/primitives/Calendar.js +4 -4
- package/dist/cjs/primitives/Card.js +88 -16
- package/dist/cjs/primitives/Card.js.map +1 -1
- package/dist/cjs/primitives/Carousel.js +187 -85
- package/dist/cjs/primitives/Carousel.js.map +1 -1
- package/dist/cjs/primitives/Chart.js +427 -189
- package/dist/cjs/primitives/Chart.js.map +1 -1
- package/dist/cjs/primitives/Checkbox.js +28 -4
- package/dist/cjs/primitives/Checkbox.js.map +1 -1
- package/dist/cjs/primitives/Collapsible.js +27 -9
- package/dist/cjs/primitives/Collapsible.js.map +1 -1
- package/dist/cjs/primitives/Combobox.js +279 -51
- package/dist/cjs/primitives/Combobox.js.map +1 -1
- package/dist/cjs/primitives/Command.js +168 -39
- package/dist/cjs/primitives/Command.js.map +1 -1
- package/dist/cjs/primitives/ContextMenu.js +217 -48
- package/dist/cjs/primitives/ContextMenu.js.map +1 -1
- package/dist/cjs/primitives/Dialog.js +62 -20
- package/dist/cjs/primitives/Dialog.js.map +1 -1
- package/dist/cjs/primitives/Drawer.js +116 -31
- package/dist/cjs/primitives/Drawer.js.map +1 -1
- package/dist/cjs/primitives/DropdownMenu.js +233 -48
- package/dist/cjs/primitives/DropdownMenu.js.map +1 -1
- package/dist/cjs/primitives/Empty.js +85 -23
- package/dist/cjs/primitives/Empty.js.map +1 -1
- package/dist/cjs/primitives/Field.js +194 -55
- package/dist/cjs/primitives/Field.js.map +1 -1
- package/dist/cjs/primitives/HoverCard.js +31 -10
- package/dist/cjs/primitives/HoverCard.js.map +1 -1
- package/dist/cjs/primitives/Input.js +3 -3
- package/dist/cjs/primitives/Input.js.map +1 -1
- package/dist/cjs/primitives/InputGroup.js +12 -12
- package/dist/cjs/primitives/InputGroup.js.map +1 -1
- package/dist/cjs/primitives/InputOTP.js +70 -13
- package/dist/cjs/primitives/InputOTP.js.map +1 -1
- package/dist/cjs/primitives/Item.js +163 -51
- package/dist/cjs/primitives/Item.js.map +1 -1
- package/dist/cjs/primitives/Kbd.js +22 -5
- package/dist/cjs/primitives/Kbd.js.map +1 -1
- package/dist/cjs/primitives/Label.js +3 -3
- package/dist/cjs/primitives/Label.js.map +1 -1
- package/dist/cjs/primitives/Menubar.js +236 -51
- package/dist/cjs/primitives/Menubar.js.map +1 -1
- package/dist/cjs/primitives/NativeSelect.js +45 -9
- package/dist/cjs/primitives/NativeSelect.js.map +1 -1
- package/dist/cjs/primitives/NavigationMenu.js +149 -27
- package/dist/cjs/primitives/NavigationMenu.js.map +1 -1
- package/dist/cjs/primitives/Pagination.js +121 -27
- package/dist/cjs/primitives/Pagination.js.map +1 -1
- package/dist/cjs/primitives/Popover.js +68 -21
- package/dist/cjs/primitives/Popover.js.map +1 -1
- package/dist/cjs/primitives/Progress.js +26 -4
- package/dist/cjs/primitives/Progress.js.map +1 -1
- package/dist/cjs/primitives/RadioGroup.js +36 -9
- package/dist/cjs/primitives/RadioGroup.js.map +1 -1
- package/dist/cjs/primitives/Resizable.js +37 -9
- package/dist/cjs/primitives/Resizable.js.map +1 -1
- package/dist/cjs/primitives/ScrollArea.js +53 -7
- package/dist/cjs/primitives/ScrollArea.js.map +1 -1
- package/dist/cjs/primitives/Select.js +169 -32
- package/dist/cjs/primitives/Select.js.map +1 -1
- package/dist/cjs/primitives/Separator.js +3 -3
- package/dist/cjs/primitives/Separator.js.map +1 -1
- package/dist/cjs/primitives/Sheet.js +79 -18
- package/dist/cjs/primitives/Sheet.js.map +1 -1
- package/dist/cjs/primitives/Sidebar.js +575 -181
- package/dist/cjs/primitives/Sidebar.js.map +1 -1
- package/dist/cjs/primitives/Skeleton.js +3 -3
- package/dist/cjs/primitives/Skeleton.js.map +1 -1
- package/dist/cjs/primitives/Slider.js +53 -9
- package/dist/cjs/primitives/Slider.js.map +1 -1
- package/dist/cjs/primitives/Sonner.js +42 -26
- package/dist/cjs/primitives/Sonner.js.map +1 -1
- package/dist/cjs/primitives/Spinner.js +4 -4
- package/dist/cjs/primitives/Spinner.js.map +1 -1
- package/dist/cjs/primitives/Switch.js +32 -2
- package/dist/cjs/primitives/Switch.js.map +1 -1
- package/dist/cjs/primitives/Table.js +109 -17
- package/dist/cjs/primitives/Table.js.map +1 -1
- package/dist/cjs/primitives/Tabs.js +78 -22
- package/dist/cjs/primitives/Tabs.js.map +1 -1
- package/dist/cjs/primitives/Textarea.js +3 -3
- package/dist/cjs/primitives/Textarea.js.map +1 -1
- package/dist/cjs/primitives/Toggle.js +4 -4
- package/dist/cjs/primitives/Toggle.js.map +1 -1
- package/dist/cjs/primitives/ToggleGroup.js +68 -17
- package/dist/cjs/primitives/ToggleGroup.js.map +1 -1
- package/dist/cjs/primitives/Tooltip.js +6 -6
- package/dist/cjs/primitives/Tooltip.js.map +1 -1
- package/dist/cjs/primitives/index.js +18 -18
- package/dist/cjs/renderIcon-BRrpZu9a.js +32 -0
- package/dist/cjs/renderIcon-BRrpZu9a.js.map +1 -0
- package/dist/cjs/search-DVHH0ihN.js +33 -0
- package/dist/cjs/search-DVHH0ihN.js.map +1 -0
- package/dist/cjs/{separator-CPy2gyg1.js → separator-DSL-aG1J.js} +21 -4
- package/dist/cjs/separator-DSL-aG1J.js.map +1 -0
- package/dist/cjs/sheet-G6ismmAK.js +147 -0
- package/dist/cjs/sheet-G6ismmAK.js.map +1 -0
- package/dist/cjs/skeleton-CL0H_mC4.js +18 -0
- package/dist/cjs/skeleton-CL0H_mC4.js.map +1 -0
- package/dist/cjs/textarea-Br-J3v7z.js +21 -0
- package/dist/cjs/textarea-Br-J3v7z.js.map +1 -0
- package/dist/cjs/{toggle-CaqzT8dI.js → toggle-Cq38rmIj.js} +34 -19
- package/dist/cjs/toggle-Cq38rmIj.js.map +1 -0
- package/dist/cjs/{tooltip-C-568jEL.js → tooltip-BYCcUMZn.js} +44 -10
- package/dist/cjs/tooltip-BYCcUMZn.js.map +1 -0
- package/dist/cjs/use-mobile-Be9CI6km.js +41 -0
- package/dist/cjs/use-mobile-Be9CI6km.js.map +1 -0
- package/dist/cjs/{utils-CTr7wn5d.js → utils-BhM0B89p.js} +2 -2
- package/dist/cjs/utils-BhM0B89p.js.map +1 -0
- package/dist/components/Accordion.js +2 -2
- package/dist/components/Alert.js +10 -10
- package/dist/components/Avatar.js +3 -3
- package/dist/components/Badge.js +4 -4
- package/dist/components/Button/Button.d.ts +1 -1
- package/dist/components/Button.js +6 -6
- package/dist/components/Callout.js +4 -4
- package/dist/components/Checkbox.js +5 -5
- package/dist/components/ColorPicker.js +5 -5
- package/dist/components/DataTable.js +15 -15
- package/dist/components/DatePicker/utils.d.ts +4 -0
- package/dist/components/DatePicker.js +9 -9
- package/dist/components/Dialog.js +7 -7
- package/dist/components/DirectionProvider.js +1 -1
- package/dist/components/DropdownMenu.js +320 -92
- package/dist/components/DropdownMenu.js.map +1 -1
- package/dist/components/Empty.js +16 -16
- package/dist/components/Input.js +9 -9
- package/dist/components/Kbd.js +3 -3
- package/dist/components/Label.js +12 -12
- package/dist/components/MultiEmailInput.js +5 -5
- package/dist/components/Pagination.js +4 -4
- package/dist/components/Popover.js +6 -6
- package/dist/components/Progress.js +2 -2
- package/dist/components/RadioGroup.js +5 -5
- package/dist/components/Select.js +10 -10
- package/dist/components/Sheet.js +7 -7
- package/dist/components/Slider.js +5 -5
- package/dist/components/Spinner.js +2 -2
- package/dist/components/Stepper.js +2 -2
- package/dist/components/Switch.js +3 -3
- package/dist/components/Tabs.js +4 -4
- package/dist/components/Textarea.js +6 -6
- package/dist/components/TimePicker/utils.d.ts +1 -0
- package/dist/components/TimePicker.js +8 -8
- package/dist/components/Toastr.js +1 -1
- package/dist/components/Tooltip.js +3 -3
- package/dist/components/TranslationProvider.js +1 -1
- package/dist/components/Tree.js +3 -3
- package/dist/components/TreeSelect/hooks/useTreeSelectState.d.ts +1 -1
- package/dist/components/TreeSelect/hooks/useTreeSelectValue.d.ts +1 -2
- package/dist/components/TreeSelect/utils/resolveFieldNames.d.ts +4 -2
- package/dist/components/TreeSelect.js +8 -8
- package/dist/components/Typography.js +3 -3
- package/dist/components/index.js +76 -76
- package/dist/dialog--Qm4MZDo.js +150 -0
- package/dist/{dialog-DK71SlsS.js.map → dialog--Qm4MZDo.js.map} +1 -1
- package/dist/formik/ActionBlock.js +56 -12
- package/dist/formik/ActionBlock.js.map +1 -1
- package/dist/formik/BlockNavigation.js +150 -79
- package/dist/formik/BlockNavigation.js.map +1 -1
- package/dist/formik/Button.js +20 -9
- package/dist/formik/Button.js.map +1 -1
- package/dist/formik/Checkbox.js +33 -15
- package/dist/formik/Checkbox.js.map +1 -1
- package/dist/formik/Form.js +105 -74
- package/dist/formik/Form.js.map +1 -1
- package/dist/formik/Input.js +32 -22
- package/dist/formik/Input.js.map +1 -1
- package/dist/formik/MultiEmailInput.js +23 -13
- package/dist/formik/MultiEmailInput.js.map +1 -1
- package/dist/formik/RadioGroup.d.ts +1 -1
- package/dist/formik/RadioGroup.js +33 -15
- package/dist/formik/RadioGroup.js.map +1 -1
- package/dist/formik/Select.js +29 -28
- package/dist/formik/Select.js.map +1 -1
- package/dist/formik/Slider.d.ts +1 -1
- package/dist/formik/Slider.js +31 -13
- package/dist/formik/Slider.js.map +1 -1
- package/dist/formik/Switch.js +28 -13
- package/dist/formik/Switch.js.map +1 -1
- package/dist/formik/Textarea.js +29 -19
- package/dist/formik/Textarea.js.map +1 -1
- package/dist/formik/TreeSelect.js +26 -15
- package/dist/formik/TreeSelect.js.map +1 -1
- package/dist/formik/index.js +26 -26
- package/dist/{index-9HvIbmnI.js → index-B7SdntLB.js} +2 -2
- package/dist/{index-9HvIbmnI.js.map → index-B7SdntLB.js.map} +1 -1
- package/dist/{index-D7Zy7P05.js → index-Bo3AAQJp.js} +2 -2
- package/dist/{index-D7Zy7P05.js.map → index-Bo3AAQJp.js.map} +1 -1
- package/dist/{index-OI_tWuLx.js → index-DnD7-4_R.js} +2 -2
- package/dist/{index-OI_tWuLx.js.map → index-DnD7-4_R.js.map} +1 -1
- package/dist/{index-B4_fVWDx.js → index-Jr4soqx3.js} +54 -54
- package/dist/index-Jr4soqx3.js.map +1 -0
- package/dist/index.js +286 -280
- package/dist/index.js.map +1 -1
- package/dist/input-1J5oQa1u.js +20 -0
- package/dist/{input-GLCCE2kT.js.map → input-1J5oQa1u.js.map} +1 -1
- package/dist/input-group-BKkj65Uq.js +140 -0
- package/dist/{input-group-C_qKMibX.js.map → input-group-BKkj65Uq.js.map} +1 -1
- package/dist/{label-B4qDF3W1.js → label-BgLSVt4u.js} +17 -4
- package/dist/{label-B4qDF3W1.js.map → label-BgLSVt4u.js.map} +1 -1
- package/dist/primitives/Accordion.js +76 -13
- package/dist/primitives/Accordion.js.map +1 -1
- package/dist/primitives/Alert.js +65 -20
- package/dist/primitives/Alert.js.map +1 -1
- package/dist/primitives/AlertDialog.js +176 -41
- package/dist/primitives/AlertDialog.js.map +1 -1
- package/dist/primitives/AspectRatio.js +5 -3
- package/dist/primitives/AspectRatio.js.map +1 -1
- package/dist/primitives/Avatar.js +94 -17
- package/dist/primitives/Avatar.js.map +1 -1
- package/dist/primitives/Badge.js +99 -69
- package/dist/primitives/Badge.js.map +1 -1
- package/dist/primitives/Breadcrumb.js +103 -21
- package/dist/primitives/Breadcrumb.js.map +1 -1
- package/dist/primitives/Button.js +5 -5
- package/dist/primitives/Button.js.map +1 -1
- package/dist/primitives/ButtonGroup.js +65 -21
- package/dist/primitives/ButtonGroup.js.map +1 -1
- package/dist/primitives/Calendar.js +4 -4
- package/dist/primitives/Card.js +88 -16
- package/dist/primitives/Card.js.map +1 -1
- package/dist/primitives/Carousel.js +187 -85
- package/dist/primitives/Carousel.js.map +1 -1
- package/dist/primitives/Chart.js +427 -189
- package/dist/primitives/Chart.js.map +1 -1
- package/dist/primitives/Checkbox.js +28 -4
- package/dist/primitives/Checkbox.js.map +1 -1
- package/dist/primitives/Collapsible.js +27 -9
- package/dist/primitives/Collapsible.js.map +1 -1
- package/dist/primitives/Combobox.js +279 -51
- package/dist/primitives/Combobox.js.map +1 -1
- package/dist/primitives/Command.js +168 -39
- package/dist/primitives/Command.js.map +1 -1
- package/dist/primitives/ContextMenu.js +217 -48
- package/dist/primitives/ContextMenu.js.map +1 -1
- package/dist/primitives/Dialog.js +62 -20
- package/dist/primitives/Dialog.js.map +1 -1
- package/dist/primitives/Drawer.js +116 -31
- package/dist/primitives/Drawer.js.map +1 -1
- package/dist/primitives/DropdownMenu.js +233 -48
- package/dist/primitives/DropdownMenu.js.map +1 -1
- package/dist/primitives/Empty.js +85 -23
- package/dist/primitives/Empty.js.map +1 -1
- package/dist/primitives/Field.js +194 -55
- package/dist/primitives/Field.js.map +1 -1
- package/dist/primitives/HoverCard.js +31 -10
- package/dist/primitives/HoverCard.js.map +1 -1
- package/dist/primitives/Input.js +3 -3
- package/dist/primitives/Input.js.map +1 -1
- package/dist/primitives/InputGroup.js +12 -12
- package/dist/primitives/InputGroup.js.map +1 -1
- package/dist/primitives/InputOTP.js +70 -13
- package/dist/primitives/InputOTP.js.map +1 -1
- package/dist/primitives/Item.js +163 -51
- package/dist/primitives/Item.js.map +1 -1
- package/dist/primitives/Kbd.js +22 -5
- package/dist/primitives/Kbd.js.map +1 -1
- package/dist/primitives/Label.js +3 -3
- package/dist/primitives/Label.js.map +1 -1
- package/dist/primitives/Menubar.js +236 -51
- package/dist/primitives/Menubar.js.map +1 -1
- package/dist/primitives/NativeSelect.js +45 -9
- package/dist/primitives/NativeSelect.js.map +1 -1
- package/dist/primitives/NavigationMenu.js +149 -27
- package/dist/primitives/NavigationMenu.js.map +1 -1
- package/dist/primitives/Pagination.js +121 -27
- package/dist/primitives/Pagination.js.map +1 -1
- package/dist/primitives/Popover.js +68 -21
- package/dist/primitives/Popover.js.map +1 -1
- package/dist/primitives/Progress.js +26 -4
- package/dist/primitives/Progress.js.map +1 -1
- package/dist/primitives/RadioGroup.js +36 -9
- package/dist/primitives/RadioGroup.js.map +1 -1
- package/dist/primitives/Resizable.js +38 -10
- package/dist/primitives/Resizable.js.map +1 -1
- package/dist/primitives/ScrollArea.js +53 -7
- package/dist/primitives/ScrollArea.js.map +1 -1
- package/dist/primitives/Select.js +169 -32
- package/dist/primitives/Select.js.map +1 -1
- package/dist/primitives/Separator.js +3 -3
- package/dist/primitives/Separator.js.map +1 -1
- package/dist/primitives/Sheet.js +79 -18
- package/dist/primitives/Sheet.js.map +1 -1
- package/dist/primitives/Sidebar.js +575 -181
- package/dist/primitives/Sidebar.js.map +1 -1
- package/dist/primitives/Skeleton.js +3 -3
- package/dist/primitives/Skeleton.js.map +1 -1
- package/dist/primitives/Slider.js +53 -9
- package/dist/primitives/Slider.js.map +1 -1
- package/dist/primitives/Sonner.js +42 -26
- package/dist/primitives/Sonner.js.map +1 -1
- package/dist/primitives/Spinner.js +4 -4
- package/dist/primitives/Spinner.js.map +1 -1
- package/dist/primitives/Switch.js +32 -2
- package/dist/primitives/Switch.js.map +1 -1
- package/dist/primitives/Table.js +109 -17
- package/dist/primitives/Table.js.map +1 -1
- package/dist/primitives/Tabs.js +78 -22
- package/dist/primitives/Tabs.js.map +1 -1
- package/dist/primitives/Textarea.js +3 -3
- package/dist/primitives/Textarea.js.map +1 -1
- package/dist/primitives/Toggle.js +5 -5
- package/dist/primitives/Toggle.js.map +1 -1
- package/dist/primitives/ToggleGroup.js +68 -17
- package/dist/primitives/ToggleGroup.js.map +1 -1
- package/dist/primitives/Tooltip.js +6 -6
- package/dist/primitives/Tooltip.js.map +1 -1
- package/dist/primitives/index.js +18 -18
- package/dist/renderIcon-C6twJSqH.js +26 -0
- package/dist/{renderIcon-tlvMyboj.js.map → renderIcon-C6twJSqH.js.map} +1 -1
- package/dist/search-B5K8FsJs.js +29 -0
- package/dist/search-B5K8FsJs.js.map +1 -0
- package/dist/{separator-BbhgePmX.js → separator-ByRsc-y-.js} +21 -4
- package/dist/{separator-BbhgePmX.js.map → separator-ByRsc-y-.js.map} +1 -1
- package/dist/sheet-BIqq9HBB.js +138 -0
- package/dist/{sheet-DVTG6X82.js.map → sheet-BIqq9HBB.js.map} +1 -1
- package/dist/skeleton-D9P1ZyiS.js +16 -0
- package/dist/skeleton-D9P1ZyiS.js.map +1 -0
- package/dist/textarea-B0vzA497.js +19 -0
- package/dist/{textarea-BSZwxzjQ.js.map → textarea-B0vzA497.js.map} +1 -1
- package/dist/toggle-bESUdU4A.js +75 -0
- package/dist/{toggle-2k9K8a5c.js.map → toggle-bESUdU4A.js.map} +1 -1
- package/dist/{tooltip-XkHLgxlU.js → tooltip-ChQ9xD1j.js} +44 -10
- package/dist/{tooltip-XkHLgxlU.js.map → tooltip-ChQ9xD1j.js.map} +1 -1
- package/dist/use-mobile-QbHL72cX.js +19 -0
- package/dist/use-mobile-QbHL72cX.js.map +1 -0
- package/dist/utils/inputMask.d.ts +38 -0
- package/dist/{utils-DdHUxIdC.js → utils-BJnb9o5c.js} +2 -2
- package/dist/{utils-DdHUxIdC.js.map → utils-BJnb9o5c.js.map} +1 -1
- package/package.json +4 -2
- package/dist/Accordion-Ch9S_qd3.js +0 -22
- package/dist/Alert-CayTuRLW.js +0 -65
- package/dist/Avatar-D5YGlXVF.js +0 -50
- package/dist/Badge-Bj3ajrWB.js +0 -59
- package/dist/Button-DSvnInaL.js +0 -93
- package/dist/Button-DSvnInaL.js.map +0 -1
- package/dist/Checkbox-zCxgcZiC.js +0 -24
- package/dist/ColorPicker-DtOvy0Gy.js +0 -278
- package/dist/ColorPicker-DtOvy0Gy.js.map +0 -1
- package/dist/DataTable-BpMBsz5i.js.map +0 -1
- package/dist/Dialog-BURSzxaP.js +0 -61
- package/dist/Empty-zyL2ZsHX.js +0 -27
- package/dist/Input-C1gcv9o2.js +0 -147
- package/dist/Kbd-EqbC0bua.js +0 -36
- package/dist/Label-DAFESZOG.js +0 -58
- package/dist/MultiEmailInput-SCTYovtX.js +0 -139
- package/dist/MultiEmailInput-SCTYovtX.js.map +0 -1
- package/dist/Pagination-DSc9yXPy.js +0 -61
- package/dist/Popover-Dmq-xK_a.js +0 -84
- package/dist/Progress-B9NlUm6e.js +0 -13
- package/dist/RadioGroup-BNeYQAoT.js +0 -34
- package/dist/Select-BgSz0fve.js +0 -563
- package/dist/Select-BgSz0fve.js.map +0 -1
- package/dist/SelectFieldWrapper-BJzq9aCY.js +0 -23
- package/dist/Sheet-B99vGwLH.js +0 -63
- package/dist/Slider-BCQXhs0Q.js +0 -25
- package/dist/Spinner-C8HSac-2.js +0 -17
- package/dist/Stepper-BoGkmkY0.js +0 -29
- package/dist/Switch-B83TGxJ_.js +0 -20
- package/dist/Tabs-DWfKnl3S.js +0 -38
- package/dist/Textarea-C0z50h0N.js +0 -73
- package/dist/TimePicker-2vhf5yYK.js +0 -146
- package/dist/TimePicker-2vhf5yYK.js.map +0 -1
- package/dist/TimePickerPanel-CiF0RExY.js +0 -126
- package/dist/TimePickerPanel-CiF0RExY.js.map +0 -1
- package/dist/Toastr-DYqpSaMd.js +0 -115
- package/dist/Tooltip-3ZzQyaDV.js +0 -59
- package/dist/Tree-C7r10UY5.js.map +0 -1
- package/dist/TreeSelect-BxsQrdjf.js +0 -168
- package/dist/TreeSelect-BxsQrdjf.js.map +0 -1
- package/dist/Typography-ClPJbLjP.js +0 -76
- package/dist/button-D6uWDFCs.js +0 -48
- package/dist/cjs/Accordion-BoTckTBI.js +0 -28
- package/dist/cjs/Accordion-BoTckTBI.js.map +0 -1
- package/dist/cjs/Alert-DnIUdIE3.js +0 -67
- package/dist/cjs/Alert-DnIUdIE3.js.map +0 -1
- package/dist/cjs/Avatar-CNao5gvP.js +0 -52
- package/dist/cjs/Avatar-CNao5gvP.js.map +0 -1
- package/dist/cjs/Badge-_-PRf6aq.js +0 -61
- package/dist/cjs/Badge-_-PRf6aq.js.map +0 -1
- package/dist/cjs/Button-BniJ4TT_.js +0 -95
- package/dist/cjs/Button-BniJ4TT_.js.map +0 -1
- package/dist/cjs/Calendar-jVF8fRaS.js.map +0 -1
- package/dist/cjs/Callout-CVNpjTde.js.map +0 -1
- package/dist/cjs/Checkbox-DOlS2oCD.js +0 -26
- package/dist/cjs/Checkbox-DOlS2oCD.js.map +0 -1
- package/dist/cjs/ColorPicker-Uxgn8U0h.js +0 -280
- package/dist/cjs/ColorPicker-Uxgn8U0h.js.map +0 -1
- package/dist/cjs/DataTable-BynOh4Bs.js.map +0 -1
- package/dist/cjs/DatePicker-C0BwxIh8.js.map +0 -1
- package/dist/cjs/Dialog-CtI_yWsJ.js +0 -63
- package/dist/cjs/Dialog-CtI_yWsJ.js.map +0 -1
- package/dist/cjs/DirectionProvider-Bec-6U8p.js.map +0 -1
- package/dist/cjs/Empty-CfPLWsLK.js +0 -29
- package/dist/cjs/Empty-CfPLWsLK.js.map +0 -1
- package/dist/cjs/Input-pkugjUb0.js +0 -149
- package/dist/cjs/Input-pkugjUb0.js.map +0 -1
- package/dist/cjs/Kbd-DHirsI--.js +0 -38
- package/dist/cjs/Kbd-DHirsI--.js.map +0 -1
- package/dist/cjs/Label-B7FbeB5i.js +0 -60
- package/dist/cjs/Label-B7FbeB5i.js.map +0 -1
- package/dist/cjs/MultiEmailInput-l0_YVjbp.js +0 -141
- package/dist/cjs/MultiEmailInput-l0_YVjbp.js.map +0 -1
- package/dist/cjs/Pagination-Byzt9Kmj.js +0 -63
- package/dist/cjs/Pagination-Byzt9Kmj.js.map +0 -1
- package/dist/cjs/Popover-DRT0YYzK.js +0 -90
- package/dist/cjs/Popover-DRT0YYzK.js.map +0 -1
- package/dist/cjs/Progress-DoCxZ_ZH.js +0 -15
- package/dist/cjs/Progress-DoCxZ_ZH.js.map +0 -1
- package/dist/cjs/RadioGroup-1RAoe38m.js +0 -36
- package/dist/cjs/RadioGroup-1RAoe38m.js.map +0 -1
- package/dist/cjs/Select-nifsTqzo.js +0 -569
- package/dist/cjs/Select-nifsTqzo.js.map +0 -1
- package/dist/cjs/SelectFieldWrapper-DEA--2wj.js +0 -25
- package/dist/cjs/SelectFieldWrapper-DEA--2wj.js.map +0 -1
- package/dist/cjs/Sheet-BTZe2VQk.js +0 -65
- package/dist/cjs/Sheet-BTZe2VQk.js.map +0 -1
- package/dist/cjs/Slider-jNUS9vt8.js +0 -27
- package/dist/cjs/Slider-jNUS9vt8.js.map +0 -1
- package/dist/cjs/Spinner-DQutDMQq.js +0 -19
- package/dist/cjs/Spinner-DQutDMQq.js.map +0 -1
- package/dist/cjs/Stepper-DCoLl2ZS.js +0 -35
- package/dist/cjs/Stepper-DCoLl2ZS.js.map +0 -1
- package/dist/cjs/Switch-CFf8DtB_.js +0 -22
- package/dist/cjs/Switch-CFf8DtB_.js.map +0 -1
- package/dist/cjs/Tabs-D2247rd7.js +0 -40
- package/dist/cjs/Tabs-D2247rd7.js.map +0 -1
- package/dist/cjs/Textarea-BfdlAJ59.js +0 -75
- package/dist/cjs/Textarea-BfdlAJ59.js.map +0 -1
- package/dist/cjs/TimePicker-DReL0GSv.js +0 -148
- package/dist/cjs/TimePicker-DReL0GSv.js.map +0 -1
- package/dist/cjs/TimePickerPanel-DGNr97cj.js +0 -132
- package/dist/cjs/TimePickerPanel-DGNr97cj.js.map +0 -1
- package/dist/cjs/Toastr-BGp7-kmf.js +0 -117
- package/dist/cjs/Toastr-BGp7-kmf.js.map +0 -1
- package/dist/cjs/Tooltip-criVUtIg.js +0 -65
- package/dist/cjs/Tooltip-criVUtIg.js.map +0 -1
- package/dist/cjs/TranslationProvider-DBZHXmzX.js.map +0 -1
- package/dist/cjs/Tree-BPd0DuLh.js.map +0 -1
- package/dist/cjs/TreeSelect-BoffO6qD.js +0 -170
- package/dist/cjs/TreeSelect-BoffO6qD.js.map +0 -1
- package/dist/cjs/Typography-DaZ0HTha.js +0 -79
- package/dist/cjs/Typography-DaZ0HTha.js.map +0 -1
- package/dist/cjs/button--P7-oIJb.js +0 -71
- package/dist/cjs/button--P7-oIJb.js.map +0 -1
- package/dist/cjs/dialog-CWSpiRjk.js +0 -52
- package/dist/cjs/dialog-CWSpiRjk.js.map +0 -1
- package/dist/cjs/index-ChSOMM8b.js.map +0 -1
- package/dist/cjs/input-CgKPISj_.js +0 -11
- package/dist/cjs/input-CgKPISj_.js.map +0 -1
- package/dist/cjs/input-group-CFZl_aQS.js +0 -66
- package/dist/cjs/input-group-CFZl_aQS.js.map +0 -1
- package/dist/cjs/label-Bdc9ytTI.js.map +0 -1
- package/dist/cjs/renderIcon-fLF3odqg.js +0 -26
- package/dist/cjs/renderIcon-fLF3odqg.js.map +0 -1
- package/dist/cjs/search-CfYUGi4v.js +0 -37
- package/dist/cjs/search-CfYUGi4v.js.map +0 -1
- package/dist/cjs/separator-CPy2gyg1.js.map +0 -1
- package/dist/cjs/sheet-BZt84aab.js +0 -50
- package/dist/cjs/sheet-BZt84aab.js.map +0 -1
- package/dist/cjs/skeleton-DffZ8bV7.js +0 -11
- package/dist/cjs/skeleton-DffZ8bV7.js.map +0 -1
- package/dist/cjs/textarea-CZSSY75H.js +0 -11
- package/dist/cjs/textarea-CZSSY75H.js.map +0 -1
- package/dist/cjs/toggle-CaqzT8dI.js.map +0 -1
- package/dist/cjs/tooltip-C-568jEL.js.map +0 -1
- package/dist/cjs/use-mobile-B-UYxtqX.js +0 -41
- package/dist/cjs/use-mobile-B-UYxtqX.js.map +0 -1
- package/dist/cjs/utils-CTr7wn5d.js.map +0 -1
- package/dist/dialog-DK71SlsS.js +0 -41
- package/dist/index-B4_fVWDx.js.map +0 -1
- package/dist/input-GLCCE2kT.js +0 -9
- package/dist/input-group-C_qKMibX.js +0 -59
- package/dist/renderIcon-tlvMyboj.js +0 -20
- package/dist/search-BK7Ozh5_.js +0 -33
- package/dist/search-BK7Ozh5_.js.map +0 -1
- package/dist/sheet-DVTG6X82.js +0 -41
- package/dist/skeleton-AR83txPr.js +0 -9
- package/dist/skeleton-AR83txPr.js.map +0 -1
- package/dist/textarea-BSZwxzjQ.js +0 -9
- package/dist/toggle-2k9K8a5c.js +0 -60
- package/dist/use-mobile-IRjN_mlT.js +0 -19
- package/dist/use-mobile-IRjN_mlT.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Input-C1gcv9o2.js","sources":["../src/components/Input/constants.ts","../src/components/Input/utils.ts","../src/components/Input/Input.tsx"],"sourcesContent":["export const SIZE_CONFIG = {\n small: { group: \"h-7\", input: \"text-xs px-2\", addon: \"px-1.5\" },\n medium: { group: \"h-8\", input: \"text-sm\", addon: \"px-2\" },\n large: { group: \"h-10\", input: \"text-sm\", addon: \"px-2.5\" },\n};\n","import React from \"react\";\n\nexport function toFixed(numStr: string, prec: number): string {\n const num = Number(numStr);\n if (Number.isNaN(num)) return numStr;\n\n return num.toFixed(prec);\n}\n\nexport function formatWithPrecision(\n value: string | number | undefined,\n precision: number\n): string | undefined {\n if (precision < 0 || !value) return value as string | undefined;\n\n const str = value.toString();\n const trimmed = str.trim();\n if (trimmed !== \"\" && !Number.isNaN(Number(trimmed)))\n return toFixed(str, precision);\n\n return str;\n}\n\nexport function enforceDecimalPrecision(\n value: string,\n precision: number\n): string {\n if (precision < 0 || !value) return value;\n\n const valueStr = value.toString();\n if (precision === 0) return valueStr.split(\".\")[0];\n\n const regex = new RegExp(`^\\\\d*\\\\.?\\\\d{0,${precision}}$`);\n if (regex.test(valueStr)) return value;\n\n const parts = valueStr.split(\".\");\n if (parts.length === 1) return parts[0];\n\n return `${parts[0]}.${parts[1].substring(0, precision)}`;\n}\n\nexport function formatWithRejectCharsRegex(\n value: string,\n rejectCharsRegex?: RegExp\n): string {\n if (!rejectCharsRegex) return value;\n\n const globalRegex = new RegExp(rejectCharsRegex, \"g\");\n\n return value.replace(globalRegex, \"\");\n}\n\nexport function getTrimmedValue(\n value: string | number,\n disableTrimOnBlur: boolean\n): string | number {\n if (disableTrimOnBlur || typeof value !== \"string\") return value;\n\n return value.trim();\n}\n\nexport function preserveCursor(\n e: React.ChangeEvent<HTMLInputElement>,\n updateValueFn: () => React.ChangeEvent<HTMLInputElement>\n) {\n const input = e.target;\n const prevCursor = input.selectionStart;\n const prevValue = input.value;\n\n const updatedEvent = updateValueFn();\n\n const lengthDiff = input.value.length - prevValue.length;\n const newCursor = Math.max(0, (prevCursor ?? 0) + lengthDiff);\n\n requestAnimationFrame(() => {\n if (document.activeElement !== input) return;\n if (input.type === \"number\") return;\n\n input.setSelectionRange(newCursor, newCursor);\n });\n\n return updatedEvent;\n}\n","import React, { forwardRef, useId, useState } from \"react\";\n\nimport { cn } from \"src/shadcn/lib/utils\";\nimport {\n Field,\n FieldLabel,\n FieldContent,\n FieldDescription,\n FieldError,\n} from \"src/primitives/Field\";\nimport {\n InputGroup,\n InputGroupAddon,\n InputGroupText,\n InputGroupInput,\n} from \"src/primitives/InputGroup\";\n\nimport { SIZE_CONFIG } from \"./constants\";\nimport {\n formatWithPrecision,\n enforceDecimalPrecision,\n formatWithRejectCharsRegex,\n getTrimmedValue,\n preserveCursor,\n} from \"./utils\";\n\ntype InputSize = \"small\" | \"medium\" | \"large\";\n\nexport interface InputProps extends Omit<\n React.ComponentProps<\"input\">,\n \"size\" | \"prefix\" | \"value\"\n> {\n /** Controlled value. */\n value?: string | number;\n /** Size of the input. */\n size?: InputSize;\n /** Input type. */\n type?: string;\n /** Label displayed above the input. */\n label?: string;\n /** Error message displayed below the input. */\n error?: string;\n /** Help text displayed below the input. Accepts string or ReactNode. */\n helpText?: React.ReactNode;\n /** Content rendered before the input. */\n prefix?: React.ReactNode;\n /** Content rendered after the input. */\n suffix?: React.ReactNode;\n /** Removes borders from the input. */\n nakedInput?: boolean;\n /** HTML size attribute for the input element. */\n contentSize?: number;\n /** Maximum character limit. Counter visible at 85%. */\n maxLength?: number;\n /** Allow typing past maxLength, show error styling on count. */\n unlimitedChars?: boolean;\n /** Regex to reject matching characters from input. */\n rejectCharsRegex?: RegExp;\n /** Prevent trimming whitespace on blur. */\n disableTrimOnBlur?: boolean;\n /** Decimal places for number formatting. -1 to disable. */\n precision?: number;\n /** Props forwarded to the Label element. */\n labelProps?: React.ComponentProps<typeof FieldLabel>;\n /** Additional class name for the outermost wrapper. */\n className?: string;\n}\n\nconst Input = forwardRef<HTMLInputElement, InputProps>(\n (\n {\n size = \"medium\",\n type = \"text\",\n label = \"\",\n error = \"\",\n helpText = \"\",\n prefix = null,\n suffix = null,\n disabled = false,\n nakedInput = false,\n contentSize,\n required = false,\n maxLength,\n unlimitedChars = false,\n rejectCharsRegex,\n disableTrimOnBlur = false,\n precision = -1,\n labelProps,\n className = \"\",\n onBlur,\n onChange,\n value: controlledValue,\n ...otherProps\n },\n ref\n ) => {\n const generatedId = useId();\n const id = otherProps.id ?? generatedId;\n const errorId = `error_${id}`;\n const helpTextId = `helpText_${id}`;\n\n // Controlled / uncontrolled value tracking\n const [valueInternal, setValueInternal] = useState(controlledValue);\n const isControlled = controlledValue !== undefined;\n\n const value =\n formatWithPrecision(controlledValue, precision) ?? valueInternal ?? \"\";\n const valueLength = value?.toString().length || 0;\n\n const isMaxLengthPresent = !!maxLength || maxLength === 0;\n const isCharacterLimitVisible =\n isMaxLengthPresent && valueLength >= maxLength! * 0.85;\n const maxLengthError = unlimitedChars && valueLength > maxLength!;\n\n // --- Handlers ---\n\n const onChangeInternal = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) {\n setValueInternal(e.target.value);\n }\n onChange?.(e);\n };\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (type === \"file\") {\n onChangeInternal(e);\n\n return;\n }\n\n let formattedValue = formatWithRejectCharsRegex(\n e.target.value,\n rejectCharsRegex\n );\n formattedValue = enforceDecimalPrecision(formattedValue, precision);\n\n if (formattedValue !== e.target.value) {\n preserveCursor(e, () => {\n const syntheticEvent = Object.create(e, {\n target: { value: { ...e.target, value: formattedValue } },\n });\n e.target.value = formattedValue;\n onChangeInternal(syntheticEvent);\n\n return syntheticEvent;\n });\n } else {\n onChangeInternal(e);\n }\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n if (type === \"file\") {\n onBlur?.(e);\n\n return;\n }\n\n const trimmedValue = getTrimmedValue(value, disableTrimOnBlur);\n const formattedValue = formatWithPrecision(trimmedValue, precision);\n\n if (formattedValue !== undefined && formattedValue !== value) {\n e.target.value = formattedValue.toString();\n handleChange(e as unknown as React.ChangeEvent<HTMLInputElement>);\n }\n\n onBlur?.(e);\n };\n\n const handleWheel = (e: React.WheelEvent<HTMLInputElement>) => {\n if (type === \"number\") (e.target as HTMLInputElement).blur();\n };\n\n // --- aria-describedby ---\n\n const ariaDescribedBy =\n [error ? errorId : null, helpText ? helpTextId : null]\n .filter(Boolean)\n .join(\" \") || undefined;\n\n // --- Render ---\n\n const hasField = !!(label || error || helpText);\n const sizeConfig = SIZE_CONFIG[size];\n\n const inputGroup = (\n <InputGroup\n className={cn(\n sizeConfig.group,\n nakedInput &&\n \"border-0 shadow-none has-[[data-slot=input-group-control]:focus-visible]:ring-0 has-[[data-slot=input-group-control]:focus-visible]:border-transparent\",\n !!error &&\n !nakedInput &&\n \"border-destructive ring-destructive/20 ring-3\",\n !hasField && className\n )}\n >\n {prefix && (\n <InputGroupAddon align=\"inline-start\" className={sizeConfig.addon}>\n <InputGroupText>{prefix}</InputGroupText>\n </InputGroupAddon>\n )}\n <InputGroupInput\n ref={ref}\n id={id}\n type={type}\n disabled={disabled}\n required={required}\n size={contentSize}\n aria-invalid={!!error || undefined}\n aria-describedby={ariaDescribedBy}\n className={cn(sizeConfig.input, nakedInput && \"px-0\")}\n value={value}\n onBlur={handleBlur}\n onChange={handleChange}\n onWheel={handleWheel}\n {...(isMaxLengthPresent && !unlimitedChars ? { maxLength } : {})}\n {...otherProps}\n />\n {suffix && (\n <InputGroupAddon align=\"inline-end\" className={sizeConfig.addon}>\n <InputGroupText>{suffix}</InputGroupText>\n </InputGroupAddon>\n )}\n </InputGroup>\n );\n\n if (!hasField) {\n return inputGroup;\n }\n\n return (\n <Field\n data-disabled={disabled || undefined}\n data-invalid={!!error || undefined}\n className={className}\n >\n {(label || isCharacterLimitVisible) && (\n <div className=\"flex items-center justify-between\">\n {label && (\n <FieldLabel htmlFor={id} {...labelProps}>\n {label}\n {required && (\n <span aria-hidden=\"true\" className=\"text-destructive\">\n *\n </span>\n )}\n </FieldLabel>\n )}\n {isCharacterLimitVisible && (\n <span\n className={cn(\n \"text-xs tabular-nums\",\n maxLengthError ? \"text-destructive\" : \"text-muted-foreground\"\n )}\n >\n {valueLength}/{maxLength}\n </span>\n )}\n </div>\n )}\n <FieldContent>\n {inputGroup}\n {!!error && <FieldError id={errorId}>{error}</FieldError>}\n {helpText && (\n <FieldDescription id={helpTextId}>{helpText}</FieldDescription>\n )}\n </FieldContent>\n </Field>\n );\n }\n);\n\nInput.displayName = \"Input\";\n\nexport { Input };\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Input-xjYQfsaz.js","sources":["../src/components/Input/constants.ts","../src/components/Input/utils.ts","../src/components/Input/Input.tsx"],"sourcesContent":["export const SIZE_CONFIG = {\n small: { group: \"h-7\", input: \"text-xs px-2\", addon: \"px-1.5\" },\n medium: { group: \"h-8\", input: \"text-sm\", addon: \"px-2\" },\n large: { group: \"h-10\", input: \"text-sm\", addon: \"px-2.5\" },\n};\n","import React from \"react\";\n\nexport function toFixed(numStr: string, prec: number): string {\n const num = Number(numStr);\n if (Number.isNaN(num)) return numStr;\n\n return num.toFixed(prec);\n}\n\nexport function formatWithPrecision(\n value: string | number | undefined,\n precision: number\n): string | undefined {\n if (precision < 0 || !value) return value as string | undefined;\n\n const str = value.toString();\n const trimmed = str.trim();\n if (trimmed !== \"\" && !Number.isNaN(Number(trimmed)))\n return toFixed(str, precision);\n\n return str;\n}\n\nexport function enforceDecimalPrecision(\n value: string,\n precision: number\n): string {\n if (precision < 0 || !value) return value;\n\n const valueStr = value.toString();\n if (precision === 0) return valueStr.split(\".\")[0];\n\n const regex = new RegExp(`^\\\\d*\\\\.?\\\\d{0,${precision}}$`);\n if (regex.test(valueStr)) return value;\n\n const parts = valueStr.split(\".\");\n if (parts.length === 1) return parts[0];\n\n return `${parts[0]}.${parts[1].substring(0, precision)}`;\n}\n\nexport function formatWithRejectCharsRegex(\n value: string,\n rejectCharsRegex?: RegExp\n): string {\n if (!rejectCharsRegex) return value;\n\n const globalRegex = new RegExp(rejectCharsRegex, \"g\");\n\n return value.replace(globalRegex, \"\");\n}\n\nexport function getTrimmedValue(\n value: string | number,\n disableTrimOnBlur: boolean\n): string | number {\n if (disableTrimOnBlur || typeof value !== \"string\") return value;\n\n return value.trim();\n}\n\nexport function preserveCursor(\n e: React.ChangeEvent<HTMLInputElement>,\n updateValueFn: () => React.ChangeEvent<HTMLInputElement>\n) {\n const input = e.target;\n const prevCursor = input.selectionStart;\n const prevValue = input.value;\n\n const updatedEvent = updateValueFn();\n\n const lengthDiff = input.value.length - prevValue.length;\n const newCursor = Math.max(0, (prevCursor ?? 0) + lengthDiff);\n\n requestAnimationFrame(() => {\n if (document.activeElement !== input) return;\n if (input.type === \"number\") return;\n\n input.setSelectionRange(newCursor, newCursor);\n });\n\n return updatedEvent;\n}\n","import React, { forwardRef, useId, useState } from \"react\";\n\nimport { cn } from \"src/shadcn/lib/utils\";\nimport {\n Field,\n FieldLabel,\n FieldContent,\n FieldDescription,\n FieldError,\n} from \"src/primitives/Field\";\nimport {\n InputGroup,\n InputGroupAddon,\n InputGroupText,\n InputGroupInput,\n} from \"src/primitives/InputGroup\";\n\nimport { SIZE_CONFIG } from \"./constants\";\nimport {\n formatWithPrecision,\n enforceDecimalPrecision,\n formatWithRejectCharsRegex,\n getTrimmedValue,\n preserveCursor,\n} from \"./utils\";\n\ntype InputSize = \"small\" | \"medium\" | \"large\";\n\nexport interface InputProps extends Omit<\n React.ComponentProps<\"input\">,\n \"size\" | \"prefix\" | \"value\"\n> {\n /** Controlled value. */\n value?: string | number;\n /** Size of the input. */\n size?: InputSize;\n /** Input type. */\n type?: string;\n /** Label displayed above the input. */\n label?: string;\n /** Error message displayed below the input. */\n error?: string;\n /** Help text displayed below the input. Accepts string or ReactNode. */\n helpText?: React.ReactNode;\n /** Content rendered before the input. */\n prefix?: React.ReactNode;\n /** Content rendered after the input. */\n suffix?: React.ReactNode;\n /** Removes borders from the input. */\n nakedInput?: boolean;\n /** HTML size attribute for the input element. */\n contentSize?: number;\n /** Maximum character limit. Counter visible at 85%. */\n maxLength?: number;\n /** Allow typing past maxLength, show error styling on count. */\n unlimitedChars?: boolean;\n /** Regex to reject matching characters from input. */\n rejectCharsRegex?: RegExp;\n /** Prevent trimming whitespace on blur. */\n disableTrimOnBlur?: boolean;\n /** Decimal places for number formatting. -1 to disable. */\n precision?: number;\n /** Props forwarded to the Label element. */\n labelProps?: React.ComponentProps<typeof FieldLabel>;\n /** Additional class name for the outermost wrapper. */\n className?: string;\n}\n\nconst Input = forwardRef<HTMLInputElement, InputProps>(\n (\n {\n size = \"medium\",\n type = \"text\",\n label = \"\",\n error = \"\",\n helpText = \"\",\n prefix = null,\n suffix = null,\n disabled = false,\n nakedInput = false,\n contentSize,\n required = false,\n maxLength,\n unlimitedChars = false,\n rejectCharsRegex,\n disableTrimOnBlur = false,\n precision = -1,\n labelProps,\n className = \"\",\n onBlur,\n onChange,\n value: controlledValue,\n ...otherProps\n },\n ref\n ) => {\n const generatedId = useId();\n const id = otherProps.id ?? generatedId;\n const errorId = `error_${id}`;\n const helpTextId = `helpText_${id}`;\n\n // Controlled / uncontrolled value tracking\n const [valueInternal, setValueInternal] = useState(controlledValue);\n const isControlled = controlledValue !== undefined;\n\n const value =\n formatWithPrecision(controlledValue, precision) ?? valueInternal ?? \"\";\n const valueLength = value?.toString().length || 0;\n\n const isMaxLengthPresent = !!maxLength || maxLength === 0;\n const isCharacterLimitVisible =\n isMaxLengthPresent && valueLength >= maxLength! * 0.85;\n const maxLengthError = unlimitedChars && valueLength > maxLength!;\n\n // --- Handlers ---\n\n const onChangeInternal = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) {\n setValueInternal(e.target.value);\n }\n onChange?.(e);\n };\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (type === \"file\") {\n onChangeInternal(e);\n\n return;\n }\n\n let formattedValue = formatWithRejectCharsRegex(\n e.target.value,\n rejectCharsRegex\n );\n formattedValue = enforceDecimalPrecision(formattedValue, precision);\n\n if (formattedValue !== e.target.value) {\n preserveCursor(e, () => {\n const syntheticEvent = Object.create(e, {\n target: { value: { ...e.target, value: formattedValue } },\n });\n e.target.value = formattedValue;\n onChangeInternal(syntheticEvent);\n\n return syntheticEvent;\n });\n } else {\n onChangeInternal(e);\n }\n };\n\n const handleBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n if (type === \"file\") {\n onBlur?.(e);\n\n return;\n }\n\n const trimmedValue = getTrimmedValue(value, disableTrimOnBlur);\n const formattedValue = formatWithPrecision(trimmedValue, precision);\n\n if (formattedValue !== undefined && formattedValue !== value) {\n e.target.value = formattedValue.toString();\n handleChange(e as unknown as React.ChangeEvent<HTMLInputElement>);\n }\n\n onBlur?.(e);\n };\n\n const handleWheel = (e: React.WheelEvent<HTMLInputElement>) => {\n if (type === \"number\") (e.target as HTMLInputElement).blur();\n };\n\n // --- aria-describedby ---\n\n const ariaDescribedBy =\n [error ? errorId : null, helpText ? helpTextId : null]\n .filter(Boolean)\n .join(\" \") || undefined;\n\n // --- Render ---\n\n const hasField = !!(label || error || helpText);\n const sizeConfig = SIZE_CONFIG[size];\n\n const inputGroup = (\n <InputGroup\n className={cn(\n sizeConfig.group,\n nakedInput &&\n \"border-0 shadow-none has-[[data-slot=input-group-control]:focus-visible]:ring-0 has-[[data-slot=input-group-control]:focus-visible]:border-transparent\",\n !!error &&\n !nakedInput &&\n \"border-destructive ring-destructive/20 ring-3\",\n !hasField && className\n )}\n >\n {prefix && (\n <InputGroupAddon align=\"inline-start\" className={sizeConfig.addon}>\n <InputGroupText>{prefix}</InputGroupText>\n </InputGroupAddon>\n )}\n <InputGroupInput\n ref={ref}\n id={id}\n type={type}\n disabled={disabled}\n required={required}\n size={contentSize}\n aria-invalid={!!error || undefined}\n aria-describedby={ariaDescribedBy}\n className={cn(sizeConfig.input, nakedInput && \"px-0\")}\n value={value}\n onBlur={handleBlur}\n onChange={handleChange}\n onWheel={handleWheel}\n {...(isMaxLengthPresent && !unlimitedChars ? { maxLength } : {})}\n {...otherProps}\n />\n {suffix && (\n <InputGroupAddon align=\"inline-end\" className={sizeConfig.addon}>\n <InputGroupText>{suffix}</InputGroupText>\n </InputGroupAddon>\n )}\n </InputGroup>\n );\n\n if (!hasField) {\n return inputGroup;\n }\n\n return (\n <Field\n data-disabled={disabled || undefined}\n data-invalid={!!error || undefined}\n className={className}\n >\n {(label || isCharacterLimitVisible) && (\n <div className=\"flex items-center justify-between\">\n {label && (\n <FieldLabel htmlFor={id} {...labelProps}>\n {label}\n {required && (\n <span aria-hidden=\"true\" className=\"text-destructive\">\n *\n </span>\n )}\n </FieldLabel>\n )}\n {isCharacterLimitVisible && (\n <span\n className={cn(\n \"text-xs tabular-nums\",\n maxLengthError ? \"text-destructive\" : \"text-muted-foreground\"\n )}\n >\n {valueLength}/{maxLength}\n </span>\n )}\n </div>\n )}\n <FieldContent>\n {inputGroup}\n {!!error && <FieldError id={errorId}>{error}</FieldError>}\n {helpText && (\n <FieldDescription id={helpTextId}>{helpText}</FieldDescription>\n )}\n </FieldContent>\n </Field>\n );\n }\n);\n\nInput.displayName = \"Input\";\n\nexport { Input };\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { c as cn } from './utils-BJnb9o5c.js';
|
|
4
|
+
import { Kbd as Kbd$1, KbdGroup as KbdGroup$1 } from './primitives/Kbd.js';
|
|
5
|
+
import { TooltipProvider, Tooltip, TooltipTrigger, TooltipContent } from './primitives/Tooltip.js';
|
|
6
|
+
|
|
7
|
+
const SIDE_MAP = {
|
|
8
|
+
top: "top",
|
|
9
|
+
bottom: "bottom",
|
|
10
|
+
left: "left",
|
|
11
|
+
right: "right",
|
|
12
|
+
"top-start": "top",
|
|
13
|
+
"top-end": "top",
|
|
14
|
+
"bottom-start": "bottom",
|
|
15
|
+
"bottom-end": "bottom",
|
|
16
|
+
"left-start": "left",
|
|
17
|
+
"left-end": "left",
|
|
18
|
+
"right-start": "right",
|
|
19
|
+
"right-end": "right",
|
|
20
|
+
auto: "top"
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
const Kbd = forwardRef(
|
|
24
|
+
({ tooltipProps, className, ...otherProps }, ref) => {
|
|
25
|
+
const kbd = /* @__PURE__ */ jsx(Kbd$1, { ref, className: cn(className), ...otherProps });
|
|
26
|
+
if (!tooltipProps?.content) {
|
|
27
|
+
return kbd;
|
|
28
|
+
}
|
|
29
|
+
const side = SIDE_MAP[tooltipProps.position ?? "auto"] ?? "top";
|
|
30
|
+
return /* @__PURE__ */ jsx(TooltipProvider, { children: /* @__PURE__ */ jsxs(Tooltip, { children: [
|
|
31
|
+
/* @__PURE__ */ jsx(TooltipTrigger, { asChild: true, children: kbd }),
|
|
32
|
+
/* @__PURE__ */ jsx(TooltipContent, { side, children: tooltipProps.content })
|
|
33
|
+
] }) });
|
|
34
|
+
}
|
|
35
|
+
);
|
|
36
|
+
Kbd.displayName = "Kbd";
|
|
37
|
+
const KbdGroup = KbdGroup$1;
|
|
38
|
+
const KbdNamespace = Object.assign(Kbd, { Group: KbdGroup });
|
|
39
|
+
|
|
40
|
+
export { KbdNamespace as K };
|
|
41
|
+
//# sourceMappingURL=Kbd-CJOM9x4C.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Kbd-
|
|
1
|
+
{"version":3,"file":"Kbd-CJOM9x4C.js","sources":["../src/components/Kbd/constants.ts","../src/components/Kbd/Kbd.tsx"],"sourcesContent":["export const SIDE_MAP: Record<string, \"top\" | \"right\" | \"bottom\" | \"left\"> = {\n top: \"top\",\n bottom: \"bottom\",\n left: \"left\",\n right: \"right\",\n \"top-start\": \"top\",\n \"top-end\": \"top\",\n \"bottom-start\": \"bottom\",\n \"bottom-end\": \"bottom\",\n \"left-start\": \"left\",\n \"left-end\": \"left\",\n \"right-start\": \"right\",\n \"right-end\": \"right\",\n auto: \"top\",\n};\n","import React, { forwardRef } from \"react\";\n\nimport { cn } from \"src/shadcn/lib/utils\";\nimport {\n Kbd as PrimitiveKbd,\n KbdGroup as PrimitiveKbdGroup,\n} from \"src/primitives/Kbd\";\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from \"src/primitives/Tooltip\";\n\nimport { SIDE_MAP } from \"./constants\";\n\nexport interface KbdProps extends React.ComponentProps<typeof PrimitiveKbd> {\n /** Optional tooltip to display on hover. */\n tooltipProps?: {\n content?: React.ReactNode;\n position?: string;\n };\n /** Additional CSS class names. */\n className?: string;\n}\n\nconst Kbd = forwardRef<HTMLElement, KbdProps>(\n ({ tooltipProps, className, ...otherProps }, ref) => {\n const kbd = (\n <PrimitiveKbd ref={ref} className={cn(className)} {...otherProps} />\n );\n\n if (!tooltipProps?.content) {\n return kbd;\n }\n\n const side = SIDE_MAP[tooltipProps.position ?? \"auto\"] ?? \"top\";\n\n return (\n <TooltipProvider>\n <Tooltip>\n <TooltipTrigger asChild>{kbd}</TooltipTrigger>\n <TooltipContent side={side}>{tooltipProps.content}</TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n }\n);\n\nKbd.displayName = \"Kbd\";\n\nconst KbdGroup = PrimitiveKbdGroup;\n\nconst KbdNamespace = Object.assign(Kbd, { Group: KbdGroup });\n\nexport { KbdNamespace as Kbd };\n"],"names":["PrimitiveKbd","PrimitiveKbdGroup"],"mappings":";;;;;;AAAO,MAAM,QAAA,GAAgE;AAAA,EAC3E,GAAA,EAAK,KAAA;AAAA,EACL,MAAA,EAAQ,QAAA;AAAA,EACR,IAAA,EAAM,MAAA;AAAA,EACN,KAAA,EAAO,OAAA;AAAA,EACP,WAAA,EAAa,KAAA;AAAA,EACb,SAAA,EAAW,KAAA;AAAA,EACX,cAAA,EAAgB,QAAA;AAAA,EAChB,YAAA,EAAc,QAAA;AAAA,EACd,YAAA,EAAc,MAAA;AAAA,EACd,UAAA,EAAY,MAAA;AAAA,EACZ,aAAA,EAAe,OAAA;AAAA,EACf,WAAA,EAAa,OAAA;AAAA,EACb,IAAA,EAAM;AACR,CAAA;;ACYA,MAAM,GAAA,GAAM,UAAA;AAAA,EACV,CAAC,EAAE,YAAA,EAAc,WAAW,GAAG,UAAA,IAAc,GAAA,KAAQ;AACnD,IAAA,MAAM,GAAA,uBACHA,KAAA,EAAA,EAAa,GAAA,EAAU,WAAW,EAAA,CAAG,SAAS,CAAA,EAAI,GAAG,UAAA,EAAY,CAAA;AAGpE,IAAA,IAAI,CAAC,cAAc,OAAA,EAAS;AAC1B,MAAA,OAAO,GAAA;AAAA,IACT;AAEA,IAAA,MAAM,IAAA,GAAO,QAAA,CAAS,YAAA,CAAa,QAAA,IAAY,MAAM,CAAA,IAAK,KAAA;AAE1D,IAAA,uBACE,GAAA,CAAC,eAAA,EAAA,EACC,QAAA,kBAAA,IAAA,CAAC,OAAA,EAAA,EACC,QAAA,EAAA;AAAA,sBAAA,GAAA,CAAC,cAAA,EAAA,EAAe,OAAA,EAAO,IAAA,EAAE,QAAA,EAAA,GAAA,EAAI,CAAA;AAAA,sBAC7B,GAAA,CAAC,cAAA,EAAA,EAAe,IAAA,EAAa,QAAA,EAAA,YAAA,CAAa,OAAA,EAAQ;AAAA,KAAA,EACpD,CAAA,EACF,CAAA;AAAA,EAEJ;AACF,CAAA;AAEA,GAAA,CAAI,WAAA,GAAc,KAAA;AAElB,MAAM,QAAA,GAAWC,UAAA;AAEjB,MAAM,eAAe,MAAA,CAAO,MAAA,CAAO,KAAK,EAAE,KAAA,EAAO,UAAU;;;;"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { c as cn } from './utils-BJnb9o5c.js';
|
|
4
|
+
import { r as renderIcon } from './renderIcon-C6twJSqH.js';
|
|
5
|
+
import { Label as Label$1 } from './primitives/Label.js';
|
|
6
|
+
import { TooltipProvider, Tooltip, TooltipTrigger, TooltipContent } from './primitives/Tooltip.js';
|
|
7
|
+
import { c as createLucideIcon } from './createLucideIcon-C8ycilSN.js';
|
|
8
|
+
import { P as Popover } from './Popover-Cco_6txS.js';
|
|
9
|
+
import { B as Button } from './Button-BCWJgHDy.js';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* @license lucide-react v0.577.0 - ISC
|
|
13
|
+
*
|
|
14
|
+
* This source code is licensed under the ISC license.
|
|
15
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
const __iconNode = [
|
|
20
|
+
["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }],
|
|
21
|
+
["path", { d: "M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3", key: "1u773s" }],
|
|
22
|
+
["path", { d: "M12 17h.01", key: "p32p05" }]
|
|
23
|
+
];
|
|
24
|
+
const CircleQuestionMark = createLucideIcon("circle-question-mark", __iconNode);
|
|
25
|
+
|
|
26
|
+
const SIDE_MAP = {
|
|
27
|
+
top: "top",
|
|
28
|
+
bottom: "bottom",
|
|
29
|
+
left: "left",
|
|
30
|
+
right: "right",
|
|
31
|
+
auto: "top"
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
const Label = forwardRef(
|
|
35
|
+
({ required, helpIconProps, className, children, ...otherProps }, ref) => {
|
|
36
|
+
const helpIcon = helpIconProps?.icon ?? CircleQuestionMark;
|
|
37
|
+
const iconElement = /* @__PURE__ */ jsx(
|
|
38
|
+
"span",
|
|
39
|
+
{
|
|
40
|
+
className: cn(
|
|
41
|
+
"inline-flex cursor-help text-muted-foreground transition-colors hover:text-foreground",
|
|
42
|
+
helpIconProps?.onClick && "cursor-pointer",
|
|
43
|
+
helpIconProps?.className
|
|
44
|
+
),
|
|
45
|
+
onClick: helpIconProps?.onClick,
|
|
46
|
+
children: renderIcon(helpIcon, "size-3.5")
|
|
47
|
+
}
|
|
48
|
+
);
|
|
49
|
+
const renderHelpIcon = () => {
|
|
50
|
+
if (!helpIconProps) return null;
|
|
51
|
+
if (helpIconProps.popoverProps) {
|
|
52
|
+
const { title, description, helpLinkProps } = helpIconProps.popoverProps;
|
|
53
|
+
return /* @__PURE__ */ jsxs(Popover, { trigger: iconElement, children: [
|
|
54
|
+
title && /* @__PURE__ */ jsx(Popover.Title, { children: title }),
|
|
55
|
+
description && /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground", children: description }),
|
|
56
|
+
helpLinkProps && /* @__PURE__ */ jsx(
|
|
57
|
+
Button,
|
|
58
|
+
{
|
|
59
|
+
variant: "link",
|
|
60
|
+
size: "sm",
|
|
61
|
+
className: "mt-1 h-auto self-start p-0",
|
|
62
|
+
...helpLinkProps,
|
|
63
|
+
href: helpLinkProps.href
|
|
64
|
+
}
|
|
65
|
+
)
|
|
66
|
+
] });
|
|
67
|
+
}
|
|
68
|
+
if (helpIconProps.tooltipProps?.content) {
|
|
69
|
+
const side = SIDE_MAP[helpIconProps.tooltipProps.position ?? "auto"] ?? "top";
|
|
70
|
+
return /* @__PURE__ */ jsx(TooltipProvider, { children: /* @__PURE__ */ jsxs(Tooltip, { children: [
|
|
71
|
+
/* @__PURE__ */ jsx(TooltipTrigger, { asChild: true, children: iconElement }),
|
|
72
|
+
/* @__PURE__ */ jsx(TooltipContent, { side, children: helpIconProps.tooltipProps.content })
|
|
73
|
+
] }) });
|
|
74
|
+
}
|
|
75
|
+
return iconElement;
|
|
76
|
+
};
|
|
77
|
+
return /* @__PURE__ */ jsxs(Label$1, { ref, className: cn(className), ...otherProps, children: [
|
|
78
|
+
children,
|
|
79
|
+
required && /* @__PURE__ */ jsx("span", { "aria-hidden": "true", className: "text-destructive", children: "*" }),
|
|
80
|
+
renderHelpIcon()
|
|
81
|
+
] });
|
|
82
|
+
}
|
|
83
|
+
);
|
|
84
|
+
Label.displayName = "Label";
|
|
85
|
+
|
|
86
|
+
export { Label as L };
|
|
87
|
+
//# sourceMappingURL=Label-CrCRic4I.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Label-
|
|
1
|
+
{"version":3,"file":"Label-CrCRic4I.js","sources":["../node_modules/lucide-react/dist/esm/icons/circle-question-mark.js","../src/components/Label/constants.ts","../src/components/Label/Label.tsx"],"sourcesContent":["/**\n * @license lucide-react v0.577.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 __iconNode = [\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"10\", key: \"1mglay\" }],\n [\"path\", { d: \"M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3\", key: \"1u773s\" }],\n [\"path\", { d: \"M12 17h.01\", key: \"p32p05\" }]\n];\nconst CircleQuestionMark = createLucideIcon(\"circle-question-mark\", __iconNode);\n\nexport { __iconNode, CircleQuestionMark as default };\n//# sourceMappingURL=circle-question-mark.js.map\n","export const SIDE_MAP: Record<string, \"top\" | \"right\" | \"bottom\" | \"left\"> = {\n top: \"top\",\n bottom: \"bottom\",\n left: \"left\",\n right: \"right\",\n auto: \"top\",\n};\n","import React, { forwardRef } from \"react\";\n\nimport { CircleHelpIcon } from \"lucide-react\";\n\nimport { cn } from \"src/shadcn/lib/utils\";\nimport { renderIcon, type IconProp } from \"src/lib/renderIcon\";\nimport { Label as PrimitiveLabel } from \"src/primitives/Label\";\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from \"src/primitives/Tooltip\";\nimport { Popover } from \"src/components/Popover\";\nimport { Button, type ButtonProps } from \"src/components/Button\";\n\nimport { SIDE_MAP } from \"./constants\";\n\ninterface HelpIconTooltipProps {\n /** Tooltip content. */\n content?: React.ReactNode;\n /** Tooltip position. */\n position?: string;\n}\n\ninterface HelpIconPopoverProps {\n /** Popover title. */\n title?: React.ReactNode;\n /** Popover description. */\n description?: React.ReactNode;\n /** Props for an optional help link button inside the popover. */\n helpLinkProps?: ButtonProps;\n}\n\ninterface HelpIconProps {\n /** Click handler on the help icon. */\n onClick?: () => void;\n /** Custom icon. Defaults to CircleHelpIcon. */\n icon?: IconProp;\n /** Show a tooltip on hover. */\n tooltipProps?: HelpIconTooltipProps;\n /** Show a popover on hover with title, description, and optional link. */\n popoverProps?: HelpIconPopoverProps;\n /** Additional class name for the help icon. */\n className?: string;\n}\n\nexport interface LabelProps extends React.ComponentProps<\n typeof PrimitiveLabel\n> {\n /** Shows a red asterisk after the label text. */\n required?: boolean;\n /** Props for the help icon (tooltip or popover mode). */\n helpIconProps?: HelpIconProps;\n /** Additional CSS class names. */\n className?: string;\n}\n\nconst Label = forwardRef<HTMLLabelElement, LabelProps>(\n ({ required, helpIconProps, className, children, ...otherProps }, ref) => {\n const helpIcon = helpIconProps?.icon ?? CircleHelpIcon;\n\n const iconElement = (\n <span\n className={cn(\n \"inline-flex cursor-help text-muted-foreground transition-colors hover:text-foreground\",\n helpIconProps?.onClick && \"cursor-pointer\",\n helpIconProps?.className\n )}\n onClick={helpIconProps?.onClick}\n >\n {renderIcon(helpIcon, \"size-3.5\")}\n </span>\n );\n\n const renderHelpIcon = () => {\n if (!helpIconProps) return null;\n\n // Popover mode\n if (helpIconProps.popoverProps) {\n const { title, description, helpLinkProps } =\n helpIconProps.popoverProps;\n\n return (\n <Popover trigger={iconElement}>\n {title && <Popover.Title>{title}</Popover.Title>}\n {description && (\n <p className=\"text-sm text-muted-foreground\">{description}</p>\n )}\n {helpLinkProps && (\n <Button\n variant=\"link\"\n size=\"sm\"\n className=\"mt-1 h-auto self-start p-0\"\n {...helpLinkProps}\n href={helpLinkProps.href}\n />\n )}\n </Popover>\n );\n }\n\n // Tooltip mode\n if (helpIconProps.tooltipProps?.content) {\n const side =\n SIDE_MAP[helpIconProps.tooltipProps.position ?? \"auto\"] ?? \"top\";\n\n return (\n <TooltipProvider>\n <Tooltip>\n <TooltipTrigger asChild>{iconElement}</TooltipTrigger>\n <TooltipContent side={side}>\n {helpIconProps.tooltipProps.content}\n </TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n }\n\n // Icon only (with optional onClick)\n return iconElement;\n };\n\n return (\n <PrimitiveLabel ref={ref} className={cn(className)} {...otherProps}>\n {children}\n {required && (\n <span aria-hidden=\"true\" className=\"text-destructive\">\n *\n </span>\n )}\n {renderHelpIcon()}\n </PrimitiveLabel>\n );\n }\n);\n\nLabel.displayName = \"Label\";\n\nexport { Label };\n"],"names":["CircleHelpIcon","PrimitiveLabel"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useState, useCallback, useMemo, forwardRef, useId } from 'react';
|
|
3
|
+
import { c as cn } from './utils-BJnb9o5c.js';
|
|
4
|
+
import { Field, FieldLabel, FieldContent } from './primitives/Field.js';
|
|
5
|
+
import { X } from './x-_o2T3n6D.js';
|
|
6
|
+
|
|
7
|
+
const EMAIL_REGEX = /^[A-Z0-9._%+-]+@[A-Z0-9-]+(?:\.[A-Z0-9-]+)*\.[A-Z]{2,}$/i;
|
|
8
|
+
const UNSTRICT_EMAIL_REGEX = /(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))/g;
|
|
9
|
+
const EMAIL_SEPARATION_REGEX = /[^\s,]+/g;
|
|
10
|
+
|
|
11
|
+
const formatEmailInputOption = (email) => ({
|
|
12
|
+
label: email,
|
|
13
|
+
value: email,
|
|
14
|
+
valid: EMAIL_REGEX.test(email)
|
|
15
|
+
});
|
|
16
|
+
const pruneDuplicates = (existing, newEmailStrings) => {
|
|
17
|
+
const seen = new Set(existing.map((e) => e.value.toLowerCase()));
|
|
18
|
+
const duplicates = [];
|
|
19
|
+
const added = [];
|
|
20
|
+
for (const emailStr of newEmailStrings) {
|
|
21
|
+
const lower = emailStr.toLowerCase();
|
|
22
|
+
if (seen.has(lower)) {
|
|
23
|
+
duplicates.push(emailStr);
|
|
24
|
+
} else {
|
|
25
|
+
seen.add(lower);
|
|
26
|
+
added.push(formatEmailInputOption(emailStr));
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return { uniqueEmails: [...existing, ...added], duplicates };
|
|
30
|
+
};
|
|
31
|
+
const filterValidEmails = (emails) => emails.filter((email) => email.valid);
|
|
32
|
+
const pluralizeEmail = (count) => count === 1 ? "email" : "emails";
|
|
33
|
+
const formatDuplicateWarning = (duplicates) => {
|
|
34
|
+
const count = duplicates.length;
|
|
35
|
+
return `Removed ${count} duplicate ${pluralizeEmail(count)} from the list: ${duplicates.join(", ")}`;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
function useMultiEmailState(props) {
|
|
39
|
+
const {
|
|
40
|
+
value = [],
|
|
41
|
+
onChange,
|
|
42
|
+
onBlur,
|
|
43
|
+
visibleEmailsCount = 3,
|
|
44
|
+
isAlwaysExpanded = false,
|
|
45
|
+
counter,
|
|
46
|
+
filterInvalidEmails
|
|
47
|
+
} = props;
|
|
48
|
+
const [inputValue, setInputValue] = useState("");
|
|
49
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
50
|
+
const [duplicateEmails, setDuplicateEmails] = useState([]);
|
|
51
|
+
const addEmails = useCallback(
|
|
52
|
+
(input) => {
|
|
53
|
+
const trimmed = input.trim();
|
|
54
|
+
if (!trimmed) return;
|
|
55
|
+
UNSTRICT_EMAIL_REGEX.lastIndex = 0;
|
|
56
|
+
EMAIL_SEPARATION_REGEX.lastIndex = 0;
|
|
57
|
+
const emailMatches = trimmed.match(UNSTRICT_EMAIL_REGEX) || trimmed.match(EMAIL_SEPARATION_REGEX) || [];
|
|
58
|
+
if (emailMatches.length === 0) return;
|
|
59
|
+
const { uniqueEmails, duplicates } = pruneDuplicates(value, emailMatches);
|
|
60
|
+
onChange?.(uniqueEmails);
|
|
61
|
+
setDuplicateEmails(duplicates);
|
|
62
|
+
setInputValue("");
|
|
63
|
+
},
|
|
64
|
+
[value, onChange]
|
|
65
|
+
);
|
|
66
|
+
const handleKeyDown = useCallback(
|
|
67
|
+
(event) => {
|
|
68
|
+
if (!inputValue && event.key === "Backspace" && value.length > 0) {
|
|
69
|
+
onChange?.(value.slice(0, -1));
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
if (!inputValue) return;
|
|
73
|
+
if (["Enter", "Tab", ",", " "].includes(event.key)) {
|
|
74
|
+
addEmails(inputValue);
|
|
75
|
+
event.preventDefault();
|
|
76
|
+
event.stopPropagation();
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
[inputValue, value, onChange, addEmails]
|
|
80
|
+
);
|
|
81
|
+
const handlePaste = useCallback(
|
|
82
|
+
(event) => {
|
|
83
|
+
const text = event.clipboardData.getData("text");
|
|
84
|
+
if (!text) return;
|
|
85
|
+
event.preventDefault();
|
|
86
|
+
addEmails(text);
|
|
87
|
+
},
|
|
88
|
+
[addEmails]
|
|
89
|
+
);
|
|
90
|
+
const handleBlur = useCallback(() => {
|
|
91
|
+
if (inputValue) {
|
|
92
|
+
addEmails(inputValue);
|
|
93
|
+
} else {
|
|
94
|
+
onBlur?.();
|
|
95
|
+
}
|
|
96
|
+
setIsFocused(false);
|
|
97
|
+
setDuplicateEmails([]);
|
|
98
|
+
}, [inputValue, addEmails, onBlur]);
|
|
99
|
+
const handleFocus = useCallback(() => setIsFocused(true), []);
|
|
100
|
+
const handleChipRemove = useCallback(
|
|
101
|
+
(emailValue) => onChange?.(value.filter((e) => e.value !== emailValue)),
|
|
102
|
+
[value, onChange]
|
|
103
|
+
);
|
|
104
|
+
const handleFilterInvalidEmails = useCallback(
|
|
105
|
+
() => onChange?.(filterValidEmails(value)),
|
|
106
|
+
[value, onChange]
|
|
107
|
+
);
|
|
108
|
+
const validCount = useMemo(() => value.filter((e) => e.valid).length, [value]);
|
|
109
|
+
const isCounterVisible = !!counter && (typeof counter === "boolean" || !counter.startsFrom || validCount >= counter.startsFrom);
|
|
110
|
+
const shouldCollapse = !isAlwaysExpanded && !isFocused && value.length > visibleEmailsCount;
|
|
111
|
+
const visibleEmails = shouldCollapse ? value.slice(0, visibleEmailsCount) : value;
|
|
112
|
+
const hiddenCount = shouldCollapse ? value.length - visibleEmailsCount : 0;
|
|
113
|
+
const isFilterLinkVisible = !!filterInvalidEmails && value.length > validCount;
|
|
114
|
+
return {
|
|
115
|
+
inputValue,
|
|
116
|
+
setInputValue,
|
|
117
|
+
isFocused,
|
|
118
|
+
duplicateEmails,
|
|
119
|
+
handleKeyDown,
|
|
120
|
+
handlePaste,
|
|
121
|
+
handleBlur,
|
|
122
|
+
handleFocus,
|
|
123
|
+
handleChipRemove,
|
|
124
|
+
handleFilterInvalidEmails,
|
|
125
|
+
isCounterVisible,
|
|
126
|
+
validCount,
|
|
127
|
+
visibleEmails,
|
|
128
|
+
hiddenCount,
|
|
129
|
+
isFilterLinkVisible
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
const CHIP_BASE = "flex h-[calc(--spacing(5.25))] w-fit items-center justify-center gap-1 rounded-sm bg-muted px-1.5 text-xs font-medium whitespace-nowrap text-foreground";
|
|
134
|
+
const CHIP_INVALID = "border border-destructive text-destructive bg-destructive/10";
|
|
135
|
+
const CHIPS_CONTAINER = "flex min-h-8 flex-wrap items-center gap-1 rounded-lg border border-input bg-transparent bg-clip-padding px-2.5 py-1 text-sm transition-colors focus-within:border-ring focus-within:ring-3 focus-within:ring-ring/50";
|
|
136
|
+
const CHIPS_ERROR = "border-destructive ring-3 ring-destructive/20 dark:border-destructive/50 dark:ring-destructive/40";
|
|
137
|
+
const MultiEmailInput = forwardRef((props, ref) => {
|
|
138
|
+
const {
|
|
139
|
+
label,
|
|
140
|
+
placeholder = "",
|
|
141
|
+
helpText,
|
|
142
|
+
error,
|
|
143
|
+
disabled = false,
|
|
144
|
+
required = false,
|
|
145
|
+
maxHeight = 200,
|
|
146
|
+
counter,
|
|
147
|
+
filterInvalidEmails,
|
|
148
|
+
prefix,
|
|
149
|
+
suffix,
|
|
150
|
+
labelProps,
|
|
151
|
+
className
|
|
152
|
+
} = props;
|
|
153
|
+
const id = useId();
|
|
154
|
+
const {
|
|
155
|
+
isCounterVisible,
|
|
156
|
+
validCount,
|
|
157
|
+
visibleEmails,
|
|
158
|
+
hiddenCount,
|
|
159
|
+
inputValue,
|
|
160
|
+
setInputValue,
|
|
161
|
+
handleKeyDown,
|
|
162
|
+
handlePaste,
|
|
163
|
+
handleFocus,
|
|
164
|
+
handleBlur,
|
|
165
|
+
handleChipRemove,
|
|
166
|
+
isFilterLinkVisible,
|
|
167
|
+
handleFilterInvalidEmails,
|
|
168
|
+
duplicateEmails
|
|
169
|
+
} = useMultiEmailState(props);
|
|
170
|
+
return /* @__PURE__ */ jsxs(Field, { className: cn("flex flex-col gap-1.5", className), children: [
|
|
171
|
+
(label || isCounterVisible) && /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
|
|
172
|
+
label && /* @__PURE__ */ jsxs(FieldLabel, { htmlFor: id, ...labelProps, children: [
|
|
173
|
+
label,
|
|
174
|
+
required && /* @__PURE__ */ jsx("span", { "aria-hidden": "true", className: "text-destructive", children: " *" })
|
|
175
|
+
] }),
|
|
176
|
+
isCounterVisible && /* @__PURE__ */ jsxs("span", { className: "text-xs text-muted-foreground", children: [
|
|
177
|
+
validCount,
|
|
178
|
+
" ",
|
|
179
|
+
typeof counter === "object" && counter?.label ? counter.label : pluralizeEmail(validCount)
|
|
180
|
+
] })
|
|
181
|
+
] }),
|
|
182
|
+
/* @__PURE__ */ jsxs(
|
|
183
|
+
"div",
|
|
184
|
+
{
|
|
185
|
+
className: cn(
|
|
186
|
+
CHIPS_CONTAINER,
|
|
187
|
+
!!error && CHIPS_ERROR,
|
|
188
|
+
disabled && "pointer-events-none opacity-50"
|
|
189
|
+
),
|
|
190
|
+
style: { maxHeight: `${maxHeight}px`, overflowY: "auto" },
|
|
191
|
+
children: [
|
|
192
|
+
prefix && /* @__PURE__ */ jsx("div", { className: "shrink-0", children: prefix }),
|
|
193
|
+
visibleEmails.map((email) => /* @__PURE__ */ jsxs(
|
|
194
|
+
"span",
|
|
195
|
+
{
|
|
196
|
+
className: cn(CHIP_BASE, !email.valid && CHIP_INVALID),
|
|
197
|
+
children: [
|
|
198
|
+
email.label,
|
|
199
|
+
!disabled && /* @__PURE__ */ jsx(
|
|
200
|
+
"button",
|
|
201
|
+
{
|
|
202
|
+
type: "button",
|
|
203
|
+
tabIndex: -1,
|
|
204
|
+
className: "-ms-0.5 rounded-xs opacity-50 hover:opacity-100",
|
|
205
|
+
onMouseDown: (e) => e.preventDefault(),
|
|
206
|
+
onClick: () => handleChipRemove(email.value),
|
|
207
|
+
"aria-label": `Remove ${email.label}`,
|
|
208
|
+
children: /* @__PURE__ */ jsx(X, { className: "size-3 pointer-events-none" })
|
|
209
|
+
}
|
|
210
|
+
)
|
|
211
|
+
]
|
|
212
|
+
},
|
|
213
|
+
email.value
|
|
214
|
+
)),
|
|
215
|
+
hiddenCount > 0 && /* @__PURE__ */ jsxs("span", { className: "flex h-[calc(--spacing(5.25))] items-center rounded-sm bg-secondary px-1.5 text-xs font-medium text-secondary-foreground", children: [
|
|
216
|
+
"+",
|
|
217
|
+
hiddenCount,
|
|
218
|
+
" more"
|
|
219
|
+
] }),
|
|
220
|
+
/* @__PURE__ */ jsx(
|
|
221
|
+
"input",
|
|
222
|
+
{
|
|
223
|
+
ref,
|
|
224
|
+
id,
|
|
225
|
+
type: "text",
|
|
226
|
+
value: inputValue,
|
|
227
|
+
onChange: (e) => setInputValue(e.target.value),
|
|
228
|
+
onKeyDown: handleKeyDown,
|
|
229
|
+
onPaste: handlePaste,
|
|
230
|
+
onFocus: handleFocus,
|
|
231
|
+
onBlur: handleBlur,
|
|
232
|
+
placeholder: props.value?.length ? "" : placeholder,
|
|
233
|
+
disabled,
|
|
234
|
+
className: "min-w-16 flex-1 bg-transparent text-sm outline-none placeholder:text-muted-foreground"
|
|
235
|
+
}
|
|
236
|
+
),
|
|
237
|
+
suffix && /* @__PURE__ */ jsx("div", { className: "shrink-0", children: suffix })
|
|
238
|
+
]
|
|
239
|
+
}
|
|
240
|
+
),
|
|
241
|
+
/* @__PURE__ */ jsxs(FieldContent, { children: [
|
|
242
|
+
!!error && /* @__PURE__ */ jsxs("p", { className: "text-[0.8rem] text-destructive", children: [
|
|
243
|
+
error,
|
|
244
|
+
isFilterLinkVisible && /* @__PURE__ */ jsx(
|
|
245
|
+
"button",
|
|
246
|
+
{
|
|
247
|
+
type: "button",
|
|
248
|
+
className: "ml-1 cursor-pointer font-semibold underline",
|
|
249
|
+
onClick: handleFilterInvalidEmails,
|
|
250
|
+
children: filterInvalidEmails?.label ?? "Click here to remove invalid emails."
|
|
251
|
+
}
|
|
252
|
+
)
|
|
253
|
+
] }),
|
|
254
|
+
!!helpText && /* @__PURE__ */ jsx("p", { className: "text-[0.8rem] text-muted-foreground", children: helpText }),
|
|
255
|
+
duplicateEmails.length > 0 && /* @__PURE__ */ jsx("p", { className: "text-[0.8rem] text-amber-600 dark:text-amber-400", children: formatDuplicateWarning(duplicateEmails) })
|
|
256
|
+
] })
|
|
257
|
+
] });
|
|
258
|
+
});
|
|
259
|
+
MultiEmailInput.displayName = "MultiEmailInput";
|
|
260
|
+
|
|
261
|
+
export { MultiEmailInput as M };
|
|
262
|
+
//# sourceMappingURL=MultiEmailInput-L-QJg0hh.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultiEmailInput-L-QJg0hh.js","sources":["../src/components/MultiEmailInput/constants.ts","../src/components/MultiEmailInput/utils.ts","../src/components/MultiEmailInput/useMultiEmailState.ts","../src/components/MultiEmailInput/MultiEmailInput.tsx"],"sourcesContent":["export const EMAIL_REGEX = /^[A-Z0-9._%+-]+@[A-Z0-9-]+(?:\\.[A-Z0-9-]+)*\\.[A-Z]{2,}$/i;\n\nexport const UNSTRICT_EMAIL_REGEX =\n /(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))/g;\n\nexport const EMAIL_SEPARATION_REGEX = /[^\\s,]+/g;\n","import { EMAIL_REGEX } from \"./constants\";\nimport type { EmailValue } from \"./types\";\n\nexport const formatEmailInputOption = (email: string): EmailValue => ({\n label: email,\n value: email,\n valid: EMAIL_REGEX.test(email),\n});\n\nexport const pruneDuplicates = (\n existing: EmailValue[],\n newEmailStrings: string[]\n): { uniqueEmails: EmailValue[]; duplicates: string[] } => {\n const seen = new Set(existing.map(e => e.value.toLowerCase()));\n const duplicates: string[] = [];\n const added: EmailValue[] = [];\n\n for (const emailStr of newEmailStrings) {\n const lower = emailStr.toLowerCase();\n if (seen.has(lower)) {\n duplicates.push(emailStr);\n } else {\n seen.add(lower);\n added.push(formatEmailInputOption(emailStr));\n }\n }\n\n return { uniqueEmails: [...existing, ...added], duplicates };\n};\n\nexport const filterValidEmails = (emails: EmailValue[]): EmailValue[] =>\n emails.filter(email => email.valid);\n\nexport const pluralizeEmail = (count: number): string =>\n count === 1 ? \"email\" : \"emails\";\n\nexport const formatDuplicateWarning = (duplicates: string[]): string => {\n const count = duplicates.length;\n\n return `Removed ${count} duplicate ${pluralizeEmail(count)} from the list: ${duplicates.join(\", \")}`;\n};\n","import { useState, useCallback, useMemo } from \"react\";\n\nimport { UNSTRICT_EMAIL_REGEX, EMAIL_SEPARATION_REGEX } from \"./constants\";\nimport { pruneDuplicates, filterValidEmails } from \"./utils\";\nimport type { MultiEmailInputProps } from \"./types\";\n\nexport function useMultiEmailState(props: MultiEmailInputProps) {\n const {\n value = [],\n onChange,\n onBlur,\n visibleEmailsCount = 3,\n isAlwaysExpanded = false,\n counter,\n filterInvalidEmails,\n } = props;\n\n const [inputValue, setInputValue] = useState(\"\");\n const [isFocused, setIsFocused] = useState(false);\n const [duplicateEmails, setDuplicateEmails] = useState<string[]>([]);\n\n const addEmails = useCallback(\n (input: string) => {\n const trimmed = input.trim();\n if (!trimmed) return;\n UNSTRICT_EMAIL_REGEX.lastIndex = 0;\n EMAIL_SEPARATION_REGEX.lastIndex = 0;\n const emailMatches =\n trimmed.match(UNSTRICT_EMAIL_REGEX) ||\n trimmed.match(EMAIL_SEPARATION_REGEX) ||\n [];\n if (emailMatches.length === 0) return;\n const { uniqueEmails, duplicates } = pruneDuplicates(value, emailMatches);\n onChange?.(uniqueEmails);\n setDuplicateEmails(duplicates);\n setInputValue(\"\");\n },\n [value, onChange]\n );\n\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (!inputValue && event.key === \"Backspace\" && value.length > 0) {\n onChange?.(value.slice(0, -1));\n return;\n }\n if (!inputValue) return;\n if ([\"Enter\", \"Tab\", \",\", \" \"].includes(event.key)) {\n addEmails(inputValue);\n event.preventDefault();\n event.stopPropagation();\n }\n },\n [inputValue, value, onChange, addEmails]\n );\n\n const handlePaste = useCallback(\n (event: React.ClipboardEvent<HTMLInputElement>) => {\n const text = event.clipboardData.getData(\"text\");\n if (!text) return;\n event.preventDefault();\n addEmails(text);\n },\n [addEmails]\n );\n\n const handleBlur = useCallback(() => {\n if (inputValue) {\n addEmails(inputValue);\n } else {\n onBlur?.();\n }\n setIsFocused(false);\n setDuplicateEmails([]);\n }, [inputValue, addEmails, onBlur]);\n\n const handleFocus = useCallback(() => setIsFocused(true), []);\n\n const handleChipRemove = useCallback(\n (emailValue: string) =>\n onChange?.(value.filter(e => e.value !== emailValue)),\n [value, onChange]\n );\n\n const handleFilterInvalidEmails = useCallback(\n () => onChange?.(filterValidEmails(value)),\n [value, onChange]\n );\n\n const validCount = useMemo(() => value.filter(e => e.valid).length, [value]);\n const isCounterVisible =\n !!counter &&\n (typeof counter === \"boolean\" ||\n !counter.startsFrom ||\n validCount >= counter.startsFrom);\n const shouldCollapse =\n !isAlwaysExpanded && !isFocused && value.length > visibleEmailsCount;\n const visibleEmails = shouldCollapse\n ? value.slice(0, visibleEmailsCount)\n : value;\n const hiddenCount = shouldCollapse ? value.length - visibleEmailsCount : 0;\n const isFilterLinkVisible =\n !!filterInvalidEmails && value.length > validCount;\n\n return {\n inputValue,\n setInputValue,\n isFocused,\n duplicateEmails,\n handleKeyDown,\n handlePaste,\n handleBlur,\n handleFocus,\n handleChipRemove,\n handleFilterInvalidEmails,\n isCounterVisible,\n validCount,\n visibleEmails,\n hiddenCount,\n isFilterLinkVisible,\n };\n}\n","import { forwardRef, useId } from \"react\";\nimport { XIcon } from \"lucide-react\";\n\nimport { cn } from \"src/shadcn/lib/utils\";\nimport { Field, FieldLabel, FieldContent } from \"src/primitives/Field\";\nimport { useMultiEmailState } from \"./useMultiEmailState\";\nimport { pluralizeEmail, formatDuplicateWarning } from \"./utils\";\nimport type { MultiEmailInputProps } from \"./types\";\n\nconst CHIP_BASE =\n \"flex h-[calc(--spacing(5.25))] w-fit items-center justify-center gap-1 rounded-sm bg-muted px-1.5 text-xs font-medium whitespace-nowrap text-foreground\";\nconst CHIP_INVALID =\n \"border border-destructive text-destructive bg-destructive/10\";\nconst CHIPS_CONTAINER =\n \"flex min-h-8 flex-wrap items-center gap-1 rounded-lg border border-input bg-transparent bg-clip-padding px-2.5 py-1 text-sm transition-colors focus-within:border-ring focus-within:ring-3 focus-within:ring-ring/50\";\nconst CHIPS_ERROR =\n \"border-destructive ring-3 ring-destructive/20 dark:border-destructive/50 dark:ring-destructive/40\";\n\nexport const MultiEmailInput = forwardRef<\n HTMLInputElement,\n MultiEmailInputProps\n>((props, ref) => {\n const {\n label,\n placeholder = \"\",\n helpText,\n error,\n disabled = false,\n required = false,\n maxHeight = 200,\n counter,\n filterInvalidEmails,\n prefix,\n suffix,\n labelProps,\n className,\n } = props;\n const id = useId();\n const {\n isCounterVisible,\n validCount,\n visibleEmails,\n hiddenCount,\n inputValue,\n setInputValue,\n handleKeyDown,\n handlePaste,\n handleFocus,\n handleBlur,\n handleChipRemove,\n isFilterLinkVisible,\n handleFilterInvalidEmails,\n duplicateEmails,\n } = useMultiEmailState(props);\n\n return (\n <Field className={cn(\"flex flex-col gap-1.5\", className)}>\n {(label || isCounterVisible) && (\n <div className=\"flex items-center justify-between\">\n {label && (\n <FieldLabel htmlFor={id} {...labelProps}>\n {label}\n {required && (\n <span aria-hidden=\"true\" className=\"text-destructive\">\n {\" *\"}\n </span>\n )}\n </FieldLabel>\n )}\n {isCounterVisible && (\n <span className=\"text-xs text-muted-foreground\">\n {validCount}{\" \"}\n {typeof counter === \"object\" && counter?.label\n ? counter.label\n : pluralizeEmail(validCount)}\n </span>\n )}\n </div>\n )}\n <div\n className={cn(\n CHIPS_CONTAINER,\n !!error && CHIPS_ERROR,\n disabled && \"pointer-events-none opacity-50\"\n )}\n style={{ maxHeight: `${maxHeight}px`, overflowY: \"auto\" }}\n >\n {prefix && <div className=\"shrink-0\">{prefix}</div>}\n {visibleEmails.map(email => (\n <span\n key={email.value}\n className={cn(CHIP_BASE, !email.valid && CHIP_INVALID)}\n >\n {email.label}\n {!disabled && (\n <button\n type=\"button\"\n tabIndex={-1}\n className=\"-ms-0.5 rounded-xs opacity-50 hover:opacity-100\"\n onMouseDown={e => e.preventDefault()}\n onClick={() => handleChipRemove(email.value)}\n aria-label={`Remove ${email.label}`}\n >\n <XIcon className=\"size-3 pointer-events-none\" />\n </button>\n )}\n </span>\n ))}\n {hiddenCount > 0 && (\n <span className=\"flex h-[calc(--spacing(5.25))] items-center rounded-sm bg-secondary px-1.5 text-xs font-medium text-secondary-foreground\">\n +{hiddenCount} more\n </span>\n )}\n <input\n ref={ref}\n id={id}\n type=\"text\"\n value={inputValue}\n onChange={e => setInputValue(e.target.value)}\n onKeyDown={handleKeyDown}\n onPaste={handlePaste}\n onFocus={handleFocus}\n onBlur={handleBlur}\n placeholder={props.value?.length ? \"\" : placeholder}\n disabled={disabled}\n className=\"min-w-16 flex-1 bg-transparent text-sm outline-none placeholder:text-muted-foreground\"\n />\n {suffix && <div className=\"shrink-0\">{suffix}</div>}\n </div>\n <FieldContent>\n {!!error && (\n <p className=\"text-[0.8rem] text-destructive\">\n {error}\n {isFilterLinkVisible && (\n <button\n type=\"button\"\n className=\"ml-1 cursor-pointer font-semibold underline\"\n onClick={handleFilterInvalidEmails}\n >\n {filterInvalidEmails?.label ??\n \"Click here to remove invalid emails.\"}\n </button>\n )}\n </p>\n )}\n {!!helpText && (\n <p className=\"text-[0.8rem] text-muted-foreground\">{helpText}</p>\n )}\n {duplicateEmails.length > 0 && (\n <p className=\"text-[0.8rem] text-amber-600 dark:text-amber-400\">\n {formatDuplicateWarning(duplicateEmails)}\n </p>\n )}\n </FieldContent>\n </Field>\n );\n});\nMultiEmailInput.displayName = \"MultiEmailInput\";\n"],"names":["XIcon"],"mappings":"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"}
|