@fuf-stack/uniform 1.8.10 → 1.10.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.
Files changed (221) hide show
  1. package/dist/Checkboxes/index.cjs +3 -8
  2. package/dist/Checkboxes/index.cjs.map +1 -1
  3. package/dist/Checkboxes/index.d.cts +2 -2
  4. package/dist/Checkboxes/index.d.ts +2 -2
  5. package/dist/Checkboxes/index.js +2 -7
  6. package/dist/{Checkboxes-CDjOYw76.d.cts → Checkboxes-CBgO9itq.d.cts} +2 -0
  7. package/dist/{Checkboxes-wWzFP2sn.d.ts → Checkboxes-CFbsc6zg.d.ts} +2 -0
  8. package/dist/FieldArray/index.cjs +5 -8
  9. package/dist/FieldArray/index.cjs.map +1 -1
  10. package/dist/FieldArray/index.d.cts +2 -2
  11. package/dist/FieldArray/index.d.ts +2 -2
  12. package/dist/FieldArray/index.js +4 -7
  13. package/dist/{FieldArray-Cql1zcch.d.cts → FieldArray-72vn2MG9.d.cts} +2 -2
  14. package/dist/{FieldArray-Cql1zcch.d.ts → FieldArray-72vn2MG9.d.ts} +2 -2
  15. package/dist/FieldCard/index.cjs +19 -0
  16. package/dist/FieldCard/index.cjs.map +1 -0
  17. package/dist/FieldCard/index.d.cts +95 -0
  18. package/dist/FieldCard/index.d.ts +95 -0
  19. package/dist/FieldCard/index.js +19 -0
  20. package/dist/Form/index.cjs +3 -13
  21. package/dist/Form/index.cjs.map +1 -1
  22. package/dist/Form/index.js +2 -12
  23. package/dist/Input/index.cjs +4 -8
  24. package/dist/Input/index.cjs.map +1 -1
  25. package/dist/Input/index.d.cts +2 -2
  26. package/dist/Input/index.d.ts +2 -2
  27. package/dist/Input/index.js +3 -7
  28. package/dist/{Input-DMVTcinm.d.cts → Input-BGYDOpbo.d.cts} +4 -2
  29. package/dist/{Input-BcdS2xBM.d.ts → Input-__SqMh2n.d.ts} +4 -2
  30. package/dist/{RadioBoxes-DpkI28l0.d.cts → RadioBox-DnqCiTR1.d.cts} +89 -37
  31. package/dist/{RadioBoxes-DpkI28l0.d.ts → RadioBox-DnqCiTR1.d.ts} +89 -37
  32. package/dist/RadioBoxes/index.cjs +5 -8
  33. package/dist/RadioBoxes/index.cjs.map +1 -1
  34. package/dist/RadioBoxes/index.d.cts +2 -2
  35. package/dist/RadioBoxes/index.d.ts +2 -2
  36. package/dist/RadioBoxes/index.js +6 -9
  37. package/dist/RadioTabs/index.cjs +3 -8
  38. package/dist/RadioTabs/index.cjs.map +1 -1
  39. package/dist/RadioTabs/index.d.cts +2 -2
  40. package/dist/RadioTabs/index.d.ts +2 -2
  41. package/dist/RadioTabs/index.js +2 -7
  42. package/dist/{RadioTabs-DTDcAZoH.d.cts → RadioTabs-DkR5fvl4.d.cts} +18 -1
  43. package/dist/{RadioTabs-DTDcAZoH.d.ts → RadioTabs-DkR5fvl4.d.ts} +18 -1
  44. package/dist/Radios/index.cjs +3 -8
  45. package/dist/Radios/index.cjs.map +1 -1
  46. package/dist/Radios/index.d.cts +2 -2
  47. package/dist/Radios/index.d.ts +2 -2
  48. package/dist/Radios/index.js +2 -7
  49. package/dist/{Radios-DprlJhoq.d.cts → Radios-lLVlvY_B.d.cts} +3 -1
  50. package/dist/{Radios-DprlJhoq.d.ts → Radios-lLVlvY_B.d.ts} +3 -1
  51. package/dist/Select/index.cjs +4 -8
  52. package/dist/Select/index.cjs.map +1 -1
  53. package/dist/Select/index.d.cts +3 -2
  54. package/dist/Select/index.d.ts +3 -2
  55. package/dist/Select/index.js +3 -7
  56. package/dist/{Select-CDkZmZp2.d.cts → Select-DWlnKj5c.d.cts} +8 -5
  57. package/dist/{Select-CDkZmZp2.d.ts → Select-DWlnKj5c.d.ts} +8 -5
  58. package/dist/Slider/index.cjs +19 -0
  59. package/dist/Slider/index.cjs.map +1 -0
  60. package/dist/Slider/index.d.cts +10 -0
  61. package/dist/Slider/index.d.ts +10 -0
  62. package/dist/Slider/index.js +19 -0
  63. package/dist/Slider-CxHvafJA.d.cts +155 -0
  64. package/dist/Slider-CxHvafJA.d.ts +155 -0
  65. package/dist/SubmitButton/index.cjs +3 -13
  66. package/dist/SubmitButton/index.cjs.map +1 -1
  67. package/dist/SubmitButton/index.js +2 -12
  68. package/dist/Switch/index.cjs +3 -8
  69. package/dist/Switch/index.cjs.map +1 -1
  70. package/dist/Switch/index.d.cts +2 -2
  71. package/dist/Switch/index.d.ts +2 -2
  72. package/dist/Switch/index.js +2 -7
  73. package/dist/{Switch-Hr6PnK98.d.cts → Switch-B4AuHAMX.d.cts} +6 -4
  74. package/dist/{Switch-Hr6PnK98.d.ts → Switch-B4AuHAMX.d.ts} +6 -4
  75. package/dist/SwitchBox/index.cjs +21 -0
  76. package/dist/SwitchBox/index.cjs.map +1 -0
  77. package/dist/SwitchBox/index.d.cts +11 -0
  78. package/dist/SwitchBox/index.d.ts +11 -0
  79. package/dist/SwitchBox/index.js +21 -0
  80. package/dist/SwitchBox/index.js.map +1 -0
  81. package/dist/SwitchBox-q1I7a0NX.d.cts +146 -0
  82. package/dist/SwitchBox-q1I7a0NX.d.ts +146 -0
  83. package/dist/TextArea/index.cjs +4 -8
  84. package/dist/TextArea/index.cjs.map +1 -1
  85. package/dist/TextArea/index.d.cts +2 -2
  86. package/dist/TextArea/index.d.ts +2 -2
  87. package/dist/TextArea/index.js +3 -7
  88. package/dist/{TextArea-DhxNWYNg.d.cts → TextArea-CYcFOcun.d.cts} +2 -0
  89. package/dist/{TextArea-DhxNWYNg.d.ts → TextArea-CYcFOcun.d.ts} +2 -0
  90. package/dist/{chunk-EFZXZNJO.js → chunk-2EQEKXG2.js} +4 -2
  91. package/dist/chunk-2EQEKXG2.js.map +1 -0
  92. package/dist/chunk-36LBVB45.js +1 -0
  93. package/dist/chunk-36LBVB45.js.map +1 -0
  94. package/dist/chunk-3JAVQAL5.cjs +1 -0
  95. package/dist/{chunk-KWJMKX5J.cjs.map → chunk-3JAVQAL5.cjs.map} +1 -1
  96. package/dist/{chunk-NTOYCWCJ.cjs → chunk-3ZQXSGR2.cjs} +1 -1
  97. package/dist/{chunk-NTOYCWCJ.cjs.map → chunk-3ZQXSGR2.cjs.map} +1 -1
  98. package/dist/{chunk-BIC7IWER.js → chunk-4KEI3VRK.js} +6 -3
  99. package/dist/chunk-4KEI3VRK.js.map +1 -0
  100. package/dist/{chunk-PFFTE4NW.cjs → chunk-4LLSZ6GN.cjs} +6 -4
  101. package/dist/chunk-4LLSZ6GN.cjs.map +1 -0
  102. package/dist/chunk-5UGCZ7OA.js +215 -0
  103. package/dist/chunk-5UGCZ7OA.js.map +1 -0
  104. package/dist/{chunk-MEIT57H2.cjs → chunk-6UORUDZV.cjs} +5 -3
  105. package/dist/chunk-6UORUDZV.cjs.map +1 -0
  106. package/dist/chunk-7TUWJWLN.js +131 -0
  107. package/dist/chunk-7TUWJWLN.js.map +1 -0
  108. package/dist/chunk-7WBYC3BC.js +149 -0
  109. package/dist/chunk-7WBYC3BC.js.map +1 -0
  110. package/dist/{chunk-QE4J4AMH.js → chunk-BUFKWZNC.js} +2 -2
  111. package/dist/chunk-BUFKWZNC.js.map +1 -0
  112. package/dist/{chunk-A3PYIWG2.js → chunk-BZ2PD2JG.js} +1 -1
  113. package/dist/chunk-BZ2PD2JG.js.map +1 -0
  114. package/dist/{chunk-37RM7TVP.cjs → chunk-CM2LLV5N.cjs} +5 -3
  115. package/dist/chunk-CM2LLV5N.cjs.map +1 -0
  116. package/dist/{chunk-OTFX4BWZ.js → chunk-FHYUMBE3.js} +80 -46
  117. package/dist/chunk-FHYUMBE3.js.map +1 -0
  118. package/dist/chunk-FQDOJIQF.cjs +149 -0
  119. package/dist/chunk-FQDOJIQF.cjs.map +1 -0
  120. package/dist/{chunk-TN7OSO3T.js → chunk-GQF5HVA4.js} +5 -5
  121. package/dist/chunk-GQF5HVA4.js.map +1 -0
  122. package/dist/{chunk-6AQ5R4U4.cjs → chunk-HYOALQIV.cjs} +7 -7
  123. package/dist/chunk-HYOALQIV.cjs.map +1 -0
  124. package/dist/{chunk-NG2KM4CA.cjs → chunk-IZ5SPNVQ.cjs} +9 -6
  125. package/dist/chunk-IZ5SPNVQ.cjs.map +1 -0
  126. package/dist/{chunk-RRG5ZLVF.cjs → chunk-JRE5KEX3.cjs} +1 -1
  127. package/dist/{chunk-RRG5ZLVF.cjs.map → chunk-JRE5KEX3.cjs.map} +1 -1
  128. package/dist/chunk-KOV7U4QA.cjs +165 -0
  129. package/dist/chunk-KOV7U4QA.cjs.map +1 -0
  130. package/dist/{chunk-ZJDU5EPE.js → chunk-LEMQGDFE.js} +1 -1
  131. package/dist/chunk-M5IL7INR.js +219 -0
  132. package/dist/chunk-M5IL7INR.js.map +1 -0
  133. package/dist/{chunk-R5AOS4DQ.js → chunk-MODH7W2M.js} +5 -3
  134. package/dist/chunk-MODH7W2M.js.map +1 -0
  135. package/dist/chunk-MSJP25N4.cjs +131 -0
  136. package/dist/chunk-MSJP25N4.cjs.map +1 -0
  137. package/dist/{chunk-OYDNTOOU.cjs → chunk-MVFEXRWQ.cjs} +3 -3
  138. package/dist/chunk-MVFEXRWQ.cjs.map +1 -0
  139. package/dist/{chunk-7WHL6K5T.js → chunk-O5KAFUBE.js} +7 -4
  140. package/dist/chunk-O5KAFUBE.js.map +1 -0
  141. package/dist/{chunk-ZNX2PT6C.cjs → chunk-OED4DYBD.cjs} +6 -3
  142. package/dist/chunk-OED4DYBD.cjs.map +1 -0
  143. package/dist/chunk-OIKPQMQ2.cjs +215 -0
  144. package/dist/chunk-OIKPQMQ2.cjs.map +1 -0
  145. package/dist/{chunk-Y7YEI6T2.js → chunk-P2TT7HU5.js} +1 -1
  146. package/dist/chunk-P2TT7HU5.js.map +1 -0
  147. package/dist/{chunk-JQQ32JOD.cjs → chunk-PTCZOUQX.cjs} +1 -1
  148. package/dist/chunk-PTCZOUQX.cjs.map +1 -0
  149. package/dist/{chunk-2UHJBGKV.js → chunk-QPKHR6WH.js} +4 -2
  150. package/dist/chunk-QPKHR6WH.js.map +1 -0
  151. package/dist/{chunk-WWSJQUTT.cjs → chunk-V45YAJT4.cjs} +7 -5
  152. package/dist/chunk-V45YAJT4.cjs.map +1 -0
  153. package/dist/chunk-WRKONOOV.cjs +219 -0
  154. package/dist/chunk-WRKONOOV.cjs.map +1 -0
  155. package/dist/{chunk-DUYZ7WW3.cjs → chunk-XSS4REAS.cjs} +80 -46
  156. package/dist/chunk-XSS4REAS.cjs.map +1 -0
  157. package/dist/{chunk-GRQVGEYI.js → chunk-XSVEW3KN.js} +5 -3
  158. package/dist/chunk-XSVEW3KN.js.map +1 -0
  159. package/dist/chunk-YMXUVBQ3.js +165 -0
  160. package/dist/chunk-YMXUVBQ3.js.map +1 -0
  161. package/dist/hooks/useFormContext/index.cjs +2 -1
  162. package/dist/hooks/useFormContext/index.cjs.map +1 -1
  163. package/dist/hooks/useFormContext/index.d.cts +2 -2
  164. package/dist/hooks/useFormContext/index.d.ts +2 -2
  165. package/dist/hooks/useFormContext/index.js +1 -0
  166. package/dist/hooks/useInputValueDebounce/index.cjs +2 -2
  167. package/dist/hooks/useInputValueDebounce/index.js +1 -1
  168. package/dist/hooks/useUniformField/index.cjs +2 -2
  169. package/dist/hooks/useUniformField/index.d.cts +9 -5
  170. package/dist/hooks/useUniformField/index.d.ts +9 -5
  171. package/dist/hooks/useUniformField/index.js +1 -1
  172. package/dist/hooks/useUniformFieldArray/index.cjs +4 -3
  173. package/dist/hooks/useUniformFieldArray/index.cjs.map +1 -1
  174. package/dist/hooks/useUniformFieldArray/index.d.cts +6 -5
  175. package/dist/hooks/useUniformFieldArray/index.d.ts +6 -5
  176. package/dist/hooks/useUniformFieldArray/index.js +3 -2
  177. package/dist/index.cjs +41 -23
  178. package/dist/index.cjs.map +1 -1
  179. package/dist/index.d.cts +17 -14
  180. package/dist/index.d.ts +17 -14
  181. package/dist/index.js +45 -27
  182. package/package.json +19 -8
  183. package/dist/chunk-2UHJBGKV.js.map +0 -1
  184. package/dist/chunk-37RM7TVP.cjs.map +0 -1
  185. package/dist/chunk-44STFB2F.cjs +0 -170
  186. package/dist/chunk-44STFB2F.cjs.map +0 -1
  187. package/dist/chunk-5ZMXUK6O.js +0 -170
  188. package/dist/chunk-5ZMXUK6O.js.map +0 -1
  189. package/dist/chunk-6AQ5R4U4.cjs.map +0 -1
  190. package/dist/chunk-7WHL6K5T.js.map +0 -1
  191. package/dist/chunk-A3PYIWG2.js.map +0 -1
  192. package/dist/chunk-BIC7IWER.js.map +0 -1
  193. package/dist/chunk-DUYZ7WW3.cjs.map +0 -1
  194. package/dist/chunk-EFZXZNJO.js.map +0 -1
  195. package/dist/chunk-GRQVGEYI.js.map +0 -1
  196. package/dist/chunk-HBPVEZJN.js +0 -105
  197. package/dist/chunk-HBPVEZJN.js.map +0 -1
  198. package/dist/chunk-JQQ32JOD.cjs.map +0 -1
  199. package/dist/chunk-KWJMKX5J.cjs +0 -1
  200. package/dist/chunk-MEIT57H2.cjs.map +0 -1
  201. package/dist/chunk-NG2KM4CA.cjs.map +0 -1
  202. package/dist/chunk-OTFX4BWZ.js.map +0 -1
  203. package/dist/chunk-OYDNTOOU.cjs.map +0 -1
  204. package/dist/chunk-PEADXODY.cjs +0 -105
  205. package/dist/chunk-PEADXODY.cjs.map +0 -1
  206. package/dist/chunk-PFFTE4NW.cjs.map +0 -1
  207. package/dist/chunk-QE4J4AMH.js.map +0 -1
  208. package/dist/chunk-R5AOS4DQ.js.map +0 -1
  209. package/dist/chunk-TN7OSO3T.js.map +0 -1
  210. package/dist/chunk-V3GDAELU.js +0 -1
  211. package/dist/chunk-WWSJQUTT.cjs.map +0 -1
  212. package/dist/chunk-Y7YEI6T2.js.map +0 -1
  213. package/dist/chunk-ZNX2PT6C.cjs.map +0 -1
  214. package/dist/hooks/index.cjs +0 -49
  215. package/dist/hooks/index.cjs.map +0 -1
  216. package/dist/hooks/index.d.cts +0 -14
  217. package/dist/hooks/index.d.ts +0 -14
  218. package/dist/hooks/index.js +0 -49
  219. /package/dist/{hooks → FieldCard}/index.js.map +0 -0
  220. /package/dist/{chunk-V3GDAELU.js.map → Slider/index.js.map} +0 -0
  221. /package/dist/{chunk-ZJDU5EPE.js.map → chunk-LEMQGDFE.js.map} +0 -0
