@fuf-stack/uniform 1.11.1 → 1.11.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Checkboxes/index.cjs +1 -1
- package/dist/Checkboxes/index.d.cts +1 -1
- package/dist/Checkboxes/index.d.ts +1 -1
- package/dist/Checkboxes/index.js +1 -1
- package/dist/{Checkboxes-CGWhnpBp.js → Checkboxes-BvW4D5Nm.js} +6 -6
- package/dist/Checkboxes-BvW4D5Nm.js.map +1 -0
- package/dist/{Checkboxes-Ds6bzl6p.cjs → Checkboxes-Cvdazf25.cjs} +18 -18
- package/dist/Checkboxes-Cvdazf25.cjs.map +1 -0
- package/dist/FieldArray/index.cjs +1 -1
- package/dist/FieldArray/index.d.cts +1 -1
- package/dist/FieldArray/index.d.ts +1 -1
- package/dist/FieldArray/index.js +1 -1
- package/dist/{FieldArray-BexXN9bO.cjs → FieldArray-CJpDgK_t.cjs} +49 -49
- package/dist/FieldArray-CJpDgK_t.cjs.map +1 -0
- package/dist/{FieldArray-D3iUaRLo.js → FieldArray-omRNwxgy.js} +9 -9
- package/dist/FieldArray-omRNwxgy.js.map +1 -0
- package/dist/FieldCard/index.cjs +1 -1
- package/dist/FieldCard/index.d.cts +1 -1
- package/dist/FieldCard/index.d.ts +1 -1
- package/dist/FieldCard/index.js +1 -1
- package/dist/{FieldCard-pP7aniZU.cjs → FieldCard-Dt6QU7o7.cjs} +13 -13
- package/dist/{FieldCard-pP7aniZU.cjs.map → FieldCard-Dt6QU7o7.cjs.map} +1 -1
- package/dist/{FieldCard-mpmErfDK.js → FieldCard-Dyi-2qr6.js} +3 -3
- package/dist/{FieldCard-mpmErfDK.js.map → FieldCard-Dyi-2qr6.js.map} +1 -1
- package/dist/{FieldCopyTestIdButton-AaLwu_8y.cjs → FieldCopyTestIdButton-By-hEZgA.cjs} +10 -10
- package/dist/{FieldCopyTestIdButton-AaLwu_8y.cjs.map → FieldCopyTestIdButton-By-hEZgA.cjs.map} +1 -1
- package/dist/{FieldCopyTestIdButton-Cx8AXJhO.js → FieldCopyTestIdButton-D9f1B-VS.js} +4 -4
- package/dist/{FieldCopyTestIdButton-Cx8AXJhO.js.map → FieldCopyTestIdButton-D9f1B-VS.js.map} +1 -1
- package/dist/{FieldValidationError-D86DPSOH.js → FieldValidationError-BYwitb_B.js} +4 -4
- package/dist/{FieldValidationError-D86DPSOH.js.map → FieldValidationError-BYwitb_B.js.map} +1 -1
- package/dist/{FieldValidationError-Cq6aI0tE.cjs → FieldValidationError-D64j5gnH.cjs} +13 -13
- package/dist/{FieldValidationError-Cq6aI0tE.cjs.map → FieldValidationError-D64j5gnH.cjs.map} +1 -1
- package/dist/Form/index.cjs +1 -1
- package/dist/Form/index.d.cts +1 -1
- package/dist/Form/index.d.ts +1 -1
- package/dist/Form/index.js +1 -1
- package/dist/{Form-CFmCTl60.js → Form-B1fvbnxi.js} +6 -6
- package/dist/{Form-CFmCTl60.js.map → Form-B1fvbnxi.js.map} +1 -1
- package/dist/{Form-FvN3SXfF.cjs → Form-CvnnGF45.cjs} +19 -19
- package/dist/{Form-FvN3SXfF.cjs.map → Form-CvnnGF45.cjs.map} +1 -1
- package/dist/{FormContext-CN9n_KdE.js → FormContext-Dl3k1r_k.js} +2 -2
- package/dist/FormContext-Dl3k1r_k.js.map +1 -0
- package/dist/{FormContext-C3GymQOA.cjs → FormContext-Lw4YL4-B.cjs} +8 -8
- package/dist/FormContext-Lw4YL4-B.cjs.map +1 -0
- package/dist/Grid/index.cjs +1 -1
- package/dist/Grid/index.d.cts +1 -1
- package/dist/Grid/index.d.ts +1 -1
- package/dist/Grid/index.js +1 -1
- package/dist/{Grid-DG60vYYG.cjs → Grid-DezBAZbx.cjs} +8 -8
- package/dist/{Grid-DG60vYYG.cjs.map → Grid-DezBAZbx.cjs.map} +1 -1
- package/dist/{Grid-DEH7Sezi.js → Grid-LRjQlZms.js} +4 -4
- package/dist/{Grid-DEH7Sezi.js.map → Grid-LRjQlZms.js.map} +1 -1
- package/dist/Input/index.cjs +1 -1
- package/dist/Input/index.d.cts +1 -1
- package/dist/Input/index.d.ts +1 -1
- package/dist/Input/index.js +1 -1
- package/dist/{Input-DKfFFOpo.cjs → Input-DR0gCf9q.cjs} +16 -15
- package/dist/Input-DR0gCf9q.cjs.map +1 -0
- package/dist/{Input--h5t7Sbl.js → Input-DksaHK1Y.js} +7 -6
- package/dist/Input-DksaHK1Y.js.map +1 -0
- package/dist/RadioBoxes/index.cjs +1 -1
- package/dist/RadioBoxes/index.d.cts +1 -1
- package/dist/RadioBoxes/index.d.ts +1 -1
- package/dist/RadioBoxes/index.js +1 -1
- package/dist/{RadioBoxes-7qdHj3ti.js → RadioBoxes-DdIHH6B5.js} +5 -5
- package/dist/RadioBoxes-DdIHH6B5.js.map +1 -0
- package/dist/{RadioBoxes-Bd9ahl4i.cjs → RadioBoxes-h-VLhJ9d.cjs} +22 -22
- package/dist/RadioBoxes-h-VLhJ9d.cjs.map +1 -0
- package/dist/RadioTabs/index.cjs +1 -1
- package/dist/RadioTabs/index.d.cts +1 -1
- package/dist/RadioTabs/index.d.ts +1 -1
- package/dist/RadioTabs/index.js +1 -1
- package/dist/{RadioTabs-DcEUdW7r.cjs → RadioTabs-D6yF9jE3.cjs} +18 -18
- package/dist/RadioTabs-D6yF9jE3.cjs.map +1 -0
- package/dist/{RadioTabs-DXs98jng.js → RadioTabs-dLdlF91p.js} +5 -5
- package/dist/RadioTabs-dLdlF91p.js.map +1 -0
- package/dist/Radios/index.cjs +1 -1
- package/dist/Radios/index.d.cts +1 -1
- package/dist/Radios/index.d.ts +1 -1
- package/dist/Radios/index.js +1 -1
- package/dist/{Radios-CIPNqPzi.cjs → Radios-D8alyG2f.cjs} +14 -14
- package/dist/{Radios-CIPNqPzi.cjs.map → Radios-D8alyG2f.cjs.map} +1 -1
- package/dist/{Radios-BIx06mzU.js → Radios-DiZ0Dfmp.js} +5 -5
- package/dist/{Radios-BIx06mzU.js.map → Radios-DiZ0Dfmp.js.map} +1 -1
- package/dist/Select/index.cjs +1 -1
- package/dist/Select/index.d.cts +1 -1
- package/dist/Select/index.d.ts +1 -1
- package/dist/Select/index.js +1 -1
- package/dist/{Select-CBjqYDcs.js → Select-C9otN8uu.js} +6 -6
- package/dist/Select-C9otN8uu.js.map +1 -0
- package/dist/{Select-BsL7qn2v.cjs → Select-DQVskslz.cjs} +19 -19
- package/dist/Select-DQVskslz.cjs.map +1 -0
- package/dist/Slider/index.cjs +1 -1
- package/dist/Slider/index.d.cts +1 -1
- package/dist/Slider/index.d.ts +1 -1
- package/dist/Slider/index.js +1 -1
- package/dist/{Slider-BDLbD7d5.cjs → Slider-DwfyCQDM.cjs} +15 -15
- package/dist/{Slider-BDLbD7d5.cjs.map → Slider-DwfyCQDM.cjs.map} +1 -1
- package/dist/{Slider-BHjHSoIk.js → Slider-meuLEC2k.js} +5 -5
- package/dist/{Slider-BHjHSoIk.js.map → Slider-meuLEC2k.js.map} +1 -1
- package/dist/SubmitButton/index.cjs +1 -1
- package/dist/SubmitButton/index.d.cts +1 -1
- package/dist/SubmitButton/index.d.ts +1 -1
- package/dist/SubmitButton/index.js +1 -1
- package/dist/{SubmitButton-DhtPJuro.cjs → SubmitButton-B0kvUqkd.cjs} +12 -12
- package/dist/{SubmitButton-DhtPJuro.cjs.map → SubmitButton-B0kvUqkd.cjs.map} +1 -1
- package/dist/{SubmitButton-7iOaKzhB.js → SubmitButton-BHP9J9ml.js} +5 -5
- package/dist/{SubmitButton-7iOaKzhB.js.map → SubmitButton-BHP9J9ml.js.map} +1 -1
- package/dist/Switch/index.cjs +1 -1
- package/dist/Switch/index.d.cts +1 -1
- package/dist/Switch/index.d.ts +1 -1
- package/dist/Switch/index.js +1 -1
- package/dist/{Switch-DCxAgt_L.js → Switch-DkciIYnD.js} +5 -5
- package/dist/{Switch-DCxAgt_L.js.map → Switch-DkciIYnD.js.map} +1 -1
- package/dist/{Switch-Dczzog3v.cjs → Switch-Ds0gDzjR.cjs} +15 -15
- package/dist/{Switch-Dczzog3v.cjs.map → Switch-Ds0gDzjR.cjs.map} +1 -1
- package/dist/SwitchBox/index.cjs +1 -1
- package/dist/SwitchBox/index.d.cts +1 -1
- package/dist/SwitchBox/index.d.ts +1 -1
- package/dist/SwitchBox/index.js +1 -1
- package/dist/{SwitchBox-DPHryDOM.js → SwitchBox-B6Z4rtWt.js} +5 -5
- package/dist/{SwitchBox-DPHryDOM.js.map → SwitchBox-B6Z4rtWt.js.map} +1 -1
- package/dist/{SwitchBox-DqVmZYId.cjs → SwitchBox-B9JqwDtN.cjs} +19 -19
- package/dist/{SwitchBox-DqVmZYId.cjs.map → SwitchBox-B9JqwDtN.cjs.map} +1 -1
- package/dist/TextArea/index.cjs +1 -1
- package/dist/TextArea/index.d.cts +1 -1
- package/dist/TextArea/index.d.ts +1 -1
- package/dist/TextArea/index.js +1 -1
- package/dist/{TextArea-CH-F6_ax.cjs → TextArea-BqQtlPSV.cjs} +14 -13
- package/dist/{TextArea-CH-F6_ax.cjs.map → TextArea-BqQtlPSV.cjs.map} +1 -1
- package/dist/{TextArea-BR6e-Fio.js → TextArea-DAx49KI6.js} +7 -6
- package/dist/{TextArea-BR6e-Fio.js.map → TextArea-DAx49KI6.js.map} +1 -1
- package/dist/helpers/index.cjs +2 -1
- package/dist/helpers/index.d.cts +164 -2
- package/dist/helpers/index.d.cts.map +1 -0
- package/dist/helpers/index.d.ts +164 -2
- package/dist/helpers/index.d.ts.map +1 -0
- package/dist/helpers/index.js +2 -2
- package/dist/{helpers-B-CJOBt3.js → helpers-CCINRgQk.js} +43 -2
- package/dist/helpers-CCINRgQk.js.map +1 -0
- package/dist/{helpers-KTgXi0lA.cjs → helpers-nYTmL2gX.cjs} +51 -4
- package/dist/helpers-nYTmL2gX.cjs.map +1 -0
- package/dist/hooks/useClientValidation/index.cjs +1 -1
- package/dist/hooks/useClientValidation/index.d.cts +1 -1
- package/dist/hooks/useClientValidation/index.d.ts +1 -1
- package/dist/hooks/useClientValidation/index.js +1 -1
- package/dist/hooks/useController/index.cjs +1 -1
- package/dist/hooks/useController/index.d.cts +1 -1
- package/dist/hooks/useController/index.d.ts +2 -2
- package/dist/hooks/useController/index.js +1 -1
- package/dist/hooks/useFormContext/index.cjs +1 -1
- package/dist/hooks/useFormContext/index.d.cts +1 -1
- package/dist/hooks/useFormContext/index.d.ts +2 -2
- package/dist/hooks/useFormContext/index.js +1 -1
- package/dist/hooks/useInput/index.cjs +3 -3
- package/dist/hooks/useInput/index.d.cts +1 -1
- package/dist/hooks/useInput/index.d.ts +1 -1
- package/dist/hooks/useInputValueDebounce/index.cjs +1 -1
- package/dist/hooks/useInputValueDebounce/index.d.cts +1 -1
- package/dist/hooks/useInputValueDebounce/index.d.ts +1 -1
- package/dist/hooks/useInputValueDebounce/index.js +1 -1
- package/dist/hooks/useInputValueTransform/index.cjs +1 -1
- package/dist/hooks/useInputValueTransform/index.d.cts +1 -1
- package/dist/hooks/useInputValueTransform/index.d.ts +1 -1
- package/dist/hooks/useInputValueTransform/index.js +1 -1
- package/dist/hooks/useUniformField/index.cjs +1 -1
- package/dist/hooks/useUniformField/index.d.cts +1 -1
- package/dist/hooks/useUniformField/index.d.ts +4 -4
- package/dist/hooks/useUniformField/index.js +1 -1
- package/dist/hooks/useUniformFieldArray/index.cjs +1 -1
- package/dist/hooks/useUniformFieldArray/index.d.cts +1 -1
- package/dist/hooks/useUniformFieldArray/index.d.ts +5 -5
- package/dist/hooks/useUniformFieldArray/index.js +1 -1
- package/dist/hooks/useWatchUserChange/index.cjs +1 -1
- package/dist/hooks/useWatchUserChange/index.d.cts +1 -1
- package/dist/hooks/useWatchUserChange/index.d.ts +1 -1
- package/dist/hooks/useWatchUserChange/index.js +1 -1
- package/dist/{index-BJ7tmJCw.d.cts → index-0wXxS5M7.d.ts} +6 -6
- package/dist/{index-DJFrZluU.d.ts.map → index-0wXxS5M7.d.ts.map} +1 -1
- package/dist/{index-ATMELmS_.d.ts → index-1Egh73pR.d.ts} +3 -3
- package/dist/{index-ATMELmS_.d.ts.map → index-1Egh73pR.d.ts.map} +1 -1
- package/dist/{index-BO2gua86.d.ts → index-3v_vja2i.d.ts} +6 -6
- package/dist/{index-BO2gua86.d.ts.map → index-3v_vja2i.d.ts.map} +1 -1
- package/dist/{index-DG83pAQU.d.cts → index-7mx-IcDp.d.ts} +1 -1
- package/dist/{index-cvKMShf8.d.ts.map → index-7mx-IcDp.d.ts.map} +1 -1
- package/dist/{index-DJFrZluU.d.ts → index-BDV3JVoX.d.cts} +7 -7
- package/dist/{index-BJ7tmJCw.d.cts.map → index-BDV3JVoX.d.cts.map} +1 -1
- package/dist/{index-BSJlD_z1.d.ts → index-BFLKkqA3.d.ts} +3 -3
- package/dist/{index-BSJlD_z1.d.ts.map → index-BFLKkqA3.d.ts.map} +1 -1
- package/dist/{index-DrAaB1si.d.cts → index-BGXgvZKr.d.ts} +36 -35
- package/dist/{index-BMSwSLB0.d.ts.map → index-BGXgvZKr.d.ts.map} +1 -1
- package/dist/{index-Ce5d5ud1.d.ts → index-BSjUaHEO.d.cts} +4 -4
- package/dist/{index-CuZ0szCF.d.cts.map → index-BSjUaHEO.d.cts.map} +1 -1
- package/dist/{index-BFMNC6rA.d.cts → index-B_aIzCcx.d.cts} +3 -3
- package/dist/{index-BFMNC6rA.d.cts.map → index-B_aIzCcx.d.cts.map} +1 -1
- package/dist/{index-CuZ0szCF.d.cts → index-Bcppi5O7.d.ts} +4 -4
- package/dist/{index-Ce5d5ud1.d.ts.map → index-Bcppi5O7.d.ts.map} +1 -1
- package/dist/{index-C1GCfD5q.d.cts → index-C2A_i57R.d.cts} +21 -21
- package/dist/index-C2A_i57R.d.cts.map +1 -0
- package/dist/{index-DHTrsq8u.d.cts → index-CHNp5R5N.d.cts} +6 -6
- package/dist/{index-DHTrsq8u.d.cts.map → index-CHNp5R5N.d.cts.map} +1 -1
- package/dist/{index-Cb0AgRRa.d.cts → index-CHXv_rNR.d.ts} +3 -3
- package/dist/{index-CQXf1sXV.d.ts.map → index-CHXv_rNR.d.ts.map} +1 -1
- package/dist/{index-t8GMrjmp.d.cts → index-CTp4vdDb.d.ts} +6 -6
- package/dist/{index-B5K7Sos4.d.ts.map → index-CTp4vdDb.d.ts.map} +1 -1
- package/dist/{index-0l1ioOFh.d.cts → index-CUn9q5KD.d.ts} +6 -6
- package/dist/{index-BDBmlcs9.d.ts.map → index-CUn9q5KD.d.ts.map} +1 -1
- package/dist/{index-CpPCHyTk.d.cts → index-CZyNkPDq.d.ts} +22 -22
- package/dist/index-CZyNkPDq.d.ts.map +1 -0
- package/dist/{index-CqIAvXWT.d.ts → index-CeYRsehb.d.cts} +22 -22
- package/dist/index-CeYRsehb.d.cts.map +1 -0
- package/dist/{index-B5K7Sos4.d.ts → index-CiF2KXB7.d.cts} +3 -3
- package/dist/{index-t8GMrjmp.d.cts.map → index-CiF2KXB7.d.cts.map} +1 -1
- package/dist/{index-BMSwSLB0.d.ts → index-CjJHVJwD.d.cts} +35 -36
- package/dist/{index-DrAaB1si.d.cts.map → index-CjJHVJwD.d.cts.map} +1 -1
- package/dist/{index-DUAqAErG.d.cts → index-CnsR8nkm.d.cts} +34 -34
- package/dist/{index-DUAqAErG.d.cts.map → index-CnsR8nkm.d.cts.map} +1 -1
- package/dist/{index-C32OyAvG.d.ts → index-CqGabrzW.d.cts} +37 -37
- package/dist/{index-BIt4xz_x.d.cts.map → index-CqGabrzW.d.cts.map} +1 -1
- package/dist/{index-cvKMShf8.d.ts → index-CuvvZMop.d.cts} +3 -3
- package/dist/{index-DG83pAQU.d.cts.map → index-CuvvZMop.d.cts.map} +1 -1
- package/dist/{index-BmW4khHl.d.cts → index-DNFUttM8.d.ts} +48 -48
- package/dist/index-DNFUttM8.d.ts.map +1 -0
- package/dist/{index-D6qgJDAm.d.ts → index-DVRtBywt.d.ts} +3 -3
- package/dist/{index-D6qgJDAm.d.ts.map → index-DVRtBywt.d.ts.map} +1 -1
- package/dist/{index-BDBmlcs9.d.ts → index-D_WidR7r.d.cts} +6 -6
- package/dist/{index-0l1ioOFh.d.cts.map → index-D_WidR7r.d.cts.map} +1 -1
- package/dist/index-D_egu-QT.d.cts +264 -0
- package/dist/{index-BNdmJR51.d.cts.map → index-D_egu-QT.d.cts.map} +1 -1
- package/dist/index-DajjPPWM.d.ts +264 -0
- package/dist/{index-Da-quK_d.d.ts.map → index-DajjPPWM.d.ts.map} +1 -1
- package/dist/{index-BLmXGxoy.d.ts → index-DcYFLiul.d.cts} +48 -48
- package/dist/index-DcYFLiul.d.cts.map +1 -0
- package/dist/{index-DiC-e6iW.d.ts → index-DnzC0GCS.d.ts} +4 -4
- package/dist/{index-DiC-e6iW.d.ts.map → index-DnzC0GCS.d.ts.map} +1 -1
- package/dist/{index-ByDAUZR8.d.cts → index-DvF_C1Bz.d.cts} +3 -3
- package/dist/{index-ByDAUZR8.d.cts.map → index-DvF_C1Bz.d.cts.map} +1 -1
- package/dist/{index-CQXf1sXV.d.ts → index-cadUZZIY.d.cts} +3 -3
- package/dist/{index-Cb0AgRRa.d.cts.map → index-cadUZZIY.d.cts.map} +1 -1
- package/dist/{index-cda9yEEN.d.cts → index-g9TZhGnE.d.cts} +3 -3
- package/dist/{index-cda9yEEN.d.cts.map → index-g9TZhGnE.d.cts.map} +1 -1
- package/dist/{index-BCXuFO6D.d.ts → index-op7zETAQ.d.ts} +34 -34
- package/dist/{index-BCXuFO6D.d.ts.map → index-op7zETAQ.d.ts.map} +1 -1
- package/dist/{index-BIt4xz_x.d.cts → index-yVkU2v6b.d.ts} +38 -38
- package/dist/index-yVkU2v6b.d.ts.map +1 -0
- package/dist/index.cjs +30 -29
- package/dist/index.d.cts +28 -28
- package/dist/index.d.ts +30 -30
- package/dist/index.js +27 -27
- package/dist/partials/FieldCopyTestIdButton/index.cjs +1 -1
- package/dist/partials/FieldCopyTestIdButton/index.d.cts +1 -1
- package/dist/partials/FieldCopyTestIdButton/index.d.ts +1 -1
- package/dist/partials/FieldCopyTestIdButton/index.js +1 -1
- package/dist/partials/FieldValidationError/index.cjs +1 -1
- package/dist/partials/FieldValidationError/index.d.cts +1 -1
- package/dist/partials/FieldValidationError/index.d.ts +1 -1
- package/dist/partials/FieldValidationError/index.js +1 -1
- package/dist/{useClientValidation-CbRkwhHc.d.ts → useClientValidation-Bg0q3Axc.d.ts} +3 -3
- package/dist/{useClientValidation-CbRkwhHc.d.ts.map → useClientValidation-Bg0q3Axc.d.ts.map} +1 -1
- package/dist/{useClientValidation-BnnscAEe.js → useClientValidation-BrTtRnqi.js} +3 -3
- package/dist/useClientValidation-BrTtRnqi.js.map +1 -0
- package/dist/{useClientValidation-DdRlhoG1.d.cts → useClientValidation-BvPDQmf6.d.cts} +3 -3
- package/dist/{useClientValidation-DdRlhoG1.d.cts.map → useClientValidation-BvPDQmf6.d.cts.map} +1 -1
- package/dist/{useClientValidation-oZd4_ocQ.cjs → useClientValidation-CdC7lEYP.cjs} +7 -7
- package/dist/useClientValidation-CdC7lEYP.cjs.map +1 -0
- package/dist/{useController-C_MZLZIp.d.cts → useController-BArZd2Vp.d.cts} +1 -1
- package/dist/{useController-C_MZLZIp.d.cts.map → useController-BArZd2Vp.d.cts.map} +1 -1
- package/dist/{useController-BzkCcbSo.cjs → useController-BBxji1nQ.cjs} +3 -3
- package/dist/{useController-BzkCcbSo.cjs.map → useController-BBxji1nQ.cjs.map} +1 -1
- package/dist/{useController-hjpJQf0w.d.ts → useController-MVHJ7WFp.d.ts} +1 -1
- package/dist/{useController-hjpJQf0w.d.ts.map → useController-MVHJ7WFp.d.ts.map} +1 -1
- package/dist/{useController-CumIERks.js → useController-g0AlWM__.js} +3 -3
- package/dist/{useController-CumIERks.js.map → useController-g0AlWM__.js.map} +1 -1
- package/dist/{useFormContext-CFwuH4nn.d.cts → useFormContext--yod5xzQ.d.cts} +3 -3
- package/dist/useFormContext--yod5xzQ.d.cts.map +1 -0
- package/dist/{useFormContext-JCm1UR_e.js → useFormContext-BFoXZNkp.js} +3 -3
- package/dist/useFormContext-BFoXZNkp.js.map +1 -0
- package/dist/{useFormContext-CWuN-_7P.cjs → useFormContext-CEr3zcL6.cjs} +3 -3
- package/dist/useFormContext-CEr3zcL6.cjs.map +1 -0
- package/dist/{useFormContext-3AAPT6eZ.d.ts → useFormContext-Cw6aAhos.d.ts} +3 -3
- package/dist/useFormContext-Cw6aAhos.d.ts.map +1 -0
- package/dist/{useInputValueDebounce-C7_bvNGH.d.ts → useInputValueDebounce-DI1C6oaU.d.cts} +5 -1
- package/dist/useInputValueDebounce-DI1C6oaU.d.cts.map +1 -0
- package/dist/{useInputValueDebounce-DaH5ONlQ.js → useInputValueDebounce-Dop_8_OK.js} +12 -3
- package/dist/useInputValueDebounce-Dop_8_OK.js.map +1 -0
- package/dist/{useInputValueDebounce-tL8maIp8.cjs → useInputValueDebounce-TiNR4jtG.cjs} +13 -4
- package/dist/useInputValueDebounce-TiNR4jtG.cjs.map +1 -0
- package/dist/{useInputValueDebounce-B2RzCWty.d.cts → useInputValueDebounce-fhmVn1aO.d.ts} +5 -1
- package/dist/useInputValueDebounce-fhmVn1aO.d.ts.map +1 -0
- package/dist/{useInputValueTransform-C-uSW8Y3.cjs → useInputValueTransform-BNmfaj5D.cjs} +4 -3
- package/dist/{useInputValueTransform-C-uSW8Y3.cjs.map → useInputValueTransform-BNmfaj5D.cjs.map} +1 -1
- package/dist/{useInputValueTransform-D7LfyYRe.d.ts → useInputValueTransform-BV8o0PMI.d.cts} +3 -2
- package/dist/useInputValueTransform-BV8o0PMI.d.cts.map +1 -0
- package/dist/{useInputValueTransform-aiIf8lq5.js → useInputValueTransform-CMNC21vX.js} +3 -2
- package/dist/{useInputValueTransform-aiIf8lq5.js.map → useInputValueTransform-CMNC21vX.js.map} +1 -1
- package/dist/{useInputValueTransform-BID-CQ-y.d.cts → useInputValueTransform-Cc0qEsnS.d.ts} +3 -2
- package/dist/useInputValueTransform-Cc0qEsnS.d.ts.map +1 -0
- package/dist/{useUniformField-u_7uBpco.d.cts → useUniformField-B2zQtEbr.d.cts} +5 -5
- package/dist/{useUniformField-u_7uBpco.d.cts.map → useUniformField-B2zQtEbr.d.cts.map} +1 -1
- package/dist/{useUniformField-ClprfrES.js → useUniformField-BKVVns0E.js} +34 -8
- package/dist/useUniformField-BKVVns0E.js.map +1 -0
- package/dist/{useUniformField-BMvnRC_r.cjs → useUniformField-D6fwSjrH.cjs} +41 -15
- package/dist/useUniformField-D6fwSjrH.cjs.map +1 -0
- package/dist/{useUniformField-DDHQ5B11.d.ts → useUniformField-RxZqXMuD.d.ts} +5 -5
- package/dist/{useUniformField-DDHQ5B11.d.ts.map → useUniformField-RxZqXMuD.d.ts.map} +1 -1
- package/dist/{useUniformFieldArray-BhPi3gPv.d.ts → useUniformFieldArray-B_c55CnX.d.ts} +3 -3
- package/dist/useUniformFieldArray-B_c55CnX.d.ts.map +1 -0
- package/dist/{useUniformFieldArray-C-0OXG3N.js → useUniformFieldArray-BwE634m6.js} +4 -4
- package/dist/useUniformFieldArray-BwE634m6.js.map +1 -0
- package/dist/{useUniformFieldArray-btjvJdZ6.cjs → useUniformFieldArray-Byfmzq97.cjs} +7 -7
- package/dist/useUniformFieldArray-Byfmzq97.cjs.map +1 -0
- package/dist/{useUniformFieldArray-D3lsJvhA.d.cts → useUniformFieldArray-WRuIMhw6.d.cts} +3 -3
- package/dist/useUniformFieldArray-WRuIMhw6.d.cts.map +1 -0
- package/dist/{useWatchUserChange-BAdiqg2q.d.ts → useWatchUserChange-Bf5JKDJJ.d.ts} +1 -1
- package/dist/{useWatchUserChange-BAdiqg2q.d.ts.map → useWatchUserChange-Bf5JKDJJ.d.ts.map} +1 -1
- package/dist/{useWatchUserChange-COVdHmki.d.cts → useWatchUserChange-Br4Q7syM.d.cts} +1 -1
- package/dist/{useWatchUserChange-COVdHmki.d.cts.map → useWatchUserChange-Br4Q7syM.d.cts.map} +1 -1
- package/dist/{useWatchUserChange-C5dr12By.cjs → useWatchUserChange-TMfaTCcp.cjs} +3 -3
- package/dist/{useWatchUserChange-C5dr12By.cjs.map → useWatchUserChange-TMfaTCcp.cjs.map} +1 -1
- package/dist/{useWatchUserChange-C1ezpj0t.js → useWatchUserChange-fZy6nGtD.js} +2 -2
- package/dist/{useWatchUserChange-C1ezpj0t.js.map → useWatchUserChange-fZy6nGtD.js.map} +1 -1
- package/package.json +10 -10
- package/dist/Checkboxes-CGWhnpBp.js.map +0 -1
- package/dist/Checkboxes-Ds6bzl6p.cjs.map +0 -1
- package/dist/FieldArray-BexXN9bO.cjs.map +0 -1
- package/dist/FieldArray-D3iUaRLo.js.map +0 -1
- package/dist/FormContext-C3GymQOA.cjs.map +0 -1
- package/dist/FormContext-CN9n_KdE.js.map +0 -1
- package/dist/Input--h5t7Sbl.js.map +0 -1
- package/dist/Input-DKfFFOpo.cjs.map +0 -1
- package/dist/RadioBoxes-7qdHj3ti.js.map +0 -1
- package/dist/RadioBoxes-Bd9ahl4i.cjs.map +0 -1
- package/dist/RadioTabs-DXs98jng.js.map +0 -1
- package/dist/RadioTabs-DcEUdW7r.cjs.map +0 -1
- package/dist/Select-BsL7qn2v.cjs.map +0 -1
- package/dist/Select-CBjqYDcs.js.map +0 -1
- package/dist/helpers-B-CJOBt3.js.map +0 -1
- package/dist/helpers-KTgXi0lA.cjs.map +0 -1
- package/dist/index-BLmXGxoy.d.ts.map +0 -1
- package/dist/index-BNdmJR51.d.cts +0 -264
- package/dist/index-BmW4khHl.d.cts.map +0 -1
- package/dist/index-C1GCfD5q.d.cts.map +0 -1
- package/dist/index-C32OyAvG.d.ts.map +0 -1
- package/dist/index-CpPCHyTk.d.cts.map +0 -1
- package/dist/index-CqIAvXWT.d.ts.map +0 -1
- package/dist/index-Da-quK_d.d.ts +0 -264
- package/dist/index-G0IgQWoU.d.cts +0 -134
- package/dist/index-G0IgQWoU.d.cts.map +0 -1
- package/dist/index-UjKqRe-8.d.ts +0 -134
- package/dist/index-UjKqRe-8.d.ts.map +0 -1
- package/dist/useClientValidation-BnnscAEe.js.map +0 -1
- package/dist/useClientValidation-oZd4_ocQ.cjs.map +0 -1
- package/dist/useFormContext-3AAPT6eZ.d.ts.map +0 -1
- package/dist/useFormContext-CFwuH4nn.d.cts.map +0 -1
- package/dist/useFormContext-CWuN-_7P.cjs.map +0 -1
- package/dist/useFormContext-JCm1UR_e.js.map +0 -1
- package/dist/useInputValueDebounce-B2RzCWty.d.cts.map +0 -1
- package/dist/useInputValueDebounce-C7_bvNGH.d.ts.map +0 -1
- package/dist/useInputValueDebounce-DaH5ONlQ.js.map +0 -1
- package/dist/useInputValueDebounce-tL8maIp8.cjs.map +0 -1
- package/dist/useInputValueTransform-BID-CQ-y.d.cts.map +0 -1
- package/dist/useInputValueTransform-D7LfyYRe.d.ts.map +0 -1
- package/dist/useUniformField-BMvnRC_r.cjs.map +0 -1
- package/dist/useUniformField-ClprfrES.js.map +0 -1
- package/dist/useUniformFieldArray-BhPi3gPv.d.ts.map +0 -1
- package/dist/useUniformFieldArray-C-0OXG3N.js.map +0 -1
- package/dist/useUniformFieldArray-D3lsJvhA.d.cts.map +0 -1
- package/dist/useUniformFieldArray-btjvJdZ6.cjs.map +0 -1
- /package/dist/{index-B3Z8gdjC.d.ts → index-BRLjimYW.d.ts} +0 -0
- /package/dist/{index-BXpMZvwA.d.cts → index-CFBmva_r.d.ts} +0 -0
- /package/dist/{index-CJNLQVjx.d.ts → index-DpEKQcoR.d.cts} +0 -0
- /package/dist/{index-CwSIy_W-.d.cts → index-lQ_hGQ08.d.cts} +0 -0
- /package/dist/{useInput-IGJqJ2tR.d.ts → useInput--wjwIBc5.d.cts} +0 -0
- /package/dist/{useInput-NMHJNZ5A.d.cts → useInput-BCdeYOOg.d.ts} +0 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
2
|
-
const require_RadioBoxes = require('../RadioBoxes-
|
|
2
|
+
const require_RadioBoxes = require('../RadioBoxes-h-VLhJ9d.cjs');
|
|
3
3
|
|
|
4
4
|
exports.RadioBoxes = require_RadioBoxes.RadioBoxes_default$1;
|
|
5
5
|
exports.default = require_RadioBoxes.RadioBoxes_default;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as RadioBoxes, r as RadioBoxesProps, t as radioBoxVariants } from "../index-
|
|
1
|
+
import { n as RadioBoxes, r as RadioBoxesProps, t as radioBoxVariants } from "../index-CjJHVJwD.cjs";
|
|
2
2
|
export { RadioBoxes, RadioBoxes as default, RadioBoxesProps, radioBoxVariants };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as RadioBoxes, r as RadioBoxesProps, t as radioBoxVariants } from "../index-
|
|
1
|
+
import { n as RadioBoxes, r as RadioBoxesProps, t as radioBoxVariants } from "../index-BGXgvZKr.js";
|
|
2
2
|
export { RadioBoxes, RadioBoxes as default, RadioBoxesProps, radioBoxVariants };
|
package/dist/RadioBoxes/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { n as RadioBoxes_default, r as radioBoxVariants, t as RadioBoxes_default$1 } from "../RadioBoxes-
|
|
1
|
+
import { n as RadioBoxes_default, r as radioBoxVariants, t as RadioBoxes_default$1 } from "../RadioBoxes-DdIHH6B5.js";
|
|
2
2
|
|
|
3
3
|
export { RadioBoxes_default as RadioBoxes, RadioBoxes_default$1 as default, radioBoxVariants };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as useUniformField } from "./useUniformField-
|
|
1
|
+
import { t as useUniformField } from "./useUniformField-BKVVns0E.js";
|
|
2
2
|
import { cn, slugify, tv, variantsToClassNames } from "@fuf-stack/pixel-utils";
|
|
3
3
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
4
4
|
import { RadioGroup, useRadio } from "@heroui/radio";
|
|
@@ -127,12 +127,12 @@ const RadioBoxes = ({ className = void 0, inline = false, name, options, ...unif
|
|
|
127
127
|
})
|
|
128
128
|
});
|
|
129
129
|
};
|
|
130
|
-
var RadioBoxes_default = RadioBoxes;
|
|
130
|
+
var RadioBoxes_default$1 = RadioBoxes;
|
|
131
131
|
|
|
132
132
|
//#endregion
|
|
133
133
|
//#region src/RadioBoxes/index.ts
|
|
134
|
-
var RadioBoxes_default
|
|
134
|
+
var RadioBoxes_default = RadioBoxes_default$1;
|
|
135
135
|
|
|
136
136
|
//#endregion
|
|
137
|
-
export { RadioBoxes_default as n, radioBoxVariants as r, RadioBoxes_default
|
|
138
|
-
//# sourceMappingURL=RadioBoxes-
|
|
137
|
+
export { RadioBoxes_default$1 as n, radioBoxVariants as r, RadioBoxes_default as t };
|
|
138
|
+
//# sourceMappingURL=RadioBoxes-DdIHH6B5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RadioBoxes-DdIHH6B5.js","names":["HeroRadioGroup","RadioBoxes"],"sources":["../src/RadioBoxes/RadioBox.tsx","../src/RadioBoxes/RadioBoxes.tsx","../src/RadioBoxes/index.ts"],"sourcesContent":["import type { TVClassName } from '@fuf-stack/pixel-utils';\nimport type { RadioProps as HeroRadioProps } from '@heroui/radio';\nimport type { ReactNode } from 'react';\n\nimport { useRadio } from '@heroui/radio';\nimport { VisuallyHidden } from '@react-aria/visually-hidden';\n\nimport { cn, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nexport const radioBoxVariants = tv({\n slots: {\n base: 'group inline-flex flex-auto cursor-pointer items-center justify-between gap-4 rounded-lg border-2 border-default p-4 hover:bg-content2 data-[selected=true]:border-focus',\n control: '',\n description: 'text-foreground opacity-70 text-small',\n icon: '',\n label: '',\n labelWrapper: 'grow',\n },\n variants: {\n isDisabled: {\n true: {\n base: 'pointer-events-none opacity-disabled',\n },\n },\n isInvalid: {\n true: {\n base: '!border-danger',\n },\n },\n },\n});\n\ntype ClassName = TVClassName<typeof radioBoxVariants>;\n\nexport interface RadioBoxProps extends Omit<HeroRadioProps, 'className'> {\n /** CSS class name */\n className?: ClassName;\n /** icon for the option */\n icon?: ReactNode;\n /** whether the radio is invalid */\n isInvalid?: boolean;\n}\n\nexport const RadioBox = ({\n classNames: _classNames = undefined,\n icon = undefined,\n isInvalid = false,\n ...props\n}: RadioBoxProps) => {\n const {\n children,\n Component,\n description,\n getBaseProps,\n getControlProps,\n getInputProps,\n getLabelProps,\n getLabelWrapperProps,\n getWrapperProps,\n isDisabled,\n } = useRadio(props as HeroRadioProps);\n\n // classNames from slots\n const variants = radioBoxVariants({\n isDisabled,\n isInvalid,\n });\n const classNames = variantsToClassNames(\n variants,\n // @ts-expect-error not sure here, but it works\n _classNames,\n 'base',\n );\n\n return (\n <Component {...getBaseProps()} className={classNames.base}>\n <VisuallyHidden>\n <input {...getInputProps()} />\n </VisuallyHidden>\n {!icon ? (\n <span {...getWrapperProps()}>\n <span\n {...getControlProps()}\n className={cn(getControlProps().className, classNames.control)}\n />\n </span>\n ) : null}\n {icon ? <div className={classNames.icon}>{icon}</div> : null}\n <div\n {...getLabelWrapperProps()}\n className={cn(\n getLabelWrapperProps().className,\n classNames.labelWrapper,\n )}\n >\n {children ? (\n <span\n {...getLabelProps()}\n className={cn(getLabelProps().className, classNames.label)}\n >\n {children}\n </span>\n ) : null}\n {description ? (\n <div className={classNames.description}>{description}</div>\n ) : null}\n </div>\n {icon ? (\n <span {...getWrapperProps()}>\n <span\n {...getControlProps()}\n className={cn(getControlProps().className, classNames.control)}\n />\n </span>\n ) : null}\n </Component>\n );\n};\n\nexport default RadioBox;\n","import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\n//\nimport type { RadioBoxProps } from './RadioBox';\n\nimport { RadioGroup as HeroRadioGroup } from '@heroui/radio';\n\nimport { slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { useUniformField } from '../hooks/useUniformField';\nimport { RadioBox } from './RadioBox';\n\nexport const radioBoxesVariants = tv({\n slots: {\n base: 'group gap-0', // Needs group for group-data condition\n boxBase: '',\n boxControl: '',\n boxDescription: '',\n boxLabel: '',\n boxLabelWrapper: '',\n // see HeroUI styles for group-data condition,\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts\n label:\n 'mb-2 inline-flex text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger',\n wrapper: '',\n },\n});\n\ntype VariantProps = TVProps<typeof radioBoxesVariants>;\ntype ClassName = TVClassName<typeof radioBoxesVariants>;\n\nexport interface RadioBoxesOption {\n /** Description of the value. Works with variant radioBox. */\n description?: ReactNode;\n /** disables the option */\n disabled?: boolean;\n /** option label */\n label?: ReactNode;\n /** option icon */\n icon?: ReactNode;\n /** HTML data-testid attribute of the option */\n testId?: string;\n /** option value */\n value: string;\n}\n\nexport interface RadioBoxesProps extends VariantProps {\n /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */\n ariaLabel?: string;\n /** CSS class name */\n className?: ClassName;\n /** Determines if the Buttons are disabled or not. */\n disabled?: boolean;\n /** determines orientation of the Buttons. */\n inline?: boolean;\n /** Label displayed next to the RadioButton. */\n label?: ReactNode;\n /** Name the RadioButtons are registered at in HTML forms (react-hook-form). */\n name: string;\n /** Radio button configuration. */\n options: RadioBoxesOption[];\n /** Id to grab element in internal tests. */\n testId?: string;\n}\n\n/**\n * RadioBoxes component based on [HeroUI RadioGroup](https://www.heroui.com//docs/components/radio-group)\n */\nconst RadioBoxes = ({\n className = undefined,\n inline = false,\n name,\n options,\n ...uniformFieldProps\n}: RadioBoxesProps) => {\n const {\n ariaLabel,\n defaultValue,\n errorMessage,\n invalid,\n disabled,\n label,\n onBlur,\n onChange,\n ref,\n required,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // classNames from slots\n const variants = radioBoxesVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n const boxClassNames: RadioBoxProps['classNames'] = {\n base: classNames.boxBase,\n control: classNames.boxControl,\n description: classNames.boxDescription,\n label: classNames.boxLabel,\n labelWrapper: classNames.boxLabelWrapper,\n };\n\n return (\n <HeroRadioGroup\n ref={ref}\n aria-label={ariaLabel}\n classNames={classNames}\n // see HeroUI styles for group-data condition (data-invalid),\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/components/select/src/use-select.ts\n data-invalid={invalid}\n data-required={required}\n data-testid={testId}\n defaultValue={defaultValue as string | undefined}\n errorMessage={errorMessage}\n isDisabled={disabled}\n isInvalid={invalid}\n isRequired={required}\n label={label ? <legend>{label}</legend> : null}\n name={name}\n onBlur={onBlur}\n onValueChange={onChange}\n orientation={inline ? 'horizontal' : 'vertical'}\n >\n {options.map((option) => {\n if ('value' in option) {\n const optionTestId = slugify(\n `${testId}_option_${option.testId ?? option.value}`,\n { replaceDots: true },\n );\n return (\n <RadioBox\n key={option.value}\n classNames={boxClassNames}\n data-testid={optionTestId}\n description={option.description}\n icon={option.icon}\n isDisabled={!!disabled || option.disabled}\n isInvalid={invalid}\n value={option.value}\n >\n {option.label ?? option.value}\n </RadioBox>\n );\n }\n return null;\n })}\n </HeroRadioGroup>\n );\n};\n\nexport default RadioBoxes;\n","import RadioBoxes from './RadioBoxes';\n\nexport type { RadioBoxesProps } from './RadioBoxes';\nexport { radioBoxVariants } from './RadioBox';\n\nexport { RadioBoxes };\n\nexport default RadioBoxes;\n"],"mappings":";;;;;;;AASA,MAAa,mBAAmB,GAAG;CACjC,OAAO;EACL,MAAM;EACN,SAAS;EACT,aAAa;EACb,MAAM;EACN,OAAO;EACP,cAAc;EACf;CACD,UAAU;EACR,YAAY,EACV,MAAM,EACJ,MAAM,wCACP,EACF;EACD,WAAW,EACT,MAAM,EACJ,MAAM,kBACP,EACF;EACF;CACF,CAAC;AAaF,MAAa,YAAY,EACvB,YAAY,cAAc,QAC1B,OAAO,QACP,YAAY,OACZ,GAAG,YACgB;CACnB,MAAM,EACJ,UACA,WACA,aACA,cACA,iBACA,eACA,eACA,sBACA,iBACA,eACE,SAAS,MAAwB;CAOrC,MAAM,aAAa,qBAJF,iBAAiB;EAChC;EACA;EACD,CAAC,EAIA,aACA,OACD;AAED,QACE,qBAAC;EAAU,GAAI,cAAc;EAAE,WAAW,WAAW;;GACnD,oBAAC,4BACC,oBAAC,WAAM,GAAI,eAAe,GAAI,GACf;GAChB,CAAC,OACA,oBAAC;IAAK,GAAI,iBAAiB;cACzB,oBAAC;KACC,GAAI,iBAAiB;KACrB,WAAW,GAAG,iBAAiB,CAAC,WAAW,WAAW,QAAQ;MAC9D;KACG,GACL;GACH,OAAO,oBAAC;IAAI,WAAW,WAAW;cAAO;KAAW,GAAG;GACxD,qBAAC;IACC,GAAI,sBAAsB;IAC1B,WAAW,GACT,sBAAsB,CAAC,WACvB,WAAW,aACZ;eAEA,WACC,oBAAC;KACC,GAAI,eAAe;KACnB,WAAW,GAAG,eAAe,CAAC,WAAW,WAAW,MAAM;KAEzD;MACI,GACL,MACH,cACC,oBAAC;KAAI,WAAW,WAAW;eAAc;MAAkB,GACzD;KACA;GACL,OACC,oBAAC;IAAK,GAAI,iBAAiB;cACzB,oBAAC;KACC,GAAI,iBAAiB;KACrB,WAAW,GAAG,iBAAiB,CAAC,WAAW,WAAW,QAAQ;MAC9D;KACG,GACL;;GACM;;;;;ACvGhB,MAAa,qBAAqB,GAAG,EACnC,OAAO;CACL,MAAM;CACN,SAAS;CACT,YAAY;CACZ,gBAAgB;CAChB,UAAU;CACV,iBAAiB;CAGjB,OACE;CACF,SAAS;CACV,EACF,CAAC;;;;AA0CF,MAAM,cAAc,EAClB,YAAY,QACZ,SAAS,OACT,MACA,SACA,GAAG,wBACkB;CACrB,MAAM,EACJ,WACA,cACA,cACA,SACA,UACA,OACA,QACA,UACA,KACA,UACA,WACE,gBAAgB;EAClB;EACA,GAAG;EACJ,CAAC;CAIF,MAAM,aAAa,qBADF,oBAAoB,EACa,WAAW,OAAO;CACpE,MAAM,gBAA6C;EACjD,MAAM,WAAW;EACjB,SAAS,WAAW;EACpB,aAAa,WAAW;EACxB,OAAO,WAAW;EAClB,cAAc,WAAW;EAC1B;AAED,QACE,oBAACA;EACM;EACL,cAAY;EACA;EAGZ,gBAAc;EACd,iBAAe;EACf,eAAa;EACC;EACA;EACd,YAAY;EACZ,WAAW;EACX,YAAY;EACZ,OAAO,QAAQ,oBAAC,sBAAQ,QAAe,GAAG;EACpC;EACE;EACR,eAAe;EACf,aAAa,SAAS,eAAe;YAEpC,QAAQ,KAAK,WAAW;AACvB,OAAI,WAAW,QAAQ;IACrB,MAAM,eAAe,QACnB,GAAG,OAAO,UAAU,OAAO,UAAU,OAAO,SAC5C,EAAE,aAAa,MAAM,CACtB;AACD,WACE,oBAAC;KAEC,YAAY;KACZ,eAAa;KACb,aAAa,OAAO;KACpB,MAAM,OAAO;KACb,YAAY,CAAC,CAAC,YAAY,OAAO;KACjC,WAAW;KACX,OAAO,OAAO;eAEb,OAAO,SAAS,OAAO;OATnB,OAAO,MAUH;;AAGf,UAAO;IACP;GACa;;AAIrB,2BAAe;;;;AChJf,yBAAeC"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
const require_FormContext = require('./FormContext-
|
|
2
|
-
const require_useUniformField = require('./useUniformField-
|
|
3
|
-
let
|
|
1
|
+
const require_FormContext = require('./FormContext-Lw4YL4-B.cjs');
|
|
2
|
+
const require_useUniformField = require('./useUniformField-D6fwSjrH.cjs');
|
|
3
|
+
let _fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
|
|
4
4
|
let react_jsx_runtime = require("react/jsx-runtime");
|
|
5
|
-
let
|
|
6
|
-
let
|
|
5
|
+
let _heroui_radio = require("@heroui/radio");
|
|
6
|
+
let _react_aria_visually_hidden = require("@react-aria/visually-hidden");
|
|
7
7
|
|
|
8
8
|
//#region src/RadioBoxes/RadioBox.tsx
|
|
9
|
-
const radioBoxVariants = (0,
|
|
9
|
+
const radioBoxVariants = (0, _fuf_stack_pixel_utils.tv)({
|
|
10
10
|
slots: {
|
|
11
11
|
base: "group inline-flex flex-auto cursor-pointer items-center justify-between gap-4 rounded-lg border-2 border-default p-4 hover:bg-content2 data-[selected=true]:border-focus",
|
|
12
12
|
control: "",
|
|
@@ -21,8 +21,8 @@ const radioBoxVariants = (0, __fuf_stack_pixel_utils.tv)({
|
|
|
21
21
|
}
|
|
22
22
|
});
|
|
23
23
|
const RadioBox = ({ classNames: _classNames = void 0, icon = void 0, isInvalid = false, ...props }) => {
|
|
24
|
-
const { children, Component, description, getBaseProps, getControlProps, getInputProps, getLabelProps, getLabelWrapperProps, getWrapperProps, isDisabled } = (0,
|
|
25
|
-
const classNames = (0,
|
|
24
|
+
const { children, Component, description, getBaseProps, getControlProps, getInputProps, getLabelProps, getLabelWrapperProps, getWrapperProps, isDisabled } = (0, _heroui_radio.useRadio)(props);
|
|
25
|
+
const classNames = (0, _fuf_stack_pixel_utils.variantsToClassNames)(radioBoxVariants({
|
|
26
26
|
isDisabled,
|
|
27
27
|
isInvalid
|
|
28
28
|
}), _classNames, "base");
|
|
@@ -30,12 +30,12 @@ const RadioBox = ({ classNames: _classNames = void 0, icon = void 0, isInvalid =
|
|
|
30
30
|
...getBaseProps(),
|
|
31
31
|
className: classNames.base,
|
|
32
32
|
children: [
|
|
33
|
-
/* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
33
|
+
/* @__PURE__ */ (0, react_jsx_runtime.jsx)(_react_aria_visually_hidden.VisuallyHidden, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("input", { ...getInputProps() }) }),
|
|
34
34
|
!icon ? /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
|
|
35
35
|
...getWrapperProps(),
|
|
36
36
|
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
|
|
37
37
|
...getControlProps(),
|
|
38
|
-
className: (0,
|
|
38
|
+
className: (0, _fuf_stack_pixel_utils.cn)(getControlProps().className, classNames.control)
|
|
39
39
|
})
|
|
40
40
|
}) : null,
|
|
41
41
|
icon ? /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
@@ -44,10 +44,10 @@ const RadioBox = ({ classNames: _classNames = void 0, icon = void 0, isInvalid =
|
|
|
44
44
|
}) : null,
|
|
45
45
|
/* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
46
46
|
...getLabelWrapperProps(),
|
|
47
|
-
className: (0,
|
|
47
|
+
className: (0, _fuf_stack_pixel_utils.cn)(getLabelWrapperProps().className, classNames.labelWrapper),
|
|
48
48
|
children: [children ? /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
|
|
49
49
|
...getLabelProps(),
|
|
50
|
-
className: (0,
|
|
50
|
+
className: (0, _fuf_stack_pixel_utils.cn)(getLabelProps().className, classNames.label),
|
|
51
51
|
children
|
|
52
52
|
}) : null, description ? /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
53
53
|
className: classNames.description,
|
|
@@ -58,7 +58,7 @@ const RadioBox = ({ classNames: _classNames = void 0, icon = void 0, isInvalid =
|
|
|
58
58
|
...getWrapperProps(),
|
|
59
59
|
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
|
|
60
60
|
...getControlProps(),
|
|
61
|
-
className: (0,
|
|
61
|
+
className: (0, _fuf_stack_pixel_utils.cn)(getControlProps().className, classNames.control)
|
|
62
62
|
})
|
|
63
63
|
}) : null
|
|
64
64
|
]
|
|
@@ -67,7 +67,7 @@ const RadioBox = ({ classNames: _classNames = void 0, icon = void 0, isInvalid =
|
|
|
67
67
|
|
|
68
68
|
//#endregion
|
|
69
69
|
//#region src/RadioBoxes/RadioBoxes.tsx
|
|
70
|
-
const radioBoxesVariants = (0,
|
|
70
|
+
const radioBoxesVariants = (0, _fuf_stack_pixel_utils.tv)({ slots: {
|
|
71
71
|
base: "group gap-0",
|
|
72
72
|
boxBase: "",
|
|
73
73
|
boxControl: "",
|
|
@@ -85,7 +85,7 @@ const RadioBoxes = ({ className = void 0, inline = false, name, options, ...unif
|
|
|
85
85
|
name,
|
|
86
86
|
...uniformFieldProps
|
|
87
87
|
});
|
|
88
|
-
const classNames = (0,
|
|
88
|
+
const classNames = (0, _fuf_stack_pixel_utils.variantsToClassNames)(radioBoxesVariants(), className, "base");
|
|
89
89
|
const boxClassNames = {
|
|
90
90
|
base: classNames.boxBase,
|
|
91
91
|
control: classNames.boxControl,
|
|
@@ -93,7 +93,7 @@ const RadioBoxes = ({ className = void 0, inline = false, name, options, ...unif
|
|
|
93
93
|
label: classNames.boxLabel,
|
|
94
94
|
labelWrapper: classNames.boxLabelWrapper
|
|
95
95
|
};
|
|
96
|
-
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
96
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_heroui_radio.RadioGroup, {
|
|
97
97
|
ref,
|
|
98
98
|
"aria-label": ariaLabel,
|
|
99
99
|
classNames,
|
|
@@ -112,7 +112,7 @@ const RadioBoxes = ({ className = void 0, inline = false, name, options, ...unif
|
|
|
112
112
|
orientation: inline ? "horizontal" : "vertical",
|
|
113
113
|
children: options.map((option) => {
|
|
114
114
|
if ("value" in option) {
|
|
115
|
-
const optionTestId = (0,
|
|
115
|
+
const optionTestId = (0, _fuf_stack_pixel_utils.slugify)(`${testId}_option_${option.testId ?? option.value}`, { replaceDots: true });
|
|
116
116
|
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(RadioBox, {
|
|
117
117
|
classNames: boxClassNames,
|
|
118
118
|
"data-testid": optionTestId,
|
|
@@ -128,23 +128,23 @@ const RadioBoxes = ({ className = void 0, inline = false, name, options, ...unif
|
|
|
128
128
|
})
|
|
129
129
|
});
|
|
130
130
|
};
|
|
131
|
-
var RadioBoxes_default = RadioBoxes;
|
|
131
|
+
var RadioBoxes_default$1 = RadioBoxes;
|
|
132
132
|
|
|
133
133
|
//#endregion
|
|
134
134
|
//#region src/RadioBoxes/index.ts
|
|
135
|
-
var RadioBoxes_default
|
|
135
|
+
var RadioBoxes_default = RadioBoxes_default$1;
|
|
136
136
|
|
|
137
137
|
//#endregion
|
|
138
138
|
Object.defineProperty(exports, 'RadioBoxes_default', {
|
|
139
139
|
enumerable: true,
|
|
140
140
|
get: function () {
|
|
141
|
-
return RadioBoxes_default
|
|
141
|
+
return RadioBoxes_default;
|
|
142
142
|
}
|
|
143
143
|
});
|
|
144
144
|
Object.defineProperty(exports, 'RadioBoxes_default$1', {
|
|
145
145
|
enumerable: true,
|
|
146
146
|
get: function () {
|
|
147
|
-
return RadioBoxes_default;
|
|
147
|
+
return RadioBoxes_default$1;
|
|
148
148
|
}
|
|
149
149
|
});
|
|
150
150
|
Object.defineProperty(exports, 'radioBoxVariants', {
|
|
@@ -153,4 +153,4 @@ Object.defineProperty(exports, 'radioBoxVariants', {
|
|
|
153
153
|
return radioBoxVariants;
|
|
154
154
|
}
|
|
155
155
|
});
|
|
156
|
-
//# sourceMappingURL=RadioBoxes-
|
|
156
|
+
//# sourceMappingURL=RadioBoxes-h-VLhJ9d.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RadioBoxes-h-VLhJ9d.cjs","names":["VisuallyHidden","useUniformField","HeroRadioGroup","RadioBoxes"],"sources":["../src/RadioBoxes/RadioBox.tsx","../src/RadioBoxes/RadioBoxes.tsx","../src/RadioBoxes/index.ts"],"sourcesContent":["import type { TVClassName } from '@fuf-stack/pixel-utils';\nimport type { RadioProps as HeroRadioProps } from '@heroui/radio';\nimport type { ReactNode } from 'react';\n\nimport { useRadio } from '@heroui/radio';\nimport { VisuallyHidden } from '@react-aria/visually-hidden';\n\nimport { cn, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nexport const radioBoxVariants = tv({\n slots: {\n base: 'group inline-flex flex-auto cursor-pointer items-center justify-between gap-4 rounded-lg border-2 border-default p-4 hover:bg-content2 data-[selected=true]:border-focus',\n control: '',\n description: 'text-foreground opacity-70 text-small',\n icon: '',\n label: '',\n labelWrapper: 'grow',\n },\n variants: {\n isDisabled: {\n true: {\n base: 'pointer-events-none opacity-disabled',\n },\n },\n isInvalid: {\n true: {\n base: '!border-danger',\n },\n },\n },\n});\n\ntype ClassName = TVClassName<typeof radioBoxVariants>;\n\nexport interface RadioBoxProps extends Omit<HeroRadioProps, 'className'> {\n /** CSS class name */\n className?: ClassName;\n /** icon for the option */\n icon?: ReactNode;\n /** whether the radio is invalid */\n isInvalid?: boolean;\n}\n\nexport const RadioBox = ({\n classNames: _classNames = undefined,\n icon = undefined,\n isInvalid = false,\n ...props\n}: RadioBoxProps) => {\n const {\n children,\n Component,\n description,\n getBaseProps,\n getControlProps,\n getInputProps,\n getLabelProps,\n getLabelWrapperProps,\n getWrapperProps,\n isDisabled,\n } = useRadio(props as HeroRadioProps);\n\n // classNames from slots\n const variants = radioBoxVariants({\n isDisabled,\n isInvalid,\n });\n const classNames = variantsToClassNames(\n variants,\n // @ts-expect-error not sure here, but it works\n _classNames,\n 'base',\n );\n\n return (\n <Component {...getBaseProps()} className={classNames.base}>\n <VisuallyHidden>\n <input {...getInputProps()} />\n </VisuallyHidden>\n {!icon ? (\n <span {...getWrapperProps()}>\n <span\n {...getControlProps()}\n className={cn(getControlProps().className, classNames.control)}\n />\n </span>\n ) : null}\n {icon ? <div className={classNames.icon}>{icon}</div> : null}\n <div\n {...getLabelWrapperProps()}\n className={cn(\n getLabelWrapperProps().className,\n classNames.labelWrapper,\n )}\n >\n {children ? (\n <span\n {...getLabelProps()}\n className={cn(getLabelProps().className, classNames.label)}\n >\n {children}\n </span>\n ) : null}\n {description ? (\n <div className={classNames.description}>{description}</div>\n ) : null}\n </div>\n {icon ? (\n <span {...getWrapperProps()}>\n <span\n {...getControlProps()}\n className={cn(getControlProps().className, classNames.control)}\n />\n </span>\n ) : null}\n </Component>\n );\n};\n\nexport default RadioBox;\n","import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\n//\nimport type { RadioBoxProps } from './RadioBox';\n\nimport { RadioGroup as HeroRadioGroup } from '@heroui/radio';\n\nimport { slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { useUniformField } from '../hooks/useUniformField';\nimport { RadioBox } from './RadioBox';\n\nexport const radioBoxesVariants = tv({\n slots: {\n base: 'group gap-0', // Needs group for group-data condition\n boxBase: '',\n boxControl: '',\n boxDescription: '',\n boxLabel: '',\n boxLabelWrapper: '',\n // see HeroUI styles for group-data condition,\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts\n label:\n 'mb-2 inline-flex text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger',\n wrapper: '',\n },\n});\n\ntype VariantProps = TVProps<typeof radioBoxesVariants>;\ntype ClassName = TVClassName<typeof radioBoxesVariants>;\n\nexport interface RadioBoxesOption {\n /** Description of the value. Works with variant radioBox. */\n description?: ReactNode;\n /** disables the option */\n disabled?: boolean;\n /** option label */\n label?: ReactNode;\n /** option icon */\n icon?: ReactNode;\n /** HTML data-testid attribute of the option */\n testId?: string;\n /** option value */\n value: string;\n}\n\nexport interface RadioBoxesProps extends VariantProps {\n /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */\n ariaLabel?: string;\n /** CSS class name */\n className?: ClassName;\n /** Determines if the Buttons are disabled or not. */\n disabled?: boolean;\n /** determines orientation of the Buttons. */\n inline?: boolean;\n /** Label displayed next to the RadioButton. */\n label?: ReactNode;\n /** Name the RadioButtons are registered at in HTML forms (react-hook-form). */\n name: string;\n /** Radio button configuration. */\n options: RadioBoxesOption[];\n /** Id to grab element in internal tests. */\n testId?: string;\n}\n\n/**\n * RadioBoxes component based on [HeroUI RadioGroup](https://www.heroui.com//docs/components/radio-group)\n */\nconst RadioBoxes = ({\n className = undefined,\n inline = false,\n name,\n options,\n ...uniformFieldProps\n}: RadioBoxesProps) => {\n const {\n ariaLabel,\n defaultValue,\n errorMessage,\n invalid,\n disabled,\n label,\n onBlur,\n onChange,\n ref,\n required,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // classNames from slots\n const variants = radioBoxesVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n const boxClassNames: RadioBoxProps['classNames'] = {\n base: classNames.boxBase,\n control: classNames.boxControl,\n description: classNames.boxDescription,\n label: classNames.boxLabel,\n labelWrapper: classNames.boxLabelWrapper,\n };\n\n return (\n <HeroRadioGroup\n ref={ref}\n aria-label={ariaLabel}\n classNames={classNames}\n // see HeroUI styles for group-data condition (data-invalid),\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/components/select/src/use-select.ts\n data-invalid={invalid}\n data-required={required}\n data-testid={testId}\n defaultValue={defaultValue as string | undefined}\n errorMessage={errorMessage}\n isDisabled={disabled}\n isInvalid={invalid}\n isRequired={required}\n label={label ? <legend>{label}</legend> : null}\n name={name}\n onBlur={onBlur}\n onValueChange={onChange}\n orientation={inline ? 'horizontal' : 'vertical'}\n >\n {options.map((option) => {\n if ('value' in option) {\n const optionTestId = slugify(\n `${testId}_option_${option.testId ?? option.value}`,\n { replaceDots: true },\n );\n return (\n <RadioBox\n key={option.value}\n classNames={boxClassNames}\n data-testid={optionTestId}\n description={option.description}\n icon={option.icon}\n isDisabled={!!disabled || option.disabled}\n isInvalid={invalid}\n value={option.value}\n >\n {option.label ?? option.value}\n </RadioBox>\n );\n }\n return null;\n })}\n </HeroRadioGroup>\n );\n};\n\nexport default RadioBoxes;\n","import RadioBoxes from './RadioBoxes';\n\nexport type { RadioBoxesProps } from './RadioBoxes';\nexport { radioBoxVariants } from './RadioBox';\n\nexport { RadioBoxes };\n\nexport default RadioBoxes;\n"],"mappings":";;;;;;;;AASA,MAAa,kDAAsB;CACjC,OAAO;EACL,MAAM;EACN,SAAS;EACT,aAAa;EACb,MAAM;EACN,OAAO;EACP,cAAc;EACf;CACD,UAAU;EACR,YAAY,EACV,MAAM,EACJ,MAAM,wCACP,EACF;EACD,WAAW,EACT,MAAM,EACJ,MAAM,kBACP,EACF;EACF;CACF,CAAC;AAaF,MAAa,YAAY,EACvB,YAAY,cAAc,QAC1B,OAAO,QACP,YAAY,OACZ,GAAG,YACgB;CACnB,MAAM,EACJ,UACA,WACA,aACA,cACA,iBACA,eACA,eACA,sBACA,iBACA,2CACW,MAAwB;CAOrC,MAAM,8DAJW,iBAAiB;EAChC;EACA;EACD,CAAC,EAIA,aACA,OACD;AAED,QACE,4CAAC;EAAU,GAAI,cAAc;EAAE,WAAW,WAAW;;GACnD,2CAACA,wDACC,2CAAC,WAAM,GAAI,eAAe,GAAI,GACf;GAChB,CAAC,OACA,2CAAC;IAAK,GAAI,iBAAiB;cACzB,2CAAC;KACC,GAAI,iBAAiB;KACrB,0CAAc,iBAAiB,CAAC,WAAW,WAAW,QAAQ;MAC9D;KACG,GACL;GACH,OAAO,2CAAC;IAAI,WAAW,WAAW;cAAO;KAAW,GAAG;GACxD,4CAAC;IACC,GAAI,sBAAsB;IAC1B,0CACE,sBAAsB,CAAC,WACvB,WAAW,aACZ;eAEA,WACC,2CAAC;KACC,GAAI,eAAe;KACnB,0CAAc,eAAe,CAAC,WAAW,WAAW,MAAM;KAEzD;MACI,GACL,MACH,cACC,2CAAC;KAAI,WAAW,WAAW;eAAc;MAAkB,GACzD;KACA;GACL,OACC,2CAAC;IAAK,GAAI,iBAAiB;cACzB,2CAAC;KACC,GAAI,iBAAiB;KACrB,0CAAc,iBAAiB,CAAC,WAAW,WAAW,QAAQ;MAC9D;KACG,GACL;;GACM;;;;;ACvGhB,MAAa,oDAAwB,EACnC,OAAO;CACL,MAAM;CACN,SAAS;CACT,YAAY;CACZ,gBAAgB;CAChB,UAAU;CACV,iBAAiB;CAGjB,OACE;CACF,SAAS;CACV,EACF,CAAC;;;;AA0CF,MAAM,cAAc,EAClB,YAAY,QACZ,SAAS,OACT,MACA,SACA,GAAG,wBACkB;CACrB,MAAM,EACJ,WACA,cACA,cACA,SACA,UACA,OACA,QACA,UACA,KACA,UACA,WACEC,wCAAgB;EAClB;EACA,GAAG;EACJ,CAAC;CAIF,MAAM,8DADW,oBAAoB,EACa,WAAW,OAAO;CACpE,MAAM,gBAA6C;EACjD,MAAM,WAAW;EACjB,SAAS,WAAW;EACpB,aAAa,WAAW;EACxB,OAAO,WAAW;EAClB,cAAc,WAAW;EAC1B;AAED,QACE,2CAACC;EACM;EACL,cAAY;EACA;EAGZ,gBAAc;EACd,iBAAe;EACf,eAAa;EACC;EACA;EACd,YAAY;EACZ,WAAW;EACX,YAAY;EACZ,OAAO,QAAQ,2CAAC,sBAAQ,QAAe,GAAG;EACpC;EACE;EACR,eAAe;EACf,aAAa,SAAS,eAAe;YAEpC,QAAQ,KAAK,WAAW;AACvB,OAAI,WAAW,QAAQ;IACrB,MAAM,mDACJ,GAAG,OAAO,UAAU,OAAO,UAAU,OAAO,SAC5C,EAAE,aAAa,MAAM,CACtB;AACD,WACE,2CAAC;KAEC,YAAY;KACZ,eAAa;KACb,aAAa,OAAO;KACpB,MAAM,OAAO;KACb,YAAY,CAAC,CAAC,YAAY,OAAO;KACjC,WAAW;KACX,OAAO,OAAO;eAEb,OAAO,SAAS,OAAO;OATnB,OAAO,MAUH;;AAGf,UAAO;IACP;GACa;;AAIrB,2BAAe;;;;AChJf,yBAAeC"}
|
package/dist/RadioTabs/index.cjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
2
|
-
const require_RadioTabs = require('../RadioTabs-
|
|
2
|
+
const require_RadioTabs = require('../RadioTabs-D6yF9jE3.cjs');
|
|
3
3
|
|
|
4
4
|
exports.RadioTabs = require_RadioTabs.RadioTabs_default$1;
|
|
5
5
|
exports.default = require_RadioTabs.RadioTabs_default;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as RadioTabsProps, t as RadioTabs } from "../index-
|
|
1
|
+
import { n as RadioTabsProps, t as RadioTabs } from "../index-BSjUaHEO.cjs";
|
|
2
2
|
export { RadioTabs, RadioTabs as default, RadioTabsProps };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as RadioTabsProps, t as RadioTabs } from "../index-
|
|
1
|
+
import { n as RadioTabsProps, t as RadioTabs } from "../index-Bcppi5O7.js";
|
|
2
2
|
export { RadioTabs, RadioTabs as default, RadioTabsProps };
|
package/dist/RadioTabs/index.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
const require_FormContext = require('./FormContext-
|
|
2
|
-
const require_useUniformField = require('./useUniformField-
|
|
3
|
-
let
|
|
1
|
+
const require_FormContext = require('./FormContext-Lw4YL4-B.cjs');
|
|
2
|
+
const require_useUniformField = require('./useUniformField-D6fwSjrH.cjs');
|
|
3
|
+
let _fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
|
|
4
4
|
let react = require("react");
|
|
5
5
|
let react_jsx_runtime = require("react/jsx-runtime");
|
|
6
|
-
let
|
|
7
|
-
let
|
|
8
|
-
let
|
|
9
|
-
|
|
6
|
+
let _heroui_radio = require("@heroui/radio");
|
|
7
|
+
let _react_aria_visually_hidden = require("@react-aria/visually-hidden");
|
|
8
|
+
let _fuf_stack_pixels_Tabs = require("@fuf-stack/pixels/Tabs");
|
|
9
|
+
_fuf_stack_pixels_Tabs = require_FormContext.__toESM(_fuf_stack_pixels_Tabs);
|
|
10
10
|
|
|
11
11
|
//#region src/RadioTabs/RadioTabs.tsx
|
|
12
|
-
const radioTabsVariants = (0,
|
|
12
|
+
const radioTabsVariants = (0, _fuf_stack_pixel_utils.tv)({
|
|
13
13
|
slots: {
|
|
14
14
|
base: "group gap-0",
|
|
15
15
|
cursor: "",
|
|
@@ -48,20 +48,20 @@ const RadioTabs = ({ className = void 0, fullWidth = false, inline = false, name
|
|
|
48
48
|
disabled: option?.disabled,
|
|
49
49
|
key: option.value,
|
|
50
50
|
label: option?.label ?? option?.value,
|
|
51
|
-
testId: (0,
|
|
51
|
+
testId: (0, _fuf_stack_pixel_utils.slugify)(`option_${option?.testId ?? option?.value}`, { replaceDots: true })
|
|
52
52
|
};
|
|
53
53
|
});
|
|
54
54
|
const disabledAllKeys = tabOptions?.map((option) => {
|
|
55
55
|
return option.key;
|
|
56
56
|
});
|
|
57
|
-
const classNames = (0,
|
|
57
|
+
const classNames = (0, _fuf_stack_pixel_utils.variantsToClassNames)(radioTabsVariants({
|
|
58
58
|
fullWidth,
|
|
59
59
|
hasContent: options.some((option) => {
|
|
60
60
|
return option.content;
|
|
61
61
|
}),
|
|
62
62
|
isInvalid: invalid
|
|
63
63
|
}), className, "base");
|
|
64
|
-
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(react_jsx_runtime.Fragment, { children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
64
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)(react_jsx_runtime.Fragment, { children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(_react_aria_visually_hidden.VisuallyHidden, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("input", {
|
|
65
65
|
ref,
|
|
66
66
|
"aria-label": ariaLabel,
|
|
67
67
|
name,
|
|
@@ -73,7 +73,7 @@ const RadioTabs = ({ className = void 0, fullWidth = false, inline = false, name
|
|
|
73
73
|
onFocus: () => {
|
|
74
74
|
(visualRadioGroupRef.current?.querySelector("[role=\"tab\"]"))?.focus();
|
|
75
75
|
}
|
|
76
|
-
}) }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
76
|
+
}) }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_heroui_radio.RadioGroup, {
|
|
77
77
|
ref: visualRadioGroupRef,
|
|
78
78
|
"aria-label": ariaLabel,
|
|
79
79
|
"data-invalid": invalid,
|
|
@@ -91,7 +91,7 @@ const RadioTabs = ({ className = void 0, fullWidth = false, inline = false, name
|
|
|
91
91
|
label: classNames.label,
|
|
92
92
|
wrapper: classNames.wrapper
|
|
93
93
|
},
|
|
94
|
-
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
94
|
+
children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_fuf_stack_pixels_Tabs.default, {
|
|
95
95
|
disabledKeys: disabled ? disabledAllKeys : void 0,
|
|
96
96
|
onSelectionChange: onChange,
|
|
97
97
|
selectedKey: value ?? "",
|
|
@@ -110,23 +110,23 @@ const RadioTabs = ({ className = void 0, fullWidth = false, inline = false, name
|
|
|
110
110
|
})
|
|
111
111
|
})] });
|
|
112
112
|
};
|
|
113
|
-
var RadioTabs_default = RadioTabs;
|
|
113
|
+
var RadioTabs_default$1 = RadioTabs;
|
|
114
114
|
|
|
115
115
|
//#endregion
|
|
116
116
|
//#region src/RadioTabs/index.ts
|
|
117
|
-
var RadioTabs_default
|
|
117
|
+
var RadioTabs_default = RadioTabs_default$1;
|
|
118
118
|
|
|
119
119
|
//#endregion
|
|
120
120
|
Object.defineProperty(exports, 'RadioTabs_default', {
|
|
121
121
|
enumerable: true,
|
|
122
122
|
get: function () {
|
|
123
|
-
return RadioTabs_default
|
|
123
|
+
return RadioTabs_default;
|
|
124
124
|
}
|
|
125
125
|
});
|
|
126
126
|
Object.defineProperty(exports, 'RadioTabs_default$1', {
|
|
127
127
|
enumerable: true,
|
|
128
128
|
get: function () {
|
|
129
|
-
return RadioTabs_default;
|
|
129
|
+
return RadioTabs_default$1;
|
|
130
130
|
}
|
|
131
131
|
});
|
|
132
|
-
//# sourceMappingURL=RadioTabs-
|
|
132
|
+
//# sourceMappingURL=RadioTabs-D6yF9jE3.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RadioTabs-D6yF9jE3.cjs","names":["useUniformField","VisuallyHidden","HeroRadioGroup","Tabs","RadioTabs"],"sources":["../src/RadioTabs/RadioTabs.tsx","../src/RadioTabs/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { TabsProps } from '@fuf-stack/pixels';\nimport type { TabProps } from '@fuf-stack/pixels/Tabs';\nimport type { ReactElement, ReactNode } from 'react';\n\nimport { useRef } from 'react';\n\nimport { RadioGroup as HeroRadioGroup } from '@heroui/radio';\nimport { VisuallyHidden } from '@react-aria/visually-hidden';\n\nimport { slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\nimport Tabs from '@fuf-stack/pixels/Tabs';\n\nimport { useUniformField } from '../hooks/useUniformField';\n\nexport const radioTabsVariants = tv({\n slots: {\n base: 'group gap-0', // Needs group for group-data condition\n cursor: '',\n label:\n 'mb-2 inline-flex text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger',\n tab: '',\n tabBase: '',\n tabContent: '',\n tabList: '',\n tabPanel: 'p-3',\n tabWrapper: '',\n wrapper: '',\n },\n variants: {\n hasContent: {\n true: {\n base: '',\n tabBase: 'p-1',\n tabWrapper: [\n // border style\n 'rounded-medium border border-divider',\n // full width\n 'w-full',\n ],\n },\n },\n fullWidth: {\n true: {\n tabWrapper: 'w-full',\n },\n },\n isInvalid: {\n true: {\n tabWrapper: 'rounded-medium border-2 !border-danger',\n },\n },\n },\n});\n\ntype VariantProps = TVProps<typeof radioTabsVariants>;\ntype ClassName = TVClassName<typeof radioTabsVariants>;\n\nexport interface RadioTabsOption {\n /** Optional content inside of the tab */\n content?: ReactNode;\n /** disables the option */\n disabled?: boolean;\n /** option label */\n label?: ReactNode;\n /** option icon */\n icon?: ReactNode;\n /** HTML data-testid attribute of the option */\n testId?: string;\n /** option value */\n value: string;\n}\n\nexport interface RadioTabsProps extends Omit<VariantProps, 'hasContent'> {\n /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */\n ariaLabel?: string;\n /** CSS class name */\n className?: ClassName;\n /** Determines if the Buttons are disabled or not. */\n disabled?: boolean;\n /** Whether tabs should take up full container width */\n fullWidth?: boolean;\n /** determines orientation of the Buttons. */\n inline?: boolean;\n /** Label displayed next to the RadioButton. */\n label?: ReactNode;\n /** Name the RadioButtons are registered at in HTML forms (react-hook-form). */\n name: string;\n /** Radio button configuration. */\n options: RadioTabsOption[];\n /** Id to grab element in internal tests. */\n testId?: string;\n /** How the RadioTabs should look like. */\n variant?: TabsProps['variant'];\n}\n\n/**\n * RadioTabs component based on [HeroUI RadioGroup](https://www.heroui.com//docs/components/radio-group)\n * and [HeroUI Tabs](https://www.heroui.com//docs/components/tabs)\n */\nconst RadioTabs = ({\n className = undefined,\n fullWidth = false,\n inline = false,\n name,\n options,\n variant = undefined,\n ...uniformFieldProps\n}: RadioTabsProps): ReactElement => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: { onBlur, onChange, ref, value },\n invalid,\n label,\n required,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // Create a ref for the visual radio group to forward focus\n const visualRadioGroupRef = useRef<HTMLDivElement>(null);\n\n const tabOptions = options.map<TabProps>((option) => {\n return {\n content: option?.content,\n disabled: option?.disabled,\n key: option.value,\n label: option?.label ?? option?.value,\n testId: slugify(`option_${option?.testId ?? option?.value}`, {\n replaceDots: true,\n }),\n };\n });\n\n const disabledAllKeys: string[] | undefined = tabOptions?.map((option) => {\n return option.key as string;\n });\n\n // check if any option has content\n // eslint-disable-next-line @typescript-eslint/no-misused-promises, @typescript-eslint/promise-function-async\n const hasContent = options.some((option) => {\n return option.content;\n });\n\n // classNames from slots\n const variants = radioTabsVariants({\n fullWidth,\n hasContent,\n isInvalid: invalid,\n });\n const classNames = variantsToClassNames(variants, className, 'base');\n\n return (\n <>\n {/* Visually hidden input for React Hook Form focus management */}\n <VisuallyHidden>\n <input\n ref={ref}\n aria-label={ariaLabel}\n name={name}\n onBlur={onBlur}\n value={value ?? ''}\n onChange={(e) => {\n onChange(e.target.value);\n }}\n onFocus={() => {\n // Forward focus to the first tab when RHF focuses this input\n const firstTab = visualRadioGroupRef.current?.querySelector(\n '[role=\"tab\"]',\n ) as HTMLElement;\n firstTab?.focus();\n }}\n />\n </VisuallyHidden>\n\n <HeroRadioGroup\n ref={visualRadioGroupRef}\n aria-label={ariaLabel}\n // see HeroUI styles for group-data condition (data-invalid),\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/components/select/src/use-select.ts\n data-invalid={invalid}\n data-required={required}\n data-testid={testId}\n errorMessage={errorMessage}\n isDisabled={disabled}\n isInvalid={invalid}\n isRequired={required}\n label={label ? <legend>{label}</legend> : null}\n name={`${name}_radiotabs`}\n orientation={inline ? 'horizontal' : 'vertical'}\n classNames={{\n base: classNames.base,\n label: classNames.label,\n wrapper: classNames.wrapper,\n }}\n >\n <Tabs\n disabledKeys={disabled ? disabledAllKeys : undefined}\n onSelectionChange={onChange}\n // make sure component is controlled\n selectedKey={value ?? ''}\n tabs={tabOptions}\n testId={testId}\n variant={variant}\n className={{\n base: classNames.tabBase,\n cursor: classNames.cursor,\n panel: classNames.tabPanel,\n tab: classNames.tab,\n tabContent: classNames.tabContent,\n tabList: classNames.tabList,\n tabWrapper: classNames.tabWrapper,\n }}\n />\n </HeroRadioGroup>\n </>\n );\n};\n\nexport default RadioTabs;\n","import RadioTabs from './RadioTabs';\n\nexport type { RadioTabsProps } from './RadioTabs';\n\nexport { RadioTabs };\n\nexport default RadioTabs;\n"],"mappings":";;;;;;;;;;;AAeA,MAAa,mDAAuB;CAClC,OAAO;EACL,MAAM;EACN,QAAQ;EACR,OACE;EACF,KAAK;EACL,SAAS;EACT,YAAY;EACZ,SAAS;EACT,UAAU;EACV,YAAY;EACZ,SAAS;EACV;CACD,UAAU;EACR,YAAY,EACV,MAAM;GACJ,MAAM;GACN,SAAS;GACT,YAAY,CAEV,wCAEA,SACD;GACF,EACF;EACD,WAAW,EACT,MAAM,EACJ,YAAY,UACb,EACF;EACD,WAAW,EACT,MAAM,EACJ,YAAY,0CACb,EACF;EACF;CACF,CAAC;;;;;AA+CF,MAAM,aAAa,EACjB,YAAY,QACZ,YAAY,OACZ,SAAS,OACT,MACA,SACA,UAAU,QACV,GAAG,wBAC+B;CAClC,MAAM,EACJ,WACA,UACA,cACA,OAAO,EAAE,QAAQ,UAAU,KAAK,SAChC,SACA,OACA,UACA,WACEA,wCAAgB;EAClB;EACA,GAAG;EACJ,CAAC;CAGF,MAAM,wCAA6C,KAAK;CAExD,MAAM,aAAa,QAAQ,KAAe,WAAW;AACnD,SAAO;GACL,SAAS,QAAQ;GACjB,UAAU,QAAQ;GAClB,KAAK,OAAO;GACZ,OAAO,QAAQ,SAAS,QAAQ;GAChC,4CAAgB,UAAU,QAAQ,UAAU,QAAQ,SAAS,EAC3D,aAAa,MACd,CAAC;GACH;GACD;CAEF,MAAM,kBAAwC,YAAY,KAAK,WAAW;AACxE,SAAO,OAAO;GACd;CAcF,MAAM,8DALW,kBAAkB;EACjC;EACA,YAPiB,QAAQ,MAAM,WAAW;AAC1C,UAAO,OAAO;IACd;EAMA,WAAW;EACZ,CAAC,EACgD,WAAW,OAAO;AAEpE,QACE,qFAEE,2CAACC,wDACC,2CAAC;EACM;EACL,cAAY;EACN;EACE;EACR,OAAO,SAAS;EAChB,WAAW,MAAM;AACf,YAAS,EAAE,OAAO,MAAM;;EAE1B,eAAe;AAKb,IAHiB,oBAAoB,SAAS,cAC5C,iBACD,GACS,OAAO;;GAEnB,GACa,EAEjB,2CAACC;EACC,KAAK;EACL,cAAY;EAGZ,gBAAc;EACd,iBAAe;EACf,eAAa;EACC;EACd,YAAY;EACZ,WAAW;EACX,YAAY;EACZ,OAAO,QAAQ,2CAAC,sBAAQ,QAAe,GAAG;EAC1C,MAAM,GAAG,KAAK;EACd,aAAa,SAAS,eAAe;EACrC,YAAY;GACV,MAAM,WAAW;GACjB,OAAO,WAAW;GAClB,SAAS,WAAW;GACrB;YAED,2CAACC;GACC,cAAc,WAAW,kBAAkB;GAC3C,mBAAmB;GAEnB,aAAa,SAAS;GACtB,MAAM;GACE;GACC;GACT,WAAW;IACT,MAAM,WAAW;IACjB,QAAQ,WAAW;IACnB,OAAO,WAAW;IAClB,KAAK,WAAW;IAChB,YAAY,WAAW;IACvB,SAAS,WAAW;IACpB,YAAY,WAAW;IACxB;IACD;GACa,IAChB;;AAIP,0BAAe;;;;ACzNf,wBAAeC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as useUniformField } from "./useUniformField-
|
|
1
|
+
import { t as useUniformField } from "./useUniformField-BKVVns0E.js";
|
|
2
2
|
import { slugify, tv, variantsToClassNames } from "@fuf-stack/pixel-utils";
|
|
3
3
|
import { useRef } from "react";
|
|
4
4
|
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
@@ -108,12 +108,12 @@ const RadioTabs = ({ className = void 0, fullWidth = false, inline = false, name
|
|
|
108
108
|
})
|
|
109
109
|
})] });
|
|
110
110
|
};
|
|
111
|
-
var RadioTabs_default = RadioTabs;
|
|
111
|
+
var RadioTabs_default$1 = RadioTabs;
|
|
112
112
|
|
|
113
113
|
//#endregion
|
|
114
114
|
//#region src/RadioTabs/index.ts
|
|
115
|
-
var RadioTabs_default
|
|
115
|
+
var RadioTabs_default = RadioTabs_default$1;
|
|
116
116
|
|
|
117
117
|
//#endregion
|
|
118
|
-
export { RadioTabs_default as n, RadioTabs_default
|
|
119
|
-
//# sourceMappingURL=RadioTabs-
|
|
118
|
+
export { RadioTabs_default$1 as n, RadioTabs_default as t };
|
|
119
|
+
//# sourceMappingURL=RadioTabs-dLdlF91p.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RadioTabs-dLdlF91p.js","names":["HeroRadioGroup","RadioTabs"],"sources":["../src/RadioTabs/RadioTabs.tsx","../src/RadioTabs/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { TabsProps } from '@fuf-stack/pixels';\nimport type { TabProps } from '@fuf-stack/pixels/Tabs';\nimport type { ReactElement, ReactNode } from 'react';\n\nimport { useRef } from 'react';\n\nimport { RadioGroup as HeroRadioGroup } from '@heroui/radio';\nimport { VisuallyHidden } from '@react-aria/visually-hidden';\n\nimport { slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\nimport Tabs from '@fuf-stack/pixels/Tabs';\n\nimport { useUniformField } from '../hooks/useUniformField';\n\nexport const radioTabsVariants = tv({\n slots: {\n base: 'group gap-0', // Needs group for group-data condition\n cursor: '',\n label:\n 'mb-2 inline-flex text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger',\n tab: '',\n tabBase: '',\n tabContent: '',\n tabList: '',\n tabPanel: 'p-3',\n tabWrapper: '',\n wrapper: '',\n },\n variants: {\n hasContent: {\n true: {\n base: '',\n tabBase: 'p-1',\n tabWrapper: [\n // border style\n 'rounded-medium border border-divider',\n // full width\n 'w-full',\n ],\n },\n },\n fullWidth: {\n true: {\n tabWrapper: 'w-full',\n },\n },\n isInvalid: {\n true: {\n tabWrapper: 'rounded-medium border-2 !border-danger',\n },\n },\n },\n});\n\ntype VariantProps = TVProps<typeof radioTabsVariants>;\ntype ClassName = TVClassName<typeof radioTabsVariants>;\n\nexport interface RadioTabsOption {\n /** Optional content inside of the tab */\n content?: ReactNode;\n /** disables the option */\n disabled?: boolean;\n /** option label */\n label?: ReactNode;\n /** option icon */\n icon?: ReactNode;\n /** HTML data-testid attribute of the option */\n testId?: string;\n /** option value */\n value: string;\n}\n\nexport interface RadioTabsProps extends Omit<VariantProps, 'hasContent'> {\n /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */\n ariaLabel?: string;\n /** CSS class name */\n className?: ClassName;\n /** Determines if the Buttons are disabled or not. */\n disabled?: boolean;\n /** Whether tabs should take up full container width */\n fullWidth?: boolean;\n /** determines orientation of the Buttons. */\n inline?: boolean;\n /** Label displayed next to the RadioButton. */\n label?: ReactNode;\n /** Name the RadioButtons are registered at in HTML forms (react-hook-form). */\n name: string;\n /** Radio button configuration. */\n options: RadioTabsOption[];\n /** Id to grab element in internal tests. */\n testId?: string;\n /** How the RadioTabs should look like. */\n variant?: TabsProps['variant'];\n}\n\n/**\n * RadioTabs component based on [HeroUI RadioGroup](https://www.heroui.com//docs/components/radio-group)\n * and [HeroUI Tabs](https://www.heroui.com//docs/components/tabs)\n */\nconst RadioTabs = ({\n className = undefined,\n fullWidth = false,\n inline = false,\n name,\n options,\n variant = undefined,\n ...uniformFieldProps\n}: RadioTabsProps): ReactElement => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: { onBlur, onChange, ref, value },\n invalid,\n label,\n required,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // Create a ref for the visual radio group to forward focus\n const visualRadioGroupRef = useRef<HTMLDivElement>(null);\n\n const tabOptions = options.map<TabProps>((option) => {\n return {\n content: option?.content,\n disabled: option?.disabled,\n key: option.value,\n label: option?.label ?? option?.value,\n testId: slugify(`option_${option?.testId ?? option?.value}`, {\n replaceDots: true,\n }),\n };\n });\n\n const disabledAllKeys: string[] | undefined = tabOptions?.map((option) => {\n return option.key as string;\n });\n\n // check if any option has content\n // eslint-disable-next-line @typescript-eslint/no-misused-promises, @typescript-eslint/promise-function-async\n const hasContent = options.some((option) => {\n return option.content;\n });\n\n // classNames from slots\n const variants = radioTabsVariants({\n fullWidth,\n hasContent,\n isInvalid: invalid,\n });\n const classNames = variantsToClassNames(variants, className, 'base');\n\n return (\n <>\n {/* Visually hidden input for React Hook Form focus management */}\n <VisuallyHidden>\n <input\n ref={ref}\n aria-label={ariaLabel}\n name={name}\n onBlur={onBlur}\n value={value ?? ''}\n onChange={(e) => {\n onChange(e.target.value);\n }}\n onFocus={() => {\n // Forward focus to the first tab when RHF focuses this input\n const firstTab = visualRadioGroupRef.current?.querySelector(\n '[role=\"tab\"]',\n ) as HTMLElement;\n firstTab?.focus();\n }}\n />\n </VisuallyHidden>\n\n <HeroRadioGroup\n ref={visualRadioGroupRef}\n aria-label={ariaLabel}\n // see HeroUI styles for group-data condition (data-invalid),\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/components/select/src/use-select.ts\n data-invalid={invalid}\n data-required={required}\n data-testid={testId}\n errorMessage={errorMessage}\n isDisabled={disabled}\n isInvalid={invalid}\n isRequired={required}\n label={label ? <legend>{label}</legend> : null}\n name={`${name}_radiotabs`}\n orientation={inline ? 'horizontal' : 'vertical'}\n classNames={{\n base: classNames.base,\n label: classNames.label,\n wrapper: classNames.wrapper,\n }}\n >\n <Tabs\n disabledKeys={disabled ? disabledAllKeys : undefined}\n onSelectionChange={onChange}\n // make sure component is controlled\n selectedKey={value ?? ''}\n tabs={tabOptions}\n testId={testId}\n variant={variant}\n className={{\n base: classNames.tabBase,\n cursor: classNames.cursor,\n panel: classNames.tabPanel,\n tab: classNames.tab,\n tabContent: classNames.tabContent,\n tabList: classNames.tabList,\n tabWrapper: classNames.tabWrapper,\n }}\n />\n </HeroRadioGroup>\n </>\n );\n};\n\nexport default RadioTabs;\n","import RadioTabs from './RadioTabs';\n\nexport type { RadioTabsProps } from './RadioTabs';\n\nexport { RadioTabs };\n\nexport default RadioTabs;\n"],"mappings":";;;;;;;;;AAeA,MAAa,oBAAoB,GAAG;CAClC,OAAO;EACL,MAAM;EACN,QAAQ;EACR,OACE;EACF,KAAK;EACL,SAAS;EACT,YAAY;EACZ,SAAS;EACT,UAAU;EACV,YAAY;EACZ,SAAS;EACV;CACD,UAAU;EACR,YAAY,EACV,MAAM;GACJ,MAAM;GACN,SAAS;GACT,YAAY,CAEV,wCAEA,SACD;GACF,EACF;EACD,WAAW,EACT,MAAM,EACJ,YAAY,UACb,EACF;EACD,WAAW,EACT,MAAM,EACJ,YAAY,0CACb,EACF;EACF;CACF,CAAC;;;;;AA+CF,MAAM,aAAa,EACjB,YAAY,QACZ,YAAY,OACZ,SAAS,OACT,MACA,SACA,UAAU,QACV,GAAG,wBAC+B;CAClC,MAAM,EACJ,WACA,UACA,cACA,OAAO,EAAE,QAAQ,UAAU,KAAK,SAChC,SACA,OACA,UACA,WACE,gBAAgB;EAClB;EACA,GAAG;EACJ,CAAC;CAGF,MAAM,sBAAsB,OAAuB,KAAK;CAExD,MAAM,aAAa,QAAQ,KAAe,WAAW;AACnD,SAAO;GACL,SAAS,QAAQ;GACjB,UAAU,QAAQ;GAClB,KAAK,OAAO;GACZ,OAAO,QAAQ,SAAS,QAAQ;GAChC,QAAQ,QAAQ,UAAU,QAAQ,UAAU,QAAQ,SAAS,EAC3D,aAAa,MACd,CAAC;GACH;GACD;CAEF,MAAM,kBAAwC,YAAY,KAAK,WAAW;AACxE,SAAO,OAAO;GACd;CAcF,MAAM,aAAa,qBALF,kBAAkB;EACjC;EACA,YAPiB,QAAQ,MAAM,WAAW;AAC1C,UAAO,OAAO;IACd;EAMA,WAAW;EACZ,CAAC,EACgD,WAAW,OAAO;AAEpE,QACE,4CAEE,oBAAC,4BACC,oBAAC;EACM;EACL,cAAY;EACN;EACE;EACR,OAAO,SAAS;EAChB,WAAW,MAAM;AACf,YAAS,EAAE,OAAO,MAAM;;EAE1B,eAAe;AAKb,IAHiB,oBAAoB,SAAS,cAC5C,iBACD,GACS,OAAO;;GAEnB,GACa,EAEjB,oBAACA;EACC,KAAK;EACL,cAAY;EAGZ,gBAAc;EACd,iBAAe;EACf,eAAa;EACC;EACd,YAAY;EACZ,WAAW;EACX,YAAY;EACZ,OAAO,QAAQ,oBAAC,sBAAQ,QAAe,GAAG;EAC1C,MAAM,GAAG,KAAK;EACd,aAAa,SAAS,eAAe;EACrC,YAAY;GACV,MAAM,WAAW;GACjB,OAAO,WAAW;GAClB,SAAS,WAAW;GACrB;YAED,oBAAC;GACC,cAAc,WAAW,kBAAkB;GAC3C,mBAAmB;GAEnB,aAAa,SAAS;GACtB,MAAM;GACE;GACC;GACT,WAAW;IACT,MAAM,WAAW;IACjB,QAAQ,WAAW;IACnB,OAAO,WAAW;IAClB,KAAK,WAAW;IAChB,YAAY,WAAW;IACvB,SAAS,WAAW;IACpB,YAAY,WAAW;IACxB;IACD;GACa,IAChB;;AAIP,0BAAe;;;;ACzNf,wBAAeC"}
|
package/dist/Radios/index.cjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
2
|
-
const require_Radios = require('../Radios-
|
|
2
|
+
const require_Radios = require('../Radios-D8alyG2f.cjs');
|
|
3
3
|
|
|
4
4
|
exports.Radios = require_Radios.Radios_default$1;
|
|
5
5
|
exports.default = require_Radios.Radios_default;
|
package/dist/Radios/index.d.cts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as RadiosProps, t as Radios } from "../index-
|
|
1
|
+
import { n as RadiosProps, t as Radios } from "../index-CnsR8nkm.cjs";
|
|
2
2
|
export { Radios, Radios as default, RadiosProps };
|
package/dist/Radios/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as RadiosProps, t as Radios } from "../index-
|
|
1
|
+
import { n as RadiosProps, t as Radios } from "../index-op7zETAQ.js";
|
|
2
2
|
export { Radios, Radios as default, RadiosProps };
|
package/dist/Radios/index.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
const require_FormContext = require('./FormContext-
|
|
2
|
-
const require_useUniformField = require('./useUniformField-
|
|
3
|
-
let
|
|
1
|
+
const require_FormContext = require('./FormContext-Lw4YL4-B.cjs');
|
|
2
|
+
const require_useUniformField = require('./useUniformField-D6fwSjrH.cjs');
|
|
3
|
+
let _fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
|
|
4
4
|
let react_jsx_runtime = require("react/jsx-runtime");
|
|
5
|
-
let
|
|
5
|
+
let _heroui_radio = require("@heroui/radio");
|
|
6
6
|
|
|
7
7
|
//#region src/Radios/Radios.tsx
|
|
8
|
-
const radiosVariants = (0,
|
|
8
|
+
const radiosVariants = (0, _fuf_stack_pixel_utils.tv)({ slots: {
|
|
9
9
|
base: "group gap-0",
|
|
10
10
|
itemBase: "",
|
|
11
11
|
itemControl: "bg-focus group-data-[invalid=true]:bg-danger",
|
|
@@ -24,7 +24,7 @@ const Radios = ({ className = void 0, inline = false, name, options, ...uniformF
|
|
|
24
24
|
name,
|
|
25
25
|
...uniformFieldProps
|
|
26
26
|
});
|
|
27
|
-
const classNames = (0,
|
|
27
|
+
const classNames = (0, _fuf_stack_pixel_utils.variantsToClassNames)(radiosVariants(), className, "base");
|
|
28
28
|
const itemClassNames = {
|
|
29
29
|
base: classNames.itemBase,
|
|
30
30
|
control: classNames.itemControl,
|
|
@@ -33,7 +33,7 @@ const Radios = ({ className = void 0, inline = false, name, options, ...uniformF
|
|
|
33
33
|
labelWrapper: classNames.itemLabelWrapper,
|
|
34
34
|
wrapper: classNames.itemWrapper
|
|
35
35
|
};
|
|
36
|
-
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
36
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_heroui_radio.RadioGroup, {
|
|
37
37
|
ref,
|
|
38
38
|
"aria-label": ariaLabel,
|
|
39
39
|
classNames,
|
|
@@ -51,8 +51,8 @@ const Radios = ({ className = void 0, inline = false, name, options, ...uniformF
|
|
|
51
51
|
orientation: inline ? "horizontal" : "vertical",
|
|
52
52
|
children: options.map((option) => {
|
|
53
53
|
if ("value" in option) {
|
|
54
|
-
const optionTestId = (0,
|
|
55
|
-
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(
|
|
54
|
+
const optionTestId = (0, _fuf_stack_pixel_utils.slugify)(`${testId}_option_${option.testId ?? option.value}`, { replaceDots: true });
|
|
55
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_heroui_radio.Radio, {
|
|
56
56
|
classNames: itemClassNames,
|
|
57
57
|
"data-testid": optionTestId,
|
|
58
58
|
isDisabled: !!disabled || option.disabled,
|
|
@@ -65,23 +65,23 @@ const Radios = ({ className = void 0, inline = false, name, options, ...uniformF
|
|
|
65
65
|
})
|
|
66
66
|
});
|
|
67
67
|
};
|
|
68
|
-
var Radios_default = Radios;
|
|
68
|
+
var Radios_default$1 = Radios;
|
|
69
69
|
|
|
70
70
|
//#endregion
|
|
71
71
|
//#region src/Radios/index.ts
|
|
72
|
-
var Radios_default
|
|
72
|
+
var Radios_default = Radios_default$1;
|
|
73
73
|
|
|
74
74
|
//#endregion
|
|
75
75
|
Object.defineProperty(exports, 'Radios_default', {
|
|
76
76
|
enumerable: true,
|
|
77
77
|
get: function () {
|
|
78
|
-
return Radios_default
|
|
78
|
+
return Radios_default;
|
|
79
79
|
}
|
|
80
80
|
});
|
|
81
81
|
Object.defineProperty(exports, 'Radios_default$1', {
|
|
82
82
|
enumerable: true,
|
|
83
83
|
get: function () {
|
|
84
|
-
return Radios_default;
|
|
84
|
+
return Radios_default$1;
|
|
85
85
|
}
|
|
86
86
|
});
|
|
87
|
-
//# sourceMappingURL=Radios-
|
|
87
|
+
//# sourceMappingURL=Radios-D8alyG2f.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Radios-
|
|
1
|
+
{"version":3,"file":"Radios-D8alyG2f.cjs","names":["useUniformField","HeroRadioGroup","HeroRadio","Radios"],"sources":["../src/Radios/Radios.tsx","../src/Radios/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactElement, ReactNode } from 'react';\n\nimport {\n Radio as HeroRadio,\n RadioGroup as HeroRadioGroup,\n} from '@heroui/radio';\n\nimport { slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { useUniformField } from '../hooks/useUniformField';\n\nexport const radiosVariants = tv({\n slots: {\n // Needs group for group-data condition\n base: 'group gap-0',\n itemBase: '',\n itemControl: 'bg-focus group-data-[invalid=true]:bg-danger',\n itemDescription: '',\n itemLabel: 'text-sm',\n itemLabelWrapper: '',\n itemWrapper:\n 'group-data-[invalid=true]:border-danger! [&:not(group-data-[invalid=\"true\"]):not(group-data-[selected=\"false\"])]:border-focus',\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts\n label:\n 'mb-2 inline-flex text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger',\n wrapper: '',\n },\n});\n\ntype VariantProps = TVProps<typeof radiosVariants>;\ntype ClassName = TVClassName<typeof radiosVariants>;\n\nexport interface RadioOption {\n /** disables the option */\n disabled?: boolean;\n /** option label */\n label?: ReactNode;\n /** option icon */\n icon?: ReactNode;\n /** HTML data-testid attribute of the option */\n testId?: string;\n /** option value */\n value: string;\n}\n\nexport interface RadiosProps extends VariantProps {\n /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */\n ariaLabel?: string;\n /** CSS class name */\n className?: ClassName;\n /** Determines if the Buttons are disabled or not. */\n disabled?: boolean;\n /** determines orientation of the Buttons. */\n inline?: boolean;\n /** Label displayed next to the RadioButton. */\n label?: ReactNode;\n /** Name the RadioButtons are registered at in HTML forms (react-hook-form). */\n name: string;\n /** Radio button configuration. */\n options: RadioOption[];\n /** Id to grab element in internal tests. */\n testId?: string;\n}\n\n/**\n * Radios component based on [HeroUI RadioGroup](https://www.heroui.com//docs/components/radio-group)\n */\nconst Radios = ({\n className = undefined,\n inline = false,\n name,\n options,\n ...uniformFieldProps\n}: RadiosProps): ReactElement => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: { onBlur, onChange, ref },\n invalid,\n label,\n required,\n defaultValue,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // classNames from slots\n const variants = radiosVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n\n const itemClassNames = {\n base: classNames.itemBase,\n control: classNames.itemControl,\n description: classNames.itemDescription,\n label: classNames.itemLabel,\n labelWrapper: classNames.itemLabelWrapper,\n wrapper: classNames.itemWrapper,\n };\n\n return (\n <HeroRadioGroup\n ref={ref}\n aria-label={ariaLabel}\n classNames={classNames}\n // see HeroUI styles for group-data condition (data-invalid),\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/components/select/src/use-select.ts\n data-invalid={invalid}\n data-required={required}\n data-testid={testId}\n defaultValue={defaultValue as string | undefined}\n errorMessage={errorMessage}\n isDisabled={disabled}\n isInvalid={invalid}\n isRequired={required}\n label={label ? <legend>{label}</legend> : null}\n name={name}\n onBlur={onBlur}\n orientation={inline ? 'horizontal' : 'vertical'}\n >\n {options.map((option) => {\n if ('value' in option) {\n const optionTestId = slugify(\n `${testId}_option_${option.testId ?? option.value}`,\n { replaceDots: true },\n );\n return (\n <HeroRadio\n key={option.value}\n classNames={itemClassNames}\n data-testid={optionTestId}\n isDisabled={!!disabled || option.disabled}\n onChange={onChange}\n value={option.value}\n >\n {option.label ?? option.value}\n </HeroRadio>\n );\n }\n return null;\n })}\n </HeroRadioGroup>\n );\n};\n\nexport default Radios;\n","import Radios from './Radios';\n\nexport type { RadiosProps } from './Radios';\n\nexport { Radios };\n\nexport default Radios;\n"],"mappings":";;;;;;;AAYA,MAAa,gDAAoB,EAC/B,OAAO;CAEL,MAAM;CACN,UAAU;CACV,aAAa;CACb,iBAAiB;CACjB,WAAW;CACX,kBAAkB;CAClB,aACE;CAEF,OACE;CACF,SAAS;CACV,EACF,CAAC;;;;AAwCF,MAAM,UAAU,EACd,YAAY,QACZ,SAAS,OACT,MACA,SACA,GAAG,wBAC4B;CAC/B,MAAM,EACJ,WACA,UACA,cACA,OAAO,EAAE,QAAQ,UAAU,OAC3B,SACA,OACA,UACA,cACA,WACEA,wCAAgB;EAClB;EACA,GAAG;EACJ,CAAC;CAIF,MAAM,8DADW,gBAAgB,EACiB,WAAW,OAAO;CAEpE,MAAM,iBAAiB;EACrB,MAAM,WAAW;EACjB,SAAS,WAAW;EACpB,aAAa,WAAW;EACxB,OAAO,WAAW;EAClB,cAAc,WAAW;EACzB,SAAS,WAAW;EACrB;AAED,QACE,2CAACC;EACM;EACL,cAAY;EACA;EAGZ,gBAAc;EACd,iBAAe;EACf,eAAa;EACC;EACA;EACd,YAAY;EACZ,WAAW;EACX,YAAY;EACZ,OAAO,QAAQ,2CAAC,sBAAQ,QAAe,GAAG;EACpC;EACE;EACR,aAAa,SAAS,eAAe;YAEpC,QAAQ,KAAK,WAAW;AACvB,OAAI,WAAW,QAAQ;IACrB,MAAM,mDACJ,GAAG,OAAO,UAAU,OAAO,UAAU,OAAO,SAC5C,EAAE,aAAa,MAAM,CACtB;AACD,WACE,2CAACC;KAEC,YAAY;KACZ,eAAa;KACb,YAAY,CAAC,CAAC,YAAY,OAAO;KACvB;KACV,OAAO,OAAO;eAEb,OAAO,SAAS,OAAO;OAPnB,OAAO,MAQF;;AAGhB,UAAO;IACP;GACa;;AAIrB,uBAAe;;;;AC9If,qBAAeC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as useUniformField } from "./useUniformField-
|
|
1
|
+
import { t as useUniformField } from "./useUniformField-BKVVns0E.js";
|
|
2
2
|
import { slugify, tv, variantsToClassNames } from "@fuf-stack/pixel-utils";
|
|
3
3
|
import { jsx } from "react/jsx-runtime";
|
|
4
4
|
import { Radio, RadioGroup } from "@heroui/radio";
|
|
@@ -64,12 +64,12 @@ const Radios = ({ className = void 0, inline = false, name, options, ...uniformF
|
|
|
64
64
|
})
|
|
65
65
|
});
|
|
66
66
|
};
|
|
67
|
-
var Radios_default = Radios;
|
|
67
|
+
var Radios_default$1 = Radios;
|
|
68
68
|
|
|
69
69
|
//#endregion
|
|
70
70
|
//#region src/Radios/index.ts
|
|
71
|
-
var Radios_default
|
|
71
|
+
var Radios_default = Radios_default$1;
|
|
72
72
|
|
|
73
73
|
//#endregion
|
|
74
|
-
export { Radios_default as n, Radios_default
|
|
75
|
-
//# sourceMappingURL=Radios-
|
|
74
|
+
export { Radios_default$1 as n, Radios_default as t };
|
|
75
|
+
//# sourceMappingURL=Radios-DiZ0Dfmp.js.map
|