@fuf-stack/uniform 1.22.3 → 1.22.5

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 (227) hide show
  1. package/dist/Checkboxes/index.cjs +2 -1
  2. package/dist/Checkboxes/index.d.cts +2 -2
  3. package/dist/Checkboxes/index.d.ts +2 -2
  4. package/dist/Checkboxes/index.js +2 -2
  5. package/dist/{Checkboxes-DHk09GmH.cjs → Checkboxes-DrJqx6O2.cjs} +7 -1
  6. package/dist/{Checkboxes-DHk09GmH.cjs.map → Checkboxes-DrJqx6O2.cjs.map} +1 -1
  7. package/dist/{Checkboxes-D1hppxDE.js → Checkboxes-X6FRwI50.js} +2 -2
  8. package/dist/{Checkboxes-D1hppxDE.js.map → Checkboxes-X6FRwI50.js.map} +1 -1
  9. package/dist/DatePicker/index.cjs +2 -1
  10. package/dist/DatePicker/index.d.cts +2 -2
  11. package/dist/DatePicker/index.d.ts +2 -2
  12. package/dist/DatePicker/index.js +2 -2
  13. package/dist/{DatePicker-BUSi8SWQ.js → DatePicker-CGIWizz9.js} +2 -2
  14. package/dist/{DatePicker-BUSi8SWQ.js.map → DatePicker-CGIWizz9.js.map} +1 -1
  15. package/dist/{DatePicker-DuBjvS5g.cjs → DatePicker-CYUuwwsm.cjs} +7 -1
  16. package/dist/{DatePicker-DuBjvS5g.cjs.map → DatePicker-CYUuwwsm.cjs.map} +1 -1
  17. package/dist/FieldArray/index.cjs +2 -1
  18. package/dist/FieldArray/index.d.cts +2 -2
  19. package/dist/FieldArray/index.d.ts +2 -2
  20. package/dist/FieldArray/index.js +2 -2
  21. package/dist/{FieldArray-BxmK1NRd.js → FieldArray-Dkw6JBnT.js} +2 -2
  22. package/dist/{FieldArray-BxmK1NRd.js.map → FieldArray-Dkw6JBnT.js.map} +1 -1
  23. package/dist/{FieldArray-DgiQpIdr.cjs → FieldArray-V66fsvtd.cjs} +7 -1
  24. package/dist/{FieldArray-DgiQpIdr.cjs.map → FieldArray-V66fsvtd.cjs.map} +1 -1
  25. package/dist/FieldCard/index.cjs +6 -2
  26. package/dist/FieldCard/index.d.cts +2 -2
  27. package/dist/FieldCard/index.d.ts +2 -2
  28. package/dist/FieldCard/index.js +2 -2
  29. package/dist/{FieldCard-C-DZ5ARr.cjs → FieldCard-CAHnM8C0.cjs} +10 -1
  30. package/dist/FieldCard-CAHnM8C0.cjs.map +1 -0
  31. package/dist/{FieldCard-BK6SNqFY.js → FieldCard-Cg31ce9J.js} +5 -2
  32. package/dist/FieldCard-Cg31ce9J.js.map +1 -0
  33. package/dist/Input/index.d.cts +1 -1
  34. package/dist/Input/index.d.ts +1 -1
  35. package/dist/RadioBoxes/index.cjs +1 -1
  36. package/dist/RadioBoxes/index.d.cts +2 -2
  37. package/dist/RadioBoxes/index.d.ts +2 -2
  38. package/dist/RadioBoxes/index.js +1 -1
  39. package/dist/{RadioBoxes-CR--FBhQ.cjs → RadioBoxes-BmLrbYXt.cjs} +3 -3
  40. package/dist/RadioBoxes-BmLrbYXt.cjs.map +1 -0
  41. package/dist/{RadioBoxes-BJz-aJp3.js → RadioBoxes-DWxJBTKR.js} +3 -3
  42. package/dist/RadioBoxes-DWxJBTKR.js.map +1 -0
  43. package/dist/RadioTabs/index.cjs +2 -1
  44. package/dist/RadioTabs/index.d.cts +2 -2
  45. package/dist/RadioTabs/index.d.ts +2 -2
  46. package/dist/RadioTabs/index.js +2 -2
  47. package/dist/{RadioTabs-Btt582Nl.cjs → RadioTabs-14XTbTJU.cjs} +20 -14
  48. package/dist/RadioTabs-14XTbTJU.cjs.map +1 -0
  49. package/dist/{RadioTabs-CYmzrPBG.js → RadioTabs-DAY6MYJI.js} +15 -15
  50. package/dist/RadioTabs-DAY6MYJI.js.map +1 -0
  51. package/dist/Radios/index.cjs +2 -1
  52. package/dist/Radios/index.d.cts +2 -2
  53. package/dist/Radios/index.d.ts +2 -2
  54. package/dist/Radios/index.js +2 -2
  55. package/dist/{Radios-DZxhrX96.js → Radios-C938-msm.js} +2 -2
  56. package/dist/{Radios-DZxhrX96.js.map → Radios-C938-msm.js.map} +1 -1
  57. package/dist/{Radios-Jg9mwE0B.cjs → Radios-D_B9Y8s2.cjs} +7 -1
  58. package/dist/{Radios-Jg9mwE0B.cjs.map → Radios-D_B9Y8s2.cjs.map} +1 -1
  59. package/dist/Select/index.cjs +2 -1
  60. package/dist/Select/index.d.cts +2 -2
  61. package/dist/Select/index.d.ts +2 -2
  62. package/dist/Select/index.js +2 -2
  63. package/dist/{Select-CgeqhZIC.js → Select-BL6k_e-D.js} +2 -2
  64. package/dist/Select-BL6k_e-D.js.map +1 -0
  65. package/dist/{Select-CZwuEAB5.cjs → Select-D66A-hYm.cjs} +7 -1
  66. package/dist/Select-D66A-hYm.cjs.map +1 -0
  67. package/dist/Slider/index.cjs +2 -1
  68. package/dist/Slider/index.d.cts +2 -2
  69. package/dist/Slider/index.d.ts +2 -2
  70. package/dist/Slider/index.js +2 -2
  71. package/dist/{Slider-Bpxt-Qgj.cjs → Slider-ChC2PZNb.cjs} +7 -1
  72. package/dist/{Slider-Bpxt-Qgj.cjs.map → Slider-ChC2PZNb.cjs.map} +1 -1
  73. package/dist/{Slider-DRfSw0uE.js → Slider-DmEwhC1T.js} +2 -2
  74. package/dist/{Slider-DRfSw0uE.js.map → Slider-DmEwhC1T.js.map} +1 -1
  75. package/dist/Switch/index.cjs +2 -1
  76. package/dist/Switch/index.d.cts +2 -2
  77. package/dist/Switch/index.d.ts +2 -2
  78. package/dist/Switch/index.js +2 -2
  79. package/dist/{Switch-hjjy34QB.cjs → Switch-Ch6_VInV.cjs} +7 -1
  80. package/dist/{Switch-hjjy34QB.cjs.map → Switch-Ch6_VInV.cjs.map} +1 -1
  81. package/dist/{Switch-D9DNrqmj.js → Switch-DvKRPFcC.js} +2 -2
  82. package/dist/{Switch-D9DNrqmj.js.map → Switch-DvKRPFcC.js.map} +1 -1
  83. package/dist/SwitchBox/index.d.cts +1 -1
  84. package/dist/SwitchBox/index.d.ts +1 -1
  85. package/dist/SwitchBox-BU1XieaZ.js.map +1 -1
  86. package/dist/SwitchBox-Dl-F5y2m.cjs.map +1 -1
  87. package/dist/TextArea/index.d.cts +1 -1
  88. package/dist/TextArea/index.d.ts +1 -1
  89. package/dist/Time/index.cjs +7 -2
  90. package/dist/Time/index.d.cts +2 -2
  91. package/dist/Time/index.d.ts +2 -2
  92. package/dist/Time/index.js +2 -2
  93. package/dist/{Time-CDptQ3CK.js → Time-B_SXrKWK.js} +5 -2
  94. package/dist/Time-B_SXrKWK.js.map +1 -0
  95. package/dist/{Time-WKgbji5k.cjs → Time-CYoWaQsz.cjs} +16 -1
  96. package/dist/Time-CYoWaQsz.cjs.map +1 -0
  97. package/dist/hooks/useUniformFieldArray/index.cjs +4 -4
  98. package/dist/hooks/useUniformFieldArray/index.cjs.map +1 -1
  99. package/dist/hooks/useUniformFieldArray/index.js +4 -4
  100. package/dist/hooks/useUniformFieldArray/index.js.map +1 -1
  101. package/dist/index-19JGtN7H.d.cts +1257 -0
  102. package/dist/index-19JGtN7H.d.cts.map +1 -0
  103. package/dist/index-B4XExHDi.d.cts +539 -0
  104. package/dist/index-B4XExHDi.d.cts.map +1 -0
  105. package/dist/index-BUZEnZDm.d.ts +1760 -0
  106. package/dist/index-BUZEnZDm.d.ts.map +1 -0
  107. package/dist/index-Bbaubtxp.d.cts +677 -0
  108. package/dist/index-Bbaubtxp.d.cts.map +1 -0
  109. package/dist/index-BdgFJ-dj.d.ts +1028 -0
  110. package/dist/index-BdgFJ-dj.d.ts.map +1 -0
  111. package/dist/index-BiZNkLK3.d.cts +1477 -0
  112. package/dist/index-BiZNkLK3.d.cts.map +1 -0
  113. package/dist/index-Bie3CWyW.d.cts +1760 -0
  114. package/dist/index-Bie3CWyW.d.cts.map +1 -0
  115. package/dist/index-BsTqcI1C.d.cts +659 -0
  116. package/dist/index-BsTqcI1C.d.cts.map +1 -0
  117. package/dist/index-C6Y8KybK.d.ts +677 -0
  118. package/dist/index-C6Y8KybK.d.ts.map +1 -0
  119. package/dist/index-CD0Wpla3.d.cts +1413 -0
  120. package/dist/index-CD0Wpla3.d.cts.map +1 -0
  121. package/dist/index-CUByIf_d.d.ts +314 -0
  122. package/dist/index-CUByIf_d.d.ts.map +1 -0
  123. package/dist/index-Cf2B9woY.d.cts +473 -0
  124. package/dist/index-Cf2B9woY.d.cts.map +1 -0
  125. package/dist/index-CqXEYILn.d.cts +1263 -0
  126. package/dist/index-CqXEYILn.d.cts.map +1 -0
  127. package/dist/index-D1cB3mbB.d.ts +3917 -0
  128. package/dist/index-D1cB3mbB.d.ts.map +1 -0
  129. package/dist/index-D7AUghFx.d.ts +1413 -0
  130. package/dist/index-D7AUghFx.d.ts.map +1 -0
  131. package/dist/index-DCwffq1f.d.ts +1263 -0
  132. package/dist/index-DCwffq1f.d.ts.map +1 -0
  133. package/dist/index-DFbuWomg.d.ts +534 -0
  134. package/dist/index-DFbuWomg.d.ts.map +1 -0
  135. package/dist/index-DXOBPBft.d.ts +659 -0
  136. package/dist/index-DXOBPBft.d.ts.map +1 -0
  137. package/dist/index-DY-d4cFe.d.cts +1028 -0
  138. package/dist/index-DY-d4cFe.d.cts.map +1 -0
  139. package/dist/index-DqMpHpu7.d.ts +1257 -0
  140. package/dist/index-DqMpHpu7.d.ts.map +1 -0
  141. package/dist/index-DwnqyNnX.d.cts +534 -0
  142. package/dist/index-DwnqyNnX.d.cts.map +1 -0
  143. package/dist/index-OdNTqjhQ.d.ts +585 -0
  144. package/dist/index-OdNTqjhQ.d.ts.map +1 -0
  145. package/dist/index-QPDvw5Z5.d.cts +585 -0
  146. package/dist/index-QPDvw5Z5.d.cts.map +1 -0
  147. package/dist/index-amMd-sQN.d.ts +473 -0
  148. package/dist/index-amMd-sQN.d.ts.map +1 -0
  149. package/dist/index-clztdahp.d.ts +1477 -0
  150. package/dist/index-clztdahp.d.ts.map +1 -0
  151. package/dist/index-jK092-MJ.d.cts +314 -0
  152. package/dist/index-jK092-MJ.d.cts.map +1 -0
  153. package/dist/index-veBM95Gw.d.cts +3917 -0
  154. package/dist/index-veBM95Gw.d.cts.map +1 -0
  155. package/dist/index-yYjVSHlN.d.ts +539 -0
  156. package/dist/index-yYjVSHlN.d.ts.map +1 -0
  157. package/dist/index.cjs +20 -11
  158. package/dist/index.d.cts +15 -15
  159. package/dist/index.d.ts +15 -15
  160. package/dist/index.js +12 -12
  161. package/package.json +6 -6
  162. package/dist/FieldCard-BK6SNqFY.js.map +0 -1
  163. package/dist/FieldCard-C-DZ5ARr.cjs.map +0 -1
  164. package/dist/RadioBoxes-BJz-aJp3.js.map +0 -1
  165. package/dist/RadioBoxes-CR--FBhQ.cjs.map +0 -1
  166. package/dist/RadioTabs-Btt582Nl.cjs.map +0 -1
  167. package/dist/RadioTabs-CYmzrPBG.js.map +0 -1
  168. package/dist/Select-CZwuEAB5.cjs.map +0 -1
  169. package/dist/Select-CgeqhZIC.js.map +0 -1
  170. package/dist/Time-CDptQ3CK.js.map +0 -1
  171. package/dist/Time-WKgbji5k.cjs.map +0 -1
  172. package/dist/index-B4jKGy-P.d.ts +0 -167
  173. package/dist/index-B4jKGy-P.d.ts.map +0 -1
  174. package/dist/index-B5SfdA5O.d.cts +0 -99
  175. package/dist/index-B5SfdA5O.d.cts.map +0 -1
  176. package/dist/index-B61zRzeS.d.cts +0 -101
  177. package/dist/index-B61zRzeS.d.cts.map +0 -1
  178. package/dist/index-BDFJDKmz.d.ts +0 -166
  179. package/dist/index-BDFJDKmz.d.ts.map +0 -1
  180. package/dist/index-BE4OAqJ2.d.cts +0 -113
  181. package/dist/index-BE4OAqJ2.d.cts.map +0 -1
  182. package/dist/index-BMEKfOWp.d.ts +0 -174
  183. package/dist/index-BMEKfOWp.d.ts.map +0 -1
  184. package/dist/index-BPaSE_7b.d.ts +0 -179
  185. package/dist/index-BPaSE_7b.d.ts.map +0 -1
  186. package/dist/index-BSjcTo7A.d.ts +0 -147
  187. package/dist/index-BSjcTo7A.d.ts.map +0 -1
  188. package/dist/index-Bgo2Dr6X.d.cts +0 -174
  189. package/dist/index-Bgo2Dr6X.d.cts.map +0 -1
  190. package/dist/index-BmMspnsJ.d.cts +0 -137
  191. package/dist/index-BmMspnsJ.d.cts.map +0 -1
  192. package/dist/index-BvbHkoH5.d.cts +0 -290
  193. package/dist/index-BvbHkoH5.d.cts.map +0 -1
  194. package/dist/index-C6DBVs7t.d.ts +0 -116
  195. package/dist/index-C6DBVs7t.d.ts.map +0 -1
  196. package/dist/index-CIiOXrrY.d.ts +0 -99
  197. package/dist/index-CIiOXrrY.d.ts.map +0 -1
  198. package/dist/index-CSRKNes5.d.cts +0 -167
  199. package/dist/index-CSRKNes5.d.cts.map +0 -1
  200. package/dist/index-CbPJiRK2.d.ts +0 -83
  201. package/dist/index-CbPJiRK2.d.ts.map +0 -1
  202. package/dist/index-CbQ8Ft4o.d.ts +0 -113
  203. package/dist/index-CbQ8Ft4o.d.ts.map +0 -1
  204. package/dist/index-CvP3tbVV.d.ts +0 -137
  205. package/dist/index-CvP3tbVV.d.ts.map +0 -1
  206. package/dist/index-Cwb7sTO0.d.ts +0 -154
  207. package/dist/index-Cwb7sTO0.d.ts.map +0 -1
  208. package/dist/index-CxY9VWv5.d.cts +0 -154
  209. package/dist/index-CxY9VWv5.d.cts.map +0 -1
  210. package/dist/index-Cz4JaCWd.d.ts +0 -122
  211. package/dist/index-Cz4JaCWd.d.ts.map +0 -1
  212. package/dist/index-DBsF7xsq.d.cts +0 -147
  213. package/dist/index-DBsF7xsq.d.cts.map +0 -1
  214. package/dist/index-DMOhTl4I.d.cts +0 -116
  215. package/dist/index-DMOhTl4I.d.cts.map +0 -1
  216. package/dist/index-DRg0anjB.d.cts +0 -179
  217. package/dist/index-DRg0anjB.d.cts.map +0 -1
  218. package/dist/index-DUmNI6cE.d.cts +0 -83
  219. package/dist/index-DUmNI6cE.d.cts.map +0 -1
  220. package/dist/index-Db0WD4d1.d.cts +0 -166
  221. package/dist/index-Db0WD4d1.d.cts.map +0 -1
  222. package/dist/index-GqydEAFk.d.ts +0 -290
  223. package/dist/index-GqydEAFk.d.ts.map +0 -1
  224. package/dist/index-PMCqBX0t.d.ts +0 -101
  225. package/dist/index-PMCqBX0t.d.ts.map +0 -1
  226. package/dist/index-Q3BWGyUO.d.cts +0 -122
  227. package/dist/index-Q3BWGyUO.d.cts.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"Time-CDptQ3CK.js","names":["HeroTimeInput"],"sources":["../src/Time/timeHelpers.ts","../src/Time/Time.tsx"],"sourcesContent":["import type { TimeInput as HeroTimeInput } from '@heroui/date-input';\nimport type { ComponentProps } from 'react';\n\nimport {\n getLocalTimeZone,\n parseAbsolute,\n parseAbsoluteToLocal,\n parseDateTime,\n parseZonedDateTime,\n} from '@internationalized/date';\n\n/** Value type accepted by HeroUI TimeInput */\nexport type TimeValue = ComponentProps<typeof HeroTimeInput>['value'];\n\n/** Cast unknown input to the TimeInput value union type. */\nconst asTimeValue = (value: unknown): TimeValue => {\n return value as TimeValue;\n};\n\n/** Check whether a value already looks like an @internationalized/date value. */\nconst isTimeValueLike = (value: unknown): value is object => {\n if (!value || typeof value !== 'object') {\n return false;\n }\n\n return 'hour' in value || 'calendar' in value;\n};\n\n/** Check if the incoming string represents a plain time (e.g. 09:30 or 09:30:45). */\nconst isTimeOnlyString = (value: string): boolean => {\n return /^\\d{2}:\\d{2}(?::\\d{2}(?:\\.\\d{1,3})?)?$/.test(value);\n};\n\n/** Check if the incoming string is a UTC time-only value (e.g. 09:30Z). */\nconst isUtcTimeOnlyString = (value: string): boolean => {\n return /^\\d{2}:\\d{2}(?::\\d{2}(?:\\.\\d{1,3})?)?Z$/.test(value);\n};\n\n/** Zero-pad integer segments for time serialization. */\nconst pad = (value: number): string => {\n return String(value).padStart(2, '0');\n};\n\n/** Convert an absolute ISO string into UTC time-only store format. */\nconst toUtcTimeString = (\n absoluteIsoString: string,\n granularity: 'hour' | 'minute',\n): string | null => {\n const utcDate = new Date(absoluteIsoString);\n if (Number.isNaN(utcDate.getTime())) {\n return null;\n }\n\n const hour = pad(utcDate.getUTCHours());\n if (granularity === 'hour') {\n return `${hour}:00Z`;\n }\n\n return `${hour}:${pad(utcDate.getUTCMinutes())}Z`;\n};\n\n/** True when an input already carries timezone/offset information. */\nconst hasExplicitTimeZone = (value: string): boolean => {\n if (value.includes('[') && value.includes(']')) {\n return true;\n }\n\n return /(?:[zZ]|[+-]\\d{2}:\\d{2})$/.test(value);\n};\n\n/** True for date-time strings without timezone/offset. */\nconst isNaiveDateTimeString = (value: string): boolean => {\n return /^\\d{4}-\\d{2}-\\d{2}T/.test(value) && !hasExplicitTimeZone(value);\n};\n\n/** Safely run a parser and return `null` on parsing errors. */\nconst tryParse = (parser: () => unknown): TimeValue => {\n try {\n return asTimeValue(parser());\n } catch {\n return null;\n }\n};\n\n/**\n * Parse a form value into a HeroUI TimeInput compatible `TimeValue`.\n *\n * Supports existing `TimeValue` objects, native `Date` instances, plain time\n * strings (`HH:mm[:ss]`), absolute ISO date-time strings, zoned date-time\n * strings, and local date-time strings.\n *\n * Time-only strings are interpreted in the active timezone and normalized to a\n * `ZonedDateTime` (using a fixed reference date) so timezone abbreviations can\n * remain visible in the UI.\n */\nexport const parseTimeValue = (\n value: unknown,\n timeZone?: string,\n): TimeValue => {\n if (value == null || value === '') {\n return null;\n }\n\n if (isTimeValueLike(value)) {\n return asTimeValue(value);\n }\n\n if (value instanceof Date) {\n return asTimeValue(\n timeZone\n ? parseAbsolute(value.toISOString(), timeZone)\n : parseAbsoluteToLocal(value.toISOString()),\n );\n }\n\n if (typeof value !== 'string') {\n return null;\n }\n\n const normalizedValue = value.trim();\n if (normalizedValue === '') {\n return null;\n }\n\n if (isTimeOnlyString(normalizedValue)) {\n return tryParse(() => {\n const [hourValue, minuteValue, secondValue] = normalizedValue\n .split(':')\n .map(Number);\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n const hour = pad(hourValue);\n const minute = pad(minuteValue);\n const second = pad(secondValue ?? 0);\n\n return parseZonedDateTime(\n `1970-01-01T${hour}:${minute}:${second}[${resolvedTimeZone}]`,\n );\n });\n }\n\n if (isUtcTimeOnlyString(normalizedValue)) {\n return tryParse(() => {\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n return parseAbsolute(`1970-01-01T${normalizedValue}`, resolvedTimeZone);\n });\n }\n\n const parsers: (() => unknown)[] = [\n ...(timeZone && isNaiveDateTimeString(normalizedValue)\n ? [\n () => {\n return parseZonedDateTime(`${normalizedValue}[${timeZone}]`);\n },\n ]\n : []),\n () => {\n return timeZone\n ? parseAbsolute(normalizedValue, timeZone)\n : parseAbsoluteToLocal(normalizedValue);\n },\n () => {\n return parseZonedDateTime(normalizedValue);\n },\n () => {\n return parseDateTime(normalizedValue);\n },\n ];\n\n return (\n parsers\n .map((parser) => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return tryParse(parser);\n })\n .find((parsedValue) => {\n return parsedValue != null;\n }) ?? null\n );\n};\n\n/** Resolve the timezone used for parsing and string conversion. */\nexport const resolveTimeFieldTimeZone = (timeZone?: string): string => {\n return timeZone ?? getLocalTimeZone();\n};\n\n/**\n * Build default placeholder value for TimeInput.\n *\n * Uses a fixed reference time to keep snapshots deterministic.\n */\nexport const getTimeFieldPlaceholderValue = (timeZone?: string): TimeValue => {\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n return asTimeValue(\n parseZonedDateTime(`1970-01-01T00:00:00[${resolvedTimeZone}]`),\n );\n};\n\n/**\n * Convert a TimeValue into a UTC time-only string for form state.\n *\n * The stored format is `HH:mmZ` (or `HH:00Z` when granularity is `hour`).\n */\nexport const timeValueToString = (\n value: TimeValue,\n timeZone: string,\n granularity: 'hour' | 'minute' = 'minute',\n): string | null => {\n if (value == null) {\n return null;\n }\n\n const maybeWithAbsoluteString = value as { toAbsoluteString?: () => string };\n if (typeof maybeWithAbsoluteString.toAbsoluteString === 'function') {\n return toUtcTimeString(\n maybeWithAbsoluteString.toAbsoluteString(),\n granularity,\n );\n }\n\n const maybeWithToDate = value as { toDate?: (zone: string) => Date };\n if (typeof maybeWithToDate.toDate === 'function') {\n return toUtcTimeString(\n maybeWithToDate.toDate(timeZone).toISOString(),\n granularity,\n );\n }\n\n const maybeTime = value as {\n hour?: number;\n minute?: number;\n second?: number;\n };\n if (\n typeof maybeTime.hour === 'number' &&\n typeof maybeTime.minute === 'number'\n ) {\n const hour = pad(maybeTime.hour);\n const minute = pad(maybeTime.minute);\n const second = pad(maybeTime.second ?? 0);\n return toUtcTimeString(\n parseZonedDateTime(\n `1970-01-01T${hour}:${minute}:${second}[${timeZone}]`,\n ).toAbsoluteString(),\n granularity,\n );\n }\n\n return null;\n};\n","import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\nimport type { TimeValue } from './timeHelpers';\n\nimport { TimeInput as HeroTimeInput } from '@heroui/date-input';\n\nimport { tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { useUniformField } from '../hooks/useUniformField';\nimport {\n getTimeFieldPlaceholderValue,\n parseTimeValue,\n resolveTimeFieldTimeZone,\n timeValueToString,\n} from './timeHelpers';\n\nexport const timeVariants = tv({\n slots: {\n /** wrapper around the whole time input */\n base: '',\n /** helper wrapper for error/description */\n helperWrapper: [\n // set padding to 0 for error message exit animation\n 'p-0',\n ],\n /** the segmented input element */\n input: '',\n /** inner wrapper around segments and optional content */\n innerWrapper: '',\n /** outer input wrapper */\n inputWrapper: 'bg-content1 focus-within:border-focus',\n /** field label */\n label: '',\n /** individual segment */\n segment: '',\n },\n});\n\ntype VariantProps = TVProps<typeof timeVariants>;\ntype ClassName = TVClassName<typeof timeVariants>;\n\nexport interface TimeProps extends VariantProps {\n /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */\n ariaLabel?: string;\n /** CSS class name */\n className?: ClassName;\n /** input is disabled */\n disabled?: boolean;\n /** smallest visible unit in the segmented time input */\n granularity?: 'hour' | 'minute';\n /** hide timezone abbreviation for zoned values */\n hideTimeZone?: boolean;\n /** force hour granularity and store UTC hour as number (0-23) */\n hourAsNumber?: boolean;\n /** hour cycle formatting */\n hourCycle?: 12 | 24;\n /** form field label */\n label?: ReactNode;\n /** form field name */\n name: string;\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n /**\n * Optional timezone used for parsing date-time strings and serializing values.\n * When omitted, local timezone is used.\n */\n timeZone?: string;\n /** value format stored in form state (`string` stores UTC minute values, e.g. `10:15Z`) */\n valueType?: 'string' | 'timeValue';\n}\n\n/**\n * Time component based on [HeroUI TimeInput](https://v2.heroui.com/docs/components/time-input)\n */\nconst Time = ({\n className: _className = undefined,\n granularity = 'minute',\n hideTimeZone = false,\n hourAsNumber = false,\n hourCycle = undefined,\n name,\n timeZone = undefined,\n valueType = 'string',\n ...uniformFieldProps\n}: TimeProps) => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: { onBlur, onChange, value },\n invalid,\n label,\n required,\n testId,\n } = useUniformField({ name, ...uniformFieldProps });\n\n // classNames from slots\n const variants = timeVariants();\n const classNames = variantsToClassNames(variants, _className, 'base');\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n const effectiveGranularity = hourAsNumber ? 'hour' : granularity;\n\n // `hourAsNumber` stores 0-23; convert this into a parseable UTC time for display.\n const normalizedFieldValue =\n hourAsNumber && typeof value === 'number'\n ? `${String(Math.max(0, Math.min(23, value))).padStart(2, '0')}:00Z`\n : value;\n\n // Normalize incoming form value into HeroUI TimeInput value shape.\n const parsedValue = parseTimeValue(normalizedFieldValue, timeZone);\n const placeholderValue = getTimeFieldPlaceholderValue(timeZone);\n\n // Normalize TimeInput output into the configured storage format.\n const handleChange = (nextValue: TimeValue) => {\n if (nextValue == null) {\n onChange(null);\n return;\n }\n\n if (hourAsNumber) {\n const serializedValue = timeValueToString(\n nextValue,\n resolvedTimeZone,\n 'hour',\n );\n\n if (!serializedValue) {\n onChange(null);\n return;\n }\n\n const [hoursSegment] = serializedValue.split(':');\n const parsedHours = Number(hoursSegment);\n onChange(Number.isNaN(parsedHours) ? null : parsedHours);\n return;\n }\n\n if (valueType === 'timeValue') {\n onChange(nextValue);\n return;\n }\n\n onChange(\n timeValueToString(nextValue, resolvedTimeZone, effectiveGranularity) ??\n String(nextValue),\n );\n };\n\n return (\n <HeroTimeInput\n aria-label={label ? undefined : ariaLabel}\n classNames={{\n base: classNames.base,\n helperWrapper: classNames.helperWrapper,\n innerWrapper: classNames.innerWrapper,\n input: classNames.input,\n inputWrapper: classNames.inputWrapper,\n label: classNames.label,\n segment: classNames.segment,\n }}\n data-testid={testId}\n errorMessage={errorMessage}\n granularity={effectiveGranularity}\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\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={handleChange}\n placeholderValue={placeholderValue ?? undefined}\n radius=\"sm\"\n value={parsedValue ?? undefined}\n variant=\"bordered\"\n />\n );\n};\n\nexport default Time;\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Time-WKgbji5k.cjs","names":["useUniformField","HeroTimeInput"],"sources":["../src/Time/timeHelpers.ts","../src/Time/Time.tsx"],"sourcesContent":["import type { TimeInput as HeroTimeInput } from '@heroui/date-input';\nimport type { ComponentProps } from 'react';\n\nimport {\n getLocalTimeZone,\n parseAbsolute,\n parseAbsoluteToLocal,\n parseDateTime,\n parseZonedDateTime,\n} from '@internationalized/date';\n\n/** Value type accepted by HeroUI TimeInput */\nexport type TimeValue = ComponentProps<typeof HeroTimeInput>['value'];\n\n/** Cast unknown input to the TimeInput value union type. */\nconst asTimeValue = (value: unknown): TimeValue => {\n return value as TimeValue;\n};\n\n/** Check whether a value already looks like an @internationalized/date value. */\nconst isTimeValueLike = (value: unknown): value is object => {\n if (!value || typeof value !== 'object') {\n return false;\n }\n\n return 'hour' in value || 'calendar' in value;\n};\n\n/** Check if the incoming string represents a plain time (e.g. 09:30 or 09:30:45). */\nconst isTimeOnlyString = (value: string): boolean => {\n return /^\\d{2}:\\d{2}(?::\\d{2}(?:\\.\\d{1,3})?)?$/.test(value);\n};\n\n/** Check if the incoming string is a UTC time-only value (e.g. 09:30Z). */\nconst isUtcTimeOnlyString = (value: string): boolean => {\n return /^\\d{2}:\\d{2}(?::\\d{2}(?:\\.\\d{1,3})?)?Z$/.test(value);\n};\n\n/** Zero-pad integer segments for time serialization. */\nconst pad = (value: number): string => {\n return String(value).padStart(2, '0');\n};\n\n/** Convert an absolute ISO string into UTC time-only store format. */\nconst toUtcTimeString = (\n absoluteIsoString: string,\n granularity: 'hour' | 'minute',\n): string | null => {\n const utcDate = new Date(absoluteIsoString);\n if (Number.isNaN(utcDate.getTime())) {\n return null;\n }\n\n const hour = pad(utcDate.getUTCHours());\n if (granularity === 'hour') {\n return `${hour}:00Z`;\n }\n\n return `${hour}:${pad(utcDate.getUTCMinutes())}Z`;\n};\n\n/** True when an input already carries timezone/offset information. */\nconst hasExplicitTimeZone = (value: string): boolean => {\n if (value.includes('[') && value.includes(']')) {\n return true;\n }\n\n return /(?:[zZ]|[+-]\\d{2}:\\d{2})$/.test(value);\n};\n\n/** True for date-time strings without timezone/offset. */\nconst isNaiveDateTimeString = (value: string): boolean => {\n return /^\\d{4}-\\d{2}-\\d{2}T/.test(value) && !hasExplicitTimeZone(value);\n};\n\n/** Safely run a parser and return `null` on parsing errors. */\nconst tryParse = (parser: () => unknown): TimeValue => {\n try {\n return asTimeValue(parser());\n } catch {\n return null;\n }\n};\n\n/**\n * Parse a form value into a HeroUI TimeInput compatible `TimeValue`.\n *\n * Supports existing `TimeValue` objects, native `Date` instances, plain time\n * strings (`HH:mm[:ss]`), absolute ISO date-time strings, zoned date-time\n * strings, and local date-time strings.\n *\n * Time-only strings are interpreted in the active timezone and normalized to a\n * `ZonedDateTime` (using a fixed reference date) so timezone abbreviations can\n * remain visible in the UI.\n */\nexport const parseTimeValue = (\n value: unknown,\n timeZone?: string,\n): TimeValue => {\n if (value == null || value === '') {\n return null;\n }\n\n if (isTimeValueLike(value)) {\n return asTimeValue(value);\n }\n\n if (value instanceof Date) {\n return asTimeValue(\n timeZone\n ? parseAbsolute(value.toISOString(), timeZone)\n : parseAbsoluteToLocal(value.toISOString()),\n );\n }\n\n if (typeof value !== 'string') {\n return null;\n }\n\n const normalizedValue = value.trim();\n if (normalizedValue === '') {\n return null;\n }\n\n if (isTimeOnlyString(normalizedValue)) {\n return tryParse(() => {\n const [hourValue, minuteValue, secondValue] = normalizedValue\n .split(':')\n .map(Number);\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n const hour = pad(hourValue);\n const minute = pad(minuteValue);\n const second = pad(secondValue ?? 0);\n\n return parseZonedDateTime(\n `1970-01-01T${hour}:${minute}:${second}[${resolvedTimeZone}]`,\n );\n });\n }\n\n if (isUtcTimeOnlyString(normalizedValue)) {\n return tryParse(() => {\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n return parseAbsolute(`1970-01-01T${normalizedValue}`, resolvedTimeZone);\n });\n }\n\n const parsers: (() => unknown)[] = [\n ...(timeZone && isNaiveDateTimeString(normalizedValue)\n ? [\n () => {\n return parseZonedDateTime(`${normalizedValue}[${timeZone}]`);\n },\n ]\n : []),\n () => {\n return timeZone\n ? parseAbsolute(normalizedValue, timeZone)\n : parseAbsoluteToLocal(normalizedValue);\n },\n () => {\n return parseZonedDateTime(normalizedValue);\n },\n () => {\n return parseDateTime(normalizedValue);\n },\n ];\n\n return (\n parsers\n .map((parser) => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return tryParse(parser);\n })\n .find((parsedValue) => {\n return parsedValue != null;\n }) ?? null\n );\n};\n\n/** Resolve the timezone used for parsing and string conversion. */\nexport const resolveTimeFieldTimeZone = (timeZone?: string): string => {\n return timeZone ?? getLocalTimeZone();\n};\n\n/**\n * Build default placeholder value for TimeInput.\n *\n * Uses a fixed reference time to keep snapshots deterministic.\n */\nexport const getTimeFieldPlaceholderValue = (timeZone?: string): TimeValue => {\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n return asTimeValue(\n parseZonedDateTime(`1970-01-01T00:00:00[${resolvedTimeZone}]`),\n );\n};\n\n/**\n * Convert a TimeValue into a UTC time-only string for form state.\n *\n * The stored format is `HH:mmZ` (or `HH:00Z` when granularity is `hour`).\n */\nexport const timeValueToString = (\n value: TimeValue,\n timeZone: string,\n granularity: 'hour' | 'minute' = 'minute',\n): string | null => {\n if (value == null) {\n return null;\n }\n\n const maybeWithAbsoluteString = value as { toAbsoluteString?: () => string };\n if (typeof maybeWithAbsoluteString.toAbsoluteString === 'function') {\n return toUtcTimeString(\n maybeWithAbsoluteString.toAbsoluteString(),\n granularity,\n );\n }\n\n const maybeWithToDate = value as { toDate?: (zone: string) => Date };\n if (typeof maybeWithToDate.toDate === 'function') {\n return toUtcTimeString(\n maybeWithToDate.toDate(timeZone).toISOString(),\n granularity,\n );\n }\n\n const maybeTime = value as {\n hour?: number;\n minute?: number;\n second?: number;\n };\n if (\n typeof maybeTime.hour === 'number' &&\n typeof maybeTime.minute === 'number'\n ) {\n const hour = pad(maybeTime.hour);\n const minute = pad(maybeTime.minute);\n const second = pad(maybeTime.second ?? 0);\n return toUtcTimeString(\n parseZonedDateTime(\n `1970-01-01T${hour}:${minute}:${second}[${timeZone}]`,\n ).toAbsoluteString(),\n granularity,\n );\n }\n\n return null;\n};\n","import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactNode } from 'react';\nimport type { TimeValue } from './timeHelpers';\n\nimport { TimeInput as HeroTimeInput } from '@heroui/date-input';\n\nimport { tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { useUniformField } from '../hooks/useUniformField';\nimport {\n getTimeFieldPlaceholderValue,\n parseTimeValue,\n resolveTimeFieldTimeZone,\n timeValueToString,\n} from './timeHelpers';\n\nexport const timeVariants = tv({\n slots: {\n /** wrapper around the whole time input */\n base: '',\n /** helper wrapper for error/description */\n helperWrapper: [\n // set padding to 0 for error message exit animation\n 'p-0',\n ],\n /** the segmented input element */\n input: '',\n /** inner wrapper around segments and optional content */\n innerWrapper: '',\n /** outer input wrapper */\n inputWrapper: 'bg-content1 focus-within:border-focus',\n /** field label */\n label: '',\n /** individual segment */\n segment: '',\n },\n});\n\ntype VariantProps = TVProps<typeof timeVariants>;\ntype ClassName = TVClassName<typeof timeVariants>;\n\nexport interface TimeProps extends VariantProps {\n /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */\n ariaLabel?: string;\n /** CSS class name */\n className?: ClassName;\n /** input is disabled */\n disabled?: boolean;\n /** smallest visible unit in the segmented time input */\n granularity?: 'hour' | 'minute';\n /** hide timezone abbreviation for zoned values */\n hideTimeZone?: boolean;\n /** force hour granularity and store UTC hour as number (0-23) */\n hourAsNumber?: boolean;\n /** hour cycle formatting */\n hourCycle?: 12 | 24;\n /** form field label */\n label?: ReactNode;\n /** form field name */\n name: string;\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n /**\n * Optional timezone used for parsing date-time strings and serializing values.\n * When omitted, local timezone is used.\n */\n timeZone?: string;\n /** value format stored in form state (`string` stores UTC minute values, e.g. `10:15Z`) */\n valueType?: 'string' | 'timeValue';\n}\n\n/**\n * Time component based on [HeroUI TimeInput](https://v2.heroui.com/docs/components/time-input)\n */\nconst Time = ({\n className: _className = undefined,\n granularity = 'minute',\n hideTimeZone = false,\n hourAsNumber = false,\n hourCycle = undefined,\n name,\n timeZone = undefined,\n valueType = 'string',\n ...uniformFieldProps\n}: TimeProps) => {\n const {\n ariaLabel,\n disabled,\n errorMessage,\n field: { onBlur, onChange, value },\n invalid,\n label,\n required,\n testId,\n } = useUniformField({ name, ...uniformFieldProps });\n\n // classNames from slots\n const variants = timeVariants();\n const classNames = variantsToClassNames(variants, _className, 'base');\n const resolvedTimeZone = resolveTimeFieldTimeZone(timeZone);\n const effectiveGranularity = hourAsNumber ? 'hour' : granularity;\n\n // `hourAsNumber` stores 0-23; convert this into a parseable UTC time for display.\n const normalizedFieldValue =\n hourAsNumber && typeof value === 'number'\n ? `${String(Math.max(0, Math.min(23, value))).padStart(2, '0')}:00Z`\n : value;\n\n // Normalize incoming form value into HeroUI TimeInput value shape.\n const parsedValue = parseTimeValue(normalizedFieldValue, timeZone);\n const placeholderValue = getTimeFieldPlaceholderValue(timeZone);\n\n // Normalize TimeInput output into the configured storage format.\n const handleChange = (nextValue: TimeValue) => {\n if (nextValue == null) {\n onChange(null);\n return;\n }\n\n if (hourAsNumber) {\n const serializedValue = timeValueToString(\n nextValue,\n resolvedTimeZone,\n 'hour',\n );\n\n if (!serializedValue) {\n onChange(null);\n return;\n }\n\n const [hoursSegment] = serializedValue.split(':');\n const parsedHours = Number(hoursSegment);\n onChange(Number.isNaN(parsedHours) ? null : parsedHours);\n return;\n }\n\n if (valueType === 'timeValue') {\n onChange(nextValue);\n return;\n }\n\n onChange(\n timeValueToString(nextValue, resolvedTimeZone, effectiveGranularity) ??\n String(nextValue),\n );\n };\n\n return (\n <HeroTimeInput\n aria-label={label ? undefined : ariaLabel}\n classNames={{\n base: classNames.base,\n helperWrapper: classNames.helperWrapper,\n innerWrapper: classNames.innerWrapper,\n input: classNames.input,\n inputWrapper: classNames.inputWrapper,\n label: classNames.label,\n segment: classNames.segment,\n }}\n data-testid={testId}\n errorMessage={errorMessage}\n granularity={effectiveGranularity}\n hideTimeZone={hideTimeZone}\n hourCycle={hourCycle}\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={handleChange}\n placeholderValue={placeholderValue ?? undefined}\n radius=\"sm\"\n value={parsedValue ?? undefined}\n variant=\"bordered\"\n />\n );\n};\n\nexport default Time;\n"],"mappings":"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"}