@@ -0,0 +1,219 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+ var _chunkOED4DYBDcjs = require('./chunk-OED4DYBD.cjs');
4
+
5
+
6
+
7
+
8
+ var _chunk555JRYCScjs = require('./chunk-555JRYCS.cjs');
9
+
10
+ // src/RadioBoxes/RadioBoxes.tsx
11
+ var _radio = require('@heroui/radio');
12
+ var _pixelutils = require('@fuf-stack/pixel-utils');
13
+
14
+ // src/RadioBoxes/RadioBox.tsx
15
+
16
+ var _visuallyhidden = require('@react-aria/visually-hidden');
17
+
18
+ var _jsxruntime = require('react/jsx-runtime');
19
+ var radioBoxVariants = _pixelutils.tv.call(void 0, {
20
+ slots: {
21
+ 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",
22
+ control: "",
23
+ description: "text-foreground opacity-70 text-small",
24
+ icon: "",
25
+ label: "",
26
+ labelWrapper: "grow"
27
+ },
28
+ variants: {
29
+ isDisabled: {
30
+ true: {
31
+ base: "pointer-events-none opacity-disabled"
32
+ }
33
+ },
34
+ isInvalid: {
35
+ true: {
36
+ base: "!border-danger"
37
+ }
38
+ }
39
+ }
40
+ });
41
+ var RadioBox = (_a) => {
42
+ var _b = _a, {
43
+ classNames: _classNames = void 0,
44
+ icon = void 0,
45
+ isInvalid = false
46
+ } = _b, props = _chunk555JRYCScjs.__objRest.call(void 0, _b, [
47
+ "classNames",
48
+ "icon",
49
+ "isInvalid"
50
+ ]);
51
+ const {
52
+ children,
53
+ Component,
54
+ description,
55
+ getBaseProps,
56
+ getControlProps,
57
+ getInputProps,
58
+ getLabelProps,
59
+ getLabelWrapperProps,
60
+ getWrapperProps,
61
+ isDisabled
62
+ } = _radio.useRadio.call(void 0, props);
63
+ const variants = radioBoxVariants({
64
+ isDisabled,
65
+ isInvalid
66
+ });
67
+ const classNames = _pixelutils.variantsToClassNames.call(void 0,
68
+ variants,
69
+ // @ts-expect-error not sure here, but it works
70
+ _classNames,
71
+ "base"
72
+ );
73
+ return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, Component, _chunk555JRYCScjs.__spreadProps.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getBaseProps()), { className: classNames.base, children: [
74
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _visuallyhidden.VisuallyHidden, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "input", _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getInputProps())) }),
75
+ !icon ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", _chunk555JRYCScjs.__spreadProps.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getWrapperProps()), { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
76
+ "span",
77
+ _chunk555JRYCScjs.__spreadProps.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getControlProps()), {
78
+ className: _pixelutils.cn.call(void 0, getControlProps().className, classNames.control)
79
+ })
80
+ ) })) : null,
81
+ icon ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: classNames.icon, children: icon }) : null,
82
+ /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
83
+ "div",
84
+ _chunk555JRYCScjs.__spreadProps.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getLabelWrapperProps()), {
85
+ className: _pixelutils.cn.call(void 0,
86
+ getLabelWrapperProps().className,
87
+ classNames.labelWrapper
88
+ ),
89
+ children: [
90
+ children ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
91
+ "span",
92
+ _chunk555JRYCScjs.__spreadProps.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getLabelProps()), {
93
+ className: _pixelutils.cn.call(void 0, getLabelProps().className, classNames.label),
94
+ children
95
+ })
96
+ ) : null,
97
+ description ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: classNames.description, children: description }) : null
98
+ ]
99
+ })
100
+ ),
101
+ icon ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", _chunk555JRYCScjs.__spreadProps.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getWrapperProps()), { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
102
+ "span",
103
+ _chunk555JRYCScjs.__spreadProps.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {}, getControlProps()), {
104
+ className: _pixelutils.cn.call(void 0, getControlProps().className, classNames.control)
105
+ })
106
+ ) })) : null
107
+ ] }));
108
+ };
109
+
110
+ // src/RadioBoxes/RadioBoxes.tsx
111
+
112
+ var radioBoxesVariants = _pixelutils.tv.call(void 0, {
113
+ slots: {
114
+ base: "group gap-0",
115
+ // Needs group for group-data condition
116
+ boxBase: "",
117
+ boxControl: "",
118
+ boxDescription: "",
119
+ boxLabel: "",
120
+ boxLabelWrapper: "",
121
+ // see HeroUI styles for group-data condition,
122
+ // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts
123
+ label: "mb-2 inline-flex text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger",
124
+ wrapper: ""
125
+ }
126
+ });
127
+ var RadioBoxes = (_a) => {
128
+ var _b = _a, {
129
+ className = void 0,
130
+ inline = false,
131
+ name,
132
+ options
133
+ } = _b, uniformFieldProps = _chunk555JRYCScjs.__objRest.call(void 0, _b, [
134
+ "className",
135
+ "inline",
136
+ "name",
137
+ "options"
138
+ ]);
139
+ const {
140
+ ariaLabel,
141
+ defaultValue,
142
+ errorMessage,
143
+ invalid,
144
+ disabled,
145
+ label,
146
+ onBlur,
147
+ onChange,
148
+ ref,
149
+ required,
150
+ testId
151
+ } = _chunkOED4DYBDcjs.useUniformField.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {
152
+ name
153
+ }, uniformFieldProps));
154
+ const variants = radioBoxesVariants();
155
+ const classNames = _pixelutils.variantsToClassNames.call(void 0, variants, className, "base");
156
+ const boxClassNames = {
157
+ base: classNames.boxBase,
158
+ control: classNames.boxControl,
159
+ description: classNames.boxDescription,
160
+ label: classNames.boxLabel,
161
+ labelWrapper: classNames.boxLabelWrapper
162
+ };
163
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
164
+ _radio.RadioGroup,
165
+ {
166
+ ref,
167
+ "aria-label": ariaLabel,
168
+ classNames,
169
+ "data-invalid": invalid,
170
+ "data-required": required,
171
+ "data-testid": testId,
172
+ defaultValue,
173
+ errorMessage,
174
+ isDisabled: disabled,
175
+ isInvalid: invalid,
176
+ isRequired: required,
177
+ label: label ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "legend", { children: label }) : null,
178
+ name,
179
+ onBlur,
180
+ onValueChange: onChange,
181
+ orientation: inline ? "horizontal" : "vertical",
182
+ children: options.map((option) => {
183
+ var _a2, _b2;
184
+ if ("value" in option) {
185
+ const optionTestId = _pixelutils.slugify.call(void 0,
186
+ `${testId}_option_${(_a2 = option.testId) != null ? _a2 : option.value}`,
187
+ { replaceDots: true }
188
+ );
189
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
190
+ RadioBox,
191
+ {
192
+ classNames: boxClassNames,
193
+ "data-testid": optionTestId,
194
+ description: option.description,
195
+ icon: option.icon,
196
+ isDisabled: !!disabled || option.disabled,
197
+ isInvalid: invalid,
198
+ value: option.value,
199
+ children: (_b2 = option.label) != null ? _b2 : option.value
200
+ },
201
+ option.value
202
+ );
203
+ }
204
+ return null;
205
+ })
206
+ }
207
+ );
208
+ };
209
+ var RadioBoxes_default = RadioBoxes;
210
+
211
+ // src/RadioBoxes/index.ts
212
+ var RadioBoxes_default2 = RadioBoxes_default;
213
+
214
+
215
+
216
+
217
+
218
+ exports.radioBoxVariants = radioBoxVariants; exports.RadioBoxes_default = RadioBoxes_default; exports.RadioBoxes_default2 = RadioBoxes_default2;
219
+ //# sourceMappingURL=chunk-WRKONOOV.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-WRKONOOV.cjs","../src/RadioBoxes/RadioBoxes.tsx","../src/RadioBoxes/RadioBox.tsx","../src/RadioBoxes/index.ts"],"names":["tv","variantsToClassNames","jsx","_a","_b","RadioBoxes_default"],"mappings":"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","file":"/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-WRKONOOV.cjs","sourcesContent":[null,"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 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 RadioBoxes from './RadioBoxes';\n\nexport type { RadioBoxesProps } from './RadioBoxes';\nexport { radioBoxVariants } from './RadioBox';\n\nexport { RadioBoxes };\n\nexport default RadioBoxes;\n"]}
@@ -1,13 +1,15 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
2
 
