@fuf-stack/uniform 0.18.5 → 0.19.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 (172) hide show
  1. package/dist/CheckboxGroup/index.cjs +5 -6
  2. package/dist/CheckboxGroup/index.cjs.map +1 -1
  3. package/dist/CheckboxGroup/index.d.cts +2 -2
  4. package/dist/CheckboxGroup/index.d.ts +2 -2
  5. package/dist/CheckboxGroup/index.js +4 -5
  6. package/dist/FieldArray/index.cjs +5 -5
  7. package/dist/FieldArray/index.js +4 -4
  8. package/dist/Form/index.cjs +4 -4
  9. package/dist/Form/index.js +3 -3
  10. package/dist/Grid/index.cjs +1 -1
  11. package/dist/Grid/index.js +1 -1
  12. package/dist/Input/index.cjs +5 -6
  13. package/dist/Input/index.cjs.map +1 -1
  14. package/dist/Input/index.js +4 -5
  15. package/dist/RadioBoxes/index.cjs +5 -6
  16. package/dist/RadioBoxes/index.cjs.map +1 -1
  17. package/dist/RadioBoxes/index.d.cts +2 -2
  18. package/dist/RadioBoxes/index.d.ts +2 -2
  19. package/dist/RadioBoxes/index.js +4 -5
  20. package/dist/RadioGroup/index.cjs +5 -6
  21. package/dist/RadioGroup/index.cjs.map +1 -1
  22. package/dist/RadioGroup/index.d.cts +2 -2
  23. package/dist/RadioGroup/index.d.ts +2 -2
  24. package/dist/RadioGroup/index.js +4 -5
  25. package/dist/RadioTabs/index.cjs +5 -6
  26. package/dist/RadioTabs/index.cjs.map +1 -1
  27. package/dist/RadioTabs/index.d.cts +2 -2
  28. package/dist/RadioTabs/index.d.ts +2 -2
  29. package/dist/RadioTabs/index.js +4 -5
  30. package/dist/Select/index.cjs +5 -6
  31. package/dist/Select/index.cjs.map +1 -1
  32. package/dist/Select/index.d.cts +2 -2
  33. package/dist/Select/index.d.ts +2 -2
  34. package/dist/Select/index.js +4 -5
  35. package/dist/SubmitButton/index.cjs +4 -4
  36. package/dist/SubmitButton/index.js +3 -3
  37. package/dist/Switch/index.cjs +5 -6
  38. package/dist/Switch/index.cjs.map +1 -1
  39. package/dist/Switch/index.d.cts +2 -2
  40. package/dist/Switch/index.d.ts +2 -2
  41. package/dist/Switch/index.js +4 -5
  42. package/dist/TextArea/index.cjs +5 -6
  43. package/dist/TextArea/index.cjs.map +1 -1
  44. package/dist/TextArea/index.js +4 -5
  45. package/dist/chunk-25Y2Q5CX.cjs +110 -0
  46. package/dist/chunk-25Y2Q5CX.cjs.map +1 -0
  47. package/dist/{chunk-IOIYK6UC.js → chunk-35I663WR.js} +29 -29
  48. package/dist/chunk-35I663WR.js.map +1 -0
  49. package/dist/{chunk-HHENF3BD.js → chunk-3JRZ5YNE.js} +6 -6
  50. package/dist/chunk-4DVYBP2O.cjs +236 -0
  51. package/dist/chunk-4DVYBP2O.cjs.map +1 -0
  52. package/dist/chunk-4IQKCUZC.cjs +145 -0
  53. package/dist/chunk-4IQKCUZC.cjs.map +1 -0
  54. package/dist/{chunk-4DAZAO6Y.cjs → chunk-555JRYCS.cjs} +4 -2
  55. package/dist/chunk-555JRYCS.cjs.map +1 -0
  56. package/dist/{chunk-R4GZXQFD.cjs → chunk-5NKR4C73.cjs} +14 -14
  57. package/dist/{chunk-R4GZXQFD.cjs.map → chunk-5NKR4C73.cjs.map} +1 -1
  58. package/dist/chunk-5W2IWHSE.js +89 -0
  59. package/dist/chunk-5W2IWHSE.js.map +1 -0
  60. package/dist/{chunk-WD4ES4JK.cjs → chunk-6GCMM22R.cjs} +35 -47
  61. package/dist/chunk-6GCMM22R.cjs.map +1 -0
  62. package/dist/chunk-7BLVIVDU.cjs +281 -0
  63. package/dist/chunk-7BLVIVDU.cjs.map +1 -0
  64. package/dist/{chunk-3DWGHDVE.js → chunk-7NZKBUL6.js} +36 -48
  65. package/dist/chunk-7NZKBUL6.js.map +1 -0
  66. package/dist/{chunk-EAEW6SOJ.js → chunk-7R2P54VS.js} +37 -49
  67. package/dist/chunk-7R2P54VS.js.map +1 -0
  68. package/dist/{chunk-P332MPVH.js → chunk-BXQ3MVNH.js} +5 -5
  69. package/dist/chunk-BXQ3MVNH.js.map +1 -0
  70. package/dist/chunk-CN5XEGV4.js +281 -0
  71. package/dist/chunk-CN5XEGV4.js.map +1 -0
  72. package/dist/chunk-DBKDDOS2.cjs +89 -0
  73. package/dist/chunk-DBKDDOS2.cjs.map +1 -0
  74. package/dist/chunk-E62JDTFS.js +110 -0
  75. package/dist/chunk-E62JDTFS.js.map +1 -0
  76. package/dist/chunk-F2LWLSBT.cjs +98 -0
  77. package/dist/chunk-F2LWLSBT.cjs.map +1 -0
  78. package/dist/{chunk-4RDTC7R6.cjs → chunk-HECO3HXR.cjs} +31 -31
  79. package/dist/chunk-HECO3HXR.cjs.map +1 -0
  80. package/dist/{chunk-CRTRMMJ7.js → chunk-K2V4ULA2.js} +3 -1
  81. package/dist/{chunk-AEUUTAJB.cjs → chunk-LYI2IDCW.cjs} +6 -6
  82. package/dist/chunk-LYI2IDCW.cjs.map +1 -0
  83. package/dist/{chunk-737UQZOW.js → chunk-N2MRIHRX.js} +109 -122
  84. package/dist/chunk-N2MRIHRX.js.map +1 -0
  85. package/dist/{chunk-ZPNMTMGE.cjs → chunk-NEHRI4EM.cjs} +60 -70
  86. package/dist/chunk-NEHRI4EM.cjs.map +1 -0
  87. package/dist/chunk-UU7SXXNI.cjs +70 -0
  88. package/dist/chunk-UU7SXXNI.cjs.map +1 -0
  89. package/dist/chunk-W2K5WX3O.js +145 -0
  90. package/dist/chunk-W2K5WX3O.js.map +1 -0
  91. package/dist/chunk-Y4YQH2QB.js +70 -0
  92. package/dist/chunk-Y4YQH2QB.js.map +1 -0
  93. package/dist/{chunk-BXZ2SBRA.js → chunk-YK2XHKK2.js} +55 -65
  94. package/dist/chunk-YK2XHKK2.js.map +1 -0
  95. package/dist/helpers/index.cjs +1 -1
  96. package/dist/helpers/index.js +1 -1
  97. package/dist/hooks/index.cjs +7 -3
  98. package/dist/hooks/index.cjs.map +1 -1
  99. package/dist/hooks/index.d.cts +47 -6
  100. package/dist/hooks/index.d.ts +47 -6
  101. package/dist/hooks/index.js +6 -2
  102. package/dist/index.cjs +17 -17
  103. package/dist/index.cjs.map +1 -1
  104. package/dist/index.d.cts +7 -8
  105. package/dist/index.d.ts +7 -8
  106. package/dist/index.js +23 -23
  107. package/dist/partials/FieldCopyTestIdButton/index.cjs +1 -1
  108. package/dist/partials/FieldCopyTestIdButton/index.js +1 -1
  109. package/dist/partials/FieldValidationError/index.cjs +1 -1
  110. package/dist/partials/FieldValidationError/index.js +1 -1
  111. package/package.json +3 -8
  112. package/dist/Controller/index.cjs +0 -11
  113. package/dist/Controller/index.cjs.map +0 -1
  114. package/dist/Controller/index.d.cts +0 -8
  115. package/dist/Controller/index.d.ts +0 -8
  116. package/dist/Controller/index.js +0 -11
  117. package/dist/Controller-8Nqugui5.d.cts +0 -37
  118. package/dist/Controller-8Nqugui5.d.ts +0 -37
  119. package/dist/chunk-3DWGHDVE.js.map +0 -1
  120. package/dist/chunk-3MPB726A.cjs +0 -82
  121. package/dist/chunk-3MPB726A.cjs.map +0 -1
  122. package/dist/chunk-3WZNMG5K.js +0 -155
  123. package/dist/chunk-3WZNMG5K.js.map +0 -1
  124. package/dist/chunk-4DAZAO6Y.cjs.map +0 -1
  125. package/dist/chunk-4HGNEE2R.js +0 -97
  126. package/dist/chunk-4HGNEE2R.js.map +0 -1
  127. package/dist/chunk-4RDTC7R6.cjs.map +0 -1
  128. package/dist/chunk-737UQZOW.js.map +0 -1
  129. package/dist/chunk-AEUUTAJB.cjs.map +0 -1
  130. package/dist/chunk-AT2VVPRD.js +0 -52
  131. package/dist/chunk-AT2VVPRD.js.map +0 -1
  132. package/dist/chunk-BXZ2SBRA.js.map +0 -1
  133. package/dist/chunk-CRTRMMJ7.js.map +0 -1
  134. package/dist/chunk-DXMJHNP3.cjs +0 -249
  135. package/dist/chunk-DXMJHNP3.cjs.map +0 -1
  136. package/dist/chunk-EAEW6SOJ.js.map +0 -1
  137. package/dist/chunk-EPYFZXEI.cjs +0 -52
  138. package/dist/chunk-EPYFZXEI.cjs.map +0 -1
  139. package/dist/chunk-IOIYK6UC.js.map +0 -1
  140. package/dist/chunk-JH4CPQHA.cjs +0 -120
  141. package/dist/chunk-JH4CPQHA.cjs.map +0 -1
  142. package/dist/chunk-JHVW42BW.cjs +0 -97
  143. package/dist/chunk-JHVW42BW.cjs.map +0 -1
  144. package/dist/chunk-JS2D6XPO.js +0 -120
  145. package/dist/chunk-JS2D6XPO.js.map +0 -1
  146. package/dist/chunk-NBAVP4ER.js +0 -135
  147. package/dist/chunk-NBAVP4ER.js.map +0 -1
  148. package/dist/chunk-P332MPVH.js.map +0 -1
  149. package/dist/chunk-QQW2FHSC.cjs +0 -135
  150. package/dist/chunk-QQW2FHSC.cjs.map +0 -1
  151. package/dist/chunk-QX652SHY.cjs +0 -110
  152. package/dist/chunk-QX652SHY.cjs.map +0 -1
  153. package/dist/chunk-SCTQXWRU.cjs +0 -155
  154. package/dist/chunk-SCTQXWRU.cjs.map +0 -1
  155. package/dist/chunk-WD4ES4JK.cjs.map +0 -1
  156. package/dist/chunk-YLLUYAY3.js +0 -82
  157. package/dist/chunk-YLLUYAY3.js.map +0 -1
  158. package/dist/chunk-ZPNMTMGE.cjs.map +0 -1
  159. package/dist/{CheckboxGroup-Dq4voRWR.d.cts → CheckboxGroup-Dh0YW4KV.d.cts} +5 -5
  160. package/dist/{CheckboxGroup-Dq4voRWR.d.ts → CheckboxGroup-Dh0YW4KV.d.ts} +5 -5
  161. package/dist/{RadioBoxes-DJ49DctW.d.cts → RadioBoxes-C61IRDCU.d.cts} +5 -5
  162. package/dist/{RadioBoxes-DJ49DctW.d.ts → RadioBoxes-C61IRDCU.d.ts} +5 -5
  163. package/dist/{RadioGroup-BYfxswoe.d.cts → RadioGroup-C7I27oav.d.cts} +5 -5
  164. package/dist/{RadioGroup-BYfxswoe.d.ts → RadioGroup-C7I27oav.d.ts} +5 -5
  165. package/dist/{RadioTabs-BYvYukGt.d.cts → RadioTabs-CT8PT7ky.d.cts} +5 -5
  166. package/dist/{RadioTabs-BYvYukGt.d.ts → RadioTabs-CT8PT7ky.d.ts} +5 -5
  167. package/dist/{Select-D2Tn4xBh.d.cts → Select-JRwrSDew.d.cts} +15 -15
  168. package/dist/{Select-D2Tn4xBh.d.ts → Select-JRwrSDew.d.ts} +15 -15
  169. package/dist/{Switch-C1H8Kyu7.d.cts → Switch-CLs964dL.d.cts} +5 -5
  170. package/dist/{Switch-C1H8Kyu7.d.ts → Switch-CLs964dL.d.ts} +5 -5
  171. /package/dist/{chunk-HHENF3BD.js.map → chunk-3JRZ5YNE.js.map} +0 -0
  172. /package/dist/{Controller/index.js.map → chunk-K2V4ULA2.js.map} +0 -0