@@ -1,167 +0,0 @@
1
- import { TVClassName, TVProps } from "@fuf-stack/pixel-utils";
2
- import { ReactNode } from "react";
3
-
4
- //#region src/Slider/Slider.d.ts
5
- declare const sliderVariants: import("tailwind-variants").TVReturnType<{
6
- [key: string]: {
7
- [key: string]: import("tailwind-merge").ClassNameValue | {
8
- label?: import("tailwind-merge").ClassNameValue;
9
- value?: import("tailwind-merge").ClassNameValue;
10
- errorMessage?: import("tailwind-merge").ClassNameValue;
11
- base?: import("tailwind-merge").ClassNameValue;
12
- mark?: import("tailwind-merge").ClassNameValue;
13
- track?: import("tailwind-merge").ClassNameValue;
14
- step?: import("tailwind-merge").ClassNameValue;
15
- endContent?: import("tailwind-merge").ClassNameValue;
16
- startContent?: import("tailwind-merge").ClassNameValue;
17
- thumb?: import("tailwind-merge").ClassNameValue;
18
- filler?: import("tailwind-merge").ClassNameValue;
19
- labelWrapper?: import("tailwind-merge").ClassNameValue;
20
- trackWrapper?: import("tailwind-merge").ClassNameValue;
21
- };
22
- };
23
- } | {
24
- [x: string]: {
25
- [x: string]: import("tailwind-merge").ClassNameValue | {
26
- label?: import("tailwind-merge").ClassNameValue;
27
- value?: import("tailwind-merge").ClassNameValue;
28
- errorMessage?: import("tailwind-merge").ClassNameValue;
29
- base?: import("tailwind-merge").ClassNameValue;
30
- mark?: import("tailwind-merge").ClassNameValue;
31
- track?: import("tailwind-merge").ClassNameValue;
32
- step?: import("tailwind-merge").ClassNameValue;
33
- endContent?: import("tailwind-merge").ClassNameValue;
34
- startContent?: import("tailwind-merge").ClassNameValue;
35
- thumb?: import("tailwind-merge").ClassNameValue;
36
- filler?: import("tailwind-merge").ClassNameValue;
37
- labelWrapper?: import("tailwind-merge").ClassNameValue;
38
- trackWrapper?: import("tailwind-merge").ClassNameValue;
39
- };
40
- };
41
- } | {}, {
42
- base: string;
43
- endContent: string;
44
- errorMessage: string;
45
- filler: string;
46
- label: string;
47
- labelWrapper: string;
48
- mark: string;
49
- startContent: string;
50
- step: string;
51
- thumb: string;
52
- track: string;
53
- trackWrapper: string;
54
- value: string;
55
- }, undefined, {
56
- [key: string]: {
57
- [key: string]: import("tailwind-merge").ClassNameValue | {
58
- label?: import("tailwind-merge").ClassNameValue;
59
- value?: import("tailwind-merge").ClassNameValue;
60
- errorMessage?: import("tailwind-merge").ClassNameValue;
61
- base?: import("tailwind-merge").ClassNameValue;
62
- mark?: import("tailwind-merge").ClassNameValue;
63
- track?: import("tailwind-merge").ClassNameValue;
64
- step?: import("tailwind-merge").ClassNameValue;
65
- endContent?: import("tailwind-merge").ClassNameValue;
66
- startContent?: import("tailwind-merge").ClassNameValue;
67
- thumb?: import("tailwind-merge").ClassNameValue;
68
- filler?: import("tailwind-merge").ClassNameValue;
69
- labelWrapper?: import("tailwind-merge").ClassNameValue;
70
- trackWrapper?: import("tailwind-merge").ClassNameValue;
71
- };
72
- };
73
- } | {}, {
74
- base: string;
75
- endContent: string;
76
- errorMessage: string;
77
- filler: string;
78
- label: string;
79
- labelWrapper: string;
80
- mark: string;
81
- startContent: string;
82
- step: string;
83
- thumb: string;
84
- track: string;
85
- trackWrapper: string;
86
- value: string;
87
- }, import("tailwind-variants").TVReturnType<unknown, {
88
- base: string;
89
- endContent: string;
90
- errorMessage: string;
91
- filler: string;
92
- label: string;
93
- labelWrapper: string;
94
- mark: string;
95
- startContent: string;
96
- step: string;
97
- thumb: string;
98
- track: string;
99
- trackWrapper: string;
100
- value: string;
101
- }, undefined, unknown, unknown, undefined>>;
102
- type VariantProps = TVProps<typeof sliderVariants>;
103
- type ClassName = TVClassName<typeof sliderVariants>;
104
- interface SliderProps extends VariantProps {
105
- /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */
106
- ariaLabel?: string;
107
- /** CSS class name */
108
- className?: ClassName;
109
- /** input field is disabled */
110
- disabled?: boolean;
111
- /** Content to display at the end of the slider */
112
- endContent?: ReactNode;
113
- /** The offset from where the fill should start */
114
- fillOffset?: number;
115
- /** form field label */
116
- label?: string;
117
- /** form field name */
118
- name: string;
119
- /**
120
- * Whether to show step dots on the slider
121
- * @default false
122
- */
123
- showSteps?: boolean;
124
- /**
125
- * The size of the slider
126
- * @default "md"
127
- */
128
- size?: 'sm' | 'md' | 'lg';
129
- /** Content to display at the start of the slider */
130
- startContent?: ReactNode;
131
- /**
132
- * The step value of the slider
133
- * @default 1
134
- */
135
- step?: number;
136
- /** HTML data-testid attribute used in e2e tests */
137
- testId?: string;
138
- /**
139
- * The minimum value of the slider
140
- * @default 0
141
- */
142
- minValue?: number;
143
- /**
144
- * The maximum value of the slider
145
- * @default 100
146
- */
147
- maxValue?: number;
148
- }
149
- /**
150
- * Slider component based on [HeroUI Slider](https://www.heroui.com//docs/components/slider)
151
- */
152
- declare const Slider: ({
153
- className,
154
- endContent,
155
- fillOffset,
156
- name,
157
- showSteps,
158
- size,
159
- startContent,
160
- step,
161
- minValue,
162
- maxValue,
163
- ...uniformFieldProps
164
- }: SliderProps) => import("react/jsx-runtime").JSX.Element;
165
- //#endregion
166
- export { SliderProps as n, Slider as t };
167
- //# sourceMappingURL=index-B4jKGy-P.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-B4jKGy-P.d.ts","names":[],"sources":["../src/Slider/Slider.tsx"],"mappings":";;;;cAYa,cAAA,8BAAc,YAAA;EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAqBtB,YAAA,GAAe,OAAO,QAAQ,cAAA;AAAA,KAC9B,SAAA,GAAY,WAAW,QAAQ,cAAA;AAAA,UAEnB,WAAA,SAAoB,YAAA;;EAEnC,SAAA;;EAEA,SAAA,GAAY,SAAA;;EAEZ,QAAA;;EAEA,UAAA,GAAa,SAAA;;EAEb,UAAA;;EAEA,KAAA;;EAEA,IAAA;;;;;EAKA,SAAA;;;;;EAKA,IAAA;;EAEA,YAAA,GAAe,SAAA;;;;;EAKf,IAAA;;EAEA,MAAA;;;;AAtCC;EA2CD,QAAA;;;AAzC+C;AAAA;EA8C/C,QAAA;AAAA;;AA7CgD;AAElD;cAiDM,MAAA;EAAU,SAAA;EAAA,UAAA;EAAA,UAAA;EAAA,IAAA;EAAA,SAAA;EAAA,IAAA;EAAA,YAAA;EAAA,IAAA;EAAA,QAAA;EAAA,QAAA;EAAA,GAAA;AAAA,GAYb,WAAA,iCAAW,GAAA,CAAA,OAAA"}
@@ -1,99 +0,0 @@
1
- import { TVClassName } from "@fuf-stack/pixel-utils";
2
- import { ReactNode } from "react";
3
-
4
- //#region src/FieldCard/FieldCard.d.ts
5
- declare const fieldCardVariants: import("tailwind-variants").TVReturnType<{
6
- invalid: {
7
- true: {
8
- base: string;
9
- label: string;
10
- errorFooter: string;
11
- errorText: string;
12
- };
13
- false: {
14
- base: string;
15
- label: string;
16
- errorFooter: string;
17
- errorText: string;
18
- };
19
- };
20
- }, {
21
- /** base class for the field card wrapper */base: string[]; /** class for the label/header */
22
- label: string[]; /** class for the content */
23
- content: string[]; /** class for the error footer wrapper */
24
- errorFooter: string[]; /** class for the error text (empty base, color controlled by variant) */
25
- errorText: never[];
26
- }, undefined, {
27
- invalid: {
28
- true: {
29
- base: string;
30
- label: string;
31
- errorFooter: string;
32
- errorText: string;
33
- };
34
- false: {
35
- base: string;
36
- label: string;
37
- errorFooter: string;
38
- errorText: string;
39
- };
40
- };
41
- }, {
42
- /** base class for the field card wrapper */base: string[]; /** class for the label/header */
43
- label: string[]; /** class for the content */
44
- content: string[]; /** class for the error footer wrapper */
45
- errorFooter: string[]; /** class for the error text (empty base, color controlled by variant) */
46
- errorText: never[];
47
- }, import("tailwind-variants").TVReturnType<{
48
- invalid: {
49
- true: {
50
- base: string;
51
- label: string;
52
- errorFooter: string;
53
- errorText: string;
54
- };
55
- false: {
56
- base: string;
57
- label: string;
58
- errorFooter: string;
59
- errorText: string;
60
- };
61
- };
62
- }, {
63
- /** base class for the field card wrapper */base: string[]; /** class for the label/header */
64
- label: string[]; /** class for the content */
65
- content: string[]; /** class for the error footer wrapper */
66
- errorFooter: string[]; /** class for the error text (empty base, color controlled by variant) */
67
- errorText: never[];
68
- }, undefined, unknown, unknown, undefined>>;
69
- type ClassName = TVClassName<typeof fieldCardVariants>;
70
- interface FieldCardProps {
71
- /** Content to render inside the card */
72
- children: ReactNode;
73
- /** CSS class name */
74
- className?: ClassName;
75
- /** Label content for the card header */
76
- label: ReactNode;
77
- /** Field name for validation */
78
- name: string;
79
- /** HTML data-testid attribute used in e2e tests */
80
- testId?: string;
81
- }
82
- /**
83
- * FieldCard component - A card-styled container with label header and error footer
84
- *
85
- * Displays form field content in a card layout with:
86
- * - Label/title in the header
87
- * - Content in the body
88
- * - Validation errors in the footer
89
- * - Danger outline when validation errors exist
90
- */
91
- declare const FieldCard: ({
92
- children,
93
- className: _className,
94
- name,
95
- ...uniformFieldProps
96
- }: FieldCardProps) => import("react/jsx-runtime").JSX.Element;
97
- //#endregion
98
- export { FieldCardProps as n, fieldCardVariants as r, FieldCard as t };
99
- //# sourceMappingURL=index-B5SfdA5O.d.cts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-B5SfdA5O.d.cts","names":[],"sources":["../src/FieldCard/FieldCard.tsx"],"mappings":";;;;cAsHa,iBAAA,8BAAiB,YAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8DA2DhB;mBAAG;qBAEA;;;;;;;;;;;;;;;;;;;8DAsBE;mBAKhB;qBAAc;yBALE;;;KAxBd,SAAA,GAAY,WAAW,QAAQ,iBAAA;AAAA,UAEnB,cAAA;EAsBE;EApBjB,QAAA,EAAU,SAAA;EAyBK;EAvBf,SAAA,GAAY,SAAA;EAkJb;EAhJC,KAAA,EAAO,SAAA;;EAEP,IAAA;;EAEA,MAAA;AAAA;;;;;;;;;;cAYI,SAAA;EAAa,QAAA;EAAA,SAAA,EAAA,UAAA;EAAA,IAAA;EAAA,GAAA;AAAA,GAKhB,cAAA,iCAAc,GAAA,CAAA,OAAA"}
@@ -1,101 +0,0 @@
1
- import { t as InputValueTransform } from "./useInputValueTransform-CNCBU7a9.cjs";
2
- import { TVClassName, TVProps } from "@fuf-stack/pixel-utils";
3
- import { ReactNode } from "react";
4
-
5
- //#region src/Input/Input.d.ts
6
- declare const inputVariants: import("tailwind-variants").TVReturnType<{
7
- [key: string]: {
8
- [key: string]: import("tailwind-merge").ClassNameValue | {
9
- base?: import("tailwind-merge").ClassNameValue;
10
- input?: import("tailwind-merge").ClassNameValue;
11
- inputWrapper?: import("tailwind-merge").ClassNameValue;
12
- clearButton?: import("tailwind-merge").ClassNameValue;
13
- };
14
- };
15
- } | {
16
- [x: string]: {
17
- [x: string]: import("tailwind-merge").ClassNameValue | {
18
- base?: import("tailwind-merge").ClassNameValue;
19
- input?: import("tailwind-merge").ClassNameValue;
20
- inputWrapper?: import("tailwind-merge").ClassNameValue;
21
- clearButton?: import("tailwind-merge").ClassNameValue;
22
- };
23
- };
24
- } | {}, {
25
- /** wrapper around the whole input */base: string; /** clear button */
26
- clearButton: string; /** actual input element */
27
- input: string; /** inner wrapper (HeroUI inputWrapper slot) */
28
- inputWrapper: string;
29
- }, undefined, {
30
- [key: string]: {
31
- [key: string]: import("tailwind-merge").ClassNameValue | {
32
- base?: import("tailwind-merge").ClassNameValue;
33
- input?: import("tailwind-merge").ClassNameValue;
34
- inputWrapper?: import("tailwind-merge").ClassNameValue;
35
- clearButton?: import("tailwind-merge").ClassNameValue;
36
- };
37
- };
38
- } | {}, {
39
- /** wrapper around the whole input */base: string; /** clear button */
40
- clearButton: string; /** actual input element */
41
- input: string; /** inner wrapper (HeroUI inputWrapper slot) */
42
- inputWrapper: string;
43
- }, import("tailwind-variants").TVReturnType<unknown, {
44
- /** wrapper around the whole input */base: string; /** clear button */
45
- clearButton: string; /** actual input element */
46
- input: string; /** inner wrapper (HeroUI inputWrapper slot) */
47
- inputWrapper: string;
48
- }, undefined, unknown, unknown, undefined>>;
49
- type VariantProps = TVProps<typeof inputVariants>;
50
- type ClassName = TVClassName<typeof inputVariants>;
51
- interface InputProps extends VariantProps {
52
- /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */
53
- ariaLabel?: string;
54
- /** CSS class name */
55
- className?: ClassName;
56
- /** shows clear button when input has value */
57
- clearable?: boolean;
58
- /** debounce delay in milliseconds for form state updates (default: 300ms) */
59
- debounceDelay?: number;
60
- /** input field is disabled */
61
- disabled?: boolean;
62
- /** added content to the end of the input Field. */
63
- endContent?: ReactNode;
64
- /** form field label */
65
- label?: ReactNode;
66
- /** form field name */
67
- name: string;
68
- /** callback that is fired when the value is cleared */
69
- onClear?: () => void;
70
- /** form field placeholder */
71
- placeholder?: string;
72
- /** size of the input */
73
- size?: 'sm' | 'md' | 'lg';
74
- /** content added to the start of the input field */
75
- startContent?: ReactNode;
76
- /** HTML data-testid attribute used in e2e tests */
77
- testId?: string;
78
- /** allows disentangled display and form values for a field */
79
- transform?: InputValueTransform<string>;
80
- /** input type */
81
- type?: 'number' | 'password';
82
- }
83
- /**
84
- * Input component based on [HeroUI Input](https://www.heroui.com//docs/components/input)
85
- */
86
- declare const Input: ({
87
- className: _className,
88
- clearable,
89
- debounceDelay,
90
- endContent,
91
- name,
92
- onClear,
93
- placeholder,
94
- size,
95
- startContent,
96
- type,
97
- ...uniformFieldProps
98
- }: InputProps) => import("react/jsx-runtime").JSX.Element;
99
- //#endregion
100
- export { InputProps as n, Input as t };
101
- //# sourceMappingURL=index-B61zRzeS.d.cts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-B61zRzeS.d.cts","names":[],"sources":["../src/Input/Input.tsx"],"mappings":";;;;;cAca,aAAA,8BAAa,YAAA;EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAarB,YAAA,GAAe,OAAO,QAAQ,aAAA;AAAA,KAC9B,SAAA,GAAY,WAAW,QAAQ,aAAA;AAAA,UAEnB,UAAA,SAAmB,YAAA;EAHhB;EAKlB,SAAA;EAJG;EAMH,SAAA,GAAY,SAAA;;EAEZ,SAAA;EAR+C;EAU/C,aAAA;EAR0B;EAU1B,QAAA;EANY;EAQZ,UAAA,GAAa,SAAA;EAEL;EAAR,KAAA,GAAQ,SAAA;EAcI;EAZZ,IAAA;EAhB8C;EAkB9C,OAAA;EAlBkC;EAoBlC,WAAA;EAhBA;EAkBA,IAAA;EAhBA;EAkBA,YAAA,GAAe,SAAA;EAdf;EAgBA,MAAA;EAda;EAgBb,SAAA,GAAY,mBAAA;EAdJ;EAgBR,IAAA;AAAA;;;;cAMI,KAAA;EAAS,SAAA,EAAA,UAAA;EAAA,SAAA;EAAA,aAAA;EAAA,UAAA;EAAA,IAAA;EAAA,OAAA;EAAA,WAAA;EAAA,IAAA;EAAA,YAAA;EAAA,IAAA;EAAA,GAAA;AAAA,GAYZ,UAAA,iCAAU,GAAA,CAAA,OAAA"}
@@ -1,166 +0,0 @@
1
- import { TVClassName, TVProps } from "@fuf-stack/pixel-utils";
2
- import { ReactNode } from "react";
3
-
4
- //#region src/DatePicker/DatePicker.d.ts
5
- declare const datePickerVariants: import("tailwind-variants").TVReturnType<{
6
- [key: string]: {
7
- [key: string]: import("tailwind-merge").ClassNameValue | {
8
- base?: import("tailwind-merge").ClassNameValue;
9
- helperWrapper?: import("tailwind-merge").ClassNameValue;
10
- inputWrapper?: import("tailwind-merge").ClassNameValue;
11
- calendar?: import("tailwind-merge").ClassNameValue;
12
- calendarContent?: import("tailwind-merge").ClassNameValue;
13
- popoverContent?: import("tailwind-merge").ClassNameValue;
14
- selectorButton?: import("tailwind-merge").ClassNameValue;
15
- selectorIcon?: import("tailwind-merge").ClassNameValue;
16
- timeInput?: import("tailwind-merge").ClassNameValue;
17
- timeInputLabel?: import("tailwind-merge").ClassNameValue;
18
- };
19
- };
20
- } | {
21
- [x: string]: {
22
- [x: string]: import("tailwind-merge").ClassNameValue | {
23
- base?: import("tailwind-merge").ClassNameValue;
24
- helperWrapper?: import("tailwind-merge").ClassNameValue;
25
- inputWrapper?: import("tailwind-merge").ClassNameValue;
26
- calendar?: import("tailwind-merge").ClassNameValue;
27
- calendarContent?: import("tailwind-merge").ClassNameValue;
28
- popoverContent?: import("tailwind-merge").ClassNameValue;
29
- selectorButton?: import("tailwind-merge").ClassNameValue;
30
- selectorIcon?: import("tailwind-merge").ClassNameValue;
31
- timeInput?: import("tailwind-merge").ClassNameValue;
32
- timeInputLabel?: import("tailwind-merge").ClassNameValue;
33
- };
34
- };
35
- } | {}, {
36
- /** wrapper around the whole date picker */base: string; /** helper wrapper for error/description */
37
- helperWrapper: string[]; /** the calendar element */
38
- calendar: string; /** the calendar's content element */
39
- calendarContent: string;
40
- /**
41
- * inner wrapper (HeroUI inputWrapper slot)
42
- *
43
- * NOTE: Unlike HeroUI Input, the DatePicker does not expose a
44
- * `data-focus` indicator on the group, so the focus border has to be
45
- * driven by the native `focus-within` state of the segment inputs.
46
- */
47
- inputWrapper: string; /** the calendar popover element */
48
- popoverContent: string; /** selector button element */
49
- selectorButton: string; /** selector icon element */
50
- selectorIcon: string; /** the time-input component element */
51
- timeInput: string; /** the time-input component's label element */
52
- timeInputLabel: string;
53
- }, undefined, {
54
- [key: string]: {
55
- [key: string]: import("tailwind-merge").ClassNameValue | {
56
- base?: import("tailwind-merge").ClassNameValue;
57
- helperWrapper?: import("tailwind-merge").ClassNameValue;
58
- inputWrapper?: import("tailwind-merge").ClassNameValue;
59
- calendar?: import("tailwind-merge").ClassNameValue;
60
- calendarContent?: import("tailwind-merge").ClassNameValue;
61
- popoverContent?: import("tailwind-merge").ClassNameValue;
62
- selectorButton?: import("tailwind-merge").ClassNameValue;
63
- selectorIcon?: import("tailwind-merge").ClassNameValue;
64
- timeInput?: import("tailwind-merge").ClassNameValue;
65
- timeInputLabel?: import("tailwind-merge").ClassNameValue;
66
- };
67
- };
68
- } | {}, {
69
- /** wrapper around the whole date picker */base: string; /** helper wrapper for error/description */
70
- helperWrapper: string[]; /** the calendar element */
71
- calendar: string; /** the calendar's content element */
72
- calendarContent: string;
73
- /**
74
- * inner wrapper (HeroUI inputWrapper slot)
75
- *
76
- * NOTE: Unlike HeroUI Input, the DatePicker does not expose a
77
- * `data-focus` indicator on the group, so the focus border has to be
78
- * driven by the native `focus-within` state of the segment inputs.
79
- */
80
- inputWrapper: string; /** the calendar popover element */
81
- popoverContent: string; /** selector button element */
82
- selectorButton: string; /** selector icon element */
83
- selectorIcon: string; /** the time-input component element */
84
- timeInput: string; /** the time-input component's label element */
85
- timeInputLabel: string;
86
- }, import("tailwind-variants").TVReturnType<unknown, {
87
- /** wrapper around the whole date picker */base: string; /** helper wrapper for error/description */
88
- helperWrapper: string[]; /** the calendar element */
89
- calendar: string; /** the calendar's content element */
90
- calendarContent: string;
91
- /**
92
- * inner wrapper (HeroUI inputWrapper slot)
93
- *
94
- * NOTE: Unlike HeroUI Input, the DatePicker does not expose a
95
- * `data-focus` indicator on the group, so the focus border has to be
96
- * driven by the native `focus-within` state of the segment inputs.
97
- */
98
- inputWrapper: string; /** the calendar popover element */
99
- popoverContent: string; /** selector button element */
100
- selectorButton: string; /** selector icon element */
101
- selectorIcon: string; /** the time-input component element */
102
- timeInput: string; /** the time-input component's label element */
103
- timeInputLabel: string;
104
- }, undefined, unknown, unknown, undefined>>;
105
- type VariantProps = TVProps<typeof datePickerVariants>;
106
- type ClassName = TVClassName<typeof datePickerVariants>;
107
- interface DatePickerProps extends VariantProps {
108
- /** Custom aria-label for accessibility. If not provided, falls back to field name when no visible label exists */
109
- ariaLabel?: string;
110
- /** CSS class name */
111
- className?: ClassName;
112
- /** date picker is disabled */
113
- disabled?: boolean;
114
- /**
115
- * Optional hour cycle override.
116
- *
117
- * When omitted, the picker uses the user's locale default (12-hour or 24-hour).
118
- */
119
- hourCycle?: 12 | 24;
120
- /** hide timezone abbreviation for zoned values */
121
- hideTimeZone?: boolean;
122
- /** form field label */
123
- label?: ReactNode;
124
- /** latest selectable value as ISO string */
125
- maxValue?: string;
126
- /** earliest selectable value as ISO string */
127
- minValue?: string;
128
- /** form field name */
129
- name: string;
130
- /** HTML data-testid attribute used in e2e tests */
131
- testId?: string;
132
- /**
133
- * Optional advanced override for the display/interpretation timezone.
134
- *
135
- * When omitted, the picker uses the current user's local timezone while
136
- * `withTime` is enabled.
137
- */
138
- timeZone?: string;
139
- /**
140
- * Enables date-time mode.
141
- *
142
- * - `false` (default): date-only input (`day` granularity)
143
- * - `true`: includes time segments (`minute` granularity)
144
- */
145
- withTime?: boolean;
146
- /** value format stored in form state (`string` stores UTC ISO values) */
147
- valueType?: 'dateValue' | 'string';
148
- }
149
- /**
150
- * DatePicker component based on [HeroUI DatePicker](https://v2.heroui.com/docs/components/date-picker)
151
- */
152
- declare const DatePicker: ({
153
- className: _className,
154
- hourCycle,
155
- hideTimeZone,
156
- maxValue,
157
- minValue,
158
- name,
159
- timeZone,
160
- valueType,
161
- withTime,
162
- ...uniformFieldProps
163
- }: DatePickerProps) => import("react/jsx-runtime").JSX.Element;
164
- //#endregion
165
- export { DatePickerProps as n, DatePicker as t };
166
- //# sourceMappingURL=index-BDFJDKmz.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-BDFJDKmz.d.ts","names":[],"sources":["../src/DatePicker/DatePicker.tsx"],"mappings":";;;;cAiBa,kBAAA,8BAAkB,YAAA;EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgC5B;;;;AAEkD;AAAA;;0BACC;0BAErB;wBAInB;qBAJ2B;;;KAHpC,YAAA,GAAe,OAAO,QAAQ,kBAAA;AAAA,KAC9B,SAAA,GAAY,WAAW,QAAQ,kBAAA;AAAA,UAEnB,eAAA,SAAwB,YAAA;EAI3B;EAFZ,SAAA;EAUA;EARA,SAAA,GAAY,SAAA;EAYZ;EAVA,QAAA;EAYA;;;;;EANA,SAAA;EA4BA;EA1BA,YAAA;EA0BS;EAxBT,KAAA,GAAQ,SAAA;EAuIT;EArIC,QAAA;EA4BkB;EA1BlB,QAAA;EA0BkB;EAxBlB,IAAA;EAwBkB;EAtBlB,MAAA;EAsBkB;;;;;;EAflB,QAAA;EAekB;;;;;;EARlB,QAAA;EAQkB;EANlB,SAAA;AAAA;;;;cAMI,UAAA;EAAc,SAAA,EAAA,UAAA;EAAA,SAAA;EAAA,YAAA;EAAA,QAAA;EAAA,QAAA;EAAA,IAAA;EAAA,QAAA;EAAA,SAAA;EAAA,QAAA;EAAA,GAAA;AAAA,GAWjB,eAAA,iCAAe,GAAA,CAAA,OAAA"}