3
- var _chunkZNX2PT6Ccjs = require('./chunk-ZNX2PT6C.cjs');
3
+ var _chunkOED4DYBDcjs = require('./chunk-OED4DYBD.cjs');
4
4
 
5
5
 
6
6
 
7
7
  var _chunk555JRYCScjs = require('./chunk-555JRYCS.cjs');
8
8
 
9
9
  // src/RadioTabs/RadioTabs.tsx
10
+ var _react = require('react');
10
11
  var _radio = require('@heroui/radio');
12
+ var _visuallyhidden = require('@react-aria/visually-hidden');
11
13
  var _pixelutils = require('@fuf-stack/pixel-utils');
12
14
  var _Tabs = require('@fuf-stack/pixels/Tabs'); var _Tabs2 = _interopRequireDefault(_Tabs);
13
15
  var _jsxruntime = require('react/jsx-runtime');
@@ -29,7 +31,7 @@ var radioTabsVariants = _pixelutils.tv.call(void 0, {
29
31
  hasContent: {
30
32
  true: {
31
33
  base: "",
32
- tabBase: "p-1 pb-0",
34
+ tabBase: "p-1",
33
35
  tabWrapper: [
34
36
  // border style
35
37
  "rounded-medium border border-divider",
@@ -42,6 +44,11 @@ var radioTabsVariants = _pixelutils.tv.call(void 0, {
42
44
  true: {
43
45
  tabWrapper: "w-full"
44
46
  }
47
+ },
48
+ isInvalid: {
49
+ true: {
50
+ tabWrapper: "rounded-medium border-2 !border-danger"
51
+ }
45
52
  }
46
53
  }
47
54
  });
@@ -62,6 +69,7 @@ var RadioTabs = (_a) => {
62
69
  "variant"
63
70
  ]);
64
71
  const {
72
+ ariaLabel,
65
73
  disabled,
66
74
  errorMessage,
67
75
  field: { onBlur, onChange, ref, value },
@@ -69,9 +77,10 @@ var RadioTabs = (_a) => {
69
77
  label,
70
78
  required,
71
79
  testId
72
- } = _chunkZNX2PT6Ccjs.useUniformField.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {
80
+ } = _chunkOED4DYBDcjs.useUniformField.call(void 0, _chunk555JRYCScjs.__spreadValues.call(void 0, {
73
81
  name
74
82
  }, uniformFieldProps));
83
+ const visualRadioGroupRef = _react.useRef.call(void 0, null);
75
84
  const tabOptions = options.map((option) => {
76
85
  var _a2, _b2;
77
86
  return {
@@ -90,50 +99,75 @@ var RadioTabs = (_a) => {
90
99
  const hasContent = options.some((option) => {
91
100
  return option.content;
92
101
  });
93
- const variants = radioTabsVariants({ hasContent, fullWidth });
102
+ const variants = radioTabsVariants({
103
+ fullWidth,
104
+ hasContent,
105
+ isInvalid: invalid
106
+ });
94
107
  const classNames = _pixelutils.variantsToClassNames.call(void 0, variants, className, "base");
95
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
96
- _radio.RadioGroup,
97
- {
98
- ref,
99
- "data-invalid": invalid,
100
- "data-required": required,
101
- "data-testid": testId,
102
- errorMessage,
103
- isDisabled: disabled,
104
- isInvalid: invalid,
105
- isRequired: required,
106
- label: label ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "legend", { children: label }) : null,
107
- name,
108
- onBlur,
109
- orientation: inline ? "horizontal" : "vertical",
110
- classNames: {
111
- base: classNames.base,
112
- label: classNames.label,
113
- wrapper: classNames.wrapper
114
- },
115
- children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
116
- _Tabs2.default,
117
- {
118
- disabledKeys: disabled ? disabledAllKeys : void 0,
119
- onSelectionChange: onChange,
120
- selectedKey: value != null ? value : "",
121
- tabs: tabOptions,
122
- testId,
123
- variant,
124
- className: {
125
- base: classNames.tabBase,
126
- cursor: classNames.cursor,
127
- panel: classNames.tabPanel,
128
- tab: classNames.tab,
129
- tabContent: classNames.tabContent,
130
- tabList: classNames.tabList,
131
- tabWrapper: classNames.tabWrapper
132
- }
108
+ return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
109
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _visuallyhidden.VisuallyHidden, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
110
+ "input",
111
+ {
112
+ ref,
113
+ name,
114
+ onBlur,
115
+ value: value != null ? value : "",
116
+ onChange: (e) => {
117
+ onChange(e.target.value);
118
+ },
119
+ onFocus: () => {
120
+ var _a2;
121
+ const firstTab = (_a2 = visualRadioGroupRef.current) == null ? void 0 : _a2.querySelector(
122
+ '[role="tab"]'
123
+ );
124
+ firstTab == null ? void 0 : firstTab.focus();
133
125
  }
134
- )
135
- }
136
- );
126
+ }
127
+ ) }),
128
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
129
+ _radio.RadioGroup,
130
+ {
131
+ ref: visualRadioGroupRef,
132
+ "aria-label": ariaLabel,
133
+ "data-invalid": invalid,
134
+ "data-required": required,
135
+ "data-testid": testId,
136
+ errorMessage,
137
+ isDisabled: disabled,
138
+ isInvalid: invalid,
139
+ isRequired: required,
140
+ label: label ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "legend", { children: label }) : null,
141
+ name: `${name}_radiotabs`,
142
+ orientation: inline ? "horizontal" : "vertical",
143
+ classNames: {
144
+ base: classNames.base,
145
+ label: classNames.label,
146
+ wrapper: classNames.wrapper
147
+ },
148
+ children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
149
+ _Tabs2.default,
150
+ {
151
+ disabledKeys: disabled ? disabledAllKeys : void 0,
152
+ onSelectionChange: onChange,
153
+ selectedKey: value != null ? value : "",
154
+ tabs: tabOptions,
155
+ testId,
156
+ variant,
157
+ className: {
158
+ base: classNames.tabBase,
159
+ cursor: classNames.cursor,
160
+ panel: classNames.tabPanel,
161
+ tab: classNames.tab,
162
+ tabContent: classNames.tabContent,
163
+ tabList: classNames.tabList,
164
+ tabWrapper: classNames.tabWrapper
165
+ }
166
+ }
167
+ )
168
+ }
169
+ )
170
+ ] });
137
171
  };
