@fuf-stack/uniform 1.11.0 → 1.11.2

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.
Files changed (311) hide show
  1. package/dist/Checkboxes/index.cjs +1 -1
  2. package/dist/Checkboxes/index.d.cts +1 -1
  3. package/dist/Checkboxes/index.d.ts +1 -1
  4. package/dist/Checkboxes/index.js +1 -1
  5. package/dist/{Checkboxes-CGWhnpBp.js → Checkboxes-BY4UK0Xf.js} +6 -6
  6. package/dist/Checkboxes-BY4UK0Xf.js.map +1 -0
  7. package/dist/{Checkboxes-Ds6bzl6p.cjs → Checkboxes-DgCK-Wq-.cjs} +18 -18
  8. package/dist/Checkboxes-DgCK-Wq-.cjs.map +1 -0
  9. package/dist/FieldArray/index.cjs +1 -1
  10. package/dist/FieldArray/index.d.cts +1 -1
  11. package/dist/FieldArray/index.d.ts +1 -1
  12. package/dist/FieldArray/index.js +1 -1
  13. package/dist/{FieldArray-D3iUaRLo.js → FieldArray-CDLaGvNj.js} +8 -8
  14. package/dist/FieldArray-CDLaGvNj.js.map +1 -0
  15. package/dist/{FieldArray-BexXN9bO.cjs → FieldArray-DBsyUQkU.cjs} +49 -49
  16. package/dist/FieldArray-DBsyUQkU.cjs.map +1 -0
  17. package/dist/FieldCard/index.cjs +1 -1
  18. package/dist/FieldCard/index.d.cts +1 -1
  19. package/dist/FieldCard/index.d.ts +1 -1
  20. package/dist/FieldCard/index.js +1 -1
  21. package/dist/{FieldCard-mpmErfDK.js → FieldCard-C1MCSbPW.js} +3 -3
  22. package/dist/{FieldCard-mpmErfDK.js.map → FieldCard-C1MCSbPW.js.map} +1 -1
  23. package/dist/{FieldCard-pP7aniZU.cjs → FieldCard-NKF358fO.cjs} +13 -13
  24. package/dist/{FieldCard-pP7aniZU.cjs.map → FieldCard-NKF358fO.cjs.map} +1 -1
  25. package/dist/{FieldCopyTestIdButton-AaLwu_8y.cjs → FieldCopyTestIdButton-BSYcSo2o.cjs} +10 -10
  26. package/dist/{FieldCopyTestIdButton-AaLwu_8y.cjs.map → FieldCopyTestIdButton-BSYcSo2o.cjs.map} +1 -1
  27. package/dist/{FieldCopyTestIdButton-Cx8AXJhO.js → FieldCopyTestIdButton-DWPCDJ-s.js} +4 -4
  28. package/dist/{FieldCopyTestIdButton-Cx8AXJhO.js.map → FieldCopyTestIdButton-DWPCDJ-s.js.map} +1 -1
  29. package/dist/{FieldValidationError-D86DPSOH.js → FieldValidationError-1hiDEFew.js} +4 -4
  30. package/dist/{FieldValidationError-D86DPSOH.js.map → FieldValidationError-1hiDEFew.js.map} +1 -1
  31. package/dist/{FieldValidationError-Cq6aI0tE.cjs → FieldValidationError-CE8R8qry.cjs} +13 -13
  32. package/dist/{FieldValidationError-Cq6aI0tE.cjs.map → FieldValidationError-CE8R8qry.cjs.map} +1 -1
  33. package/dist/Form/index.cjs +1 -1
  34. package/dist/Form/index.d.ts +1 -1
  35. package/dist/Form/index.js +1 -1
  36. package/dist/{Form-FvN3SXfF.cjs → Form-BsD69fql.cjs} +19 -19
  37. package/dist/{Form-FvN3SXfF.cjs.map → Form-BsD69fql.cjs.map} +1 -1
  38. package/dist/{Form-CFmCTl60.js → Form-DRNEwHsi.js} +4 -4
  39. package/dist/{Form-CFmCTl60.js.map → Form-DRNEwHsi.js.map} +1 -1
  40. package/dist/{FormContext-C3GymQOA.cjs → FormContext-Bb6d8hdG.cjs} +8 -8
  41. package/dist/FormContext-Bb6d8hdG.cjs.map +1 -0
  42. package/dist/FormContext-CN9n_KdE.js.map +1 -1
  43. package/dist/Grid/index.cjs +1 -1
  44. package/dist/Grid/index.d.cts +1 -1
  45. package/dist/Grid/index.d.ts +1 -1
  46. package/dist/Grid/index.js +1 -1
  47. package/dist/{Grid-DG60vYYG.cjs → Grid-D84e76CE.cjs} +8 -8
  48. package/dist/{Grid-DG60vYYG.cjs.map → Grid-D84e76CE.cjs.map} +1 -1
  49. package/dist/{Grid-DEH7Sezi.js → Grid-LRjQlZms.js} +4 -4
  50. package/dist/{Grid-DEH7Sezi.js.map → Grid-LRjQlZms.js.map} +1 -1
  51. package/dist/Input/index.cjs +1 -1
  52. package/dist/Input/index.d.cts +1 -1
  53. package/dist/Input/index.d.ts +1 -1
  54. package/dist/Input/index.js +1 -1
  55. package/dist/{Input--h5t7Sbl.js → Input-DXMWGTBh.js} +5 -5
  56. package/dist/Input-DXMWGTBh.js.map +1 -0
  57. package/dist/{Input-DKfFFOpo.cjs → Input-DeTpxiK_.cjs} +15 -15
  58. package/dist/Input-DeTpxiK_.cjs.map +1 -0
  59. package/dist/RadioBoxes/index.cjs +1 -1
  60. package/dist/RadioBoxes/index.d.cts +1 -1
  61. package/dist/RadioBoxes/index.d.ts +1 -1
  62. package/dist/RadioBoxes/index.js +1 -1
  63. package/dist/{RadioBoxes-7qdHj3ti.js → RadioBoxes-BEln4a-B.js} +5 -5
  64. package/dist/RadioBoxes-BEln4a-B.js.map +1 -0
  65. package/dist/{RadioBoxes-Bd9ahl4i.cjs → RadioBoxes-gsQGqQCd.cjs} +22 -22
  66. package/dist/RadioBoxes-gsQGqQCd.cjs.map +1 -0
  67. package/dist/RadioTabs/index.cjs +1 -1
  68. package/dist/RadioTabs/index.d.cts +1 -1
  69. package/dist/RadioTabs/index.d.ts +1 -1
  70. package/dist/RadioTabs/index.js +1 -1
  71. package/dist/{RadioTabs-DcEUdW7r.cjs → RadioTabs-BYpP0tKA.cjs} +18 -18
  72. package/dist/RadioTabs-BYpP0tKA.cjs.map +1 -0
  73. package/dist/{RadioTabs-DXs98jng.js → RadioTabs-DLr9QiXI.js} +5 -5
  74. package/dist/RadioTabs-DLr9QiXI.js.map +1 -0
  75. package/dist/Radios/index.cjs +1 -1
  76. package/dist/Radios/index.d.cts +1 -1
  77. package/dist/Radios/index.d.ts +1 -1
  78. package/dist/Radios/index.js +1 -1
  79. package/dist/{Radios-CIPNqPzi.cjs → Radios-BCOfnTke.cjs} +14 -14
  80. package/dist/{Radios-CIPNqPzi.cjs.map → Radios-BCOfnTke.cjs.map} +1 -1
  81. package/dist/{Radios-BIx06mzU.js → Radios-DCXI2kMf.js} +5 -5
  82. package/dist/{Radios-BIx06mzU.js.map → Radios-DCXI2kMf.js.map} +1 -1
  83. package/dist/Select/index.cjs +1 -1
  84. package/dist/Select/index.d.cts +1 -1
  85. package/dist/Select/index.d.ts +1 -1
  86. package/dist/Select/index.js +1 -1
  87. package/dist/{Select-CBjqYDcs.js → Select-CyfEmWiD.js} +5 -5
  88. package/dist/Select-CyfEmWiD.js.map +1 -0
  89. package/dist/{Select-BsL7qn2v.cjs → Select-KnPGOO27.cjs} +19 -19
  90. package/dist/Select-KnPGOO27.cjs.map +1 -0
  91. package/dist/Slider/index.cjs +1 -1
  92. package/dist/Slider/index.d.cts +1 -1
  93. package/dist/Slider/index.d.ts +1 -1
  94. package/dist/Slider/index.js +1 -1
  95. package/dist/{Slider-BDLbD7d5.cjs → Slider-C7xxYPgR.cjs} +15 -15
  96. package/dist/{Slider-BDLbD7d5.cjs.map → Slider-C7xxYPgR.cjs.map} +1 -1
  97. package/dist/{Slider-BHjHSoIk.js → Slider-Dlhb-9hC.js} +5 -5
  98. package/dist/{Slider-BHjHSoIk.js.map → Slider-Dlhb-9hC.js.map} +1 -1
  99. package/dist/SubmitButton/index.cjs +1 -1
  100. package/dist/SubmitButton/index.d.cts +1 -1
  101. package/dist/SubmitButton/index.d.ts +1 -1
  102. package/dist/SubmitButton/index.js +1 -1
  103. package/dist/{SubmitButton-7iOaKzhB.js → SubmitButton-C5f6j0N4.js} +4 -4
  104. package/dist/{SubmitButton-7iOaKzhB.js.map → SubmitButton-C5f6j0N4.js.map} +1 -1
  105. package/dist/{SubmitButton-DhtPJuro.cjs → SubmitButton-CUBItcBn.cjs} +12 -12
  106. package/dist/{SubmitButton-DhtPJuro.cjs.map → SubmitButton-CUBItcBn.cjs.map} +1 -1
  107. package/dist/Switch/index.cjs +1 -1
  108. package/dist/Switch/index.d.cts +1 -1
  109. package/dist/Switch/index.d.ts +1 -1
  110. package/dist/Switch/index.js +1 -1
  111. package/dist/{Switch-DCxAgt_L.js → Switch--m02Xcq8.js} +5 -5
  112. package/dist/{Switch-DCxAgt_L.js.map → Switch--m02Xcq8.js.map} +1 -1
  113. package/dist/{Switch-Dczzog3v.cjs → Switch-6LyeZHJh.cjs} +15 -15
  114. package/dist/{Switch-Dczzog3v.cjs.map → Switch-6LyeZHJh.cjs.map} +1 -1
  115. package/dist/SwitchBox/index.cjs +1 -1
  116. package/dist/SwitchBox/index.d.cts +1 -1
  117. package/dist/SwitchBox/index.d.ts +1 -1
  118. package/dist/SwitchBox/index.js +1 -1
  119. package/dist/{SwitchBox-DqVmZYId.cjs → SwitchBox-CtGiQdys.cjs} +19 -19
  120. package/dist/{SwitchBox-DqVmZYId.cjs.map → SwitchBox-CtGiQdys.cjs.map} +1 -1
  121. package/dist/{SwitchBox-DPHryDOM.js → SwitchBox-D0-e-pbM.js} +5 -5
  122. package/dist/{SwitchBox-DPHryDOM.js.map → SwitchBox-D0-e-pbM.js.map} +1 -1
  123. package/dist/TextArea/index.cjs +1 -1
  124. package/dist/TextArea/index.d.cts +1 -1
  125. package/dist/TextArea/index.d.ts +1 -1
  126. package/dist/TextArea/index.js +1 -1
  127. package/dist/{TextArea-BR6e-Fio.js → TextArea-BiSnvJ69.js} +5 -5
  128. package/dist/{TextArea-BR6e-Fio.js.map → TextArea-BiSnvJ69.js.map} +1 -1
  129. package/dist/{TextArea-CH-F6_ax.cjs → TextArea-PtdSABZS.cjs} +13 -13
  130. package/dist/{TextArea-CH-F6_ax.cjs.map → TextArea-PtdSABZS.cjs.map} +1 -1
  131. package/dist/helpers/index.cjs +1 -1
  132. package/dist/helpers-B-CJOBt3.js.map +1 -1
  133. package/dist/{helpers-KTgXi0lA.cjs → helpers-B84E9vHd.cjs} +4 -4
  134. package/dist/helpers-B84E9vHd.cjs.map +1 -0
  135. package/dist/hooks/useClientValidation/index.cjs +1 -1
  136. package/dist/hooks/useClientValidation/index.d.cts +1 -1
  137. package/dist/hooks/useClientValidation/index.d.ts +1 -1
  138. package/dist/hooks/useController/index.cjs +1 -1
  139. package/dist/hooks/useController/index.d.ts +0 -1
  140. package/dist/hooks/useFormContext/index.cjs +1 -1
  141. package/dist/hooks/useFormContext/index.d.cts +1 -1
  142. package/dist/hooks/useFormContext/index.d.ts +2 -2
  143. package/dist/hooks/useInput/index.cjs +3 -3
  144. package/dist/hooks/useInput/index.d.cts +1 -1
  145. package/dist/hooks/useInput/index.d.ts +1 -1
  146. package/dist/hooks/useInputValueDebounce/index.cjs +1 -1
  147. package/dist/hooks/useInputValueDebounce/index.d.cts +1 -1
  148. package/dist/hooks/useInputValueDebounce/index.d.ts +1 -1
  149. package/dist/hooks/useInputValueTransform/index.cjs +1 -1
  150. package/dist/hooks/useUniformField/index.cjs +1 -1
  151. package/dist/hooks/useUniformField/index.d.cts +1 -1
  152. package/dist/hooks/useUniformField/index.d.ts +3 -3
  153. package/dist/hooks/useUniformField/index.js +1 -1
  154. package/dist/hooks/useUniformFieldArray/index.cjs +1 -1
  155. package/dist/hooks/useUniformFieldArray/index.d.cts +1 -1
  156. package/dist/hooks/useUniformFieldArray/index.d.ts +24 -4
  157. package/dist/hooks/useUniformFieldArray/index.js +1 -1
  158. package/dist/hooks/useWatchUserChange/index.cjs +1 -1
  159. package/dist/{index-CzypMcVS.d.cts → index--E2ZsMya.d.ts} +6 -6
  160. package/dist/{index-C_ATGeaX.d.ts.map → index--E2ZsMya.d.ts.map} +1 -1
  161. package/dist/{index-C56I3SOi.d.cts → index-BITJ-CZL.d.cts} +4 -4
  162. package/dist/{index-C56I3SOi.d.cts.map → index-BITJ-CZL.d.cts.map} +1 -1
  163. package/dist/{index-CVY05bZf.d.ts → index-BL0DnIzh.d.ts} +3 -3
  164. package/dist/{index-CVY05bZf.d.ts.map → index-BL0DnIzh.d.ts.map} +1 -1
  165. package/dist/{index-CHmS3ri3.d.ts → index-BQDEnYTq.d.ts} +1 -1
  166. package/dist/{index-CHmS3ri3.d.ts.map → index-BQDEnYTq.d.ts.map} +1 -1
  167. package/dist/{index-DHHBSmJb.d.ts → index-BTTo_ufh.d.ts} +1 -1
  168. package/dist/{index-DHHBSmJb.d.ts.map → index-BTTo_ufh.d.ts.map} +1 -1
  169. package/dist/{index-B74QlCAy.d.cts → index-BWNJdLDV.d.ts} +48 -48
  170. package/dist/{index-B4Wkijem.d.ts.map → index-BWNJdLDV.d.ts.map} +1 -1
  171. package/dist/{index-CraZe1qS.d.ts → index-Bj_lpc5r.d.cts} +21 -21
  172. package/dist/{index-CI9QBUoM.d.cts.map → index-Bj_lpc5r.d.cts.map} +1 -1
  173. package/dist/{index-B4Wkijem.d.ts → index-Bo_n9sse.d.cts} +47 -47
  174. package/dist/{index-B74QlCAy.d.cts.map → index-Bo_n9sse.d.cts.map} +1 -1
  175. package/dist/{index-iuLEYAix.d.cts → index-BxA_pJWn.d.cts} +21 -21
  176. package/dist/{index-iuLEYAix.d.cts.map → index-BxA_pJWn.d.cts.map} +1 -1
  177. package/dist/{index-Drl7euco.d.ts → index-C-2nxT8D.d.ts} +21 -21
  178. package/dist/{index-Drl7euco.d.ts.map → index-C-2nxT8D.d.ts.map} +1 -1
  179. package/dist/{index-C1fYmoY0.d.ts → index-C0L7GvgN.d.cts} +34 -34
  180. package/dist/index-C0L7GvgN.d.cts.map +1 -0
  181. package/dist/{index-DzuP5q-2.d.ts → index-C1PUx1tH.d.ts} +6 -6
  182. package/dist/index-C1PUx1tH.d.ts.map +1 -0
  183. package/dist/index-CADnFWHq.d.ts +264 -0
  184. package/dist/{index-BTEsKen4.d.ts.map → index-CADnFWHq.d.ts.map} +1 -1
  185. package/dist/{index-BM4XWo1K.d.ts → index-CGnr_e53.d.ts} +36 -36
  186. package/dist/{index-BM4XWo1K.d.ts.map → index-CGnr_e53.d.ts.map} +1 -1
  187. package/dist/{index-DhMSgdwM.d.ts → index-CSBE6Et0.d.cts} +6 -6
  188. package/dist/{index-Dklb-p_1.d.cts.map → index-CSBE6Et0.d.cts.map} +1 -1
  189. package/dist/{index-D6RB3b5L.d.ts → index-CVnn6mEI.d.ts} +4 -4
  190. package/dist/{index-D6RB3b5L.d.ts.map → index-CVnn6mEI.d.ts.map} +1 -1
  191. package/dist/{index-BMN2XNyT.d.cts → index-CYdvpGJF.d.cts} +3 -3
  192. package/dist/{index-BMN2XNyT.d.cts.map → index-CYdvpGJF.d.cts.map} +1 -1
  193. package/dist/{index-CbAh0Kfo.d.cts → index-Cb0AgRRa.d.cts} +3 -3
  194. package/dist/{index-CbAh0Kfo.d.cts.map → index-Cb0AgRRa.d.cts.map} +1 -1
  195. package/dist/{index-DA5um0u6.d.cts → index-D38wOL-M.d.ts} +34 -34
  196. package/dist/index-D38wOL-M.d.ts.map +1 -0
  197. package/dist/{index-DpD4MxGD.d.cts → index-DG9C0kHA.d.ts} +35 -34
  198. package/dist/{index-RvYO46Vg.d.ts.map → index-DG9C0kHA.d.ts.map} +1 -1
  199. package/dist/{index-RvYO46Vg.d.ts → index-DNkZrb7P.d.cts} +35 -36
  200. package/dist/{index-DpD4MxGD.d.cts.map → index-DNkZrb7P.d.cts.map} +1 -1
  201. package/dist/{index-C_ATGeaX.d.ts → index-DRij_w43.d.cts} +5 -5
  202. package/dist/{index-CzypMcVS.d.cts.map → index-DRij_w43.d.cts.map} +1 -1
  203. package/dist/{index-Dklb-p_1.d.cts → index-DmMenZfj.d.ts} +5 -5
  204. package/dist/{index-DhMSgdwM.d.ts.map → index-DmMenZfj.d.ts.map} +1 -1
  205. package/dist/{index-CI9QBUoM.d.cts → index-DnzC0GCS.d.ts} +3 -3
  206. package/dist/index-DnzC0GCS.d.ts.map +1 -0
  207. package/dist/{index-BOI0cy-n.d.cts → index-DoS0lVRe.d.cts} +34 -34
  208. package/dist/index-DoS0lVRe.d.cts.map +1 -0
  209. package/dist/{index-aHcGnXHf.d.ts → index-DvB46QAb.d.ts} +3 -3
  210. package/dist/{index-aHcGnXHf.d.ts.map → index-DvB46QAb.d.ts.map} +1 -1
  211. package/dist/{index-BW9EUWZE.d.cts → index-DxdaxM3o.d.cts} +3 -3
  212. package/dist/{index-BW9EUWZE.d.cts.map → index-DxdaxM3o.d.cts.map} +1 -1
  213. package/dist/{index-CQWoxgWk.d.ts → index-Edx7MxXu.d.ts} +3 -3
  214. package/dist/{index-CQWoxgWk.d.ts.map → index-Edx7MxXu.d.ts.map} +1 -1
  215. package/dist/{index-BaBZGCqS.d.cts → index-F11geOHD.d.ts} +6 -6
  216. package/dist/{index-CvA5yKx9.d.ts.map → index-F11geOHD.d.ts.map} +1 -1
  217. package/dist/{index-1gPh6Uoh.d.cts → index-PU5WNOH9.d.cts} +3 -3
  218. package/dist/{index-1gPh6Uoh.d.cts.map → index-PU5WNOH9.d.cts.map} +1 -1
  219. package/dist/{index-CO-l7RmT.d.cts → index-WogV9uVV.d.cts} +6 -6
  220. package/dist/{index-CO-l7RmT.d.cts.map → index-WogV9uVV.d.cts.map} +1 -1
  221. package/dist/{index-CvA5yKx9.d.ts → index-oyX8xu0F.d.cts} +4 -4
  222. package/dist/{index-BaBZGCqS.d.cts.map → index-oyX8xu0F.d.cts.map} +1 -1
  223. package/dist/index-sJZ434Sg.d.cts +264 -0
  224. package/dist/index-sJZ434Sg.d.cts.map +1 -0
  225. package/dist/index.cjs +29 -29
  226. package/dist/index.d.cts +22 -22
  227. package/dist/index.d.ts +24 -25
  228. package/dist/index.js +19 -19
  229. package/dist/partials/FieldCopyTestIdButton/index.cjs +1 -1
  230. package/dist/partials/FieldCopyTestIdButton/index.d.cts +1 -1
  231. package/dist/partials/FieldCopyTestIdButton/index.d.ts +1 -1
  232. package/dist/partials/FieldCopyTestIdButton/index.js +1 -1
  233. package/dist/partials/FieldValidationError/index.cjs +1 -1
  234. package/dist/partials/FieldValidationError/index.d.cts +1 -1
  235. package/dist/partials/FieldValidationError/index.d.ts +1 -1
  236. package/dist/partials/FieldValidationError/index.js +1 -1
  237. package/dist/{useClientValidation-CkBtUSco.d.ts → useClientValidation-BQqwz628.d.cts} +3 -3
  238. package/dist/{useClientValidation-C3Q5UCy9.d.cts.map → useClientValidation-BQqwz628.d.cts.map} +1 -1
  239. package/dist/useClientValidation-BnnscAEe.js.map +1 -1
  240. package/dist/{useClientValidation-oZd4_ocQ.cjs → useClientValidation-CmYVGlLr.cjs} +7 -7
  241. package/dist/useClientValidation-CmYVGlLr.cjs.map +1 -0
  242. package/dist/{useClientValidation-C3Q5UCy9.d.cts → useClientValidation-DJ4JuN_9.d.ts} +3 -3
  243. package/dist/{useClientValidation-CkBtUSco.d.ts.map → useClientValidation-DJ4JuN_9.d.ts.map} +1 -1
  244. package/dist/{useController-BzkCcbSo.cjs → useController-CkmO5CLh.cjs} +3 -3
  245. package/dist/{useController-BzkCcbSo.cjs.map → useController-CkmO5CLh.cjs.map} +1 -1
  246. package/dist/{useFormContext-CZh7pv8f.d.cts → useFormContext-B083Y-kw.d.cts} +17 -17
  247. package/dist/{useFormContext-CZh7pv8f.d.cts.map → useFormContext-B083Y-kw.d.cts.map} +1 -1
  248. package/dist/{useFormContext-3AAPT6eZ.d.ts → useFormContext-B2TS6xq0.d.ts} +1 -1
  249. package/dist/{useFormContext-3AAPT6eZ.d.ts.map → useFormContext-B2TS6xq0.d.ts.map} +1 -1
  250. package/dist/{useFormContext-CWuN-_7P.cjs → useFormContext-Bp0EODoO.cjs} +3 -3
  251. package/dist/useFormContext-Bp0EODoO.cjs.map +1 -0
  252. package/dist/useFormContext-JCm1UR_e.js.map +1 -1
  253. package/dist/{useInputValueDebounce-B2RzCWty.d.cts → useInputValueDebounce-B5b-v8Hc.d.cts} +1 -1
  254. package/dist/{useInputValueDebounce-B2RzCWty.d.cts.map → useInputValueDebounce-B5b-v8Hc.d.cts.map} +1 -1
  255. package/dist/{useInputValueDebounce-tL8maIp8.cjs → useInputValueDebounce-BcUyaS94.cjs} +2 -2
  256. package/dist/{useInputValueDebounce-tL8maIp8.cjs.map → useInputValueDebounce-BcUyaS94.cjs.map} +1 -1
  257. package/dist/{useInputValueDebounce-C7_bvNGH.d.ts → useInputValueDebounce-DoRuSF6R.d.ts} +1 -1
  258. package/dist/{useInputValueDebounce-C7_bvNGH.d.ts.map → useInputValueDebounce-DoRuSF6R.d.ts.map} +1 -1
  259. package/dist/{useInputValueTransform-C-uSW8Y3.cjs → useInputValueTransform-DFPA3KVy.cjs} +2 -2
  260. package/dist/{useInputValueTransform-C-uSW8Y3.cjs.map → useInputValueTransform-DFPA3KVy.cjs.map} +1 -1
  261. package/dist/{useUniformField-Be3kdnhK.d.cts → useUniformField-B2OZ-Z1G.d.cts} +3 -3
  262. package/dist/{useUniformField-Be3kdnhK.d.cts.map → useUniformField-B2OZ-Z1G.d.cts.map} +1 -1
  263. package/dist/{useUniformField-BMvnRC_r.cjs → useUniformField-Bj23Kvbs.cjs} +13 -13
  264. package/dist/useUniformField-Bj23Kvbs.cjs.map +1 -0
  265. package/dist/{useUniformField-DDHQ5B11.d.ts → useUniformField-CwEHonNe.d.ts} +3 -3
  266. package/dist/{useUniformField-DDHQ5B11.d.ts.map → useUniformField-CwEHonNe.d.ts.map} +1 -1
  267. package/dist/{useUniformField-ClprfrES.js → useUniformField-gU4qYUwL.js} +3 -3
  268. package/dist/useUniformField-gU4qYUwL.js.map +1 -0
  269. package/dist/{useUniformFieldArray-C-0OXG3N.js → useUniformFieldArray-B5PyxL1P.js} +2 -2
  270. package/dist/{useUniformFieldArray-C-0OXG3N.js.map → useUniformFieldArray-B5PyxL1P.js.map} +1 -1
  271. package/dist/{useUniformFieldArray-BhPi3gPv.d.ts → useUniformFieldArray-CXoWvu6m.d.ts} +3 -3
  272. package/dist/{useUniformFieldArray-BhPi3gPv.d.ts.map → useUniformFieldArray-CXoWvu6m.d.ts.map} +1 -1
  273. package/dist/{useUniformFieldArray-btjvJdZ6.cjs → useUniformFieldArray-G1lokW7x.cjs} +7 -7
  274. package/dist/{useUniformFieldArray-btjvJdZ6.cjs.map → useUniformFieldArray-G1lokW7x.cjs.map} +1 -1
  275. package/dist/{useUniformFieldArray-BBFw08qL.d.cts → useUniformFieldArray-qtJMEosJ.d.cts} +13 -13
  276. package/dist/{useUniformFieldArray-BBFw08qL.d.cts.map → useUniformFieldArray-qtJMEosJ.d.cts.map} +1 -1
  277. package/dist/{useWatchUserChange-C5dr12By.cjs → useWatchUserChange-BnxYE-0b.cjs} +3 -3
  278. package/dist/{useWatchUserChange-C5dr12By.cjs.map → useWatchUserChange-BnxYE-0b.cjs.map} +1 -1
  279. package/package.json +10 -10
  280. package/dist/Checkboxes-CGWhnpBp.js.map +0 -1
  281. package/dist/Checkboxes-Ds6bzl6p.cjs.map +0 -1
  282. package/dist/FieldArray-BexXN9bO.cjs.map +0 -1
  283. package/dist/FieldArray-D3iUaRLo.js.map +0 -1
  284. package/dist/FormContext-C3GymQOA.cjs.map +0 -1
  285. package/dist/Input--h5t7Sbl.js.map +0 -1
  286. package/dist/Input-DKfFFOpo.cjs.map +0 -1
  287. package/dist/RadioBoxes-7qdHj3ti.js.map +0 -1
  288. package/dist/RadioBoxes-Bd9ahl4i.cjs.map +0 -1
  289. package/dist/RadioTabs-DXs98jng.js.map +0 -1
  290. package/dist/RadioTabs-DcEUdW7r.cjs.map +0 -1
  291. package/dist/Select-BsL7qn2v.cjs.map +0 -1
  292. package/dist/Select-CBjqYDcs.js.map +0 -1
  293. package/dist/helpers-KTgXi0lA.cjs.map +0 -1
  294. package/dist/index-BOI0cy-n.d.cts.map +0 -1
  295. package/dist/index-BTEsKen4.d.ts +0 -264
  296. package/dist/index-C1fYmoY0.d.ts.map +0 -1
  297. package/dist/index-CJNLQVjx.d.ts +0 -1
  298. package/dist/index-CqV2Q3da.d.cts +0 -264
  299. package/dist/index-CqV2Q3da.d.cts.map +0 -1
  300. package/dist/index-CraZe1qS.d.ts.map +0 -1
  301. package/dist/index-CwSIy_W-.d.cts +0 -1
  302. package/dist/index-DA5um0u6.d.cts.map +0 -1
  303. package/dist/index-DzuP5q-2.d.ts.map +0 -1
  304. package/dist/useClientValidation-oZd4_ocQ.cjs.map +0 -1
  305. package/dist/useFormContext-CWuN-_7P.cjs.map +0 -1
  306. package/dist/useUniformField-BMvnRC_r.cjs.map +0 -1
  307. package/dist/useUniformField-ClprfrES.js.map +0 -1
  308. /package/dist/{index-B3Z8gdjC.d.ts → index-BRLjimYW.d.ts} +0 -0
  309. /package/dist/{index-BXpMZvwA.d.cts → index-DpEKQcoR.d.cts} +0 -0
  310. /package/dist/{useInput-IGJqJ2tR.d.ts → useInput--wjwIBc5.d.cts} +0 -0
  311. /package/dist/{useInput-NMHJNZ5A.d.cts → useInput-BCdeYOOg.d.ts} +0 -0
