@fuf-stack/uniform 1.13.0 → 1.14.0
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-BQI2kTIb.js → Checkboxes-C57URc95.js} +2 -2
- package/dist/{Checkboxes-BQI2kTIb.js.map → Checkboxes-C57URc95.js.map} +1 -1
- package/dist/{Checkboxes-mc1ZItR5.cjs → Checkboxes-D5sibD6f.cjs} +2 -2
- package/dist/{Checkboxes-mc1ZItR5.cjs.map → Checkboxes-D5sibD6f.cjs.map} +1 -1
- 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-CsAyIsw9.cjs → FieldArray-CWxV0Q6O.cjs} +3 -3
- package/dist/{FieldArray-CsAyIsw9.cjs.map → FieldArray-CWxV0Q6O.cjs.map} +1 -1
- package/dist/{FieldArray-D4eGdGXA.js → FieldArray-D-vR7oCb.js} +3 -3
- package/dist/{FieldArray-D4eGdGXA.js.map → FieldArray-D-vR7oCb.js.map} +1 -1
- 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-BPQIqqW5.js → FieldCard-CKEeknzL.js} +2 -2
- package/dist/{FieldCard-BPQIqqW5.js.map → FieldCard-CKEeknzL.js.map} +1 -1
- package/dist/{FieldCard-CgWjzrRD.cjs → FieldCard-DiaY4qXt.cjs} +2 -2
- package/dist/{FieldCard-CgWjzrRD.cjs.map → FieldCard-DiaY4qXt.cjs.map} +1 -1
- package/dist/Form/index.d.ts +1 -1
- package/dist/Grid/index.d.cts +1 -1
- package/dist/Grid/index.d.ts +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-7TmTrrV7.cjs → Input-BJkL5IVO.cjs} +2 -2
- package/dist/{Input-7TmTrrV7.cjs.map → Input-BJkL5IVO.cjs.map} +1 -1
- package/dist/{Input-BUfOTtDR.js → Input-CUeTrgO_.js} +2 -2
- package/dist/{Input-BUfOTtDR.js.map → Input-CUeTrgO_.js.map} +1 -1
- 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-Dpd71z1S.js → RadioBoxes-B-EbjvDm.js} +6 -6
- package/dist/{RadioBoxes-Dpd71z1S.js.map → RadioBoxes-B-EbjvDm.js.map} +1 -1
- package/dist/{RadioBoxes-CjxWldIR.cjs → RadioBoxes-BXAo2Nom.cjs} +6 -6
- package/dist/{RadioBoxes-CjxWldIR.cjs.map → RadioBoxes-BXAo2Nom.cjs.map} +1 -1
- 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-BZlC19z0.js → RadioTabs-C2FIAjx-.js} +2 -2
- package/dist/{RadioTabs-BZlC19z0.js.map → RadioTabs-C2FIAjx-.js.map} +1 -1
- package/dist/{RadioTabs-BA-EMFRc.cjs → RadioTabs-rDuug93J.cjs} +2 -2
- package/dist/{RadioTabs-BA-EMFRc.cjs.map → RadioTabs-rDuug93J.cjs.map} +1 -1
- 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-Bfxy-Vnf.cjs → Radios-LD2USByC.cjs} +6 -6
- package/dist/Radios-LD2USByC.cjs.map +1 -0
- package/dist/{Radios-ClBrO7QR.js → Radios-N5qCQRBU.js} +6 -6
- package/dist/Radios-N5qCQRBU.js.map +1 -0
- 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-CdTgOiUU.cjs → Select-C5mS7WZC.cjs} +102 -92
- package/dist/Select-C5mS7WZC.cjs.map +1 -0
- package/dist/{Select-9MyYYGeZ.js → Select-D_LJBu0p.js} +102 -92
- package/dist/Select-D_LJBu0p.js.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-Cy5vz5as.js → Slider-CNlNpxV-.js} +2 -2
- package/dist/{Slider-Cy5vz5as.js.map → Slider-CNlNpxV-.js.map} +1 -1
- package/dist/{Slider-CK9n0ryX.cjs → Slider-D-bfkzoh.cjs} +2 -2
- package/dist/{Slider-CK9n0ryX.cjs.map → Slider-D-bfkzoh.cjs.map} +1 -1
- package/dist/SubmitButton/index.d.cts +1 -1
- package/dist/SubmitButton/index.d.ts +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-BBhxgBHh.cjs → Switch-BBAkWBHA.cjs} +2 -2
- package/dist/{Switch-BBhxgBHh.cjs.map → Switch-BBAkWBHA.cjs.map} +1 -1
- package/dist/{Switch-s64WUP5i.js → Switch-DZptJsFF.js} +2 -2
- package/dist/{Switch-s64WUP5i.js.map → Switch-DZptJsFF.js.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-BwdvgHpG.cjs → SwitchBox-DHAJ_YXU.cjs} +2 -2
- package/dist/{SwitchBox-BwdvgHpG.cjs.map → SwitchBox-DHAJ_YXU.cjs.map} +1 -1
- package/dist/{SwitchBox-CMw1MGJ0.js → SwitchBox-DZQCW3SK.js} +2 -2
- package/dist/{SwitchBox-CMw1MGJ0.js.map → SwitchBox-DZQCW3SK.js.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-COe8XP7f.cjs → TextArea-BBpGkB5f.cjs} +2 -2
- package/dist/{TextArea-COe8XP7f.cjs.map → TextArea-BBpGkB5f.cjs.map} +1 -1
- package/dist/{TextArea-DTkDJr6g.js → TextArea-Dg2ZqJm2.js} +2 -2
- package/dist/{TextArea-DTkDJr6g.js.map → TextArea-Dg2ZqJm2.js.map} +1 -1
- package/dist/helpers/index.d.cts +2 -186
- package/dist/helpers/index.d.ts +2 -186
- package/dist/hooks/useClientValidation/index.d.cts +1 -1
- package/dist/hooks/useClientValidation/index.d.ts +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 +1 -2
- package/dist/hooks/useController/index.js +1 -1
- package/dist/hooks/useFormContext/index.d.cts +1 -1
- package/dist/hooks/useFormContext/index.d.ts +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 +3 -3
- 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 +24 -4
- package/dist/hooks/useUniformFieldArray/index.js +1 -1
- package/dist/hooks/useWatchUserChange/index.d.cts +1 -1
- package/dist/hooks/useWatchUserChange/index.d.ts +1 -1
- package/dist/{index-_njc33cQ.d.cts → index-5Hp_MzN_.d.cts} +4 -4
- package/dist/{index-_njc33cQ.d.cts.map → index-5Hp_MzN_.d.cts.map} +1 -1
- package/dist/{index-DsyY9X04.d.cts → index-6eckRMZA.d.cts} +3 -3
- package/dist/{index-DsyY9X04.d.cts.map → index-6eckRMZA.d.cts.map} +1 -1
- package/dist/{index-CVY05bZf.d.ts → index-B5BDC8Al.d.ts} +3 -3
- package/dist/{index-CVY05bZf.d.ts.map → index-B5BDC8Al.d.ts.map} +1 -1
- package/dist/{index-DMojDmML.d.ts → index-BHklv3dW.d.ts} +48 -48
- package/dist/index-BHklv3dW.d.ts.map +1 -0
- package/dist/{index-OwPGP648.d.ts → index-BOgOCyFF.d.cts} +4 -4
- package/dist/{index-acwVBMcR.d.cts.map → index-BOgOCyFF.d.cts.map} +1 -1
- package/dist/index-BPjrrFuM.d.ts +186 -0
- package/dist/index-BPjrrFuM.d.ts.map +1 -0
- package/dist/index-BTr_gid3.d.cts +186 -0
- package/dist/index-BTr_gid3.d.cts.map +1 -0
- package/dist/{index--J1-cUWg.d.cts → index-BZ9HvBM6.d.cts} +35 -35
- package/dist/{index--J1-cUWg.d.cts.map → index-BZ9HvBM6.d.cts.map} +1 -1
- package/dist/{index-BFeKALeM.d.ts → index-BbAjuXqS.d.cts} +5 -5
- package/dist/{index-BhqOFcsS.d.cts.map → index-BbAjuXqS.d.cts.map} +1 -1
- package/dist/{index-CASoDHjE.d.cts → index-BeinxTzw.d.cts} +21 -21
- package/dist/{index-CASoDHjE.d.cts.map → index-BeinxTzw.d.cts.map} +1 -1
- package/dist/{index-TbDhDIfv.d.ts → index-BuaPmiMt.d.ts} +3 -3
- package/dist/{index-TbDhDIfv.d.ts.map → index-BuaPmiMt.d.ts.map} +1 -1
- package/dist/{index-rK5GxEPh.d.ts → index-ByQXPNeM.d.ts} +6 -6
- package/dist/{index-rK5GxEPh.d.ts.map → index-ByQXPNeM.d.ts.map} +1 -1
- package/dist/{index-DEtF7ckd.d.ts → index-C0--RHyE.d.cts} +34 -34
- package/dist/index-C0--RHyE.d.cts.map +1 -0
- package/dist/{index-CPbrUN5A.d.ts → index-CEzwxdlZ.d.ts} +21 -21
- package/dist/{index-CPbrUN5A.d.ts.map → index-CEzwxdlZ.d.ts.map} +1 -1
- package/dist/{index-CXkSuHEL.d.ts → index-CJcgEkPo.d.ts} +3 -3
- package/dist/{index-CXkSuHEL.d.ts.map → index-CJcgEkPo.d.ts.map} +1 -1
- package/dist/{index-DtWIiEFa.d.cts → index-CPE2gcz3.d.ts} +24 -24
- package/dist/index-CPE2gcz3.d.ts.map +1 -0
- package/dist/{index-Cs-7Ptqc.d.cts → index-CYdvpGJF.d.cts} +3 -3
- package/dist/{index-Cs-7Ptqc.d.cts.map → index-CYdvpGJF.d.cts.map} +1 -1
- package/dist/{index-Bd7H1tdb.d.cts → index-Cb0AgRRa.d.cts} +3 -3
- package/dist/{index-Bd7H1tdb.d.cts.map → index-Cb0AgRRa.d.cts.map} +1 -1
- package/dist/{index-D3o2YTBb.d.ts → index-Cb8jQhHS.d.ts} +36 -36
- package/dist/index-Cb8jQhHS.d.ts.map +1 -0
- package/dist/{index-D9VXD1rv.d.cts → index-CbK-kEVY.d.cts} +21 -21
- package/dist/{index-D9VXD1rv.d.cts.map → index-CbK-kEVY.d.cts.map} +1 -1
- package/dist/{index-BhqOFcsS.d.cts → index-CkhVD2Pw.d.ts} +6 -6
- package/dist/{index-BFeKALeM.d.ts.map → index-CkhVD2Pw.d.ts.map} +1 -1
- package/dist/{index-JfAmWj81.d.cts → index-ClQFLoqX.d.ts} +34 -34
- package/dist/index-ClQFLoqX.d.ts.map +1 -0
- package/dist/{index-_zWAtv8G.d.ts → index-CusdoJv3.d.ts} +35 -35
- package/dist/{index-_zWAtv8G.d.ts.map → index-CusdoJv3.d.ts.map} +1 -1
- package/dist/{index-Z0IxHoXS.d.ts → index-DElTYKk8.d.ts} +1 -1
- package/dist/{index-Z0IxHoXS.d.ts.map → index-DElTYKk8.d.ts.map} +1 -1
- package/dist/{index-CrpdF1Xw.d.cts → index-DMOAkVG4.d.ts} +6 -6
- package/dist/{index-JdksqsGh.d.ts.map → index-DMOAkVG4.d.ts.map} +1 -1
- package/dist/{index-7C539UUH.d.cts → index-DS54nHWk.d.cts} +6 -6
- package/dist/{index-7C539UUH.d.cts.map → index-DS54nHWk.d.cts.map} +1 -1
- package/dist/{index-DCZwOjSs.d.cts → index-DamFEDHU.d.cts} +36 -36
- package/dist/index-DamFEDHU.d.cts.map +1 -0
- package/dist/{index-BHmMP-ps.d.ts → index-DeHDOwxr.d.ts} +21 -21
- package/dist/{index-BHmMP-ps.d.ts.map → index-DeHDOwxr.d.ts.map} +1 -1
- package/dist/{index-JdksqsGh.d.ts → index-DsQabhNC.d.cts} +6 -6
- package/dist/{index-CrpdF1Xw.d.cts.map → index-DsQabhNC.d.cts.map} +1 -1
- package/dist/{index-KgMMIPyM.d.cts → index-P3_aBCSt.d.cts} +3 -3
- package/dist/{index-KgMMIPyM.d.cts.map → index-P3_aBCSt.d.cts.map} +1 -1
- package/dist/{index-DvB46QAb.d.ts → index-aHcGnXHf.d.ts} +3 -3
- package/dist/{index-DvB46QAb.d.ts.map → index-aHcGnXHf.d.ts.map} +1 -1
- package/dist/{index-acwVBMcR.d.cts → index-ecrJ75NW.d.ts} +4 -4
- package/dist/{index-OwPGP648.d.ts.map → index-ecrJ75NW.d.ts.map} +1 -1
- package/dist/index-jeFGTign.d.cts +264 -0
- package/dist/index-jeFGTign.d.cts.map +1 -0
- package/dist/{index-DMVoX5pj.d.cts → index-nE7tTo2d.d.cts} +48 -48
- package/dist/index-nE7tTo2d.d.cts.map +1 -0
- package/dist/{index-DsuMjcQk.d.ts → index-qNwZcAWj.d.ts} +6 -6
- package/dist/{index-DsuMjcQk.d.ts.map → index-qNwZcAWj.d.ts.map} +1 -1
- package/dist/index.cjs +15 -15
- package/dist/index.d.cts +23 -23
- package/dist/index.d.ts +24 -25
- package/dist/index.js +15 -15
- package/dist/partials/FieldCopyTestIdButton/index.d.cts +1 -1
- package/dist/partials/FieldCopyTestIdButton/index.d.ts +1 -1
- package/dist/partials/FieldValidationError/index.d.cts +1 -1
- package/dist/partials/FieldValidationError/index.d.ts +1 -1
- package/dist/{useClientValidation-Bg0q3Axc.d.ts → useClientValidation-Bv0yxTyV.d.ts} +1 -1
- package/dist/{useClientValidation-Bg0q3Axc.d.ts.map → useClientValidation-Bv0yxTyV.d.ts.map} +1 -1
- package/dist/{useClientValidation-BvPDQmf6.d.cts → useClientValidation-DSMw7f-t.d.cts} +1 -1
- package/dist/{useClientValidation-BvPDQmf6.d.cts.map → useClientValidation-DSMw7f-t.d.cts.map} +1 -1
- package/dist/{useController-DHRkSHem.cjs → useController-BySgDIes.cjs} +2 -2
- package/dist/{useController-DHRkSHem.cjs.map → useController-BySgDIes.cjs.map} +1 -1
- package/dist/{useController-BArZd2Vp.d.cts → useController-C_MZLZIp.d.cts} +1 -1
- package/dist/{useController-BArZd2Vp.d.cts.map → useController-C_MZLZIp.d.cts.map} +1 -1
- package/dist/{useController-BPDcwfTj.js → useController-Dleq15tG.js} +2 -2
- package/dist/{useController-BPDcwfTj.js.map → useController-Dleq15tG.js.map} +1 -1
- package/dist/{useController-MVHJ7WFp.d.ts → useController-hjpJQf0w.d.ts} +1 -1
- package/dist/{useController-MVHJ7WFp.d.ts.map → useController-hjpJQf0w.d.ts.map} +1 -1
- package/dist/{useFormContext-B2TS6xq0.d.ts → useFormContext-B7ooPCfd.d.ts} +3 -3
- package/dist/useFormContext-B7ooPCfd.d.ts.map +1 -0
- package/dist/{useFormContext-n3WYgGkW.d.cts → useFormContext-DihY1N8O.d.cts} +3 -3
- package/dist/useFormContext-DihY1N8O.d.cts.map +1 -0
- package/dist/{useUniformField-CGiibqg4.cjs → useUniformField-BJTRfqCQ.cjs} +2 -2
- package/dist/{useUniformField-CGiibqg4.cjs.map → useUniformField-BJTRfqCQ.cjs.map} +1 -1
- package/dist/{useUniformField-D2NgevBI.js → useUniformField-Brwxoghf.js} +2 -2
- package/dist/{useUniformField-D2NgevBI.js.map → useUniformField-Brwxoghf.js.map} +1 -1
- package/dist/{useUniformField-CrEz5lkV.d.cts → useUniformField-Dz_-tPrO.d.cts} +3 -3
- package/dist/{useUniformField-CrEz5lkV.d.cts.map → useUniformField-Dz_-tPrO.d.cts.map} +1 -1
- package/dist/{useUniformField-Bzv-6MG1.d.ts → useUniformField-giYkUMG_.d.ts} +3 -3
- package/dist/{useUniformField-Bzv-6MG1.d.ts.map → useUniformField-giYkUMG_.d.ts.map} +1 -1
- package/dist/{useUniformFieldArray-B2-Bfl74.d.cts → useUniformFieldArray-BMBc3o7P.d.cts} +4 -4
- package/dist/{useUniformFieldArray-B2-Bfl74.d.cts.map → useUniformFieldArray-BMBc3o7P.d.cts.map} +1 -1
- package/dist/{useUniformFieldArray-jUCzsveX.d.ts → useUniformFieldArray-COp7qAwf.d.ts} +4 -4
- package/dist/{useUniformFieldArray-jUCzsveX.d.ts.map → useUniformFieldArray-COp7qAwf.d.ts.map} +1 -1
- package/dist/{useUniformFieldArray-Ct8jD7JJ.cjs → useUniformFieldArray-N5uHlvRy.cjs} +2 -2
- package/dist/{useUniformFieldArray-Ct8jD7JJ.cjs.map → useUniformFieldArray-N5uHlvRy.cjs.map} +1 -1
- package/dist/{useUniformFieldArray-DcoVYtqx.js → useUniformFieldArray-SlUu--d6.js} +2 -2
- package/dist/{useUniformFieldArray-DcoVYtqx.js.map → useUniformFieldArray-SlUu--d6.js.map} +1 -1
- package/dist/{useWatchUserChange-Bf5JKDJJ.d.ts → useWatchUserChange-BAdiqg2q.d.ts} +1 -1
- package/dist/{useWatchUserChange-Bf5JKDJJ.d.ts.map → useWatchUserChange-BAdiqg2q.d.ts.map} +1 -1
- package/dist/{useWatchUserChange-Br4Q7syM.d.cts → useWatchUserChange-COVdHmki.d.cts} +1 -1
- package/dist/{useWatchUserChange-Br4Q7syM.d.cts.map → useWatchUserChange-COVdHmki.d.cts.map} +1 -1
- package/package.json +6 -6
- package/dist/Radios-Bfxy-Vnf.cjs.map +0 -1
- package/dist/Radios-ClBrO7QR.js.map +0 -1
- package/dist/Select-9MyYYGeZ.js.map +0 -1
- package/dist/Select-CdTgOiUU.cjs.map +0 -1
- package/dist/helpers/index.d.cts.map +0 -1
- package/dist/helpers/index.d.ts.map +0 -1
- package/dist/index-CFBmva_r.d.ts +0 -1
- package/dist/index-CNFk4ygb.d.ts +0 -264
- package/dist/index-CNFk4ygb.d.ts.map +0 -1
- package/dist/index-D3o2YTBb.d.ts.map +0 -1
- package/dist/index-DCZwOjSs.d.cts.map +0 -1
- package/dist/index-DEtF7ckd.d.ts.map +0 -1
- package/dist/index-DMVoX5pj.d.cts.map +0 -1
- package/dist/index-DMojDmML.d.ts.map +0 -1
- package/dist/index-DtWIiEFa.d.cts.map +0 -1
- package/dist/index-JfAmWj81.d.cts.map +0 -1
- package/dist/index-lQ_hGQ08.d.cts +0 -1
- package/dist/useFormContext-B2TS6xq0.d.ts.map +0 -1
- package/dist/useFormContext-n3WYgGkW.d.cts.map +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
const require_FormContext = require('./FormContext-CeFKQmVH.cjs');
|
|
2
2
|
const require_helpers = require('./helpers-CncbgvW_.cjs');
|
|
3
3
|
const require_useFormContext = require('./useFormContext-DJiJlfGJ.cjs');
|
|
4
|
-
const require_useUniformField = require('./useUniformField-
|
|
4
|
+
const require_useUniformField = require('./useUniformField-BJTRfqCQ.cjs');
|
|
5
5
|
let _fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
|
|
6
6
|
let react = require("react");
|
|
7
7
|
let react_jsx_runtime = require("react/jsx-runtime");
|
|
@@ -80,6 +80,71 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
80
80
|
const [isFocused, setIsFocused] = (0, react.useState)(false);
|
|
81
81
|
const { convertToOriginalType } = require_helpers.createOptionValueConverter(options);
|
|
82
82
|
const classNames = (0, _fuf_stack_pixel_utils.variantsToClassNames)(selectVariants(), className, "base");
|
|
83
|
+
const reactSelectClassNames = {
|
|
84
|
+
clearIndicator: () => {
|
|
85
|
+
return classNames.clearIndicator;
|
|
86
|
+
},
|
|
87
|
+
control: () => {
|
|
88
|
+
return (0, _fuf_stack_pixel_utils.cn)(classNames.control, { [classNames.control_focused]: isFocused && !invalid });
|
|
89
|
+
},
|
|
90
|
+
dropdownIndicator: () => {
|
|
91
|
+
return classNames.dropdownIndicator;
|
|
92
|
+
},
|
|
93
|
+
groupHeading: () => {
|
|
94
|
+
return classNames.groupHeading;
|
|
95
|
+
},
|
|
96
|
+
indicatorSeparator: () => {
|
|
97
|
+
return classNames.indicatorSeparator;
|
|
98
|
+
},
|
|
99
|
+
indicatorsContainer: () => {
|
|
100
|
+
return classNames.indicatorsContainer;
|
|
101
|
+
},
|
|
102
|
+
input: () => {
|
|
103
|
+
return classNames.input;
|
|
104
|
+
},
|
|
105
|
+
loadingIndicator: () => {
|
|
106
|
+
return classNames.loadingIndicator;
|
|
107
|
+
},
|
|
108
|
+
loadingMessage: () => {
|
|
109
|
+
return classNames.loadingMessage;
|
|
110
|
+
},
|
|
111
|
+
menu: () => {
|
|
112
|
+
return classNames.menu;
|
|
113
|
+
},
|
|
114
|
+
menuList: () => {
|
|
115
|
+
return classNames.menuList;
|
|
116
|
+
},
|
|
117
|
+
menuPortal: () => {
|
|
118
|
+
return classNames.menuPortal;
|
|
119
|
+
},
|
|
120
|
+
multiValue: () => {
|
|
121
|
+
return classNames.multiValue;
|
|
122
|
+
},
|
|
123
|
+
multiValueLabel: () => {
|
|
124
|
+
return (0, _fuf_stack_pixel_utils.cn)(classNames.multiValueLabel, `${getValueProps().className}`);
|
|
125
|
+
},
|
|
126
|
+
multiValueRemove: () => {
|
|
127
|
+
return classNames.multiValueRemove;
|
|
128
|
+
},
|
|
129
|
+
noOptionsMessage: () => {
|
|
130
|
+
return classNames.noOptionsMessage;
|
|
131
|
+
},
|
|
132
|
+
option: ({ isFocused: optionIsFocused, isSelected: optionIsSelected }) => {
|
|
133
|
+
return (0, _fuf_stack_pixel_utils.cn)(classNames.option, {
|
|
134
|
+
[classNames.option_focused]: optionIsFocused,
|
|
135
|
+
[classNames.option_selected]: optionIsSelected
|
|
136
|
+
});
|
|
137
|
+
},
|
|
138
|
+
placeholder: () => {
|
|
139
|
+
return classNames.placeholder;
|
|
140
|
+
},
|
|
141
|
+
singleValue: () => {
|
|
142
|
+
return (0, _fuf_stack_pixel_utils.cn)(classNames.singleValue, `${getValueProps().className}`);
|
|
143
|
+
},
|
|
144
|
+
valueContainer: () => {
|
|
145
|
+
return classNames.valueContainer;
|
|
146
|
+
}
|
|
147
|
+
};
|
|
83
148
|
const { getBaseProps, getTriggerProps, getValueProps } = (0, _heroui_select.useSelect)({
|
|
84
149
|
children: [],
|
|
85
150
|
classNames,
|
|
@@ -91,6 +156,32 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
91
156
|
label,
|
|
92
157
|
labelPlacement: "outside"
|
|
93
158
|
});
|
|
159
|
+
const selectedOptions = multiSelect ? options.filter((option) => {
|
|
160
|
+
if (!Array.isArray(value)) return false;
|
|
161
|
+
return value.some((v) => {
|
|
162
|
+
return String(option.value) === String(v);
|
|
163
|
+
});
|
|
164
|
+
}) : options.find((option) => {
|
|
165
|
+
return String(option.value) === String(value);
|
|
166
|
+
}) ?? null;
|
|
167
|
+
const handleChange = (option) => {
|
|
168
|
+
if (multiSelect) onChange(option?.map((_option) => {
|
|
169
|
+
return convertToOriginalType(_option.value);
|
|
170
|
+
}));
|
|
171
|
+
else {
|
|
172
|
+
const newValue = option?.value;
|
|
173
|
+
onChange(newValue != null ? convertToOriginalType(newValue) : newValue);
|
|
174
|
+
}
|
|
175
|
+
const { isTouched: currentIsTouched } = getFieldState(name, testId);
|
|
176
|
+
if (!currentIsTouched) onBlur();
|
|
177
|
+
};
|
|
178
|
+
const handleBlur = () => {
|
|
179
|
+
setIsFocused(false);
|
|
180
|
+
onBlur();
|
|
181
|
+
};
|
|
182
|
+
const handleFocus = () => {
|
|
183
|
+
setIsFocused(true);
|
|
184
|
+
};
|
|
94
185
|
return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
|
|
95
186
|
...getBaseProps(),
|
|
96
187
|
className: (0, _fuf_stack_pixel_utils.cn)(classNames.base),
|
|
@@ -111,6 +202,7 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
111
202
|
"aria-errormessage": "",
|
|
112
203
|
"aria-invalid": invalid,
|
|
113
204
|
"aria-label": ariaLabel,
|
|
205
|
+
classNames: reactSelectClassNames,
|
|
114
206
|
"data-testid": testId,
|
|
115
207
|
filterOption,
|
|
116
208
|
formatOptionLabel: renderOptionLabel,
|
|
@@ -122,102 +214,20 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
122
214
|
isMulti: multiSelect,
|
|
123
215
|
menuPosition: "fixed",
|
|
124
216
|
name,
|
|
217
|
+
onBlur: handleBlur,
|
|
218
|
+
onChange: handleChange,
|
|
219
|
+
onFocus: handleFocus,
|
|
125
220
|
onInputChange,
|
|
126
221
|
options,
|
|
127
222
|
placeholder,
|
|
223
|
+
value: selectedOptions,
|
|
128
224
|
"aria-labelledby": label ? getTriggerProps()["aria-labelledby"]?.split(" ")[1] : void 0,
|
|
129
|
-
classNames: {
|
|
130
|
-
control: () => {
|
|
131
|
-
return (0, _fuf_stack_pixel_utils.cn)(classNames.control, { [classNames.control_focused]: isFocused && !invalid });
|
|
132
|
-
},
|
|
133
|
-
clearIndicator: () => {
|
|
134
|
-
return classNames.clearIndicator;
|
|
135
|
-
},
|
|
136
|
-
dropdownIndicator: () => {
|
|
137
|
-
return classNames.dropdownIndicator;
|
|
138
|
-
},
|
|
139
|
-
groupHeading: () => {
|
|
140
|
-
return classNames.groupHeading;
|
|
141
|
-
},
|
|
142
|
-
indicatorsContainer: () => {
|
|
143
|
-
return classNames.indicatorsContainer;
|
|
144
|
-
},
|
|
145
|
-
indicatorSeparator: () => {
|
|
146
|
-
return classNames.indicatorSeparator;
|
|
147
|
-
},
|
|
148
|
-
loadingIndicator: () => {
|
|
149
|
-
return classNames.loadingIndicator;
|
|
150
|
-
},
|
|
151
|
-
loadingMessage: () => {
|
|
152
|
-
return classNames.loadingMessage;
|
|
153
|
-
},
|
|
154
|
-
input: () => {
|
|
155
|
-
return classNames.input;
|
|
156
|
-
},
|
|
157
|
-
menu: () => {
|
|
158
|
-
return classNames.menu;
|
|
159
|
-
},
|
|
160
|
-
menuList: () => {
|
|
161
|
-
return classNames.menuList;
|
|
162
|
-
},
|
|
163
|
-
menuPortal: () => {
|
|
164
|
-
return classNames.menuPortal;
|
|
165
|
-
},
|
|
166
|
-
multiValue: () => {
|
|
167
|
-
return classNames.multiValue;
|
|
168
|
-
},
|
|
169
|
-
multiValueLabel: () => {
|
|
170
|
-
return (0, _fuf_stack_pixel_utils.cn)(classNames.multiValueLabel, `${getValueProps().className}`);
|
|
171
|
-
},
|
|
172
|
-
multiValueRemove: () => {
|
|
173
|
-
return classNames.multiValueRemove;
|
|
174
|
-
},
|
|
175
|
-
noOptionsMessage: () => {
|
|
176
|
-
return classNames.noOptionsMessage;
|
|
177
|
-
},
|
|
178
|
-
option: ({ isFocused: optionIsFocused, isSelected: optionIsSelected }) => {
|
|
179
|
-
return (0, _fuf_stack_pixel_utils.cn)(classNames.option, {
|
|
180
|
-
[classNames.option_focused]: optionIsFocused,
|
|
181
|
-
[classNames.option_selected]: optionIsSelected
|
|
182
|
-
});
|
|
183
|
-
},
|
|
184
|
-
placeholder: () => {
|
|
185
|
-
return classNames.placeholder;
|
|
186
|
-
},
|
|
187
|
-
singleValue: () => {
|
|
188
|
-
return (0, _fuf_stack_pixel_utils.cn)(classNames.singleValue, `${getValueProps().className}`);
|
|
189
|
-
},
|
|
190
|
-
valueContainer: () => {
|
|
191
|
-
return classNames.valueContainer;
|
|
192
|
-
}
|
|
193
|
-
},
|
|
194
225
|
components: {
|
|
195
|
-
|
|
196
|
-
Option: OptionComponent,
|
|
226
|
+
Control: ControlComponent,
|
|
197
227
|
DropdownIndicator: DropdownIndicatorComponent,
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
setIsFocused(false);
|
|
202
|
-
onBlur();
|
|
203
|
-
},
|
|
204
|
-
onChange: (option) => {
|
|
205
|
-
if (multiSelect) onChange(option?.map((_option) => {
|
|
206
|
-
return convertToOriginalType(_option.value);
|
|
207
|
-
}));
|
|
208
|
-
else {
|
|
209
|
-
const selectedValue = option?.value;
|
|
210
|
-
onChange(selectedValue != null ? convertToOriginalType(selectedValue) : selectedValue);
|
|
211
|
-
}
|
|
212
|
-
const { isTouched: currentIsTouched } = getFieldState(name, testId);
|
|
213
|
-
if (!currentIsTouched) onBlur();
|
|
214
|
-
},
|
|
215
|
-
onFocus: (_e) => {
|
|
216
|
-
setIsFocused(true);
|
|
217
|
-
},
|
|
218
|
-
value: options.find((option) => {
|
|
219
|
-
return String(option.value) === String(value);
|
|
220
|
-
})
|
|
228
|
+
Input: InputComponent,
|
|
229
|
+
Option: OptionComponent
|
|
230
|
+
}
|
|
221
231
|
}),
|
|
222
232
|
invalid ? /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
223
233
|
...getHelperWrapperProps(),
|
|
@@ -248,4 +258,4 @@ Object.defineProperty(exports, 'Select_default$1', {
|
|
|
248
258
|
return Select_default$1;
|
|
249
259
|
}
|
|
250
260
|
});
|
|
251
|
-
//# sourceMappingURL=Select-
|
|
261
|
+
//# sourceMappingURL=Select-C5mS7WZC.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Select-C5mS7WZC.cjs","names":["components","useUniformField","useFormContext","createOptionValueConverter","ReactSelect","Select"],"sources":["../src/Select/Select.tsx","../src/Select/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\nimport type { MultiValue, Props, SingleValue } from 'react-select';\n\nimport { useState } from 'react';\nimport ReactSelect, { components } from 'react-select';\n\nimport { useSelect } from '@heroui/select';\n\nimport { cn, slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { createOptionValueConverter } from '../helpers';\nimport { useFormContext } from '../hooks/useFormContext';\nimport { useUniformField } from '../hooks/useUniformField';\n\nexport const selectVariants = tv({\n slots: {\n base: 'group leading-normal',\n clearIndicator:\n 'rounded-md p-1 text-foreground-500 hover:cursor-pointer hover:bg-default-200 hover:text-foreground-800',\n control:\n 'duration-150! rounded-lg border-2 border-default-200 bg-content1 transition-background hover:border-default-400 group-data-[invalid=true]:border-danger group-data-[invalid=true]:hover:border-danger motion-reduce:transition-none',\n control_focused: 'border-focus',\n crossIcon: '',\n downChevron: '',\n dropdownIndicator:\n 'rounded-md p-1 text-foreground-500 hover:cursor-pointer hover:bg-default-200 hover:text-black',\n group: '',\n groupHeading: 'mb-1 ml-3 mt-2 text-sm text-foreground-500',\n indicatorsContainer: 'gap-1 p-1',\n indicatorSeparator: 'bg-default-300',\n input: 'py-0.5 pl-1',\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 'pointer-events-auto relative bottom-1.5 ml-1 subpixel-antialiased text-small group-data-[invalid=true]:!text-danger group-data-[required=true]:after:ml-0.5 group-data-[required=true]:after:text-danger group-data-[required=true]:after:content-[\"*\"]',\n loadingIndicator: '',\n loadingMessage: 'rounded-sm p-2 text-foreground-500',\n menu: 'mt-2 rounded-xl border border-default-200 bg-content1 p-1 shadow-lg',\n menuList: '',\n // ensure menu has same z-index as modal so it is visible when rendered in modal\n // see: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/modal.ts (see z-50)\n menuPortal: 'z-50!',\n multiValue: 'items-center gap-1.5 rounded bg-default-100 py-0.5 pl-2 pr-1',\n multiValueContainer: '',\n multiValueLabel: 'py-0.5 leading-6',\n multiValueRemove:\n 'rounded text-default-500 hover:cursor-pointer hover:border-default-300 hover:text-default-800',\n noOptionsMessage: 'rounded-sm p-2 text-foreground-500',\n option_focused: 'bg-default-100 active:bg-default-200',\n option_selected: 'bg-default-300',\n option: 'rounded px-3 py-2 hover:cursor-pointer',\n placeholder: 'ml-1 py-0.5 pl-1 text-sm text-foreground-500',\n selectContainer: '',\n singleValue: 'ml-1! leading-7!',\n valueContainer: 'gap-1 p-1',\n },\n});\n\ninterface SelectOption {\n /** option label */\n label?: ReactNode;\n /** option value */\n value: string | number;\n}\n\ntype VariantProps = TVProps<typeof selectVariants>;\ntype ClassName = TVClassName<typeof selectVariants>;\n\nexport interface SelectProps 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; // string;\n /** Determine if the */\n clearable?: boolean;\n /** Set the select to disabled state. */\n disabled?: boolean;\n /** Filter Select Options */\n filterOption?:\n | undefined\n | ((option?: SelectOption, inputValue?: string) => boolean);\n /** Format the label of the option */\n renderOptionLabel?: undefined | Props['formatOptionLabel'];\n /** The value of the search input */\n inputValue?: string;\n /** Label that should be associated with the select. */\n label?: ReactNode;\n /** Set the select to a loading state. */\n loading?: boolean;\n /** switch between single and multi select mode. */\n multiSelect?: boolean;\n /** The name for the Select component, used by react-hook-form */\n name: string;\n /** Placeholder that is displayed when nothing is selected */\n placeholder?: string;\n /** The options for the Select component */\n options: SelectOption[];\n /** Handle change events on the input */\n onInputChange?: Props['onInputChange'];\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n}\n\nconst InputComponent: typeof components.Input = (props) => {\n // @ts-expect-error data-testid is not a default prop\n // eslint-disable-next-line react/destructuring-assignment\n const testId = `${props.selectProps['data-testid']}`;\n\n return <components.Input data-testid={testId} {...props} />;\n};\n\nconst ControlComponent: typeof components.Control = (props) => {\n // @ts-expect-error data-testid is not a default prop\n // eslint-disable-next-line react/destructuring-assignment\n const testId = `${props.selectProps['data-testid']}_select`;\n return (\n <div data-testid={testId}>\n {}\n <components.Control {...props} />\n </div>\n );\n};\n\nconst OptionComponent: typeof components.Option = (props) => {\n // @ts-expect-error data-testid is not a default prop\n // eslint-disable-next-line react/destructuring-assignment\n const testId = `${props.selectProps['data-testid']}_select_option_${slugify(String(props?.data?.testId ?? props?.data?.value), { replaceDots: true })}`;\n return (\n <div data-testid={testId}>\n {}\n <components.Option {...props} />\n </div>\n );\n};\n\nconst DropdownIndicatorComponent: typeof components.DropdownIndicator = (\n props,\n) => {\n // @ts-expect-error data-testid is not a default prop\n\n const testId = props?.selectProps['data-testid'] as string;\n return (\n <div data-testid={`${testId}_select_dropdown`}>\n {}\n <components.DropdownIndicator {...props} />\n </div>\n );\n};\n\n/** Select component based on [HeroUI Select](https://www.heroui.com//docs/components/select) and [React-Select](https://react-select.com/home) */\nconst Select = ({\n className = undefined,\n clearable = true,\n filterOption = undefined,\n renderOptionLabel = undefined,\n inputValue = undefined,\n loading = false,\n multiSelect = false,\n name,\n onInputChange = undefined,\n options,\n placeholder = undefined,\n ...uniformFieldProps\n}: SelectProps) => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: { onBlur, onChange, ref, value },\n getErrorMessageProps,\n getHelperWrapperProps,\n getLabelProps,\n invalid,\n label,\n required,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // Get getFieldState to check isTouched in onChange callback\n const { getFieldState } = useFormContext();\n\n // Track if the select is focused\n const [isFocused, setIsFocused] = useState(false);\n\n // Create converter to preserve number types for option values\n const { convertToOriginalType } = createOptionValueConverter(options);\n\n // classNames from slots\n const variants = selectVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n\n // React-select classNames configuration\n const reactSelectClassNames = {\n clearIndicator: () => {\n return classNames.clearIndicator;\n },\n control: () => {\n return cn(classNames.control, {\n [classNames.control_focused]: isFocused && !invalid,\n });\n },\n dropdownIndicator: () => {\n return classNames.dropdownIndicator;\n },\n groupHeading: () => {\n return classNames.groupHeading;\n },\n indicatorSeparator: () => {\n return classNames.indicatorSeparator;\n },\n indicatorsContainer: () => {\n return classNames.indicatorsContainer;\n },\n input: () => {\n return classNames.input;\n },\n loadingIndicator: () => {\n return classNames.loadingIndicator;\n },\n loadingMessage: () => {\n return classNames.loadingMessage;\n },\n menu: () => {\n return classNames.menu;\n },\n menuList: () => {\n return classNames.menuList;\n },\n menuPortal: () => {\n return classNames.menuPortal;\n },\n multiValue: () => {\n return classNames.multiValue;\n },\n multiValueLabel: () => {\n return cn(classNames.multiValueLabel, `${getValueProps().className}`);\n },\n multiValueRemove: () => {\n return classNames.multiValueRemove;\n },\n noOptionsMessage: () => {\n return classNames.noOptionsMessage;\n },\n option: ({\n isFocused: optionIsFocused,\n isSelected: optionIsSelected,\n }: {\n isFocused: boolean;\n isSelected: boolean;\n }) => {\n return cn(classNames.option, {\n [classNames.option_focused]: optionIsFocused,\n [classNames.option_selected]: optionIsSelected,\n });\n },\n placeholder: () => {\n return classNames.placeholder;\n },\n singleValue: () => {\n return cn(classNames.singleValue, `${getValueProps().className}`);\n },\n valueContainer: () => {\n return classNames.valueContainer;\n },\n };\n\n const { getBaseProps, getTriggerProps, getValueProps } = useSelect({\n children: [],\n classNames,\n errorMessage,\n isDisabled: disabled,\n isInvalid: invalid,\n isLoading: loading,\n isRequired: required,\n label,\n labelPlacement: 'outside',\n });\n\n // Compute selected option(s) for react-select\n // Compare as strings to handle both string and number values\n // Use null fallback to properly clear react-select when no value is selected\n const selectedOptions = multiSelect\n ? options.filter((option) => {\n if (!Array.isArray(value)) {\n return false;\n }\n return value.some((v) => {\n return String(option.value) === String(v);\n });\n })\n : (options.find((option) => {\n return String(option.value) === String(value);\n }) ?? null);\n\n // Handle selection change\n const handleChange = (\n option: MultiValue<SelectOption> | SingleValue<SelectOption>,\n ) => {\n if (multiSelect) {\n onChange(\n (option as SelectOption[])?.map((_option) => {\n return convertToOriginalType(_option.value);\n }),\n );\n } else {\n const newValue = (option as SelectOption)?.value;\n onChange(newValue != null ? convertToOriginalType(newValue) : newValue);\n }\n // Mark field as touched immediately when a selection is made if not already touched\n // This ensures validation errors show right away (isTouched becomes true)\n // For Select components, selecting an option is a complete user action\n // (unlike text inputs where typing is ongoing), so we mark as touched immediately\n const { isTouched: currentIsTouched } = getFieldState(name, testId);\n if (!currentIsTouched) {\n onBlur();\n }\n };\n\n // Handle blur event\n const handleBlur = () => {\n setIsFocused(false);\n onBlur();\n };\n\n // Handle focus event\n const handleFocus = () => {\n setIsFocused(true);\n };\n\n return (\n <div\n {...getBaseProps()}\n className={cn(classNames.base)}\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-required={required}\n data-testid={`${testId}_wrapper`}\n >\n {label ? (\n <label\n className={classNames.label}\n data-slot=\"label\"\n htmlFor={`react-select-${name}-input`}\n id={getLabelProps().id}\n >\n {label}\n </label>\n ) : null}\n <ReactSelect\n ref={ref}\n menuShouldBlockScroll\n unstyled\n aria-errormessage=\"\"\n aria-invalid={invalid}\n // set aria-labelledby to the label id so that the select is accessible\n aria-label={ariaLabel}\n classNames={reactSelectClassNames}\n // Does not affect the testId of the select, but is needed to pass it to sub-components\n data-testid={testId}\n filterOption={filterOption}\n formatOptionLabel={renderOptionLabel}\n inputValue={inputValue}\n instanceId={name}\n isClearable={clearable}\n isDisabled={disabled}\n isLoading={loading}\n isMulti={multiSelect}\n // set menuPosition to fixed so that menu can be rendered\n // inside Card / Modal components, menuShouldBlockScroll\n // prevents container scroll when menu is open\n menuPosition=\"fixed\"\n name={name}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={handleFocus}\n onInputChange={onInputChange}\n options={options}\n placeholder={placeholder}\n value={selectedOptions}\n // set aria-labelledby to the label id so that the select is accessible\n aria-labelledby={\n label\n ? getTriggerProps()['aria-labelledby']?.split(' ')[1]\n : undefined\n }\n components={{\n Control: ControlComponent,\n DropdownIndicator: DropdownIndicatorComponent,\n Input: InputComponent,\n Option: OptionComponent,\n }}\n />\n {invalid ? (\n <div {...getHelperWrapperProps()}>\n <div {...getErrorMessageProps()}>{errorMessage}</div>\n </div>\n ) : null}\n </div>\n );\n};\n\nexport default Select;\n","import Select from './Select';\n\nexport type { SelectProps } from './Select';\n\nexport { Select };\n\nexport default Select;\n"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { c as createOptionValueConverter } from "./helpers-D3A5d3M1.js";
|
|
2
2
|
import { n as useFormContext } from "./useFormContext-UFBqUfOr.js";
|
|
3
|
-
import { t as useUniformField } from "./useUniformField-
|
|
3
|
+
import { t as useUniformField } from "./useUniformField-Brwxoghf.js";
|
|
4
4
|
import { cn, slugify, tv, variantsToClassNames } from "@fuf-stack/pixel-utils";
|
|
5
5
|
import { useState } from "react";
|
|
6
6
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
@@ -78,6 +78,71 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
78
78
|
const [isFocused, setIsFocused] = useState(false);
|
|
79
79
|
const { convertToOriginalType } = createOptionValueConverter(options);
|
|
80
80
|
const classNames = variantsToClassNames(selectVariants(), className, "base");
|
|
81
|
+
const reactSelectClassNames = {
|
|
82
|
+
clearIndicator: () => {
|
|
83
|
+
return classNames.clearIndicator;
|
|
84
|
+
},
|
|
85
|
+
control: () => {
|
|
86
|
+
return cn(classNames.control, { [classNames.control_focused]: isFocused && !invalid });
|
|
87
|
+
},
|
|
88
|
+
dropdownIndicator: () => {
|
|
89
|
+
return classNames.dropdownIndicator;
|
|
90
|
+
},
|
|
91
|
+
groupHeading: () => {
|
|
92
|
+
return classNames.groupHeading;
|
|
93
|
+
},
|
|
94
|
+
indicatorSeparator: () => {
|
|
95
|
+
return classNames.indicatorSeparator;
|
|
96
|
+
},
|
|
97
|
+
indicatorsContainer: () => {
|
|
98
|
+
return classNames.indicatorsContainer;
|
|
99
|
+
},
|
|
100
|
+
input: () => {
|
|
101
|
+
return classNames.input;
|
|
102
|
+
},
|
|
103
|
+
loadingIndicator: () => {
|
|
104
|
+
return classNames.loadingIndicator;
|
|
105
|
+
},
|
|
106
|
+
loadingMessage: () => {
|
|
107
|
+
return classNames.loadingMessage;
|
|
108
|
+
},
|
|
109
|
+
menu: () => {
|
|
110
|
+
return classNames.menu;
|
|
111
|
+
},
|
|
112
|
+
menuList: () => {
|
|
113
|
+
return classNames.menuList;
|
|
114
|
+
},
|
|
115
|
+
menuPortal: () => {
|
|
116
|
+
return classNames.menuPortal;
|
|
117
|
+
},
|
|
118
|
+
multiValue: () => {
|
|
119
|
+
return classNames.multiValue;
|
|
120
|
+
},
|
|
121
|
+
multiValueLabel: () => {
|
|
122
|
+
return cn(classNames.multiValueLabel, `${getValueProps().className}`);
|
|
123
|
+
},
|
|
124
|
+
multiValueRemove: () => {
|
|
125
|
+
return classNames.multiValueRemove;
|
|
126
|
+
},
|
|
127
|
+
noOptionsMessage: () => {
|
|
128
|
+
return classNames.noOptionsMessage;
|
|
129
|
+
},
|
|
130
|
+
option: ({ isFocused: optionIsFocused, isSelected: optionIsSelected }) => {
|
|
131
|
+
return cn(classNames.option, {
|
|
132
|
+
[classNames.option_focused]: optionIsFocused,
|
|
133
|
+
[classNames.option_selected]: optionIsSelected
|
|
134
|
+
});
|
|
135
|
+
},
|
|
136
|
+
placeholder: () => {
|
|
137
|
+
return classNames.placeholder;
|
|
138
|
+
},
|
|
139
|
+
singleValue: () => {
|
|
140
|
+
return cn(classNames.singleValue, `${getValueProps().className}`);
|
|
141
|
+
},
|
|
142
|
+
valueContainer: () => {
|
|
143
|
+
return classNames.valueContainer;
|
|
144
|
+
}
|
|
145
|
+
};
|
|
81
146
|
const { getBaseProps, getTriggerProps, getValueProps } = useSelect({
|
|
82
147
|
children: [],
|
|
83
148
|
classNames,
|
|
@@ -89,6 +154,32 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
89
154
|
label,
|
|
90
155
|
labelPlacement: "outside"
|
|
91
156
|
});
|
|
157
|
+
const selectedOptions = multiSelect ? options.filter((option) => {
|
|
158
|
+
if (!Array.isArray(value)) return false;
|
|
159
|
+
return value.some((v) => {
|
|
160
|
+
return String(option.value) === String(v);
|
|
161
|
+
});
|
|
162
|
+
}) : options.find((option) => {
|
|
163
|
+
return String(option.value) === String(value);
|
|
164
|
+
}) ?? null;
|
|
165
|
+
const handleChange = (option) => {
|
|
166
|
+
if (multiSelect) onChange(option?.map((_option) => {
|
|
167
|
+
return convertToOriginalType(_option.value);
|
|
168
|
+
}));
|
|
169
|
+
else {
|
|
170
|
+
const newValue = option?.value;
|
|
171
|
+
onChange(newValue != null ? convertToOriginalType(newValue) : newValue);
|
|
172
|
+
}
|
|
173
|
+
const { isTouched: currentIsTouched } = getFieldState(name, testId);
|
|
174
|
+
if (!currentIsTouched) onBlur();
|
|
175
|
+
};
|
|
176
|
+
const handleBlur = () => {
|
|
177
|
+
setIsFocused(false);
|
|
178
|
+
onBlur();
|
|
179
|
+
};
|
|
180
|
+
const handleFocus = () => {
|
|
181
|
+
setIsFocused(true);
|
|
182
|
+
};
|
|
92
183
|
return /* @__PURE__ */ jsxs("div", {
|
|
93
184
|
...getBaseProps(),
|
|
94
185
|
className: cn(classNames.base),
|
|
@@ -109,6 +200,7 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
109
200
|
"aria-errormessage": "",
|
|
110
201
|
"aria-invalid": invalid,
|
|
111
202
|
"aria-label": ariaLabel,
|
|
203
|
+
classNames: reactSelectClassNames,
|
|
112
204
|
"data-testid": testId,
|
|
113
205
|
filterOption,
|
|
114
206
|
formatOptionLabel: renderOptionLabel,
|
|
@@ -120,102 +212,20 @@ const Select = ({ className = void 0, clearable = true, filterOption = void 0, r
|
|
|
120
212
|
isMulti: multiSelect,
|
|
121
213
|
menuPosition: "fixed",
|
|
122
214
|
name,
|
|
215
|
+
onBlur: handleBlur,
|
|
216
|
+
onChange: handleChange,
|
|
217
|
+
onFocus: handleFocus,
|
|
123
218
|
onInputChange,
|
|
124
219
|
options,
|
|
125
220
|
placeholder,
|
|
221
|
+
value: selectedOptions,
|
|
126
222
|
"aria-labelledby": label ? getTriggerProps()["aria-labelledby"]?.split(" ")[1] : void 0,
|
|
127
|
-
classNames: {
|
|
128
|
-
control: () => {
|
|
129
|
-
return cn(classNames.control, { [classNames.control_focused]: isFocused && !invalid });
|
|
130
|
-
},
|
|
131
|
-
clearIndicator: () => {
|
|
132
|
-
return classNames.clearIndicator;
|
|
133
|
-
},
|
|
134
|
-
dropdownIndicator: () => {
|
|
135
|
-
return classNames.dropdownIndicator;
|
|
136
|
-
},
|
|
137
|
-
groupHeading: () => {
|
|
138
|
-
return classNames.groupHeading;
|
|
139
|
-
},
|
|
140
|
-
indicatorsContainer: () => {
|
|
141
|
-
return classNames.indicatorsContainer;
|
|
142
|
-
},
|
|
143
|
-
indicatorSeparator: () => {
|
|
144
|
-
return classNames.indicatorSeparator;
|
|
145
|
-
},
|
|
146
|
-
loadingIndicator: () => {
|
|
147
|
-
return classNames.loadingIndicator;
|
|
148
|
-
},
|
|
149
|
-
loadingMessage: () => {
|
|
150
|
-
return classNames.loadingMessage;
|
|
151
|
-
},
|
|
152
|
-
input: () => {
|
|
153
|
-
return classNames.input;
|
|
154
|
-
},
|
|
155
|
-
menu: () => {
|
|
156
|
-
return classNames.menu;
|
|
157
|
-
},
|
|
158
|
-
menuList: () => {
|
|
159
|
-
return classNames.menuList;
|
|
160
|
-
},
|
|
161
|
-
menuPortal: () => {
|
|
162
|
-
return classNames.menuPortal;
|
|
163
|
-
},
|
|
164
|
-
multiValue: () => {
|
|
165
|
-
return classNames.multiValue;
|
|
166
|
-
},
|
|
167
|
-
multiValueLabel: () => {
|
|
168
|
-
return cn(classNames.multiValueLabel, `${getValueProps().className}`);
|
|
169
|
-
},
|
|
170
|
-
multiValueRemove: () => {
|
|
171
|
-
return classNames.multiValueRemove;
|
|
172
|
-
},
|
|
173
|
-
noOptionsMessage: () => {
|
|
174
|
-
return classNames.noOptionsMessage;
|
|
175
|
-
},
|
|
176
|
-
option: ({ isFocused: optionIsFocused, isSelected: optionIsSelected }) => {
|
|
177
|
-
return cn(classNames.option, {
|
|
178
|
-
[classNames.option_focused]: optionIsFocused,
|
|
179
|
-
[classNames.option_selected]: optionIsSelected
|
|
180
|
-
});
|
|
181
|
-
},
|
|
182
|
-
placeholder: () => {
|
|
183
|
-
return classNames.placeholder;
|
|
184
|
-
},
|
|
185
|
-
singleValue: () => {
|
|
186
|
-
return cn(classNames.singleValue, `${getValueProps().className}`);
|
|
187
|
-
},
|
|
188
|
-
valueContainer: () => {
|
|
189
|
-
return classNames.valueContainer;
|
|
190
|
-
}
|
|
191
|
-
},
|
|
192
223
|
components: {
|
|
193
|
-
|
|
194
|
-
Option: OptionComponent,
|
|
224
|
+
Control: ControlComponent,
|
|
195
225
|
DropdownIndicator: DropdownIndicatorComponent,
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
setIsFocused(false);
|
|
200
|
-
onBlur();
|
|
201
|
-
},
|
|
202
|
-
onChange: (option) => {
|
|
203
|
-
if (multiSelect) onChange(option?.map((_option) => {
|
|
204
|
-
return convertToOriginalType(_option.value);
|
|
205
|
-
}));
|
|
206
|
-
else {
|
|
207
|
-
const selectedValue = option?.value;
|
|
208
|
-
onChange(selectedValue != null ? convertToOriginalType(selectedValue) : selectedValue);
|
|
209
|
-
}
|
|
210
|
-
const { isTouched: currentIsTouched } = getFieldState(name, testId);
|
|
211
|
-
if (!currentIsTouched) onBlur();
|
|
212
|
-
},
|
|
213
|
-
onFocus: (_e) => {
|
|
214
|
-
setIsFocused(true);
|
|
215
|
-
},
|
|
216
|
-
value: options.find((option) => {
|
|
217
|
-
return String(option.value) === String(value);
|
|
218
|
-
})
|
|
226
|
+
Input: InputComponent,
|
|
227
|
+
Option: OptionComponent
|
|
228
|
+
}
|
|
219
229
|
}),
|
|
220
230
|
invalid ? /* @__PURE__ */ jsx("div", {
|
|
221
231
|
...getHelperWrapperProps(),
|
|
@@ -235,4 +245,4 @@ var Select_default = Select_default$1;
|
|
|
235
245
|
|
|
236
246
|
//#endregion
|
|
237
247
|
export { Select_default$1 as n, Select_default as t };
|
|
238
|
-
//# sourceMappingURL=Select-
|
|
248
|
+
//# sourceMappingURL=Select-D_LJBu0p.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Select-D_LJBu0p.js","names":["Select"],"sources":["../src/Select/Select.tsx","../src/Select/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\nimport type { MultiValue, Props, SingleValue } from 'react-select';\n\nimport { useState } from 'react';\nimport ReactSelect, { components } from 'react-select';\n\nimport { useSelect } from '@heroui/select';\n\nimport { cn, slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { createOptionValueConverter } from '../helpers';\nimport { useFormContext } from '../hooks/useFormContext';\nimport { useUniformField } from '../hooks/useUniformField';\n\nexport const selectVariants = tv({\n slots: {\n base: 'group leading-normal',\n clearIndicator:\n 'rounded-md p-1 text-foreground-500 hover:cursor-pointer hover:bg-default-200 hover:text-foreground-800',\n control:\n 'duration-150! rounded-lg border-2 border-default-200 bg-content1 transition-background hover:border-default-400 group-data-[invalid=true]:border-danger group-data-[invalid=true]:hover:border-danger motion-reduce:transition-none',\n control_focused: 'border-focus',\n crossIcon: '',\n downChevron: '',\n dropdownIndicator:\n 'rounded-md p-1 text-foreground-500 hover:cursor-pointer hover:bg-default-200 hover:text-black',\n group: '',\n groupHeading: 'mb-1 ml-3 mt-2 text-sm text-foreground-500',\n indicatorsContainer: 'gap-1 p-1',\n indicatorSeparator: 'bg-default-300',\n input: 'py-0.5 pl-1',\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 'pointer-events-auto relative bottom-1.5 ml-1 subpixel-antialiased text-small group-data-[invalid=true]:!text-danger group-data-[required=true]:after:ml-0.5 group-data-[required=true]:after:text-danger group-data-[required=true]:after:content-[\"*\"]',\n loadingIndicator: '',\n loadingMessage: 'rounded-sm p-2 text-foreground-500',\n menu: 'mt-2 rounded-xl border border-default-200 bg-content1 p-1 shadow-lg',\n menuList: '',\n // ensure menu has same z-index as modal so it is visible when rendered in modal\n // see: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/modal.ts (see z-50)\n menuPortal: 'z-50!',\n multiValue: 'items-center gap-1.5 rounded bg-default-100 py-0.5 pl-2 pr-1',\n multiValueContainer: '',\n multiValueLabel: 'py-0.5 leading-6',\n multiValueRemove:\n 'rounded text-default-500 hover:cursor-pointer hover:border-default-300 hover:text-default-800',\n noOptionsMessage: 'rounded-sm p-2 text-foreground-500',\n option_focused: 'bg-default-100 active:bg-default-200',\n option_selected: 'bg-default-300',\n option: 'rounded px-3 py-2 hover:cursor-pointer',\n placeholder: 'ml-1 py-0.5 pl-1 text-sm text-foreground-500',\n selectContainer: '',\n singleValue: 'ml-1! leading-7!',\n valueContainer: 'gap-1 p-1',\n },\n});\n\ninterface SelectOption {\n /** option label */\n label?: ReactNode;\n /** option value */\n value: string | number;\n}\n\ntype VariantProps = TVProps<typeof selectVariants>;\ntype ClassName = TVClassName<typeof selectVariants>;\n\nexport interface SelectProps 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; // string;\n /** Determine if the */\n clearable?: boolean;\n /** Set the select to disabled state. */\n disabled?: boolean;\n /** Filter Select Options */\n filterOption?:\n | undefined\n | ((option?: SelectOption, inputValue?: string) => boolean);\n /** Format the label of the option */\n renderOptionLabel?: undefined | Props['formatOptionLabel'];\n /** The value of the search input */\n inputValue?: string;\n /** Label that should be associated with the select. */\n label?: ReactNode;\n /** Set the select to a loading state. */\n loading?: boolean;\n /** switch between single and multi select mode. */\n multiSelect?: boolean;\n /** The name for the Select component, used by react-hook-form */\n name: string;\n /** Placeholder that is displayed when nothing is selected */\n placeholder?: string;\n /** The options for the Select component */\n options: SelectOption[];\n /** Handle change events on the input */\n onInputChange?: Props['onInputChange'];\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n}\n\nconst InputComponent: typeof components.Input = (props) => {\n // @ts-expect-error data-testid is not a default prop\n // eslint-disable-next-line react/destructuring-assignment\n const testId = `${props.selectProps['data-testid']}`;\n\n return <components.Input data-testid={testId} {...props} />;\n};\n\nconst ControlComponent: typeof components.Control = (props) => {\n // @ts-expect-error data-testid is not a default prop\n // eslint-disable-next-line react/destructuring-assignment\n const testId = `${props.selectProps['data-testid']}_select`;\n return (\n <div data-testid={testId}>\n {}\n <components.Control {...props} />\n </div>\n );\n};\n\nconst OptionComponent: typeof components.Option = (props) => {\n // @ts-expect-error data-testid is not a default prop\n // eslint-disable-next-line react/destructuring-assignment\n const testId = `${props.selectProps['data-testid']}_select_option_${slugify(String(props?.data?.testId ?? props?.data?.value), { replaceDots: true })}`;\n return (\n <div data-testid={testId}>\n {}\n <components.Option {...props} />\n </div>\n );\n};\n\nconst DropdownIndicatorComponent: typeof components.DropdownIndicator = (\n props,\n) => {\n // @ts-expect-error data-testid is not a default prop\n\n const testId = props?.selectProps['data-testid'] as string;\n return (\n <div data-testid={`${testId}_select_dropdown`}>\n {}\n <components.DropdownIndicator {...props} />\n </div>\n );\n};\n\n/** Select component based on [HeroUI Select](https://www.heroui.com//docs/components/select) and [React-Select](https://react-select.com/home) */\nconst Select = ({\n className = undefined,\n clearable = true,\n filterOption = undefined,\n renderOptionLabel = undefined,\n inputValue = undefined,\n loading = false,\n multiSelect = false,\n name,\n onInputChange = undefined,\n options,\n placeholder = undefined,\n ...uniformFieldProps\n}: SelectProps) => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: { onBlur, onChange, ref, value },\n getErrorMessageProps,\n getHelperWrapperProps,\n getLabelProps,\n invalid,\n label,\n required,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // Get getFieldState to check isTouched in onChange callback\n const { getFieldState } = useFormContext();\n\n // Track if the select is focused\n const [isFocused, setIsFocused] = useState(false);\n\n // Create converter to preserve number types for option values\n const { convertToOriginalType } = createOptionValueConverter(options);\n\n // classNames from slots\n const variants = selectVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n\n // React-select classNames configuration\n const reactSelectClassNames = {\n clearIndicator: () => {\n return classNames.clearIndicator;\n },\n control: () => {\n return cn(classNames.control, {\n [classNames.control_focused]: isFocused && !invalid,\n });\n },\n dropdownIndicator: () => {\n return classNames.dropdownIndicator;\n },\n groupHeading: () => {\n return classNames.groupHeading;\n },\n indicatorSeparator: () => {\n return classNames.indicatorSeparator;\n },\n indicatorsContainer: () => {\n return classNames.indicatorsContainer;\n },\n input: () => {\n return classNames.input;\n },\n loadingIndicator: () => {\n return classNames.loadingIndicator;\n },\n loadingMessage: () => {\n return classNames.loadingMessage;\n },\n menu: () => {\n return classNames.menu;\n },\n menuList: () => {\n return classNames.menuList;\n },\n menuPortal: () => {\n return classNames.menuPortal;\n },\n multiValue: () => {\n return classNames.multiValue;\n },\n multiValueLabel: () => {\n return cn(classNames.multiValueLabel, `${getValueProps().className}`);\n },\n multiValueRemove: () => {\n return classNames.multiValueRemove;\n },\n noOptionsMessage: () => {\n return classNames.noOptionsMessage;\n },\n option: ({\n isFocused: optionIsFocused,\n isSelected: optionIsSelected,\n }: {\n isFocused: boolean;\n isSelected: boolean;\n }) => {\n return cn(classNames.option, {\n [classNames.option_focused]: optionIsFocused,\n [classNames.option_selected]: optionIsSelected,\n });\n },\n placeholder: () => {\n return classNames.placeholder;\n },\n singleValue: () => {\n return cn(classNames.singleValue, `${getValueProps().className}`);\n },\n valueContainer: () => {\n return classNames.valueContainer;\n },\n };\n\n const { getBaseProps, getTriggerProps, getValueProps } = useSelect({\n children: [],\n classNames,\n errorMessage,\n isDisabled: disabled,\n isInvalid: invalid,\n isLoading: loading,\n isRequired: required,\n label,\n labelPlacement: 'outside',\n });\n\n // Compute selected option(s) for react-select\n // Compare as strings to handle both string and number values\n // Use null fallback to properly clear react-select when no value is selected\n const selectedOptions = multiSelect\n ? options.filter((option) => {\n if (!Array.isArray(value)) {\n return false;\n }\n return value.some((v) => {\n return String(option.value) === String(v);\n });\n })\n : (options.find((option) => {\n return String(option.value) === String(value);\n }) ?? null);\n\n // Handle selection change\n const handleChange = (\n option: MultiValue<SelectOption> | SingleValue<SelectOption>,\n ) => {\n if (multiSelect) {\n onChange(\n (option as SelectOption[])?.map((_option) => {\n return convertToOriginalType(_option.value);\n }),\n );\n } else {\n const newValue = (option as SelectOption)?.value;\n onChange(newValue != null ? convertToOriginalType(newValue) : newValue);\n }\n // Mark field as touched immediately when a selection is made if not already touched\n // This ensures validation errors show right away (isTouched becomes true)\n // For Select components, selecting an option is a complete user action\n // (unlike text inputs where typing is ongoing), so we mark as touched immediately\n const { isTouched: currentIsTouched } = getFieldState(name, testId);\n if (!currentIsTouched) {\n onBlur();\n }\n };\n\n // Handle blur event\n const handleBlur = () => {\n setIsFocused(false);\n onBlur();\n };\n\n // Handle focus event\n const handleFocus = () => {\n setIsFocused(true);\n };\n\n return (\n <div\n {...getBaseProps()}\n className={cn(classNames.base)}\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-required={required}\n data-testid={`${testId}_wrapper`}\n >\n {label ? (\n <label\n className={classNames.label}\n data-slot=\"label\"\n htmlFor={`react-select-${name}-input`}\n id={getLabelProps().id}\n >\n {label}\n </label>\n ) : null}\n <ReactSelect\n ref={ref}\n menuShouldBlockScroll\n unstyled\n aria-errormessage=\"\"\n aria-invalid={invalid}\n // set aria-labelledby to the label id so that the select is accessible\n aria-label={ariaLabel}\n classNames={reactSelectClassNames}\n // Does not affect the testId of the select, but is needed to pass it to sub-components\n data-testid={testId}\n filterOption={filterOption}\n formatOptionLabel={renderOptionLabel}\n inputValue={inputValue}\n instanceId={name}\n isClearable={clearable}\n isDisabled={disabled}\n isLoading={loading}\n isMulti={multiSelect}\n // set menuPosition to fixed so that menu can be rendered\n // inside Card / Modal components, menuShouldBlockScroll\n // prevents container scroll when menu is open\n menuPosition=\"fixed\"\n name={name}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={handleFocus}\n onInputChange={onInputChange}\n options={options}\n placeholder={placeholder}\n value={selectedOptions}\n // set aria-labelledby to the label id so that the select is accessible\n aria-labelledby={\n label\n ? getTriggerProps()['aria-labelledby']?.split(' ')[1]\n : undefined\n }\n components={{\n Control: ControlComponent,\n DropdownIndicator: DropdownIndicatorComponent,\n Input: InputComponent,\n Option: OptionComponent,\n }}\n />\n {invalid ? (\n <div {...getHelperWrapperProps()}>\n <div {...getErrorMessageProps()}>{errorMessage}</div>\n </div>\n ) : null}\n </div>\n );\n};\n\nexport default Select;\n","import Select from './Select';\n\nexport type { SelectProps } from './Select';\n\nexport { Select };\n\nexport default Select;\n"],"mappings":"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"}
|
package/dist/Slider/index.cjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
2
|
-
const require_Slider = require('../Slider-
|
|
2
|
+
const require_Slider = require('../Slider-D-bfkzoh.cjs');
|
|
3
3
|
|
|
4
4
|
exports.Slider = require_Slider.Slider_default$1;
|
|
5
5
|
exports.default = require_Slider.Slider_default;
|
package/dist/Slider/index.d.cts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as SliderProps, t as Slider } from "../index-
|
|
1
|
+
import { n as SliderProps, t as Slider } from "../index-nE7tTo2d.cjs";
|
|
2
2
|
export { Slider, Slider as default, SliderProps };
|
package/dist/Slider/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as SliderProps, t as Slider } from "../index-
|
|
1
|
+
import { n as SliderProps, t as Slider } from "../index-BHklv3dW.js";
|
|
2
2
|
export { Slider, Slider as default, SliderProps };
|
package/dist/Slider/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as useUniformField } from "./useUniformField-
|
|
1
|
+
import { t as useUniformField } from "./useUniformField-Brwxoghf.js";
|
|
2
2
|
import { cn, tv, variantsToClassNames } from "@fuf-stack/pixel-utils";
|
|
3
3
|
import { useRef } from "react";
|
|
4
4
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
@@ -108,4 +108,4 @@ var Slider_default = Slider_default$1;
|
|
|
108
108
|
|
|
109
109
|
//#endregion
|
|
110
110
|
export { Slider_default$1 as n, Slider_default as t };
|
|
111
|
-
//# sourceMappingURL=Slider-
|
|
111
|
+
//# sourceMappingURL=Slider-CNlNpxV-.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Slider-
|
|
1
|
+
{"version":3,"file":"Slider-CNlNpxV-.js","names":["Slider","HeroUISlider","Slider"],"sources":["../src/Slider/Slider.tsx","../src/Slider/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\n\nimport { useRef } from 'react';\n\nimport { Slider as HeroUISlider } from '@heroui/slider';\nimport { VisuallyHidden } from '@react-aria/visually-hidden';\n\nimport { cn, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { useUniformField } from '../hooks/useUniformField';\n\nexport const sliderVariants = tv({\n slots: {\n base: 'group',\n endContent: '',\n errorMessage: 'ml-1 mt-1',\n filler: '',\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 'text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:!text-danger group-data-[required=true]:after:ml-0.5 group-data-[required=true]:after:text-danger group-data-[required=true]:after:content-[\"*\"]',\n labelWrapper: '',\n mark: '',\n startContent: '',\n step: '',\n thumb: '',\n track: '',\n trackWrapper: '',\n value: '',\n },\n});\n\ntype VariantProps = TVProps<typeof sliderVariants>;\ntype ClassName = TVClassName<typeof sliderVariants>;\n\nexport interface SliderProps 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 /** input field is disabled */\n disabled?: boolean;\n /** Content to display at the end of the slider */\n endContent?: ReactNode;\n /** The offset from where the fill should start */\n fillOffset?: number;\n /** form field label */\n label?: string;\n /** form field name */\n name: string;\n /**\n * Whether to show step dots on the slider\n * @default false\n */\n showSteps?: boolean;\n /**\n * The size of the slider\n * @default \"md\"\n */\n size?: 'sm' | 'md' | 'lg';\n /** Content to display at the start of the slider */\n startContent?: ReactNode;\n /**\n * The step value of the slider\n * @default 1\n */\n step?: number;\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n /**\n * The minimum value of the slider\n * @default 0\n */\n minValue?: number;\n /**\n * The maximum value of the slider\n * @default 100\n */\n maxValue?: number;\n}\n\n/**\n * Slider component based on [HeroUI Slider](https://www.heroui.com//docs/components/slider)\n */\nconst Slider = ({\n className = undefined,\n endContent = undefined,\n fillOffset = undefined,\n name,\n showSteps = false,\n size = 'md',\n startContent = undefined,\n step = 1,\n minValue = 0,\n maxValue = 100,\n ...uniformFieldProps\n}: SliderProps) => {\n const {\n ariaLabel,\n disabled,\n field,\n getErrorMessageProps,\n getHelperWrapperProps,\n invalid,\n label,\n onBlur,\n onChange,\n ref,\n required,\n errorMessage,\n testId,\n } = useUniformField({\n name,\n ...uniformFieldProps,\n });\n\n // Ref for the visual slider to forward focus\n const visualSliderRef = useRef<HTMLDivElement>(null);\n\n // classNames from slots\n const variants = sliderVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n\n // Get the current value, defaulting to minValue if null/undefined\n const currentValue = field.value != null ? Number(field.value) : minValue;\n\n return (\n <div\n className={classNames.base}\n data-invalid={invalid}\n data-required={required}\n data-testid={testId}\n >\n {/* Visually hidden input for form accessibility and focus management */}\n <VisuallyHidden>\n <input\n ref={ref}\n aria-label={ariaLabel}\n disabled={disabled}\n max={maxValue}\n min={minValue}\n name={name}\n onBlur={onBlur}\n step={step}\n tabIndex={-1}\n type=\"range\"\n value={currentValue}\n onChange={(e) => {\n onChange(Number(e.target.value));\n }}\n onFocus={() => {\n // When RHF focuses this hidden input (e.g., on validation error),\n // forward focus to the visual slider to show focus ring\n visualSliderRef.current?.focus();\n }}\n />\n </VisuallyHidden>\n {/* Visual HeroUISlider component */}\n <HeroUISlider\n ref={visualSliderRef}\n aria-label={ariaLabel}\n color={invalid ? 'danger' : 'primary'}\n endContent={endContent}\n fillOffset={fillOffset}\n isDisabled={disabled}\n label={label}\n maxValue={maxValue}\n minValue={minValue}\n name={`${name}_slider`}\n onBlur={onBlur}\n onChange={onChange}\n showSteps={showSteps}\n size={size}\n startContent={startContent}\n step={step}\n value={currentValue}\n classNames={{\n endContent: classNames.endContent,\n filler: classNames.filler,\n label: classNames.label,\n labelWrapper: classNames.labelWrapper,\n mark: classNames.mark,\n startContent: classNames.startContent,\n step: classNames.step,\n thumb: classNames.thumb,\n track: classNames.track,\n trackWrapper: classNames.trackWrapper,\n value: classNames.value,\n }}\n />\n {invalid ? (\n <div\n {...getHelperWrapperProps()}\n className={cn(\n getHelperWrapperProps()?.className,\n // force helper to be visible (for some reason it's hidden by default) and remove margin\n 'ml-0 block',\n )}\n >\n <div {...getErrorMessageProps()}>{errorMessage}</div>\n </div>\n ) : null}\n </div>\n );\n};\n\nexport default Slider;\n","import Slider from './Slider';\n\nexport type { SliderProps } from './Slider';\n\nexport { Slider };\n\nexport default Slider;\n"],"mappings":";;;;;;;;AAYA,MAAa,iBAAiB,GAAG,EAC/B,OAAO;CACL,MAAM;CACN,YAAY;CACZ,cAAc;CACd,QAAQ;CAGR,OACE;CACF,cAAc;CACd,MAAM;CACN,cAAc;CACd,MAAM;CACN,OAAO;CACP,OAAO;CACP,cAAc;CACd,OAAO;CACR,EACF,CAAC;;;;AAsDF,MAAMA,YAAU,EACd,YAAY,QACZ,aAAa,QACb,aAAa,QACb,MACA,YAAY,OACZ,OAAO,MACP,eAAe,QACf,OAAO,GACP,WAAW,GACX,WAAW,KACX,GAAG,wBACc;CACjB,MAAM,EACJ,WACA,UACA,OACA,sBACA,uBACA,SACA,OACA,QACA,UACA,KACA,UACA,cACA,WACE,gBAAgB;EAClB;EACA,GAAG;EACJ,CAAC;CAGF,MAAM,kBAAkB,OAAuB,KAAK;CAIpD,MAAM,aAAa,qBADF,gBAAgB,EACiB,WAAW,OAAO;CAGpE,MAAM,eAAe,MAAM,SAAS,OAAO,OAAO,MAAM,MAAM,GAAG;AAEjE,QACE,qBAAC;EACC,WAAW,WAAW;EACtB,gBAAc;EACd,iBAAe;EACf,eAAa;;GAGb,oBAAC,4BACC,oBAAC;IACM;IACL,cAAY;IACF;IACV,KAAK;IACL,KAAK;IACC;IACE;IACF;IACN,UAAU;IACV,MAAK;IACL,OAAO;IACP,WAAW,MAAM;AACf,cAAS,OAAO,EAAE,OAAO,MAAM,CAAC;;IAElC,eAAe;AAGb,qBAAgB,SAAS,OAAO;;KAElC,GACa;GAEjB,oBAACC;IACC,KAAK;IACL,cAAY;IACZ,OAAO,UAAU,WAAW;IAChB;IACA;IACZ,YAAY;IACL;IACG;IACA;IACV,MAAM,GAAG,KAAK;IACN;IACE;IACC;IACL;IACQ;IACR;IACN,OAAO;IACP,YAAY;KACV,YAAY,WAAW;KACvB,QAAQ,WAAW;KACnB,OAAO,WAAW;KAClB,cAAc,WAAW;KACzB,MAAM,WAAW;KACjB,cAAc,WAAW;KACzB,MAAM,WAAW;KACjB,OAAO,WAAW;KAClB,OAAO,WAAW;KAClB,cAAc,WAAW;KACzB,OAAO,WAAW;KACnB;KACD;GACD,UACC,oBAAC;IACC,GAAI,uBAAuB;IAC3B,WAAW,GACT,uBAAuB,EAAE,WAEzB,aACD;cAED,oBAAC;KAAI,GAAI,sBAAsB;eAAG;MAAmB;KACjD,GACJ;;GACA;;AAIV,uBAAeD;;;;ACzMf,qBAAeE"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
const require_FormContext = require('./FormContext-CeFKQmVH.cjs');
|
|
2
|
-
const require_useUniformField = require('./useUniformField-
|
|
2
|
+
const require_useUniformField = require('./useUniformField-BJTRfqCQ.cjs');
|
|
3
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");
|
|
@@ -120,4 +120,4 @@ Object.defineProperty(exports, 'Slider_default$1', {
|
|
|
120
120
|
return Slider_default$1;
|
|
121
121
|
}
|
|
122
122
|
});
|
|
123
|
-
//# sourceMappingURL=Slider-
|
|
123
|
+
//# sourceMappingURL=Slider-D-bfkzoh.cjs.map
|