138
172
  var RadioTabs_default = RadioTabs;
139
173
 
@@ -144,4 +178,4 @@ var RadioTabs_default2 = RadioTabs_default;
144
178
 
145
179
 
146
180
  exports.RadioTabs_default = RadioTabs_default; exports.RadioTabs_default2 = RadioTabs_default2;
147
- //# sourceMappingURL=chunk-DUYZ7WW3.cjs.map
181
+ //# sourceMappingURL=chunk-XSS4REAS.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-XSS4REAS.cjs","../src/RadioTabs/RadioTabs.tsx","../src/RadioTabs/index.ts"],"names":["_a","_b"],"mappings":"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","file":"/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-XSS4REAS.cjs","sourcesContent":[null,"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 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"]}
@@ -1,9 +1,9 @@
1
1
  import {
2
2
  useInputValueDebounce
3
- } from "./chunk-ZJDU5EPE.js";
3
+ } from "./chunk-LEMQGDFE.js";
4
4
  import {
5
5
  useUniformField
6
- } from "./chunk-BIC7IWER.js";
6
+ } from "./chunk-4KEI3VRK.js";
7
7
  import {
8
8
  __objRest,
9
9
  __spreadValues
@@ -40,6 +40,7 @@ var TextArea = (_a) => {
40
40
  "placeholder"
41
41
  ]);