@@ -1,13 +1,13 @@
1
- const require_FormContext = require('./FormContext-C3GymQOA.cjs');
2
- const require_useUniformField = require('./useUniformField-BMvnRC_r.cjs');
3
- const require_useInputValueDebounce = require('./useInputValueDebounce-tL8maIp8.cjs');
4
- let __fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
1
+ const require_FormContext = require('./FormContext-Bb6d8hdG.cjs');
2
+ const require_useUniformField = require('./useUniformField-Bj23Kvbs.cjs');
3
+ const require_useInputValueDebounce = require('./useInputValueDebounce-BcUyaS94.cjs');
4
+ let _fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
5
5
  let react_jsx_runtime = require("react/jsx-runtime");
6
- let __heroui_input = require("@heroui/input");
7
- let __heroui_number_input = require("@heroui/number-input");
6
+ let _heroui_input = require("@heroui/input");
7
+ let _heroui_number_input = require("@heroui/number-input");
8
8
 
9
9
  //#region src/Input/Input.tsx
10
- const inputVariants = (0, __fuf_stack_pixel_utils.tv)({ slots: {
10
+ const inputVariants = (0, _fuf_stack_pixel_utils.tv)({ slots: {
11
11
  base: "",
12
12
  clearButton: "",
13
13
  input: "",
@@ -35,7 +35,7 @@ const Input = ({ className: _className = void 0, clearable = false, debounceDela
35
35
  if (onClear) onClear();
36
36
  }
37
37
  } : {};
38
- const classNames = (0, __fuf_stack_pixel_utils.variantsToClassNames)(inputVariants(), _className, "base");
38
+ const classNames = (0, _fuf_stack_pixel_utils.variantsToClassNames)(inputVariants(), _className, "base");
39
39
  const commonProps = {
40
40
  ref,
41
41
  "aria-label": !placeholder || placeholder.trim() === "" ? ariaLabel : void 0,
@@ -67,7 +67,7 @@ const Input = ({ className: _className = void 0, clearable = false, debounceDela
67
67
  };
68
68
  if (type === "number") {
69
69
  const numberValue = value !== "" && value != null && !Number.isNaN(Number(value)) ? Number(value) : null;
70
- return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__heroui_number_input.NumberInput, {
70
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_heroui_number_input.NumberInput, {
71
71
  ...commonProps,
72
72
  value: numberValue,
73
73
  formatOptions: { useGrouping: false },
@@ -77,30 +77,30 @@ const Input = ({ className: _className = void 0, clearable = false, debounceDela
77
77
  }
78
78
  });
79
79
  }
80
- return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(__heroui_input.Input, {
80
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_heroui_input.Input, {
81
81
  ...commonProps,
82
82
  onChange,
83
83
  type,
84
84
  value
85
85
  });
86
86
  };
87
- var Input_default = Input;
87
+ var Input_default$1 = Input;
88
88
 
89
89
  //#endregion
90
90
  //#region src/Input/index.ts
91
- var Input_default$1 = Input_default;
91
+ var Input_default = Input_default$1;
92
92
 
93
93
  //#endregion
94
94
  Object.defineProperty(exports, 'Input_default', {
95
95
  enumerable: true,
96
96
  get: function () {
97
- return Input_default$1;
97
+ return Input_default;
98
98
  }
99
99
  });
100
100
  Object.defineProperty(exports, 'Input_default$1', {
101
101
  enumerable: true,
102
102
  get: function () {
103
- return Input_default;
103
+ return Input_default$1;
104
104
  }
105
105
  });
106
- //# sourceMappingURL=Input-DKfFFOpo.cjs.map
106
+ //# sourceMappingURL=Input-DeTpxiK_.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Input-DeTpxiK_.cjs","names":["useUniformField","useInputValueDebounce","HeroNumberInput","HeroInput","Input"],"sources":["../src/Input/Input.tsx","../src/Input/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { InputProps as HeroInputProps } from '@heroui/input';\nimport type { ReactNode } from 'react';\nimport type { InputValueTransform } from '../hooks/useInputValueTransform';\n\nimport { Input as HeroInput } from '@heroui/input';\nimport { NumberInput as HeroNumberInput } from '@heroui/number-input';\n\nimport { tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { useInputValueDebounce } from '../hooks/useInputValueDebounce';\nimport { useUniformField } from '../hooks/useUniformField';\n\n// input variants\nexport const inputVariants = tv({\n slots: {\n /** wrapper around the whole input */\n base: '',\n /** clear button */\n clearButton: '',\n /** actual input element */\n input: '',\n /** inner wrapper (HeroUI inputWrapper slot) */\n inputWrapper: 'bg-content1 group-data-[focus=true]:border-focus',\n },\n});\n\ntype VariantProps = TVProps<typeof inputVariants>;\ntype ClassName = TVClassName<typeof inputVariants>;\n\nexport interface InputProps 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 /** shows clear button when input has value */\n clearable?: boolean;\n /** debounce delay in milliseconds for form state updates (default: 300ms) */\n debounceDelay?: number;\n /** input field is disabled */\n disabled?: boolean;\n /** added content to the end of the input Field. */\n endContent?: ReactNode;\n /** form field label */\n label?: ReactNode;\n /** form field name */\n name: string;\n /** callback that is fired when the value is cleared */\n onClear?: () => void;\n /** form field placeholder */\n placeholder?: string;\n /** size of the input */\n size?: 'sm' | 'md' | 'lg';\n /** content added to the start of the input field */\n startContent?: ReactNode;\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n /** allows disentangled display and form values for a field */\n transform?: InputValueTransform<string>;\n /** input type */\n type?: 'number' | 'password';\n}\n\n/**\n * Input component based on [HeroUI Input](https://www.heroui.com//docs/components/input)\n */\nconst Input = ({\n className: _className = undefined,\n clearable = false,\n debounceDelay = 300,\n endContent = undefined,\n name,\n onClear = undefined,\n placeholder = ' ',\n size = undefined,\n startContent = undefined,\n type = undefined,\n ...uniformFieldProps\n}: InputProps) => {\n const {\n ariaLabel,\n disabled,\n field: {\n onChange: fieldOnChange,\n onBlur: fieldOnBlur,\n value: fieldValue,\n ref,\n },\n errorMessage,\n invalid,\n label,\n required,\n testId,\n resetField,\n } = useUniformField({ name, type, ...uniformFieldProps });\n\n // Use hook that provides debounced onChange and enhanced blur handling\n const { onChange, onBlur, value } = useInputValueDebounce({\n debounceDelay,\n onBlur: fieldOnBlur,\n onChange: fieldOnChange,\n value: fieldValue,\n });\n\n // If input is clearable add props for clearing input value\n const clearableProps: Pick<HeroInputProps, 'isClearable' | 'onClear'> =\n clearable\n ? {\n isClearable: true,\n onClear: () => {\n // if field had initial value we do not reset it\n // to that value, but clear it instead\n resetField(name, { defaultValue: null });\n // if onClear cb provided we call it\n if (onClear) {\n onClear();\n }\n },\n }\n : {};\n\n // classNames from slots\n const variants = inputVariants();\n const classNames = variantsToClassNames(variants, _className, 'base');\n\n // Common props for both Input and NumberInput\n const commonProps = {\n ref,\n // Only add aria-label if there's no meaningful placeholder (HeroUI uses placeholder as aria-label)\n 'aria-label':\n !placeholder || placeholder.trim() === '' ? ariaLabel : undefined,\n // disable autocomplete\n autoComplete: 'off',\n classNames: {\n base: classNames.base,\n clearButton: classNames.clearButton,\n // set padding to 0 for error message exit animation\n helperWrapper: 'p-0',\n input: classNames.input,\n inputWrapper: classNames.inputWrapper,\n },\n 'data-testid': testId,\n endContent,\n errorMessage,\n id: testId,\n isDisabled: disabled,\n isInvalid: invalid,\n isRequired: required,\n label,\n labelPlacement: 'outside' as const,\n name,\n onBlur,\n placeholder,\n radius: 'sm' as const,\n size,\n startContent,\n variant: 'bordered' as const,\n ...clearableProps,\n };\n\n // Render NumberInput for number type\n if (type === 'number') {\n // Parse the string value to number - use null for empty/cleared state to keep component controlled\n const numberValue =\n value !== '' && value != null && !Number.isNaN(Number(value))\n ? Number(value)\n : null;\n\n return (\n <HeroNumberInput\n {...commonProps}\n // @ts-expect-error - HeroUI NumberInput type is not compatible with null,\n // but it needs to be for empty/cleared state to be controlled\n value={numberValue}\n // Disable thousands separator to avoid parsing issues\n formatOptions={{\n useGrouping: false,\n }}\n // NumberInput onChange receives either an event or a number\n onChange={(e: React.ChangeEvent<HTMLInputElement> | number) => {\n if (typeof e === 'number') {\n // Convert number to synthetic event and pass through debounced onChange\n onChange({\n target: { value: String(e) },\n } as React.ChangeEvent<HTMLInputElement>);\n } else {\n // Pass event through debounced onChange\n onChange(e);\n }\n }}\n />\n );\n }\n\n // Render regular Input for text/password\n return (\n <HeroInput {...commonProps} onChange={onChange} type={type} value={value} />\n );\n};\n\nexport default Input;\n","import Input from './Input';\n\nexport type { InputProps } from './Input';\n\nexport { Input };\n\nexport default Input;\n"],"mappings":";;;;;;;;;AAcA,MAAa,+CAAmB,EAC9B,OAAO;CAEL,MAAM;CAEN,aAAa;CAEb,OAAO;CAEP,cAAc;CACf,EACF,CAAC;;;;AAyCF,MAAM,SAAS,EACb,WAAW,aAAa,QACxB,YAAY,OACZ,gBAAgB,KAChB,aAAa,QACb,MACA,UAAU,QACV,cAAc,KACd,OAAO,QACP,eAAe,QACf,OAAO,QACP,GAAG,wBACa;CAChB,MAAM,EACJ,WACA,UACA,OAAO,EACL,UAAU,eACV,QAAQ,aACR,OAAO,YACP,OAEF,cACA,SACA,OACA,UACA,QACA,eACEA,wCAAgB;EAAE;EAAM;EAAM,GAAG;EAAmB,CAAC;CAGzD,MAAM,EAAE,UAAU,QAAQ,UAAUC,oDAAsB;EACxD;EACA,QAAQ;EACR,UAAU;EACV,OAAO;EACR,CAAC;CAGF,MAAM,iBACJ,YACI;EACE,aAAa;EACb,eAAe;AAGb,cAAW,MAAM,EAAE,cAAc,MAAM,CAAC;AAExC,OAAI,QACF,UAAS;;EAGd,GACD,EAAE;CAIR,MAAM,8DADW,eAAe,EACkB,YAAY,OAAO;CAGrE,MAAM,cAAc;EAClB;EAEA,cACE,CAAC,eAAe,YAAY,MAAM,KAAK,KAAK,YAAY;EAE1D,cAAc;EACd,YAAY;GACV,MAAM,WAAW;GACjB,aAAa,WAAW;GAExB,eAAe;GACf,OAAO,WAAW;GAClB,cAAc,WAAW;GAC1B;EACD,eAAe;EACf;EACA;EACA,IAAI;EACJ,YAAY;EACZ,WAAW;EACX,YAAY;EACZ;EACA,gBAAgB;EAChB;EACA;EACA;EACA,QAAQ;EACR;EACA;EACA,SAAS;EACT,GAAG;EACJ;AAGD,KAAI,SAAS,UAAU;EAErB,MAAM,cACJ,UAAU,MAAM,SAAS,QAAQ,CAAC,OAAO,MAAM,OAAO,MAAM,CAAC,GACzD,OAAO,MAAM,GACb;AAEN,SACE,2CAACC;GACC,GAAI;GAGJ,OAAO;GAEP,eAAe,EACb,aAAa,OACd;GAED,WAAW,MAAoD;AAC7D,QAAI,OAAO,MAAM,SAEf,UAAS,EACP,QAAQ,EAAE,OAAO,OAAO,EAAE,EAAE,EAC7B,CAAwC;QAGzC,UAAS,EAAE;;IAGf;;AAKN,QACE,2CAACC;EAAU,GAAI;EAAuB;EAAgB;EAAa;GAAS;;AAIhF,sBAAe;;;;AClMf,oBAAeC"}
@@ -1,5 +1,5 @@
1
1
  Object.defineProperty(exports, '__esModule', { value: true });
2
- const require_RadioBoxes = require('../RadioBoxes-Bd9ahl4i.cjs');
2
+ const require_RadioBoxes = require('../RadioBoxes-gsQGqQCd.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-DpD4MxGD.cjs";
1
+ import { n as RadioBoxes, r as RadioBoxesProps, t as radioBoxVariants } from "../index-DNkZrb7P.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-RvYO46Vg.js";
1
+ import { n as RadioBoxes, r as RadioBoxesProps, t as radioBoxVariants } from "../index-DG9C0kHA.js";
2
2
  export { RadioBoxes, RadioBoxes as default, RadioBoxesProps, radioBoxVariants };
@@ -1,3 +1,3 @@
1
- import { n as RadioBoxes_default, r as radioBoxVariants, t as RadioBoxes_default$1 } from "../RadioBoxes-7qdHj3ti.js";
1
+ import { n as RadioBoxes_default, r as radioBoxVariants, t as RadioBoxes_default$1 } from "../RadioBoxes-BEln4a-B.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-ClprfrES.js";
1
+ import { t as useUniformField } from "./useUniformField-gU4qYUwL.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$1 = 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$1 as t };
138
- //# sourceMappingURL=RadioBoxes-7qdHj3ti.js.map
137
+ export { RadioBoxes_default$1 as n, radioBoxVariants as r, RadioBoxes_default as t };
138
+ //# sourceMappingURL=RadioBoxes-BEln4a-B.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioBoxes-BEln4a-B.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-C3GymQOA.cjs');
2
- const require_useUniformField = require('./useUniformField-BMvnRC_r.cjs');
3
- let __fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
1
+ const require_FormContext = require('./FormContext-Bb6d8hdG.cjs');
2
+ const require_useUniformField = require('./useUniformField-Bj23Kvbs.cjs');
3
+ let _fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
4
4
  let react_jsx_runtime = require("react/jsx-runtime");
5
- let __heroui_radio = require("@heroui/radio");
6
- let __react_aria_visually_hidden = require("@react-aria/visually-hidden");
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, __fuf_stack_pixel_utils.tv)({
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, __heroui_radio.useRadio)(props);
25
- const classNames = (0, __fuf_stack_pixel_utils.variantsToClassNames)(radioBoxVariants({
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)(__react_aria_visually_hidden.VisuallyHidden, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("input", { ...getInputProps() }) }),
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, __fuf_stack_pixel_utils.cn)(getControlProps().className, classNames.control)
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, __fuf_stack_pixel_utils.cn)(getLabelWrapperProps().className, classNames.labelWrapper),
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, __fuf_stack_pixel_utils.cn)(getLabelProps().className, classNames.label),
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, __fuf_stack_pixel_utils.cn)(getControlProps().className, classNames.control)
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, __fuf_stack_pixel_utils.tv)({ slots: {
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, __fuf_stack_pixel_utils.variantsToClassNames)(radioBoxesVariants(), className, "base");
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)(__heroui_radio.RadioGroup, {
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, __fuf_stack_pixel_utils.slugify)(`${testId}_option_${option.testId ?? option.value}`, { replaceDots: true });
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$1 = 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$1;
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-Bd9ahl4i.cjs.map
156
+ //# sourceMappingURL=RadioBoxes-gsQGqQCd.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioBoxes-gsQGqQCd.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"}
@@ -1,5 +1,5 @@
1
1
  Object.defineProperty(exports, '__esModule', { value: true });
2
- const require_RadioTabs = require('../RadioTabs-DcEUdW7r.cjs');
2
+ const require_RadioTabs = require('../RadioTabs-BYpP0tKA.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-C56I3SOi.cjs";
1
+ import { n as RadioTabsProps, t as RadioTabs } from "../index-BITJ-CZL.cjs";
2
2
  export { RadioTabs, RadioTabs as default, RadioTabsProps };
@@ -1,2 +1,2 @@
1
- import { n as RadioTabsProps, t as RadioTabs } from "../index-D6RB3b5L.js";
1
+ import { n as RadioTabsProps, t as RadioTabs } from "../index-CVnn6mEI.js";
2
2
  export { RadioTabs, RadioTabs as default, RadioTabsProps };
@@ -1,3 +1,3 @@
1
- import { n as RadioTabs_default, t as RadioTabs_default$1 } from "../RadioTabs-DXs98jng.js";
1
+ import { n as RadioTabs_default, t as RadioTabs_default$1 } from "../RadioTabs-DLr9QiXI.js";
2
2
 
3
3
  export { RadioTabs_default as RadioTabs, RadioTabs_default$1 as default };
@@ -1,15 +1,15 @@
1
- const require_FormContext = require('./FormContext-C3GymQOA.cjs');
2
- const require_useUniformField = require('./useUniformField-BMvnRC_r.cjs');
3
- let __fuf_stack_pixel_utils = require("@fuf-stack/pixel-utils");
1
+ const require_FormContext = require('./FormContext-Bb6d8hdG.cjs');
2
+ const require_useUniformField = require('./useUniformField-Bj23Kvbs.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 __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);
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, __fuf_stack_pixel_utils.tv)({
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, __fuf_stack_pixel_utils.slugify)(`option_${option?.testId ?? option?.value}`, { replaceDots: true })
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, __fuf_stack_pixel_utils.variantsToClassNames)(radioTabsVariants({
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)(__react_aria_visually_hidden.VisuallyHidden, { children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)("input", {
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)(__heroui_radio.RadioGroup, {
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)(__fuf_stack_pixels_Tabs.default, {
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$1 = 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$1;
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-DcEUdW7r.cjs.map
132
+ //# sourceMappingURL=RadioTabs-BYpP0tKA.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioTabs-BYpP0tKA.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-ClprfrES.js";
1
+ import { t as useUniformField } from "./useUniformField-gU4qYUwL.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$1 = RadioTabs_default;
115
+ var RadioTabs_default = RadioTabs_default$1;
116
116
 
117
117
  //#endregion
118
- export { RadioTabs_default as n, RadioTabs_default$1 as t };
119
- //# sourceMappingURL=RadioTabs-DXs98jng.js.map
118
+ export { RadioTabs_default$1 as n, RadioTabs_default as t };
119
+ //# sourceMappingURL=RadioTabs-DLr9QiXI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioTabs-DLr9QiXI.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"}
@@ -1,5 +1,5 @@
1
1
  Object.defineProperty(exports, '__esModule', { value: true });
2
- const require_Radios = require('../Radios-CIPNqPzi.cjs');
2
+ const require_Radios = require('../Radios-BCOfnTke.cjs');
3
3
 
4
4
  exports.Radios = require_Radios.Radios_default$1;
5
5
  exports.default = require_Radios.Radios_default;
@@ -1,2 +1,2 @@
1
- import { n as RadiosProps, t as Radios } from "../index-DA5um0u6.cjs";
1
+ import { n as RadiosProps, t as Radios } from "../index-C0L7GvgN.cjs";
2
2
  export { Radios, Radios as default, RadiosProps };
@@ -1,2 +1,2 @@
1
- import { n as RadiosProps, t as Radios } from "../index-C1fYmoY0.js";
1
+ import { n as RadiosProps, t as Radios } from "../index-D38wOL-M.js";
2
2
  export { Radios, Radios as default, RadiosProps };
@@ -1,3 +1,3 @@
1
- import { n as Radios_default, t as Radios_default$1 } from "../Radios-BIx06mzU.js";
1
+ import { n as Radios_default, t as Radios_default$1 } from "../Radios-DCXI2kMf.js";
2
2
 
3
3
  export { Radios_default as Radios, Radios_default$1 as default };