@delightui/components 0.1.162-alpha.0 → 0.1.162-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -18,5 +18,8 @@ declare const usePresenter: <TFieldValues extends FieldValues = FieldValues, TNa
18
18
  field: import("react-hook-form").ControllerRenderProps<TFieldValues, TName>;
19
19
  children: import("react").ReactNode;
20
20
  disabled: boolean | undefined;
21
+ className: string | undefined;
22
+ style: import("react").CSSProperties | undefined;
23
+ hasMessage: boolean | undefined;
21
24
  };
22
25
  export default usePresenter;
@@ -1,4 +1,4 @@
1
- import type { ReactNode } from 'react';
1
+ import type { HTMLAttributes, ReactNode } from 'react';
2
2
  import type { FieldValues, Path, PathValue } from 'react-hook-form';
3
3
  /**
4
4
  * Type representing allowed field values
@@ -59,7 +59,7 @@ export type AsyncFieldValidationFunction<TValue = FieldValue> = (value: TValue)
59
59
  /**
60
60
  * FormField component props for use within a Form
61
61
  */
62
- export type FormFieldProps<TFieldValues extends FieldValues = FieldValues, TName extends Path<TFieldValues> = Path<TFieldValues>> = {
62
+ export type FormFieldProps<TFieldValues extends FieldValues = FieldValues, TName extends Path<TFieldValues> = Path<TFieldValues>> = Omit<HTMLAttributes<HTMLDivElement>, 'id' | 'children'> & {
63
63
  /** Field name (must match form value key) - type-safe */
64
64
  name: TName;
65
65
  /** Field label */
@@ -87,13 +87,15 @@ export type FormFieldProps<TFieldValues extends FieldValues = FieldValues, TName
87
87
  invalid?: boolean;
88
88
  /** Info icon element */
89
89
  infoIcon?: ReactNode;
90
- /** Field ID */
90
+ /** Field ID - for the input element */
91
91
  id?: string;
92
+ /** @deprecated Legacy prop for backwards compatibility - use message prop instead */
93
+ hasMessage?: boolean;
92
94
  };
93
95
  /**
94
96
  * Standalone FormField props (works without Form context)
95
97
  */
96
- export type StandaloneFieldProps<TValue = FieldValue> = {
98
+ export type StandaloneFieldProps<TValue = FieldValue> = Omit<HTMLAttributes<HTMLDivElement>, 'id' | 'children' | 'onChange'> & {
97
99
  /** Field name */
98
100
  name: string;
99
101
  /** Field label */
@@ -120,6 +122,8 @@ export type StandaloneFieldProps<TValue = FieldValue> = {
120
122
  disabled?: boolean;
121
123
  /** Info icon element */
122
124
  infoIcon?: ReactNode;
123
- /** Field ID */
125
+ /** Field ID - for the input element */
124
126
  id?: string;
127
+ /** @deprecated Legacy prop for backwards compatibility - use message prop instead */
128
+ hasMessage?: boolean;
125
129
  };
@@ -13,9 +13,278 @@ declare const usePresenter: <TFormValues extends FieldValues = FieldValues>(prop
13
13
  variantProps: {
14
14
  'component-variant': string;
15
15
  };
16
- children: import("react").ReactNode;
17
- className?: string;
18
- style?: React.CSSProperties;
16
+ className?: string | undefined;
17
+ children?: import("react").ReactNode | undefined;
18
+ role?: import("react").AriaRole | undefined;
19
+ onLoad?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
20
+ onError?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
21
+ defaultChecked?: boolean | undefined;
22
+ defaultValue?: string | number | readonly string[] | undefined;
23
+ suppressContentEditableWarning?: boolean | undefined;
24
+ suppressHydrationWarning?: boolean | undefined;
25
+ accessKey?: string | undefined;
26
+ autoFocus?: boolean | undefined;
27
+ contentEditable?: (boolean | "true" | "false") | "inherit" | "plaintext-only" | undefined;
28
+ contextMenu?: string | undefined;
29
+ dir?: string | undefined;
30
+ draggable?: (boolean | "true" | "false") | undefined;
31
+ hidden?: boolean | undefined;
32
+ id?: string | undefined;
33
+ lang?: string | undefined;
34
+ nonce?: string | undefined;
35
+ slot?: string | undefined;
36
+ spellCheck?: (boolean | "true" | "false") | undefined;
37
+ style?: import("react").CSSProperties | undefined;
38
+ tabIndex?: number | undefined;
39
+ title?: string | undefined;
40
+ translate?: "yes" | "no" | undefined;
41
+ radioGroup?: string | undefined;
42
+ about?: string | undefined;
43
+ content?: string | undefined;
44
+ datatype?: string | undefined;
45
+ inlist?: any;
46
+ prefix?: string | undefined;
47
+ property?: string | undefined;
48
+ rel?: string | undefined;
49
+ resource?: string | undefined;
50
+ rev?: string | undefined;
51
+ typeof?: string | undefined;
52
+ vocab?: string | undefined;
53
+ autoCapitalize?: string | undefined;
54
+ autoCorrect?: string | undefined;
55
+ autoSave?: string | undefined;
56
+ color?: string | undefined;
57
+ itemProp?: string | undefined;
58
+ itemScope?: boolean | undefined;
59
+ itemType?: string | undefined;
60
+ itemID?: string | undefined;
61
+ itemRef?: string | undefined;
62
+ results?: number | undefined;
63
+ security?: string | undefined;
64
+ unselectable?: "on" | "off" | undefined;
65
+ inputMode?: "none" | "text" | "tel" | "url" | "email" | "numeric" | "decimal" | "search" | undefined;
66
+ is?: string | undefined;
67
+ "aria-activedescendant"?: string | undefined;
68
+ "aria-atomic"?: (boolean | "true" | "false") | undefined;
69
+ "aria-autocomplete"?: "none" | "inline" | "list" | "both" | undefined;
70
+ "aria-braillelabel"?: string | undefined;
71
+ "aria-brailleroledescription"?: string | undefined;
72
+ "aria-busy"?: (boolean | "true" | "false") | undefined;
73
+ "aria-checked"?: boolean | "false" | "mixed" | "true" | undefined;
74
+ "aria-colcount"?: number | undefined;
75
+ "aria-colindex"?: number | undefined;
76
+ "aria-colindextext"?: string | undefined;
77
+ "aria-colspan"?: number | undefined;
78
+ "aria-controls"?: string | undefined;
79
+ "aria-current"?: boolean | "false" | "true" | "page" | "step" | "location" | "date" | "time" | undefined;
80
+ "aria-describedby"?: string | undefined;
81
+ "aria-description"?: string | undefined;
82
+ "aria-details"?: string | undefined;
83
+ "aria-disabled"?: (boolean | "true" | "false") | undefined;
84
+ "aria-dropeffect"?: "none" | "copy" | "execute" | "link" | "move" | "popup" | undefined;
85
+ "aria-errormessage"?: string | undefined;
86
+ "aria-expanded"?: (boolean | "true" | "false") | undefined;
87
+ "aria-flowto"?: string | undefined;
88
+ "aria-grabbed"?: (boolean | "true" | "false") | undefined;
89
+ "aria-haspopup"?: boolean | "false" | "true" | "menu" | "listbox" | "tree" | "grid" | "dialog" | undefined;
90
+ "aria-hidden"?: (boolean | "true" | "false") | undefined;
91
+ "aria-invalid"?: boolean | "false" | "true" | "grammar" | "spelling" | undefined;
92
+ "aria-keyshortcuts"?: string | undefined;
93
+ "aria-label"?: string | undefined;
94
+ "aria-labelledby"?: string | undefined;
95
+ "aria-level"?: number | undefined;
96
+ "aria-live"?: "off" | "assertive" | "polite" | undefined;
97
+ "aria-modal"?: (boolean | "true" | "false") | undefined;
98
+ "aria-multiline"?: (boolean | "true" | "false") | undefined;
99
+ "aria-multiselectable"?: (boolean | "true" | "false") | undefined;
100
+ "aria-orientation"?: "horizontal" | "vertical" | undefined;
101
+ "aria-owns"?: string | undefined;
102
+ "aria-placeholder"?: string | undefined;
103
+ "aria-posinset"?: number | undefined;
104
+ "aria-pressed"?: boolean | "false" | "mixed" | "true" | undefined;
105
+ "aria-readonly"?: (boolean | "true" | "false") | undefined;
106
+ "aria-relevant"?: "additions" | "additions removals" | "additions text" | "all" | "removals" | "removals additions" | "removals text" | "text" | "text additions" | "text removals" | undefined;
107
+ "aria-required"?: (boolean | "true" | "false") | undefined;
108
+ "aria-roledescription"?: string | undefined;
109
+ "aria-rowcount"?: number | undefined;
110
+ "aria-rowindex"?: number | undefined;
111
+ "aria-rowindextext"?: string | undefined;
112
+ "aria-rowspan"?: number | undefined;
113
+ "aria-selected"?: (boolean | "true" | "false") | undefined;
114
+ "aria-setsize"?: number | undefined;
115
+ "aria-sort"?: "none" | "ascending" | "descending" | "other" | undefined;
116
+ "aria-valuemax"?: number | undefined;
117
+ "aria-valuemin"?: number | undefined;
118
+ "aria-valuenow"?: number | undefined;
119
+ "aria-valuetext"?: string | undefined;
120
+ dangerouslySetInnerHTML?: {
121
+ __html: string | TrustedHTML;
122
+ } | undefined;
123
+ onCopy?: import("react").ClipboardEventHandler<HTMLFormElement> | undefined;
124
+ onCopyCapture?: import("react").ClipboardEventHandler<HTMLFormElement> | undefined;
125
+ onCut?: import("react").ClipboardEventHandler<HTMLFormElement> | undefined;
126
+ onCutCapture?: import("react").ClipboardEventHandler<HTMLFormElement> | undefined;
127
+ onPaste?: import("react").ClipboardEventHandler<HTMLFormElement> | undefined;
128
+ onPasteCapture?: import("react").ClipboardEventHandler<HTMLFormElement> | undefined;
129
+ onCompositionEnd?: import("react").CompositionEventHandler<HTMLFormElement> | undefined;
130
+ onCompositionEndCapture?: import("react").CompositionEventHandler<HTMLFormElement> | undefined;
131
+ onCompositionStart?: import("react").CompositionEventHandler<HTMLFormElement> | undefined;
132
+ onCompositionStartCapture?: import("react").CompositionEventHandler<HTMLFormElement> | undefined;
133
+ onCompositionUpdate?: import("react").CompositionEventHandler<HTMLFormElement> | undefined;
134
+ onCompositionUpdateCapture?: import("react").CompositionEventHandler<HTMLFormElement> | undefined;
135
+ onFocus?: import("react").FocusEventHandler<HTMLFormElement> | undefined;
136
+ onFocusCapture?: import("react").FocusEventHandler<HTMLFormElement> | undefined;
137
+ onBlur?: import("react").FocusEventHandler<HTMLFormElement> | undefined;
138
+ onBlurCapture?: import("react").FocusEventHandler<HTMLFormElement> | undefined;
139
+ onChange?: import("react").FormEventHandler<HTMLFormElement> | undefined;
140
+ onChangeCapture?: import("react").FormEventHandler<HTMLFormElement> | undefined;
141
+ onBeforeInput?: import("react").FormEventHandler<HTMLFormElement> | undefined;
142
+ onBeforeInputCapture?: import("react").FormEventHandler<HTMLFormElement> | undefined;
143
+ onInput?: import("react").FormEventHandler<HTMLFormElement> | undefined;
144
+ onInputCapture?: import("react").FormEventHandler<HTMLFormElement> | undefined;
145
+ onReset?: import("react").FormEventHandler<HTMLFormElement> | undefined;
146
+ onResetCapture?: import("react").FormEventHandler<HTMLFormElement> | undefined;
147
+ onSubmitCapture?: import("react").FormEventHandler<HTMLFormElement> | undefined;
148
+ onInvalid?: import("react").FormEventHandler<HTMLFormElement> | undefined;
149
+ onInvalidCapture?: import("react").FormEventHandler<HTMLFormElement> | undefined;
150
+ onLoadCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
151
+ onErrorCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
152
+ onKeyDown?: import("react").KeyboardEventHandler<HTMLFormElement> | undefined;
153
+ onKeyDownCapture?: import("react").KeyboardEventHandler<HTMLFormElement> | undefined;
154
+ onKeyPress?: import("react").KeyboardEventHandler<HTMLFormElement> | undefined;
155
+ onKeyPressCapture?: import("react").KeyboardEventHandler<HTMLFormElement> | undefined;
156
+ onKeyUp?: import("react").KeyboardEventHandler<HTMLFormElement> | undefined;
157
+ onKeyUpCapture?: import("react").KeyboardEventHandler<HTMLFormElement> | undefined;
158
+ onAbort?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
159
+ onAbortCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
160
+ onCanPlay?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
161
+ onCanPlayCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
162
+ onCanPlayThrough?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
163
+ onCanPlayThroughCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
164
+ onDurationChange?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
165
+ onDurationChangeCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
166
+ onEmptied?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
167
+ onEmptiedCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
168
+ onEncrypted?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
169
+ onEncryptedCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
170
+ onEnded?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
171
+ onEndedCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
172
+ onLoadedData?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
173
+ onLoadedDataCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
174
+ onLoadedMetadata?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
175
+ onLoadedMetadataCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
176
+ onLoadStart?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
177
+ onLoadStartCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
178
+ onPause?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
179
+ onPauseCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
180
+ onPlay?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
181
+ onPlayCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
182
+ onPlaying?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
183
+ onPlayingCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
184
+ onProgress?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
185
+ onProgressCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
186
+ onRateChange?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
187
+ onRateChangeCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
188
+ onResize?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
189
+ onResizeCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
190
+ onSeeked?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
191
+ onSeekedCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
192
+ onSeeking?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
193
+ onSeekingCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
194
+ onStalled?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
195
+ onStalledCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
196
+ onSuspend?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
197
+ onSuspendCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
198
+ onTimeUpdate?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
199
+ onTimeUpdateCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
200
+ onVolumeChange?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
201
+ onVolumeChangeCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
202
+ onWaiting?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
203
+ onWaitingCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
204
+ onAuxClick?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
205
+ onAuxClickCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
206
+ onClick?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
207
+ onClickCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
208
+ onContextMenu?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
209
+ onContextMenuCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
210
+ onDoubleClick?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
211
+ onDoubleClickCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
212
+ onDrag?: import("react").DragEventHandler<HTMLFormElement> | undefined;
213
+ onDragCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
214
+ onDragEnd?: import("react").DragEventHandler<HTMLFormElement> | undefined;
215
+ onDragEndCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
216
+ onDragEnter?: import("react").DragEventHandler<HTMLFormElement> | undefined;
217
+ onDragEnterCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
218
+ onDragExit?: import("react").DragEventHandler<HTMLFormElement> | undefined;
219
+ onDragExitCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
220
+ onDragLeave?: import("react").DragEventHandler<HTMLFormElement> | undefined;
221
+ onDragLeaveCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
222
+ onDragOver?: import("react").DragEventHandler<HTMLFormElement> | undefined;
223
+ onDragOverCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
224
+ onDragStart?: import("react").DragEventHandler<HTMLFormElement> | undefined;
225
+ onDragStartCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
226
+ onDrop?: import("react").DragEventHandler<HTMLFormElement> | undefined;
227
+ onDropCapture?: import("react").DragEventHandler<HTMLFormElement> | undefined;
228
+ onMouseDown?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
229
+ onMouseDownCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
230
+ onMouseEnter?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
231
+ onMouseLeave?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
232
+ onMouseMove?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
233
+ onMouseMoveCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
234
+ onMouseOut?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
235
+ onMouseOutCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
236
+ onMouseOver?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
237
+ onMouseOverCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
238
+ onMouseUp?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
239
+ onMouseUpCapture?: import("react").MouseEventHandler<HTMLFormElement> | undefined;
240
+ onSelect?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
241
+ onSelectCapture?: import("react").ReactEventHandler<HTMLFormElement> | undefined;
242
+ onTouchCancel?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
243
+ onTouchCancelCapture?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
244
+ onTouchEnd?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
245
+ onTouchEndCapture?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
246
+ onTouchMove?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
247
+ onTouchMoveCapture?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
248
+ onTouchStart?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
249
+ onTouchStartCapture?: import("react").TouchEventHandler<HTMLFormElement> | undefined;
250
+ onPointerDown?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
251
+ onPointerDownCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
252
+ onPointerMove?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
253
+ onPointerMoveCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
254
+ onPointerUp?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
255
+ onPointerUpCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
256
+ onPointerCancel?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
257
+ onPointerCancelCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
258
+ onPointerEnter?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
259
+ onPointerLeave?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
260
+ onPointerOver?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
261
+ onPointerOverCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
262
+ onPointerOut?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
263
+ onPointerOutCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
264
+ onGotPointerCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
265
+ onGotPointerCaptureCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
266
+ onLostPointerCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
267
+ onLostPointerCaptureCapture?: import("react").PointerEventHandler<HTMLFormElement> | undefined;
268
+ onScroll?: import("react").UIEventHandler<HTMLFormElement> | undefined;
269
+ onScrollCapture?: import("react").UIEventHandler<HTMLFormElement> | undefined;
270
+ onWheel?: import("react").WheelEventHandler<HTMLFormElement> | undefined;
271
+ onWheelCapture?: import("react").WheelEventHandler<HTMLFormElement> | undefined;
272
+ onAnimationStart?: import("react").AnimationEventHandler<HTMLFormElement> | undefined;
273
+ onAnimationStartCapture?: import("react").AnimationEventHandler<HTMLFormElement> | undefined;
274
+ onAnimationEnd?: import("react").AnimationEventHandler<HTMLFormElement> | undefined;
275
+ onAnimationEndCapture?: import("react").AnimationEventHandler<HTMLFormElement> | undefined;
276
+ onAnimationIteration?: import("react").AnimationEventHandler<HTMLFormElement> | undefined;
277
+ onAnimationIterationCapture?: import("react").AnimationEventHandler<HTMLFormElement> | undefined;
278
+ onTransitionEnd?: import("react").TransitionEventHandler<HTMLFormElement> | undefined;
279
+ onTransitionEndCapture?: import("react").TransitionEventHandler<HTMLFormElement> | undefined;
280
+ autoComplete?: string | undefined;
281
+ name?: string | undefined;
282
+ action?: string | undefined | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_EXPERIMENTAL_FORM_ACTIONS[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_EXPERIMENTAL_FORM_ACTIONS];
283
+ target?: string | undefined;
284
+ acceptCharset?: string | undefined;
285
+ encType?: string | undefined;
286
+ method?: string | undefined;
287
+ noValidate?: boolean | undefined;
19
288
  formRef?: React.Ref<HTMLFormElement>;
20
289
  };
21
290
  export default usePresenter;
@@ -1,4 +1,4 @@
1
- import type { ReactNode } from 'react';
1
+ import type { FormHTMLAttributes } from 'react';
2
2
  import type { FieldValues, UseFormProps } from 'react-hook-form';
3
3
  export type { FieldValue, FieldValidationFunction, AsyncFieldValidationFunction, } from '../../molecules/FormField/FormField.types';
4
4
  /**
@@ -8,11 +8,10 @@ export type FormSubmitHandler<TFormValues extends FieldValues = FieldValues> = (
8
8
  /**
9
9
  * Form component props
10
10
  */
11
- export type FormProps<TFormValues extends FieldValues = FieldValues> = {
12
- children: ReactNode;
11
+ export type FormProps<TFormValues extends FieldValues = FieldValues> = Omit<FormHTMLAttributes<HTMLFormElement>, 'onSubmit' | 'ref'> & {
13
12
  /** Initial form values (uncontrolled mode) */
14
13
  defaultValues?: UseFormProps<TFormValues>['defaultValues'];
15
- /** Form submission handler */
14
+ /** Form submission handler - receives typed form values */
16
15
  onSubmit?: FormSubmitHandler<TFormValues>;
17
16
  /** Enable autosave functionality */
18
17
  autosave?: boolean;
@@ -22,9 +21,7 @@ export type FormProps<TFormValues extends FieldValues = FieldValues> = {
22
21
  mode?: UseFormProps<TFormValues>['mode'];
23
22
  /** Additional RHF options */
24
23
  formOptions?: Omit<UseFormProps<TFormValues>, 'defaultValues' | 'mode'>;
25
- /** Form HTML attributes */
26
- className?: string;
27
- style?: React.CSSProperties;
24
+ /** Ref to the form element */
28
25
  formRef?: React.Ref<HTMLFormElement>;
29
26
  };
30
27
  /**