42
42
  const {
43
+ ariaLabel,
43
44
  disabled,
44
45
  errorMessage,
45
46
  field: {
@@ -79,6 +80,7 @@ var TextArea = (_a) => {
79
80
  placeholder,
80
81
  value,
81
82
  variant: "bordered",
83
+ "aria-label": !placeholder || placeholder.trim() === "" ? ariaLabel : void 0,
82
84
  classNames: {
83
85
  base: classNames.base,
84
86
  clearButton: classNames.clearButton,
@@ -100,4 +102,4 @@ export {
100
102
  TextArea_default,
101
103
  TextArea_default2
102
104
  };
103
- //# sourceMappingURL=chunk-GRQVGEYI.js.map
105
+ //# sourceMappingURL=chunk-XSVEW3KN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/TextArea/TextArea.tsx","../src/TextArea/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\n\nimport { Textarea as HeroTextArea } from '@heroui/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 textAreaVariants = 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 textAreaVariants>;\ntype ClassName = TVClassName<typeof textAreaVariants>;\n\nexport interface TextAreaProps 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 /** Child components. The content of the textarea. */\n children?: ReactNode;\n /** CSS class name */\n className?: ClassName;\n /** debounce delay in milliseconds for form state updates (default: 300ms) */\n debounceDelay?: number;\n /** Determines if the TextArea is disabled or not. */\n disabled?: boolean;\n /** Label displayed above the TextArea. */\n label?: ReactNode;\n /** Name the TextArea is registered at in HTML forms (react-hook-form). */\n name: string;\n /** placeholder for the textArea content. */\n placeholder?: string;\n /** Id to grab element in internal tests. */\n testId?: string;\n}\n\n/**\n * TextArea component based on [HeroUI TextArea](https://www.heroui.com//docs/components/textarea)\n */\nconst TextArea = ({\n children = null,\n className: _className = undefined,\n debounceDelay = 300,\n name,\n placeholder = ' ',\n ...uniformFieldProps\n}: TextAreaProps) => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: {\n onChange: fieldOnChange,\n onBlur: fieldOnBlur,\n value: fieldValue,\n ref,\n },\n invalid,\n label,\n required,\n testId,\n } = useUniformField({ name, ...uniformFieldProps });\n\n // Use debounced handlers for form updates\n const { onChange, onBlur, value } = useInputValueDebounce({\n debounceDelay,\n onBlur: fieldOnBlur,\n onChange: fieldOnChange,\n value: fieldValue,\n });\n\n // classNames from slots\n const variants = textAreaVariants();\n const classNames = variantsToClassNames(variants, _className, 'base');\n\n return (\n <HeroTextArea\n ref={ref}\n data-testid={testId}\n errorMessage={errorMessage}\n id={testId}\n isDisabled={disabled}\n isInvalid={invalid}\n isRequired={required}\n label={label}\n labelPlacement=\"outside\"\n name={name}\n onBlur={onBlur}\n onChange={onChange}\n placeholder={placeholder}\n value={value}\n variant=\"bordered\"\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 }\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 >\n {children}\n </HeroTextArea>\n );\n};\n\nexport default TextArea;\n","import TextArea from './TextArea';\n\nexport type { TextAreaProps } from './TextArea';\n\nexport { TextArea };\n\nexport default TextArea;\n"],"mappings":";;;;;;;;;;;;AAGA,SAAS,YAAY,oBAAoB;AAEzC,SAAS,IAAI,4BAA4B;AAmFrC;AA7EG,IAAM,mBAAmB,GAAG;AAAA,EACjC,OAAO;AAAA;AAAA,IAEL,MAAM;AAAA;AAAA,IAEN,aAAa;AAAA;AAAA,IAEb,OAAO;AAAA;AAAA,IAEP,cAAc;AAAA,EAChB;AACF,CAAC;AA6BD,IAAM,WAAW,CAAC,OAOG;AAPH,eAChB;AAAA,eAAW;AAAA,IACX,WAAW,aAAa;AAAA,IACxB,gBAAgB;AAAA,IAChB;AAAA,IACA,cAAc;AAAA,EAxDhB,IAmDkB,IAMb,8BANa,IAMb;AAAA,IALH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;AAGA,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA,OAAO;AAAA,MACL,UAAU;AAAA,MACV,QAAQ;AAAA,MACR,OAAO;AAAA,MACP;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,gBAAgB,iBAAE,QAAS,kBAAmB;AAGlD,QAAM,EAAE,UAAU,QAAQ,MAAM,IAAI,sBAAsB;AAAA,IACxD;AAAA,IACA,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,OAAO;AAAA,EACT,CAAC;AAGD,QAAM,WAAW,iBAAiB;AAClC,QAAM,aAAa,qBAAqB,UAAU,YAAY,MAAM;AAEpE,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA,eAAa;AAAA,MACb;AAAA,MACA,IAAI;AAAA,MACJ,YAAY;AAAA,MACZ,WAAW;AAAA,MACX,YAAY;AAAA,MACZ;AAAA,MACA,gBAAe;AAAA,MACf;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,SAAQ;AAAA,MAER,cACE,CAAC,eAAe,YAAY,KAAK,MAAM,KAAK,YAAY;AAAA,MAE1D,YAAY;AAAA,QACV,MAAM,WAAW;AAAA,QACjB,aAAa,WAAW;AAAA;AAAA,QAExB,eAAe;AAAA,QACf,OAAO,WAAW;AAAA,QAClB,cAAc,WAAW;AAAA,MAC3B;AAAA,MAEC;AAAA;AAAA,EACH;AAEJ;AAEA,IAAO,mBAAQ;;;ACpHf,IAAOA,oBAAQ;","names":["TextArea_default"]}
@@ -0,0 +1,165 @@
1
+ import {
2
+ useUniformField
3
+ } from "./chunk-4KEI3VRK.js";
4
+ import {
5
+ __objRest,
6
+ __spreadProps,
7
+ __spreadValues
8
+ } from "./chunk-K2V4ULA2.js";
9
+
10
+ // src/Slider/Slider.tsx
11
+ import { useRef } from "react";
12
+ import { Slider as HeroUISlider } from "@heroui/slider";
13
+ import { VisuallyHidden } from "@react-aria/visually-hidden";
14
+ import { tv, variantsToClassNames } from "@fuf-stack/pixel-utils";
15
+ import { jsx, jsxs } from "react/jsx-runtime";
16
+ var sliderVariants = tv({
17
+ slots: {
18
+ base: "group",
19
+ endContent: "",
20
+ errorMessage: "ml-1 mt-1",
21
+ filler: "",
22
+ // see HeroUI styles for group-data condition,
23
+ // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts
24
+ label: '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-["*"]',
25
+ labelWrapper: "",
26
+ mark: "",
27
+ startContent: "",
28
+ step: "",
29
+ thumb: "",
30
+ track: "",
31
+ trackWrapper: "",
32
+ value: ""
33
+ }
34
+ });
35
+ var Slider = (_a) => {
36
+ var _b = _a, {
37
+ className = void 0,
38
+ endContent = void 0,
39
+ fillOffset = void 0,
40
+ name,
41
+ showSteps = false,
42
+ size = "md",
43
+ startContent = void 0,
44
+ step = 1,
45
+ minValue = 0,
46
+ maxValue = 100
47
+ } = _b, uniformFieldProps = __objRest(_b, [
48
+ "className",
49
+ "endContent",
50
+ "fillOffset",
51
+ "name",
52
+ "showSteps",
53
+ "size",
54
+ "startContent",
55
+ "step",
56
+ "minValue",
57
+ "maxValue"
58
+ ]);
59
+ const {
60
+ ariaLabel,
61
+ disabled,
62
+ field,
63
+ getErrorMessageProps,
64
+ getHelperWrapperProps,
65
+ invalid,
66
+ label,
67
+ onBlur,
68
+ onChange,
69
+ ref,
70
+ required,
71
+ errorMessage,
72
+ testId
73
+ } = useUniformField(__spreadValues({
74
+ name
75
+ }, uniformFieldProps));
76
+ const visualSliderRef = useRef(null);
77
+ const variants = sliderVariants();
78
+ const classNames = variantsToClassNames(variants, className, "base");
79
+ const currentValue = field.value != null ? Number(field.value) : minValue;
80
+ return /* @__PURE__ */ jsxs(
81
+ "div",
82
+ {
83
+ className: classNames.base,
84
+ "data-invalid": invalid,
85
+ "data-required": required,
86
+ "data-testid": testId,
87
+ children: [
88
+ /* @__PURE__ */ jsx(VisuallyHidden, { children: /* @__PURE__ */ jsx(
89
+ "input",
90
+ {
91
+ ref,
92
+ "aria-label": typeof label === "string" ? label : name,
93
+ disabled,
94
+ max: maxValue,
95
+ min: minValue,
96
+ name,
97
+ onBlur,
98
+ step,
99
+ tabIndex: -1,
100
+ type: "range",
101
+ value: currentValue,
102
+ onChange: (e) => {
103
+ onChange(Number(e.target.value));
104
+ },
105
+ onFocus: () => {
106
+ var _a2;
107
+ (_a2 = visualSliderRef.current) == null ? void 0 : _a2.focus();
108
+ }
109
+ }
110
+ ) }),
111
+ /* @__PURE__ */ jsx(
112
+ HeroUISlider,
113
+ {
114
+ ref: visualSliderRef,
115
+ "aria-label": ariaLabel,
116
+ color: invalid ? "danger" : "primary",
117
+ endContent,
118
+ fillOffset,
119
+ isDisabled: disabled,
120
+ label,
121
+ maxValue,
122
+ minValue,
123
+ name: `${name}_slider`,
124
+ onBlur,
125
+ showSteps,
126
+ size,
127
+ startContent,
128
+ step,
129
+ value: currentValue,
130
+ classNames: {
131
+ endContent: classNames.endContent,
132
+ filler: classNames.filler,
133
+ label: classNames.label,
134
+ labelWrapper: classNames.labelWrapper,
135
+ mark: classNames.mark,
136
+ startContent: classNames.startContent,
137
+ step: classNames.step,
138
+ thumb: classNames.thumb,
139
+ track: classNames.track,
140
+ trackWrapper: classNames.trackWrapper,
141
+ value: classNames.value
142
+ },
143
+ onChange: (value) => {
144
+ onChange(value);
145
+ },
146
+ onChangeEnd: (_value) => {
147
+ onBlur();
148
+ }
149
+ }
150
+ ),
151
+ /* @__PURE__ */ jsx("div", __spreadProps(__spreadValues({}, getHelperWrapperProps()), { children: /* @__PURE__ */ jsx("div", __spreadProps(__spreadValues({}, getErrorMessageProps()), { children: errorMessage })) }))
152
+ ]
153
+ }
154
+ );
155
+ };
156
+ var Slider_default = Slider;
157
+
158
+ // src/Slider/index.ts
159
+ var Slider_default2 = Slider_default;
160
+
161
+ export {
162
+ Slider_default,
163
+ Slider_default2
164
+ };
165
+ //# sourceMappingURL=chunk-YMXUVBQ3.js.map