@@ -1,52 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
-
4
- var _chunkCESGUF6Fcjs = require('./chunk-CESGUF6F.cjs');
5
-
6
-
7
-
8
-
9
- var _chunk4DAZAO6Ycjs = require('./chunk-4DAZAO6Y.cjs');
10
-
11
- // src/Controller/Controller.tsx
12
- var _reacthookform = require('react-hook-form');
13
- var _jsxruntime = require('react/jsx-runtime');
14
- var Controller = (_a) => {
15
- var _b = _a, {
16
- render
17
- } = _b, props = _chunk4DAZAO6Ycjs.__objRest.call(void 0, _b, [
18
- "render"
19
- ]);
20
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
21
- _reacthookform.Controller,
22
- _chunk4DAZAO6Ycjs.__spreadProps.call(void 0, _chunk4DAZAO6Ycjs.__spreadValues.call(void 0, {}, props), {
23
- disabled: props.disabled || void 0,
24
- render: (_a2) => {
25
- var _b2 = _a2, { field } = _b2, rest = _chunk4DAZAO6Ycjs.__objRest.call(void 0, _b2, ["field"]);
26
- return render(_chunk4DAZAO6Ycjs.__spreadValues.call(void 0, {
27
- field: _chunk4DAZAO6Ycjs.__spreadProps.call(void 0, _chunk4DAZAO6Ycjs.__spreadValues.call(void 0, {}, field), {
28
- // Handles both direct values (onChange("value")) and events (onChange(event))
29
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
30
- onChange: (...event) => {
31
- var _a3, _b3, _c;
32
- const value = (_c = (_b3 = (_a3 = event[0]) == null ? void 0 : _a3.target) == null ? void 0 : _b3.value) != null ? _c : event[0];
33
- field.onChange(_chunkCESGUF6Fcjs.toNullishString.call(void 0, value));
34
- },
35
- // Convert null/undefined to empty string for UI display
36
- value: _chunkCESGUF6Fcjs.fromNullishString.call(void 0, field.value)
37
- })
38
- }, rest));
39
- }
40
- })
41
- );
42
- };
43
- var Controller_default = Controller;
44
-
45
- // src/Controller/index.ts
46
- var Controller_default2 = Controller_default;
47
-
48
-
49
-
50
-
51
- exports.Controller_default = Controller_default; exports.Controller_default2 = Controller_default2;
52
- //# sourceMappingURL=chunk-EPYFZXEI.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-EPYFZXEI.cjs","../src/Controller/Controller.tsx","../src/Controller/index.ts"],"names":["_a","_b","Controller_default"],"mappings":"AAAA;AACE;AACA;AACF,wDAA6B;AAC7B;AACE;AACA;AACA;AACF,wDAA6B;AAC7B;AACA;ACHA,gDAA4C;AA8CxC,+CAAA;AALJ,IAAM,WAAA,EAAa,CAAuC,EAAA,EAAA,GAGrB;AAHqB,EAAA,IAAA,GAAA,EAAA,EAAA,EACxD;AAAA,IAAA;AAAA,EAjDF,EAAA,EAgD0D,EAAA,EAErD,MAAA,EAAA,yCAAA,EAFqD,EAErD;AAAA,IADH;AAAA,EAAA,CAAA,CAAA;AAGA,EAAA,uBACE,6BAAA;AAAA,IAAC,yBAAA;AAAA,IAAA,6CAAA,8CAAA,CAAA,CAAA,EAEK,KAAA,CAAA,EAFL;AAAA,MAIC,QAAA,EAAU,KAAA,CAAM,SAAA,GAAY,KAAA,CAAA;AAAA,MAC5B,MAAA,EAAQ,CAACA,GAAAA,EAAAA,GAAuB;AAAvB,QAAA,IAAAC,IAAAA,EAAAD,GAAAA,EAAE,EAAA,MA1DjB,EAAA,EA0DeC,GAAAA,EAAY,KAAA,EAAA,yCAAA,GAAZA,EAAY,CAAV,OAAA,CAAA,CAAA;AACT,QAAA,OAAO,MAAA,CAAO,8CAAA;AAAA,UACZ,KAAA,EAAO,6CAAA,8CAAA,CAAA,CAAA,EACF,KAAA,CAAA,EADE;AAAA;AAAA;AAAA,YAIL,QAAA,EAAU,CAAA,GAAI,KAAA,EAAA,GAAiB;AAhE3C,cAAA,IAAAD,GAAAA,EAAAC,GAAAA,EAAA,EAAA;AAiEc,cAAA,MAAM,MAAA,EAAA,CAAQ,GAAA,EAAA,CAAAA,IAAAA,EAAAA,CAAAD,IAAAA,EAAA,KAAA,CAAM,CAAC,CAAA,EAAA,GAAP,KAAA,EAAA,KAAA,EAAA,EAAAA,GAAAA,CAAU,MAAA,EAAA,GAAV,KAAA,EAAA,KAAA,EAAA,EAAAC,GAAAA,CAAkB,KAAA,EAAA,GAAlB,KAAA,EAAA,GAAA,EAA2B,KAAA,CAAM,CAAC,CAAA;AAChD,cAAA,KAAA,CAAM,QAAA,CAAS,+CAAA,KAAqB,CAAC,CAAA;AAAA,YACvC,CAAA;AAAA;AAAA,YAEA,KAAA,EAAO,iDAAA,KAAkB,CAAM,KAAK;AAAA,UACtC,CAAA;AAAA,QAAA,CAAA,EACG,IAAA,CACJ,CAAA;AAAA,MACH;AAAA,IAAA,CAAA;AAAA,EACF,CAAA;AAEJ,CAAA;AAEA,IAAO,mBAAA,EAAQ,UAAA;ADnCf;AACA;AEtCA,IAAOC,oBAAAA,EAAQ,kBAAA;AFwCf;AACA;AACE;AACA;AACF,mGAAC","file":"/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-EPYFZXEI.cjs","sourcesContent":[null,"import type {\n ControllerFieldState,\n ControllerRenderProps,\n ControllerProps as RHFControllerProps,\n UseFormStateReturn,\n} from 'react-hook-form';\n\nimport { Controller as RHFController } from 'react-hook-form';\n\nimport { fromNullishString, toNullishString } from '../helpers';\n\nexport type ControllerProps<TFieldValues extends object = object> = Omit<\n RHFControllerProps<TFieldValues>,\n 'render'\n> & {\n /**\n * Render prop that receives the form control props with nullish string handling.\n * The field object contains all the properties needed to control an input:\n * - onChange: Handles both direct value changes and event objects\n * - value: Always provides a string value, converting null/undefined to empty string\n * - name, ref, etc: Other standard field properties from react-hook-form\n */\n render: (props: {\n field: Omit<ControllerRenderProps<TFieldValues>, 'onChange' | 'value'> & {\n // Using any[] to support both direct value changes and React synthetic events\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n onChange: (...event: any[]) => void;\n value: string;\n };\n formState: UseFormStateReturn<TFieldValues>;\n fieldState: ControllerFieldState;\n }) => React.ReactElement;\n};\n\n/**\n * A wrapper around react-hook-form's Controller that transparently handles nullish string conversions.\n *\n * Key features:\n * 1. Empty strings ('') in the UI are stored as null in form state\n * 2. Null/undefined values in form state are displayed as empty strings in the UI\n * 3. Handles both direct value changes and React synthetic events\n * 4. Maintains the same API as react-hook-form's Controller\n *\n * This enables consistent handling of empty/null values while keeping a clean API\n * for form inputs that expect string values.\n *\n * @see https://react-hook-form.com/docs/usecontroller/controller\n */\nconst Controller = <TFieldValues extends object = object>({\n render,\n ...props\n}: ControllerProps<TFieldValues>) => {\n return (\n <RHFController<TFieldValues>\n // eslint-disable-next-line react/jsx-props-no-spreading\n {...props}\n // INFO: prevent 'A component is changing an uncontrolled input to be controlled'\n disabled={props.disabled || undefined}\n render={({ field, ...rest }) => {\n return render({\n field: {\n ...field,\n // Handles both direct values (onChange(\"value\")) and events (onChange(event))\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n onChange: (...event: any[]) => {\n const value = event[0]?.target?.value ?? event[0];\n field.onChange(toNullishString(value));\n },\n // Convert null/undefined to empty string for UI display\n value: fromNullishString(field.value) as string,\n },\n ...rest,\n });\n }}\n />\n );\n};\n\nexport default Controller;\n","import Controller from './Controller';\n\nexport type { ControllerProps } from './Controller';\n\nexport { Controller };\n\nexport default Controller;\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/Form/Form.tsx","../src/Form/subcomponents/FormDebugViewer.tsx","../src/Form/index.ts"],"sourcesContent":["import type { VetoInstance } from '@fuf-stack/veto';\nimport type { ReactNode } from 'react';\nimport type { FieldValues, SubmitHandler } from 'react-hook-form';\nimport type { DebugModeSettings } from './subcomponents/FormContext';\n\nimport { cn, slugify } from '@fuf-stack/pixel-utils';\n\nimport FormProvider from './subcomponents/FormContext';\nimport FormDebugViewer from './subcomponents/FormDebugViewer';\n\nconst IS_TEST = process.env.NODE_ENV === 'test';\n\nexport interface FormProps {\n /** form children */\n children: ReactNode | ReactNode[];\n /** CSS class name */\n className?: string | string[];\n /** settings for from debug mode */\n debug?: DebugModeSettings;\n /** initial form values */\n initialValues?: FieldValues;\n /** name of the form */\n name?: string;\n /** form submit handler */\n onSubmit: SubmitHandler<FieldValues>;\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n /** veto validation schema */\n validation?: VetoInstance;\n /** when the validation should be triggered */\n validationTrigger?: 'onChange' | 'onBlur' | 'onSubmit' | 'onTouched' | 'all';\n}\n\n/**\n * Form component that has to wrap every uniform\n */\nconst Form = ({\n children,\n className = undefined,\n debug = undefined,\n initialValues = undefined,\n name = undefined,\n onSubmit,\n testId = undefined,\n validation = undefined,\n validationTrigger = 'all',\n}: FormProps) => {\n return (\n <FormProvider\n debugModeSettings={debug}\n initialValues={initialValues}\n onSubmit={onSubmit}\n validation={validation}\n validationTrigger={validationTrigger}\n >\n {({ handleSubmit }) => (\n <div className=\"flex w-full flex-row justify-between gap-6\">\n <form\n className={cn('flex-grow', className)}\n data-testid={slugify(testId || name || '')}\n name={name}\n onSubmit={handleSubmit}\n >\n {children}\n </form>\n {/* render debug viewer when not in test environment and debug not disabled */}\n {!IS_TEST && !debug?.disable && (\n <FormDebugViewer className=\"w-96 flex-shrink\" />\n )}\n </div>\n )}\n </FormProvider>\n );\n};\n\nexport default Form;\n","import type { VetoError } from '@fuf-stack/veto';\n\nimport { useEffect, useState } from 'react';\nimport { FaTimes } from 'react-icons/fa';\nimport { FaBug, FaBullseye } from 'react-icons/fa6';\n\nimport { cn } from '@fuf-stack/pixel-utils';\nimport { Button } from '@fuf-stack/pixels/Button';\nimport { Card } from '@fuf-stack/pixels/Card';\nimport { Json } from '@fuf-stack/pixels/Json';\n\nimport { toValidationFormat } from '../../helpers';\nimport { useFormContext } from '../../hooks';\n\n// import Json css (theme)\nimport '@fuf-stack/pixels/Json.css';\n\ninterface FormDebugViewerProps {\n /** CSS class name */\n className?: string;\n}\n\n/** Renders a form debug panel with information about the current form state */\nconst FormDebugViewer = ({ className = undefined }: FormDebugViewerProps) => {\n const {\n debugMode,\n formState: { dirtyFields, isValid, isSubmitting },\n setDebugMode,\n validation,\n watch,\n } = useFormContext();\n\n const [validationErrors, setValidationErrors] = useState<\n VetoError['errors'] | null\n >(null);\n\n const validationValues = toValidationFormat(watch());\n const debugTestIdsEnabled = debugMode === 'debug-testids';\n\n useEffect(\n () => {\n const updateValidationErrors = async () => {\n if (validation) {\n const validateResult =\n await validation?.validateAsync(validationValues);\n setValidationErrors(validateResult?.errors);\n }\n };\n updateValidationErrors();\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [JSON.stringify(validationValues)],\n );\n\n if (!debugMode || debugMode === 'off') {\n return (\n <Button\n ariaLabel=\"Enable form debug mode\"\n onClick={() => setDebugMode('debug')}\n className=\"fixed bottom-2.5 right-2.5 w-5 text-default-400\"\n variant=\"light\"\n icon={<FaBug />}\n />\n );\n }\n\n return (\n <Card\n className={cn(className)}\n header={\n <div className=\"flex w-full flex-row justify-between\">\n <span className=\"text-lg\">Debug Mode</span>\n <Button\n color=\"danger\"\n icon={<FaTimes />}\n onClick={() => setDebugMode('off')}\n size=\"sm\"\n variant=\"light\"\n />\n </div>\n }\n >\n <Button\n variant={debugTestIdsEnabled ? 'solid' : 'light'}\n icon={<FaBullseye />}\n className=\"mb-4 ml-auto mr-auto\"\n onClick={() =>\n setDebugMode(debugMode === 'debug' ? 'debug-testids' : 'debug')\n }\n >\n {debugTestIdsEnabled ? 'Hide CopyButton' : 'Show CopyButton'}\n </Button>\n <Json\n value={{\n values: validationValues,\n errors: validationErrors,\n dirtyFields,\n isValid,\n isSubmitting,\n }}\n />\n </Card>\n );\n};\nexport default FormDebugViewer;\n","import Form from './Form';\n\nexport type { FormProps } from './Form';\n\nexport { Form };\n\nexport default Form;\n"],"mappings":"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","names":["cn","jsx","jsxs","cn","Form_default"]}
@@ -1,120 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkEPYFZXEIcjs = require('./chunk-EPYFZXEI.cjs');
4
-
5
-
6
- var _chunkPA2DQCBYcjs = require('./chunk-PA2DQCBY.cjs');
7
-
8
-
9
- var _chunkGNYQC5IJcjs = require('./chunk-GNYQC5IJ.cjs');
10
-
11
-
12
- var _chunkQQW2FHSCcjs = require('./chunk-QQW2FHSC.cjs');
13
-
14
- // src/RadioGroup/RadioGroup.tsx
15
- var _radio = require('@heroui/radio');
16
- var _pixelutils = require('@fuf-stack/pixel-utils');
17
- var _jsxruntime = require('react/jsx-runtime');
18
- var radioGroupVariants = _pixelutils.tv.call(void 0, {
19
- slots: {
20
- base: "group",
21
- // Needs group for group-data condition
22
- itemBase: "",
23
- itemControl: "bg-focus group-data-[invalid=true]:bg-danger",
24
- itemDescription: "",
25
- itemLabel: "text-sm",
26
- itemLabelWrapper: "",
27
- itemWrapper: 'group-data-[invalid=true]:!border-danger [&:not(group-data-[invalid="true"]):not(group-data-[selected="false"])]:border-focus',
28
- // TODO: get rid of !.
29
- // see HeroUI styles for group-data condition,
30
- // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts
31
- label: "text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger",
32
- wrapper: ""
33
- }
34
- });
35
- var RadioGroup = ({
36
- className = void 0,
37
- disabled = false,
38
- inline = false,
39
- label = void 0,
40
- name,
41
- options,
42
- testId: _testId = void 0
43
- }) => {
44
- const { control, debugMode, getFieldState, getValues } = _chunkQQW2FHSCcjs.useFormContext.call(void 0, );
45
- const { error, invalid, required, testId } = getFieldState(name, _testId);
46
- const showTestIdCopyButton = debugMode === "debug-testids";
47
- const showLabel = label || showTestIdCopyButton;
48
- const variants = radioGroupVariants();
49
- const classNames = _pixelutils.variantsToClassNames.call(void 0, variants, className, "base");
50
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
51
- _chunkEPYFZXEIcjs.Controller_default,
52
- {
53
- control,
54
- disabled,
55
- name,
56
- render: ({ field: { onChange, disabled: isDisabled, onBlur, ref } }) => {
57
- const itemClassNames = {
58
- base: classNames.itemBase,
59
- control: classNames.itemControl,
60
- description: classNames.itemDescription,
61
- label: classNames.itemLabel,
62
- labelWrapper: classNames.itemLabelWrapper,
63
- wrapper: classNames.itemWrapper
64
- };
65
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
66
- _radio.RadioGroup,
67
- {
68
- classNames,
69
- "data-invalid": invalid,
70
- "data-required": required,
71
- "data-testid": testId,
72
- defaultValue: getValues()[name],
73
- errorMessage: error && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGNYQC5IJcjs.FieldValidationError_default, { error, testId }),
74
- isDisabled,
75
- isInvalid: invalid,
76
- isRequired: required,
77
- label: showLabel && // eslint-disable-next-line jsx-a11y/label-has-associated-control
78
- /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "label", { children: [
79
- label,
80
- showTestIdCopyButton && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkPA2DQCBYcjs.FieldCopyTestIdButton_default, { testId })
81
- ] }),
82
- name,
83
- orientation: inline ? "horizontal" : "vertical",
84
- onBlur,
85
- ref,
86
- children: options.map((option) => {
87
- if ("value" in option) {
88
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
89
- _radio.Radio,
90
- {
91
- classNames: itemClassNames,
92
- "data-testid": _pixelutils.slugify.call(void 0,
93
- `${testId}_option_${option.testId || option.value}`
94
- ),
95
- isDisabled: isDisabled || option.disabled,
96
- onChange,
97
- value: option.value,
98
- children: option.label ? option.label : option.value
99
- },
100
- option.value
101
- );
102
- }
103
- return null;
104
- })
105
- }
106
- );
107
- }
108
- }
109
- );
110
- };
111
- var RadioGroup_default = RadioGroup;
112
-
113
- // src/RadioGroup/index.ts
114
- var RadioGroup_default2 = RadioGroup_default;
115
-
116
-
117
-
118
-
119
- exports.RadioGroup_default = RadioGroup_default; exports.RadioGroup_default2 = RadioGroup_default2;
120
- //# sourceMappingURL=chunk-JH4CPQHA.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-JH4CPQHA.cjs","../src/RadioGroup/RadioGroup.tsx","../src/RadioGroup/index.ts"],"names":["RadioGroup_default"],"mappings":"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","file":"/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-JH4CPQHA.cjs","sourcesContent":[null,"import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactElement, ReactNode } from 'react';\n\nimport { RadioGroup as HeroRadioGroup, Radio } from '@heroui/radio';\n\nimport { slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { Controller } from '../Controller';\nimport { useFormContext } from '../hooks';\nimport { FieldCopyTestIdButton } from '../partials/FieldCopyTestIdButton';\nimport { FieldValidationError } from '../partials/FieldValidationError';\n\nexport const radioGroupVariants = tv({\n slots: {\n base: 'group', // Needs group for group-data condition\n itemBase: '',\n itemControl: 'bg-focus group-data-[invalid=true]:bg-danger',\n itemDescription: '',\n itemLabel: 'text-sm',\n itemLabelWrapper: '',\n itemWrapper:\n 'group-data-[invalid=true]:!border-danger [&:not(group-data-[invalid=\"true\"]):not(group-data-[selected=\"false\"])]:border-focus', // TODO: get rid of !.\n // see HeroUI styles for group-data condition,\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts\n label:\n 'text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger',\n wrapper: '',\n },\n});\n\ntype VariantProps = TVProps<typeof radioGroupVariants>;\ntype ClassName = TVClassName<typeof radioGroupVariants>;\n\nexport interface RadioGroupOption {\n /** disables the option */\n disabled?: boolean;\n /** option label */\n label?: React.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 RadioGroupProps extends VariantProps {\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: RadioGroupOption[];\n /** Id to grab element in internal tests. */\n testId?: string;\n}\n\n/**\n * RadioGroup component based on [HeroUI RadioGroup](https://www.heroui.com//docs/components/radio-group)\n */\nconst RadioGroup = ({\n className = undefined,\n disabled = false,\n inline = false,\n label = undefined,\n name,\n options,\n testId: _testId = undefined,\n}: RadioGroupProps): ReactElement => {\n const { control, debugMode, getFieldState, getValues } = useFormContext();\n\n const { error, invalid, required, testId } = getFieldState(name, _testId);\n\n const showTestIdCopyButton = debugMode === 'debug-testids';\n const showLabel = label || showTestIdCopyButton;\n\n const variants = radioGroupVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n\n return (\n <Controller\n control={control}\n disabled={disabled}\n name={name}\n render={({ field: { onChange, disabled: isDisabled, onBlur, ref } }) => {\n const itemClassNames = {\n base: classNames.itemBase,\n control: classNames.itemControl,\n description: classNames.itemDescription,\n label: classNames.itemLabel,\n labelWrapper: classNames.itemLabelWrapper,\n wrapper: classNames.itemWrapper,\n };\n\n return (\n <HeroRadioGroup\n 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={getValues()[name]}\n errorMessage={\n error && <FieldValidationError error={error} testId={testId} />\n }\n isDisabled={isDisabled}\n isInvalid={invalid}\n isRequired={required}\n label={\n showLabel && (\n // eslint-disable-next-line jsx-a11y/label-has-associated-control\n <label>\n {label}\n {showTestIdCopyButton && (\n <FieldCopyTestIdButton testId={testId} />\n )}\n </label>\n )\n }\n name={name}\n orientation={inline ? 'horizontal' : 'vertical'}\n onBlur={onBlur}\n ref={ref}\n >\n {options.map((option) => {\n if ('value' in option) {\n return (\n <Radio\n classNames={itemClassNames}\n data-testid={slugify(\n `${testId}_option_${option.testId || option.value}`,\n )}\n isDisabled={isDisabled || option.disabled}\n key={option.value}\n onChange={onChange}\n value={option.value}\n >\n {option.label ? option.label : option.value}\n </Radio>\n );\n }\n return null;\n })}\n </HeroRadioGroup>\n );\n }}\n />\n );\n};\n\nexport default RadioGroup;\n","import RadioGroup from './RadioGroup';\n\nexport type { RadioGroupProps } from './RadioGroup';\n\nexport { RadioGroup };\n\nexport default RadioGroup;\n"]}
@@ -1,97 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkEPYFZXEIcjs = require('./chunk-EPYFZXEI.cjs');
4
-
5
-
6
- var _chunkPA2DQCBYcjs = require('./chunk-PA2DQCBY.cjs');
7
-
8
-
9
- var _chunkGNYQC5IJcjs = require('./chunk-GNYQC5IJ.cjs');
10
-
11
-
12
- var _chunkQQW2FHSCcjs = require('./chunk-QQW2FHSC.cjs');
13
-
14
- // src/Input/Input.tsx
15
- var _input = require('@heroui/input');
16
- var _pixelutils = require('@fuf-stack/pixel-utils');
17
- var _jsxruntime = require('react/jsx-runtime');
18
- var Input = ({
19
- className = void 0,
20
- disabled = false,
21
- endContent = void 0,
22
- label = void 0,
23
- name,
24
- placeholder = " ",
25
- startContent = void 0,
26
- testId: _testId = void 0,
27
- transformValue = void 0,
28
- type = void 0
29
- }) => {
30
- const { control, debugMode, getFieldState } = _chunkQQW2FHSCcjs.useFormContext.call(void 0, );
31
- const { error, invalid, required, testId } = getFieldState(name, _testId);
32
- const showTestIdCopyButton = debugMode === "debug-testids";
33
- const showLabel = label || showTestIdCopyButton;
34
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
35
- _chunkEPYFZXEIcjs.Controller_default,
36
- {
37
- control,
38
- disabled,
39
- name,
40
- render: ({
41
- field: { disabled: isDisabled, onChange, onBlur, value = "", ref }
42
- }) => {
43
- const displayValue = (transformValue == null ? void 0 : transformValue.displayValue) ? transformValue.displayValue(value != null ? value : "") : value != null ? value : "";
44
- const handleChange = (e) => {
45
- const inputValue = e.target.value;
46
- if (type === "number") {
47
- onChange(inputValue === "" ? "" : Number(inputValue));
48
- } else {
49
- onChange(
50
- (transformValue == null ? void 0 : transformValue.formValue) ? transformValue.formValue(inputValue) : inputValue
51
- );
52
- }
53
- };
54
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
55
- _input.Input,
56
- {
57
- className: _pixelutils.cn.call(void 0, className),
58
- classNames: {
59
- inputWrapper: "group-data-[focus=true]:border-focus"
60
- },
61
- "data-testid": testId,
62
- endContent,
63
- errorMessage: error && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGNYQC5IJcjs.FieldValidationError_default, { error, testId }),
64
- isDisabled,
65
- isInvalid: invalid,
66
- isRequired: required,
67
- label: showLabel && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
68
- label,
69
- showTestIdCopyButton && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkPA2DQCBYcjs.FieldCopyTestIdButton_default, { testId })
70
- ] }),
71
- labelPlacement: "outside",
72
- name,
73
- onBlur,
74
- onChange: handleChange,
75
- placeholder,
76
- radius: "sm",
77
- ref,
78
- startContent,
79
- type,
80
- value: displayValue,
81
- variant: "bordered"
82
- }
83
- );
84
- }
85
- }
86
- );
87
- };
88
- var Input_default = Input;
89
-
90
- // src/Input/index.ts
91
- var Input_default2 = Input_default;
92
-
93
-
94
-
95
-
96
- exports.Input_default = Input_default; exports.Input_default2 = Input_default2;
97
- //# sourceMappingURL=chunk-JHVW42BW.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-JHVW42BW.cjs","../src/Input/Input.tsx","../src/Input/index.ts"],"names":["Input_default"],"mappings":"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","file":"/home/runner/work/pixels/pixels/packages/uniform/dist/chunk-JHVW42BW.cjs","sourcesContent":[null,"import type { ReactNode } from 'react';\n\nimport { Input as HeroInput } from '@heroui/input';\n\nimport { cn } from '@fuf-stack/pixel-utils';\n\nimport { Controller } from '../Controller';\nimport { useFormContext } from '../hooks';\nimport { FieldCopyTestIdButton } from '../partials/FieldCopyTestIdButton';\nimport { FieldValidationError } from '../partials/FieldValidationError';\n\nexport interface InputProps {\n /** CSS class name */\n className?: string;\n /** input field is disabled */\n disabled?: boolean;\n /** added content to the end of the input Field. */\n endContent?: ReactNode;\n /** form field label (set to false to disable label) */\n label?: string | false;\n /** form field name */\n name: string;\n /** form field placeholder */\n placeholder?: string;\n /** content added to the start of the input field */\n startContent?: ReactNode;\n /** HTML data-testid attribute used in e2e tests */\n testId?: string;\n /** allows disentangled display and form values for a field */\n transformValue?: {\n /** transforms the formValue of the field to the display value of the field */\n displayValue: (value: string | number) => string | number;\n /** transforms the displayValue of the field to the form value of the field */\n formValue: (value: string) => string | number;\n };\n /** input type */\n type?: 'number' | 'password';\n}\n\n/**\n * Input component based on [HeroUI Input](https://www.heroui.com//docs/components/input)\n */\nconst Input = ({\n className = undefined,\n disabled = false,\n endContent = undefined,\n label = undefined,\n name,\n placeholder = ' ',\n startContent = undefined,\n testId: _testId = undefined,\n transformValue = undefined,\n type = undefined,\n}: InputProps) => {\n const { control, debugMode, getFieldState } = useFormContext();\n const { error, invalid, required, testId } = getFieldState(name, _testId);\n\n const showTestIdCopyButton = debugMode === 'debug-testids';\n const showLabel = label || showTestIdCopyButton;\n\n return (\n <Controller\n control={control}\n disabled={disabled}\n name={name}\n render={({\n field: { disabled: isDisabled, onChange, onBlur, value = '', ref },\n }) => {\n /**\n * Determines the display value for the input field:\n * 1. If transformValue.displayValue is provided, applies the transform to the current value\n * (useful for formatting like adding currency symbols, date formatting, etc.)\n * 2. Falls back to the raw value if no transform is provided\n * 3. Ensures a defined value by using empty string as fallback (prevents uncontrolled input warnings)\n *\n * Examples:\n * - With transform: value \"1000\" → displayValue \"$1,000\"\n * - Without transform: value \"1000\" → displayValue \"1000\"\n * - Undefined value: value undefined → displayValue \"\"\n */\n const displayValue = transformValue?.displayValue\n ? transformValue.displayValue(value ?? '')\n : (value ?? '');\n\n /**\n * Handles input value changes with special processing:\n * 1. For number inputs:\n * - Preserves empty string (prevents NaN in the form state)\n * - Converts non-empty values to numbers\n * Example: \"\" → \"\" (empty stays empty)\n * \"42\" → 42 (converts to number)\n *\n * 2. For text inputs with transformValue.formValue:\n * - Applies custom transform before updating form state\n * - Useful for converting display format to storage format\n * Example: \"$1,000\" → \"1000\" (strips formatting)\n *\n * 3. For regular text inputs:\n * - Passes through the raw input value\n * Example: \"hello\" → \"hello\" (no transformation)\n *\n * @param e The input change event\n */\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const inputValue = e.target.value;\n if (type === 'number') {\n onChange(inputValue === '' ? '' : Number(inputValue));\n } else {\n onChange(\n transformValue?.formValue\n ? transformValue.formValue(inputValue)\n : inputValue,\n );\n }\n };\n\n return (\n <HeroInput\n className={cn(className)}\n classNames={{\n inputWrapper: 'group-data-[focus=true]:border-focus',\n }}\n data-testid={testId}\n endContent={endContent}\n errorMessage={\n error && <FieldValidationError error={error} testId={testId} />\n }\n isDisabled={isDisabled}\n isInvalid={invalid}\n isRequired={required}\n label={\n showLabel && (\n <>\n {label}\n {showTestIdCopyButton && (\n <FieldCopyTestIdButton testId={testId} />\n )}\n </>\n )\n }\n labelPlacement=\"outside\"\n name={name}\n onBlur={onBlur}\n onChange={handleChange}\n placeholder={placeholder}\n radius=\"sm\"\n ref={ref}\n startContent={startContent}\n type={type}\n // @ts-expect-error number is ok here\n value={displayValue}\n variant=\"bordered\"\n />\n );\n }}\n />\n );\n};\n\nexport default Input;\n","import Input from './Input';\n\nexport type { InputProps } from './Input';\n\nexport { Input };\n\nexport default Input;\n"]}
@@ -1,120 +0,0 @@
1
- import {
2
- Controller_default
3
- } from "./chunk-AT2VVPRD.js";
4
- import {
5
- FieldCopyTestIdButton_default
6
- } from "./chunk-BQGN3JTU.js";
7
- import {
8
- FieldValidationError_default
9
- } from "./chunk-UTFZRBBS.js";
10
- import {
11
- useFormContext
12
- } from "./chunk-NBAVP4ER.js";
13
-
14
- // src/RadioGroup/RadioGroup.tsx
15
- import { RadioGroup as HeroRadioGroup, Radio } from "@heroui/radio";
16
- import { slugify, tv, variantsToClassNames } from "@fuf-stack/pixel-utils";
17
- import { jsx, jsxs } from "react/jsx-runtime";
18
- var radioGroupVariants = tv({
19
- slots: {
20
- base: "group",
21
- // Needs group for group-data condition
22
- itemBase: "",
23
- itemControl: "bg-focus group-data-[invalid=true]:bg-danger",
24
- itemDescription: "",
25
- itemLabel: "text-sm",
26
- itemLabelWrapper: "",
27
- itemWrapper: 'group-data-[invalid=true]:!border-danger [&:not(group-data-[invalid="true"]):not(group-data-[selected="false"])]:border-focus',
28
- // TODO: get rid of !.
29
- // see HeroUI styles for group-data condition,
30
- // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts
31
- label: "text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger",
32
- wrapper: ""
33
- }
34
- });
35
- var RadioGroup = ({
36
- className = void 0,
37
- disabled = false,
38
- inline = false,
39
- label = void 0,
40
- name,
41
- options,
42
- testId: _testId = void 0
43
- }) => {
44
- const { control, debugMode, getFieldState, getValues } = useFormContext();
45
- const { error, invalid, required, testId } = getFieldState(name, _testId);
46
- const showTestIdCopyButton = debugMode === "debug-testids";
47
- const showLabel = label || showTestIdCopyButton;
48
- const variants = radioGroupVariants();
49
- const classNames = variantsToClassNames(variants, className, "base");
50
- return /* @__PURE__ */ jsx(
51
- Controller_default,
52
- {
53
- control,
54
- disabled,
55
- name,
56
- render: ({ field: { onChange, disabled: isDisabled, onBlur, ref } }) => {
57
- const itemClassNames = {
58
- base: classNames.itemBase,
59
- control: classNames.itemControl,
60
- description: classNames.itemDescription,
61
- label: classNames.itemLabel,
62
- labelWrapper: classNames.itemLabelWrapper,
63
- wrapper: classNames.itemWrapper
64
- };
65
- return /* @__PURE__ */ jsx(
66
- HeroRadioGroup,
67
- {
68
- classNames,
69
- "data-invalid": invalid,
70
- "data-required": required,
71
- "data-testid": testId,
72
- defaultValue: getValues()[name],
73
- errorMessage: error && /* @__PURE__ */ jsx(FieldValidationError_default, { error, testId }),
74
- isDisabled,
75
- isInvalid: invalid,
76
- isRequired: required,
77
- label: showLabel && // eslint-disable-next-line jsx-a11y/label-has-associated-control
78
- /* @__PURE__ */ jsxs("label", { children: [
79
- label,
80
- showTestIdCopyButton && /* @__PURE__ */ jsx(FieldCopyTestIdButton_default, { testId })
81
- ] }),
82
- name,
83
- orientation: inline ? "horizontal" : "vertical",
84
- onBlur,
85
- ref,
86
- children: options.map((option) => {
87
- if ("value" in option) {
88
- return /* @__PURE__ */ jsx(
89
- Radio,
90
- {
91
- classNames: itemClassNames,
92
- "data-testid": slugify(
93
- `${testId}_option_${option.testId || option.value}`
94
- ),
95
- isDisabled: isDisabled || option.disabled,
96
- onChange,
97
- value: option.value,
98
- children: option.label ? option.label : option.value
99
- },
100
- option.value
101
- );
102
- }
103
- return null;
104
- })
105
- }
106
- );
107
- }
108
- }
109
- );
110
- };
111
- var RadioGroup_default = RadioGroup;
112
-
113
- // src/RadioGroup/index.ts
114
- var RadioGroup_default2 = RadioGroup_default;
115
-
116
- export {
117
- RadioGroup_default,
118
- RadioGroup_default2
119
- };
120
- //# sourceMappingURL=chunk-JS2D6XPO.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/RadioGroup/RadioGroup.tsx","../src/RadioGroup/index.ts"],"sourcesContent":["import type { TVClassName, TVProps } from '@fuf-stack/pixel-utils';\nimport type { ReactElement, ReactNode } from 'react';\n\nimport { RadioGroup as HeroRadioGroup, Radio } from '@heroui/radio';\n\nimport { slugify, tv, variantsToClassNames } from '@fuf-stack/pixel-utils';\n\nimport { Controller } from '../Controller';\nimport { useFormContext } from '../hooks';\nimport { FieldCopyTestIdButton } from '../partials/FieldCopyTestIdButton';\nimport { FieldValidationError } from '../partials/FieldValidationError';\n\nexport const radioGroupVariants = tv({\n slots: {\n base: 'group', // Needs group for group-data condition\n itemBase: '',\n itemControl: 'bg-focus group-data-[invalid=true]:bg-danger',\n itemDescription: '',\n itemLabel: 'text-sm',\n itemLabelWrapper: '',\n itemWrapper:\n 'group-data-[invalid=true]:!border-danger [&:not(group-data-[invalid=\"true\"]):not(group-data-[selected=\"false\"])]:border-focus', // TODO: get rid of !.\n // see HeroUI styles for group-data condition,\n // e.g.: https://github.com/heroui-inc/heroui/blob/main/packages/core/theme/src/components/select.ts\n label:\n 'text-sm text-foreground subpixel-antialiased group-data-[invalid=true]:text-danger',\n wrapper: '',\n },\n});\n\ntype VariantProps = TVProps<typeof radioGroupVariants>;\ntype ClassName = TVClassName<typeof radioGroupVariants>;\n\nexport interface RadioGroupOption {\n /** disables the option */\n disabled?: boolean;\n /** option label */\n label?: React.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 RadioGroupProps extends VariantProps {\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: RadioGroupOption[];\n /** Id to grab element in internal tests. */\n testId?: string;\n}\n\n/**\n * RadioGroup component based on [HeroUI RadioGroup](https://www.heroui.com//docs/components/radio-group)\n */\nconst RadioGroup = ({\n className = undefined,\n disabled = false,\n inline = false,\n label = undefined,\n name,\n options,\n testId: _testId = undefined,\n}: RadioGroupProps): ReactElement => {\n const { control, debugMode, getFieldState, getValues } = useFormContext();\n\n const { error, invalid, required, testId } = getFieldState(name, _testId);\n\n const showTestIdCopyButton = debugMode === 'debug-testids';\n const showLabel = label || showTestIdCopyButton;\n\n const variants = radioGroupVariants();\n const classNames = variantsToClassNames(variants, className, 'base');\n\n return (\n <Controller\n control={control}\n disabled={disabled}\n name={name}\n render={({ field: { onChange, disabled: isDisabled, onBlur, ref } }) => {\n const itemClassNames = {\n base: classNames.itemBase,\n control: classNames.itemControl,\n description: classNames.itemDescription,\n label: classNames.itemLabel,\n labelWrapper: classNames.itemLabelWrapper,\n wrapper: classNames.itemWrapper,\n };\n\n return (\n <HeroRadioGroup\n 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={getValues()[name]}\n errorMessage={\n error && <FieldValidationError error={error} testId={testId} />\n }\n isDisabled={isDisabled}\n isInvalid={invalid}\n isRequired={required}\n label={\n showLabel && (\n // eslint-disable-next-line jsx-a11y/label-has-associated-control\n <label>\n {label}\n {showTestIdCopyButton && (\n <FieldCopyTestIdButton testId={testId} />\n )}\n </label>\n )\n }\n name={name}\n orientation={inline ? 'horizontal' : 'vertical'}\n onBlur={onBlur}\n ref={ref}\n >\n {options.map((option) => {\n if ('value' in option) {\n return (\n <Radio\n classNames={itemClassNames}\n data-testid={slugify(\n `${testId}_option_${option.testId || option.value}`,\n )}\n isDisabled={isDisabled || option.disabled}\n key={option.value}\n onChange={onChange}\n value={option.value}\n >\n {option.label ? option.label : option.value}\n </Radio>\n );\n }\n return null;\n })}\n </HeroRadioGroup>\n );\n }}\n />\n );\n};\n\nexport default RadioGroup;\n","import RadioGroup from './RadioGroup';\n\nexport type { RadioGroupProps } from './RadioGroup';\n\nexport { RadioGroup };\n\nexport default RadioGroup;\n"],"mappings":";;;;;;;;;;;;;;AAGA,SAAS,cAAc,gBAAgB,aAAa;AAEpD,SAAS,SAAS,IAAI,4BAA4B;AAyG3B,cAQP,YARO;AAlGhB,IAAM,qBAAqB,GAAG;AAAA,EACnC,OAAO;AAAA,IACL,MAAM;AAAA;AAAA,IACN,UAAU;AAAA,IACV,aAAa;AAAA,IACb,iBAAiB;AAAA,IACjB,WAAW;AAAA,IACX,kBAAkB;AAAA,IAClB,aACE;AAAA;AAAA;AAAA;AAAA,IAGF,OACE;AAAA,IACF,SAAS;AAAA,EACX;AACF,CAAC;AAsCD,IAAM,aAAa,CAAC;AAAA,EAClB,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,SAAS;AAAA,EACT,QAAQ;AAAA,EACR;AAAA,EACA;AAAA,EACA,QAAQ,UAAU;AACpB,MAAqC;AACnC,QAAM,EAAE,SAAS,WAAW,eAAe,UAAU,IAAI,eAAe;AAExE,QAAM,EAAE,OAAO,SAAS,UAAU,OAAO,IAAI,cAAc,MAAM,OAAO;AAExE,QAAM,uBAAuB,cAAc;AAC3C,QAAM,YAAY,SAAS;AAE3B,QAAM,WAAW,mBAAmB;AACpC,QAAM,aAAa,qBAAqB,UAAU,WAAW,MAAM;AAEnE,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MACA,QAAQ,CAAC,EAAE,OAAO,EAAE,UAAU,UAAU,YAAY,QAAQ,IAAI,EAAE,MAAM;AACtE,cAAM,iBAAiB;AAAA,UACrB,MAAM,WAAW;AAAA,UACjB,SAAS,WAAW;AAAA,UACpB,aAAa,WAAW;AAAA,UACxB,OAAO,WAAW;AAAA,UAClB,cAAc,WAAW;AAAA,UACzB,SAAS,WAAW;AAAA,QACtB;AAEA,eACE;AAAA,UAAC;AAAA;AAAA,YACC;AAAA,YAGA,gBAAc;AAAA,YACd,iBAAe;AAAA,YACf,eAAa;AAAA,YACb,cAAc,UAAU,EAAE,IAAI;AAAA,YAC9B,cACE,SAAS,oBAAC,gCAAqB,OAAc,QAAgB;AAAA,YAE/D;AAAA,YACA,WAAW;AAAA,YACX,YAAY;AAAA,YACZ,OACE;AAAA,YAEE,qBAAC,WACE;AAAA;AAAA,cACA,wBACC,oBAAC,iCAAsB,QAAgB;AAAA,eAE3C;AAAA,YAGJ;AAAA,YACA,aAAa,SAAS,eAAe;AAAA,YACrC;AAAA,YACA;AAAA,YAEC,kBAAQ,IAAI,CAAC,WAAW;AACvB,kBAAI,WAAW,QAAQ;AACrB,uBACE;AAAA,kBAAC;AAAA;AAAA,oBACC,YAAY;AAAA,oBACZ,eAAa;AAAA,sBACX,GAAG,MAAM,WAAW,OAAO,UAAU,OAAO,KAAK;AAAA,oBACnD;AAAA,oBACA,YAAY,cAAc,OAAO;AAAA,oBAEjC;AAAA,oBACA,OAAO,OAAO;AAAA,oBAEb,iBAAO,QAAQ,OAAO,QAAQ,OAAO;AAAA;AAAA,kBAJjC,OAAO;AAAA,gBAKd;AAAA,cAEJ;AACA,qBAAO;AAAA,YACT,CAAC;AAAA;AAAA,QACH;AAAA,MAEJ;AAAA;AAAA,EACF;AAEJ;AAEA,IAAO,qBAAQ;;;ACvJf,IAAOA,sBAAQ;","names":["RadioGroup_default"]}
@@ -1,135 +0,0 @@
1
- import {
2
- toValidationFormat
3
- } from "./chunk-UAV6PVB4.js";
4
- import {
5
- __async,
6
- __objRest,
7
- __spreadProps,
8
- __spreadValues
9
- } from "./chunk-CRTRMMJ7.js";
10
-
11
- // src/hooks/useFieldArray/useFieldArray.ts
12
- import { useFieldArray } from "react-hook-form";
13
-
14
- // src/hooks/useFormContext/useFormContext.ts
15
- import { useContext } from "react";
16
- import { useFormContext as useHookFormContext } from "react-hook-form";
17
- import { slugify } from "@fuf-stack/pixel-utils";
18
-
19
- // src/Form/subcomponents/FormContext.tsx
20
- import React, { useMemo, useState } from "react";
21
- import { FormProvider as HookFormProvider, useForm } from "react-hook-form";
22
- import { useLocalStorage } from "@fuf-stack/pixels";
23
- import { jsx } from "react/jsx-runtime";
24
- var DEBUG_MODE_LOCAL_STORAGE_KEY_DEFAULT = "uniform:debug-mode";
25
- var UniformContext = React.createContext({
26
- debugMode: "off",
27
- preventSubmit: () => void 0,
28
- setDebugMode: () => void 0,
29
- triggerSubmit: () => void 0,
30
- validation: void 0
31
- });
32
- var FormProvider = ({
33
- children,
34
- debugModeSettings = void 0,
35
- initialValues = void 0,
36
- onSubmit,
37
- validation = void 0,
38
- validationTrigger
39
- }) => {
40
- const [preventSubmit, setPreventSubmit] = useState(false);
41
- const [debugMode, setDebugMode] = useLocalStorage(
42
- (debugModeSettings == null ? void 0 : debugModeSettings.localStorageKey) || DEBUG_MODE_LOCAL_STORAGE_KEY_DEFAULT,
43
- "off"
44
- );
45
- const methods = useForm(__spreadValues({
46
- defaultValues: initialValues
47
- }, validation ? {
48
- // set rhf mode
49
- // see: https://react-hook-form.com/docs/useform#mode
50
- mode: validationTrigger,
51
- resolver: (values) => __async(void 0, null, function* () {
52
- const _a = yield validation.validateAsync(
53
- toValidationFormat(values)
54
- ), { data, errors } = _a, rest = __objRest(_a, ["data", "errors"]);
55
- return __spreadValues({ values: data || {}, errors: errors || {} }, rest);
56
- })
57
- } : {}));
58
- const handleSubmit = (e) => __async(void 0, null, function* () {
59
- if (methods.formState.isValid && preventSubmit) {
60
- console.warn(
61
- "[FormProvider] form submit was prevented because preventSubmit is true..."
62
- );
63
- e == null ? void 0 : e.preventDefault();
64
- return Promise.resolve();
65
- }
66
- yield methods.handleSubmit(onSubmit)(e);
67
- });
68
- const contextValue = useMemo(
69
- () => ({
70
- // set debugMode to disabled when debugModeSettings.disable is true
71
- // otherwise use current debug mode from localStorage
72
- debugMode: (debugModeSettings == null ? void 0 : debugModeSettings.disable) ? "disabled" : debugMode,
73
- preventSubmit: (prevent) => {
74
- setPreventSubmit(prevent);
75
- },
76
- setDebugMode,
77
- triggerSubmit: handleSubmit,
78
- validation
79
- }),
80
- // eslint-disable-next-line react-hooks/exhaustive-deps
81
- [debugMode, debugModeSettings == null ? void 0 : debugModeSettings.disable]
82
- );
83
- return /* @__PURE__ */ jsx(UniformContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx(HookFormProvider, __spreadProps(__spreadValues({}, methods), { children: children({ handleSubmit }) })) });
84
- };
85
- var FormContext_default = FormProvider;
86
-
87
- // src/hooks/useFormContext/useFormContext.ts
88
- var checkFieldIsRequired = (validation, path) => {
89
- const checkRequired = (schema) => {
90
- if (schema.type === "array" && (schema == null ? void 0 : schema.minLength)) {
91
- return true;
92
- }
93
- return !schema.isOptional && !schema.isNullable;
94
- };
95
- return validation.checkSchemaPath(checkRequired, path);
96
- };
97
- var useFormContext = () => {
98
- const _a = useHookFormContext(), {
99
- formState,
100
- getFieldState: getFieldStateOrig
101
- } = _a, otherMethods = __objRest(_a, [
102
- "formState",
103
- // https://react-hook-form.com/docs/useform/getfieldstate
104
- // for getFieldState a subscription to formState properties is needed!
105
- "getFieldState"
106
- ]);
107
- const uniformContext = useContext(UniformContext);
108
- const getFieldState = (name, testId) => {
109
- const fieldPath = typeof name === "string" ? name.replace(/\[\d+\]/g, "").split(".") : name;
110
- const required = (uniformContext == null ? void 0 : uniformContext.validation) ? checkFieldIsRequired(uniformContext.validation, fieldPath) : false;
111
- const _a2 = getFieldStateOrig(name, formState), { error } = _a2, rest = __objRest(_a2, ["error"]);
112
- return __spreadProps(__spreadValues({}, rest), {
113
- error,
114
- // Ensure correct type for error
115
- required,
116
- testId: slugify(testId || name)
117
- });
118
- };
119
- return __spreadProps(__spreadValues(__spreadValues({}, otherMethods), uniformContext), {
120
- getFieldState,
121
- formState
122
- });
123
- };
124
-
125
- // src/hooks/useInput/useInput.ts
126
- import { useInput } from "@heroui/input";
127
-
128
- export {
129
- useFieldArray,
130
- FormContext_default,
131
- checkFieldIsRequired,
132
- useFormContext,
133
- useInput
134
- };
135
- //# sourceMappingURL=chunk-NBAVP4ER.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/hooks/useFieldArray/useFieldArray.ts","../src/hooks/useFormContext/useFormContext.ts","../src/Form/subcomponents/FormContext.tsx","../src/hooks/useInput/useInput.ts"],"sourcesContent":["/* eslint-disable import/prefer-default-export */\n\n/** @see https://react-hook-form.com/docs/usefieldarray */\nexport { useFieldArray } from 'react-hook-form';\n","import type { VetoInstance } from '@fuf-stack/veto';\nimport type { FieldError } from 'react-hook-form';\n\nimport { useContext } from 'react';\nimport { useFormContext as useHookFormContext } from 'react-hook-form';\n\nimport { slugify } from '@fuf-stack/pixel-utils';\n\nimport { UniformContext } from '../../Form/subcomponents/FormContext';\n\n/** Schema check whether a field is required or optional */\nexport const checkFieldIsRequired = (\n validation: VetoInstance,\n path: string[],\n): boolean => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const checkRequired = (schema: any) => {\n // arrays with minLength are required\n if (schema.type === 'array' && schema?.minLength) {\n return true;\n }\n // all other fields are required if they are\n // not optional and not nullable\n return !schema.isOptional && !schema.isNullable;\n };\n\n return validation.checkSchemaPath(checkRequired, path);\n};\n\n/**\n * Custom hook that extends react-hook-form's useFormContext to add validation and state management.\n */\nexport const useFormContext = () => {\n const {\n formState,\n // https://react-hook-form.com/docs/useform/getfieldstate\n // for getFieldState a subscription to formState properties is needed!\n getFieldState: getFieldStateOrig,\n ...otherMethods\n } = useHookFormContext();\n\n const uniformContext = useContext(UniformContext);\n\n /**\n * Updated getFieldState method which returns:\n * - Whether the field is required by checking the validation schema\n * - Existing field state information (errors, etc.)\n */\n const getFieldState = (name: string, testId?: string) => {\n const fieldPath =\n typeof name === 'string' ? name.replace(/\\[\\d+\\]/g, '').split('.') : name;\n\n // Check if the field is required using the validation schema\n const required = uniformContext?.validation\n ? checkFieldIsRequired(uniformContext.validation, fieldPath)\n : false;\n\n // Get the original field state (errors, etc.) from react-hook-form\n const { error, ...rest } = getFieldStateOrig(name, formState);\n\n return {\n ...rest,\n error: error as FieldError[] | undefined, // Ensure correct type for error\n required,\n testId: slugify(testId || name),\n };\n };\n\n return {\n ...otherMethods,\n ...uniformContext,\n getFieldState,\n formState,\n };\n};\n","import type { VetoInstance } from '@fuf-stack/veto';\nimport type { BaseSyntheticEvent, ReactNode } from 'react';\nimport type { FieldValues, SubmitHandler } from 'react-hook-form';\n\nimport React, { useMemo, useState } from 'react';\nimport { FormProvider as HookFormProvider, useForm } from 'react-hook-form';\n\nimport { useLocalStorage } from '@fuf-stack/pixels';\n\nimport { toValidationFormat } from '../../helpers';\n\ntype DebugMode = 'debug' | 'debug-testids' | 'off' | 'disabled';\n\nexport type DebugModeSettings = {\n /** disable form debug completely */\n disable?: boolean;\n /** custom localStorage key to save debug mode state */\n localStorageKey?: string;\n};\n\nconst DEBUG_MODE_LOCAL_STORAGE_KEY_DEFAULT = 'uniform:debug-mode';\n\n/**\n * The `UniformContext` provides control over the form's submission behavior and may optionally include\n * a Veto validation schema for form validation.\n *\n * Specifically, this context offers:\n * 1. **Form Submission Control**: The `preventSubmit` function allows components to enable or disable\n * form submissions.\n * 2. **Optional Validation Schema**: The `validation` property may hold a Veto validation schema instance\n * that can be used to validate form fields and handle validation logic.\n *\n * This context is useful for components that need to interact with or control the form submission state,\n * or access the validation schema for managing form validation logic.\n */\nexport const UniformContext = React.createContext<{\n /** Form debug mode enabled or not */\n debugMode: DebugMode;\n /** settings for from debug mode */\n debugModeSettings?: DebugModeSettings;\n /** Function to update if the form can currently be submitted */\n preventSubmit: (prevent: boolean) => void;\n /** Setter to enable or disable form debug mode */\n setDebugMode: (debugMode: DebugMode) => void;\n /** Function to trigger form submit programmatically */\n triggerSubmit: (e?: BaseSyntheticEvent) => Promise<void> | void;\n /** Optional Veto validation schema instance for form validation */\n validation?: VetoInstance;\n}>({\n debugMode: 'off',\n preventSubmit: () => undefined,\n setDebugMode: () => undefined,\n triggerSubmit: () => undefined,\n validation: undefined,\n});\n\n// Define props for the FormProvider component, extending HookForm's props\ninterface FormProviderProps {\n /** children form render function */\n children: (childProps: {\n handleSubmit: (e?: BaseSyntheticEvent) => Promise<void>;\n }) => ReactNode;\n /** settings for from debug mode */\n debugModeSettings?: DebugModeSettings;\n /** initial form values */\n initialValues?: FieldValues;\n /** form submit handler */\n onSubmit: SubmitHandler<FieldValues>;\n /** Veto validation schema instance */\n validation?: VetoInstance;\n /** when the validation should be triggered */\n validationTrigger: 'onChange' | 'onBlur' | 'onSubmit' | 'onTouched' | 'all';\n}\n\n/**\n * FormProvider component provides:\n * - The veto validation schema context\n * - Submit handler creation and submission control with preventSubmit\n * - Form Debug Mode state\n * - React Hook Form context\n */\nconst FormProvider: React.FC<FormProviderProps> = ({\n children,\n debugModeSettings = undefined,\n initialValues = undefined,\n onSubmit,\n validation = undefined,\n validationTrigger,\n}) => {\n // Control if the form can currently be submitted\n const [preventSubmit, setPreventSubmit] = useState(false);\n\n // Form Debug mode state is handled in the form context\n const [debugMode, setDebugMode] = useLocalStorage<DebugMode>(\n debugModeSettings?.localStorageKey || DEBUG_MODE_LOCAL_STORAGE_KEY_DEFAULT,\n 'off',\n );\n\n // Initialize react hook form\n const methods = useForm({\n defaultValues: initialValues,\n // add validation config when validation schema provided\n ...(validation\n ? {\n // set rhf mode\n // see: https://react-hook-form.com/docs/useform#mode\n mode: validationTrigger,\n resolver: async (values) => {\n const { data, errors, ...rest } = await validation.validateAsync(\n toValidationFormat(values),\n );\n // https://github.com/react-hook-form/resolvers/blob/master/zod/src/zod.ts\n return { values: data || {}, errors: errors || {}, ...rest };\n },\n }\n : {}),\n });\n\n // Create submit handler\n // eslint-disable-next-line consistent-return\n const handleSubmit = async (e?: React.BaseSyntheticEvent) => {\n // only prevent submit when form state is valid, because otherwise\n // submit will only trigger validation and add errors / focus invalid fields\n if (methods.formState.isValid && preventSubmit) {\n console.warn(\n '[FormProvider] form submit was prevented because preventSubmit is true...',\n );\n e?.preventDefault();\n return Promise.resolve();\n }\n await methods.handleSubmit(onSubmit)(e);\n };\n\n // Memoize the context value to prevent re-renders\n const contextValue = useMemo(\n () => ({\n // set debugMode to disabled when debugModeSettings.disable is true\n // otherwise use current debug mode from localStorage\n debugMode: debugModeSettings?.disable ? 'disabled' : debugMode,\n preventSubmit: (prevent: boolean) => {\n setPreventSubmit(prevent);\n },\n setDebugMode,\n triggerSubmit: handleSubmit,\n validation,\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [debugMode, debugModeSettings?.disable],\n );\n\n return (\n <UniformContext.Provider value={contextValue}>\n {/* Spread all hook form props into HookFormProvider */}\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <HookFormProvider {...methods}>\n {children({ handleSubmit })}\n </HookFormProvider>\n </UniformContext.Provider>\n );\n};\n\nexport default FormProvider;\n","/* eslint-disable import/prefer-default-export */\nexport { useInput } from '@heroui/input';\n"],"mappings":"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","names":["_a"]}