@saas-ui/forms 2.1.3 → 2.2.0
Sign up to get free protection for your applications and to get access to all the features.
- package/CHANGELOG.md +14 -0
- package/dist/index.d.ts +41 -29
- package/dist/index.js +64 -43
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +65 -48
- package/dist/index.mjs.map +1 -1
- package/dist/yup/index.d.ts +57 -41
- package/dist/yup/index.js.map +1 -1
- package/dist/yup/index.mjs.map +1 -1
- package/dist/zod/index.d.ts +58 -46
- package/dist/zod/index.js +17 -5
- package/dist/zod/index.js.map +1 -1
- package/dist/zod/index.mjs +17 -5
- package/dist/zod/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/create-field.tsx +7 -3
- package/src/default-fields.tsx +12 -4
- package/src/display-field.tsx +4 -3
- package/src/fields.tsx +7 -1
- package/src/index.ts +1 -0
- package/src/layout.tsx +2 -13
- package/src/number-input/number-input.tsx +14 -1
- package/src/types.ts +1 -1
- package/src/use-step-form.tsx +20 -4
package/CHANGELOG.md
CHANGED
@@ -1,5 +1,19 @@
|
|
1
1
|
# @saas-ui/forms
|
2
2
|
|
3
|
+
## 2.2.0
|
4
|
+
|
5
|
+
### Minor Changes
|
6
|
+
|
7
|
+
- 87fcdc2c: FormLayout no longer renders each child in a wrapper div
|
8
|
+
|
9
|
+
### Patch Changes
|
10
|
+
|
11
|
+
- 9ad407a7: Zod schema enum types now render a Select by default
|
12
|
+
- 654ad186: Fixed issue where Field would not infer correct onChange handler
|
13
|
+
- 87fcdc2c: Fixed issue where not all StepForm data would be passed to onSubmit
|
14
|
+
- 9ad407a7: ZodForm now infers defaultValues from the schema
|
15
|
+
- be52e785: Fixed issue where placeholder would not be passed to the NumberInputField
|
16
|
+
|
3
17
|
## 2.1.3
|
4
18
|
|
5
19
|
### Patch Changes
|
package/dist/index.d.ts
CHANGED
@@ -4,7 +4,7 @@ import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
4
4
|
import * as react_hook_form from 'react-hook-form';
|
5
5
|
import { FieldValues, FieldPath, UseFieldArrayReturn, RegisterOptions, UseFormReturn as UseFormReturn$1, UseFormProps, WatchObserver, SubmitHandler, SubmitErrorHandler, ResolverOptions, ResolverResult, FormProviderProps as FormProviderProps$1 } from 'react-hook-form';
|
6
6
|
export { BatchFieldArrayUpdate, ChangeHandler, Control, Controller, ControllerFieldState, ControllerProps, ControllerRenderProps, CriteriaMode, CustomElement, DeepMap, DeepPartial, DeepPartialSkipArrayKey, DefaultValues, DelayCallback, EmptyObject, ErrorOption, EventType, FieldArray, FieldArrayMethodProps, FieldArrayWithId, Field as FieldDef, FieldElement, FieldError, FieldErrors, FieldName, FieldNamesMarkedBoolean, FieldRefs, FieldValue, FieldValues, FormProviderProps, FormState, FormStateProxy, FormStateSubjectRef, GetIsDirty, InternalFieldErrors, InternalFieldName, InternalNameSet, IsAny, IsFlatObject, KeepStateOptions, LiteralUnion, Message, Mode, MultipleFieldErrors, Names, NativeFieldValue, NestedValue, NonUndefined, Noop, Primitive, ReadFormState, Ref, RefCallBack, RegisterOptions, Resolver, ResolverError, ResolverOptions, ResolverResult, ResolverSuccess, SetFieldValue, SetValueConfig, Subjects, SubmitErrorHandler, SubmitHandler, TriggerConfig, UnpackNestedValue, UseControllerProps, UseControllerReturn, UseFieldArrayProps, UseFieldArrayReturn, UseFormClearErrors, UseFormGetValues, UseFormHandleSubmit, UseFormProps, UseFormRegister, UseFormRegisterReturn, UseFormReset, UseFormResetField, UseFormReturn, UseFormSetError, UseFormSetFocus, UseFormSetValue, UseFormStateProps, UseFormStateReturn, UseFormTrigger, UseFormUnregister, UseFormWatch, UseWatchProps, Validate, ValidateResult, ValidationMode, ValidationRule, ValidationValue, ValidationValueMessage, WatchInternal, WatchObserver, appendErrors, useController, useFieldArray, useForm, useFormState, useWatch } from 'react-hook-form';
|
7
|
-
import { NumberInputProps as NumberInputProps$1, InputProps, RadioProps, RadioGroupProps, SystemProps, StackDirection, MenuProps, ThemingProps, ButtonProps, MenuListProps, MenuItemOptionProps, SelectProps as SelectProps$1, TextareaProps, SwitchProps, CheckboxProps, UsePinInputProps, ResponsiveValue, FormLabelProps, SimpleGridProps, FormControlProps, HTMLChakraProps } from '@chakra-ui/react';
|
7
|
+
import { NumberInputProps as NumberInputProps$1, NumberInputFieldProps as NumberInputFieldProps$1, InputProps, RadioProps, RadioGroupProps, SystemProps, StackDirection, MenuProps, ThemingProps, ButtonProps, MenuListProps, MenuItemOptionProps, SelectProps as SelectProps$1, TextareaProps, SwitchProps, CheckboxProps, UsePinInputProps, ResponsiveValue, FormLabelProps, SimpleGridProps, FormControlProps, HTMLChakraProps } from '@chakra-ui/react';
|
8
8
|
import { UseStepperReturn, UseStepperProps, StepsProps, StepsItemProps } from '@saas-ui/core';
|
9
9
|
import { FocusableElement } from '@chakra-ui/utils';
|
10
10
|
import { MaybeRenderProp } from '@chakra-ui/react-utils';
|
@@ -23,6 +23,14 @@ interface NumberInputOptions {
|
|
23
23
|
* Render a custom decrement icon.
|
24
24
|
*/
|
25
25
|
decrementIcon?: React$1.ReactNode;
|
26
|
+
/**
|
27
|
+
* The placeholder text when no value is selected.
|
28
|
+
*/
|
29
|
+
placeholder?: string;
|
30
|
+
/**
|
31
|
+
* Props to pass to the NumberInputField component.
|
32
|
+
*/
|
33
|
+
fieldProps?: NumberInputFieldProps$1;
|
26
34
|
}
|
27
35
|
interface NumberInputProps extends NumberInputProps$1, NumberInputOptions {
|
28
36
|
}
|
@@ -140,38 +148,42 @@ interface InputFieldProps extends InputProps {
|
|
140
148
|
leftAddon?: React$1.ReactNode;
|
141
149
|
rightAddon?: React$1.ReactNode;
|
142
150
|
}
|
143
|
-
declare const InputField: React$1.FC<
|
151
|
+
declare const InputField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof InputFieldProps> & InputFieldProps>;
|
144
152
|
interface NumberInputFieldProps extends NumberInputProps {
|
145
153
|
type: 'number';
|
146
154
|
}
|
147
|
-
declare const NumberInputField: React$1.FC<
|
148
|
-
declare const PasswordInputField: React$1.FC<
|
149
|
-
declare const TextareaField: React$1.FC<
|
150
|
-
declare const SwitchField: React$1.FC<
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
+
declare const NumberInputField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof NumberInputFieldProps> & NumberInputFieldProps>;
|
156
|
+
declare const PasswordInputField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof PasswordInputProps> & PasswordInputProps>;
|
157
|
+
declare const TextareaField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof TextareaProps> & TextareaProps>;
|
158
|
+
declare const SwitchField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof SwitchProps> & SwitchProps>;
|
159
|
+
interface SelectFieldProps extends SelectProps {
|
160
|
+
buttonProps?: SelectButtonProps;
|
161
|
+
listProps?: SelectListProps;
|
162
|
+
}
|
163
|
+
declare const SelectField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof SelectFieldProps> & SelectFieldProps>;
|
164
|
+
declare const CheckboxField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof CheckboxProps> & CheckboxProps>;
|
165
|
+
declare const RadioField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof RadioInputProps> & RadioInputProps>;
|
166
|
+
declare const NativeSelectField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof NativeSelectProps> & NativeSelectProps>;
|
155
167
|
interface PinFieldProps extends Omit<UsePinInputProps, 'type'> {
|
156
168
|
pinLength?: number;
|
157
169
|
pinType?: 'alphanumeric' | 'number';
|
158
170
|
spacing?: SystemProps['margin'];
|
159
171
|
}
|
160
|
-
declare const PinField: React$1.FC<
|
172
|
+
declare const PinField: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof PinFieldProps> & PinFieldProps>;
|
161
173
|
declare const defaultFieldTypes: {
|
162
|
-
text: React$1.FC<
|
163
|
-
email: React$1.FC<
|
164
|
-
url: React$1.FC<
|
165
|
-
phone: React$1.FC<
|
166
|
-
number: React$1.FC<
|
167
|
-
password: React$1.FC<
|
168
|
-
textarea: React$1.FC<
|
169
|
-
switch: React$1.FC<
|
170
|
-
select: React$1.FC<
|
171
|
-
checkbox: React$1.FC<
|
172
|
-
radio: React$1.FC<
|
173
|
-
pin: React$1.FC<
|
174
|
-
'native-select': React$1.FC<
|
174
|
+
text: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof InputFieldProps> & InputFieldProps>;
|
175
|
+
email: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof InputFieldProps> & InputFieldProps>;
|
176
|
+
url: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof InputFieldProps> & InputFieldProps>;
|
177
|
+
phone: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof InputFieldProps> & InputFieldProps>;
|
178
|
+
number: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof NumberInputFieldProps> & NumberInputFieldProps>;
|
179
|
+
password: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof PasswordInputProps> & PasswordInputProps>;
|
180
|
+
textarea: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof TextareaProps> & TextareaProps>;
|
181
|
+
switch: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof SwitchProps> & SwitchProps>;
|
182
|
+
select: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof SelectFieldProps> & SelectFieldProps>;
|
183
|
+
checkbox: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof CheckboxProps> & CheckboxProps>;
|
184
|
+
radio: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof RadioInputProps> & RadioInputProps>;
|
185
|
+
pin: React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof PinFieldProps> & PinFieldProps>;
|
186
|
+
'native-select': React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof NativeSelectProps> & NativeSelectProps>;
|
175
187
|
};
|
176
188
|
type DefaultFields = typeof defaultFieldTypes;
|
177
189
|
|
@@ -432,7 +444,7 @@ type Split<S extends string, D extends string> = string extends S ? string[] : S
|
|
432
444
|
type MapPath<T extends string[]> = T extends [infer U, ...infer R] ? U extends string ? `${U extends `${number}` ? '$' : U}${R[0] extends string ? '.' : ''}${R extends string[] ? MapPath<R> : ''}` : '' : '';
|
433
445
|
type TransformPath<T extends string> = MapPath<Split<T, '.'>>;
|
434
446
|
type ArrayFieldPath<Name extends string> = Name extends string ? TransformPath<Name> : never;
|
435
|
-
interface BaseFieldProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> extends Omit<FormControlProps, 'label' | 'type'> {
|
447
|
+
interface BaseFieldProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> extends Omit<FormControlProps, 'label' | 'type' | 'onChange'> {
|
436
448
|
/**
|
437
449
|
* The field name
|
438
450
|
*/
|
@@ -728,10 +740,10 @@ type FormType<FieldDefs, ExtraProps = object, ExtraOverrides = object> = (<TSche
|
|
728
740
|
};
|
729
741
|
declare function createForm<FieldDefs>({ resolver, fieldResolver, fields, }?: CreateFormProps<FieldDefs>): FormType<FieldDefs, object, object>;
|
730
742
|
|
731
|
-
interface DisplayFieldProps extends FormControlProps, Omit<FieldProps, 'type' | 'label'> {
|
743
|
+
interface DisplayFieldProps extends Omit<FormControlProps, 'onChange'>, Omit<FieldProps, 'type' | 'label' | 'onChange'> {
|
732
744
|
}
|
733
745
|
/**
|
734
|
-
*
|
746
|
+
* Display a field value.
|
735
747
|
*
|
736
748
|
* @see Docs https://saas-ui.dev/
|
737
749
|
*/
|
@@ -838,7 +850,7 @@ interface CreateFieldOptions {
|
|
838
850
|
* @param options.isControlled Set this to true if this is a controlled field.
|
839
851
|
* @param options.hideLabel Hide the field label, for example for the checkbox field.
|
840
852
|
*/
|
841
|
-
declare const createField: <TProps extends object>(component: React$1.FC<TProps>, options?: CreateFieldOptions) => React$1.FC<
|
853
|
+
declare const createField: <TProps extends object>(component: React$1.FC<TProps>, options?: CreateFieldOptions) => React$1.FC<Omit<BaseFieldProps<react_hook_form.FieldValues, string>, keyof TProps> & TProps>;
|
842
854
|
|
843
855
|
/**
|
844
856
|
* Form component.
|
@@ -854,4 +866,4 @@ declare const Form: FormType<unknown, object, object>;
|
|
854
866
|
*/
|
855
867
|
declare const StepForm: StepFormType<unknown, object, object>;
|
856
868
|
|
857
|
-
export { ArrayField, ArrayFieldAddButton, ArrayFieldButtonProps, ArrayFieldContainer, ArrayFieldContainerProps, ArrayFieldOptions, ArrayFieldProps, ArrayFieldProvider, ArrayFieldRemoveButton, ArrayFieldRow, ArrayFieldRowContainer, ArrayFieldRowFields, ArrayFieldRowFieldsProps, ArrayFieldRowProvider, ArrayFieldRows, ArrayFieldRowsProps, AutoFields, BaseField, BaseFieldProps, Form$1 as BaseForm, CheckboxField, CreateFieldOptions, CreateFormProps, CreateStepFormProps, DefaultFieldOverrides, DefaultFields, DisplayField, DisplayFieldProps, DisplayIf, DisplayIfProps, Field, FieldOptions, FieldProps, FieldResolver, FieldRules, FieldsProps, FieldsProvider, Form, FormComponent, FormLayout, FormLayoutProps, FormLegend, FormProps, FormProvider, FormRenderContext, FormStep, FormStepOptions, FormStepProps, FormStepSubmitHandler, FormStepper, FormStepperProps, FormType, FormValue, GetFieldResolver, InputField, InputFieldProps, InputRightButton, InputRightButtonProps, NativeSelect, NativeSelectField, NativeSelectProps, NextButton, NextButtonProps, NumberInputField, NumberInputFieldProps, ObjectField, ObjectFieldProps, ObjectSchema, Option, PasswordInput, PasswordInputField, PasswordInputProps, PinField, PinFieldProps, PrevButton, RadioField, RadioInput, RadioInputProps, RadioOption, RadioOptions, Select, SelectButton, SelectButtonProps, SelectField, SelectList, SelectListProps, SelectOption, SelectProps, StepForm, StepFormContext, StepFormProps, StepFormProvider, StepFormRenderContext, StepState, StepsOptions, SubmitButton, SubmitButtonProps, SwitchField, TextareaField, UseArrayFieldReturn, UseArrayFieldRowProps, UseArrayFieldRowReturn, UseFormStepProps, UseStepFormProps, UseStepFormReturn, WatchField, WatchFieldProps, WithFields, WithStepFields, createField, createForm, createStepForm, defaultFieldTypes, objectFieldResolver, useArrayField, useArrayFieldAddButton, useArrayFieldContext, useArrayFieldRemoveButton, useArrayFieldRow, useArrayFieldRowContext, useField, useFormContext, useFormStep, useStepForm, useStepFormContext };
|
869
|
+
export { ArrayField, ArrayFieldAddButton, ArrayFieldButtonProps, ArrayFieldContainer, ArrayFieldContainerProps, ArrayFieldOptions, ArrayFieldProps, ArrayFieldProvider, ArrayFieldRemoveButton, ArrayFieldRow, ArrayFieldRowContainer, ArrayFieldRowFields, ArrayFieldRowFieldsProps, ArrayFieldRowProvider, ArrayFieldRows, ArrayFieldRowsProps, AutoFields, BaseField, BaseFieldProps, Form$1 as BaseForm, CheckboxField, CreateFieldOptions, CreateFormProps, CreateStepFormProps, DefaultFieldOverrides, DefaultFields, DisplayField, DisplayFieldProps, DisplayIf, DisplayIfProps, Field, FieldOptions, FieldProps, FieldResolver, FieldRules, FieldsProps, FieldsProvider, Form, FormComponent, FormLayout, FormLayoutProps, FormLegend, FormProps, FormProvider, FormRenderContext, FormStep, FormStepOptions, FormStepProps, FormStepSubmitHandler, FormStepper, FormStepperProps, FormType, FormValue, GetFieldResolver, InputField, InputFieldProps, InputRightButton, InputRightButtonProps, NativeSelect, NativeSelectField, NativeSelectProps, NextButton, NextButtonProps, NumberInputField, NumberInputFieldProps, ObjectField, ObjectFieldProps, ObjectSchema, Option, PasswordInput, PasswordInputField, PasswordInputProps, PinField, PinFieldProps, PrevButton, RadioField, RadioInput, RadioInputProps, RadioOption, RadioOptions, Select, SelectButton, SelectButtonProps, SelectField, SelectFieldProps, SelectList, SelectListProps, SelectOption, SelectProps, StepForm, StepFormContext, StepFormProps, StepFormProvider, StepFormRenderContext, StepState, StepsOptions, SubmitButton, SubmitButtonProps, SwitchField, TextareaField, UseArrayFieldReturn, UseArrayFieldRowProps, UseArrayFieldRowReturn, UseFormStepProps, UseStepFormProps, UseStepFormReturn, WatchField, WatchFieldProps, WithFields, WithStepFields, createField, createForm, createStepForm, defaultFieldTypes, objectFieldResolver, useArrayField, useArrayFieldAddButton, useArrayFieldContext, useArrayFieldRemoveButton, useArrayFieldRow, useArrayFieldRowContext, useField, useFormContext, useFormStep, useStepForm, useStepFormContext };
|
package/dist/index.js
CHANGED
@@ -172,10 +172,13 @@ var NumberInput = (0, import_react2.forwardRef)((props, ref) => {
|
|
172
172
|
hideStepper,
|
173
173
|
incrementIcon = /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_core.ChevronUpIcon, {}),
|
174
174
|
decrementIcon = /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_core.ChevronDownIcon, {}),
|
175
|
+
placeholder,
|
176
|
+
fieldProps: _fieldProps,
|
175
177
|
...rest
|
176
178
|
} = props;
|
179
|
+
const fieldProps = { placeholder, ..._fieldProps };
|
177
180
|
return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(import_react2.NumberInput, { ...rest, ref, children: [
|
178
|
-
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react2.NumberInputField, {}),
|
181
|
+
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react2.NumberInputField, { ...fieldProps }),
|
179
182
|
!hideStepper && /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(import_react2.NumberInputStepper, { children: [
|
180
183
|
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react2.NumberIncrementStepper, { children: incrementIcon }),
|
181
184
|
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react2.NumberDecrementStepper, { children: decrementIcon })
|
@@ -601,6 +604,7 @@ var withControlledInput = (InputComponent) => {
|
|
601
604
|
return (0, import_react12.forwardRef)(
|
602
605
|
({ name, rules, ...inputProps }, ref) => {
|
603
606
|
const { control } = useFormContext();
|
607
|
+
const onChange = inputProps.onChange;
|
604
608
|
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
|
605
609
|
import_react_hook_form3.Controller,
|
606
610
|
{
|
@@ -612,7 +616,7 @@ var withControlledInput = (InputComponent) => {
|
|
612
616
|
{
|
613
617
|
...field,
|
614
618
|
...inputProps,
|
615
|
-
onChange: (0, import_utils4.callAllHandlers)(
|
619
|
+
onChange: (0, import_utils4.callAllHandlers)(onChange, field.onChange),
|
616
620
|
onBlur: (0, import_utils4.callAllHandlers)(inputProps.onBlur, field.onBlur),
|
617
621
|
ref: (0, import_react12.useMergeRefs)(ref, _ref)
|
618
622
|
}
|
@@ -627,12 +631,13 @@ var withUncontrolledInput = (InputComponent) => {
|
|
627
631
|
({ name, rules, ...inputProps }, ref) => {
|
628
632
|
const { register } = useFormContext();
|
629
633
|
const { ref: _ref, ...field } = register(name, rules);
|
634
|
+
const onChange = inputProps.onChange;
|
630
635
|
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
|
631
636
|
InputComponent,
|
632
637
|
{
|
633
638
|
...field,
|
634
639
|
...inputProps,
|
635
|
-
onChange: (0, import_utils4.callAllHandlers)(
|
640
|
+
onChange: (0, import_utils4.callAllHandlers)(onChange, field.onChange),
|
636
641
|
onBlur: (0, import_utils4.callAllHandlers)(inputProps.onBlur, field.onBlur),
|
637
642
|
ref: (0, import_react12.useMergeRefs)(ref, _ref)
|
638
643
|
}
|
@@ -691,9 +696,10 @@ var SwitchField = createField(
|
|
691
696
|
);
|
692
697
|
var SelectField = createField(
|
693
698
|
(0, import_react13.forwardRef)((props, ref) => {
|
694
|
-
|
695
|
-
|
696
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)(
|
699
|
+
const { buttonProps, listProps, ...rest } = props;
|
700
|
+
return /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(Select, { ref, ...rest, children: [
|
701
|
+
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)(SelectButton, { ...buttonProps }),
|
702
|
+
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)(SelectList, { ...listProps })
|
697
703
|
] });
|
698
704
|
}),
|
699
705
|
{
|
@@ -770,10 +776,9 @@ var Field = React6.forwardRef(
|
|
770
776
|
);
|
771
777
|
|
772
778
|
// src/fields.tsx
|
773
|
-
var
|
779
|
+
var React9 = __toESM(require("react"));
|
774
780
|
|
775
781
|
// src/layout.tsx
|
776
|
-
var React7 = __toESM(require("react"));
|
777
782
|
var import_react15 = require("@chakra-ui/react");
|
778
783
|
var import_utils5 = require("@chakra-ui/utils");
|
779
784
|
var import_jsx_runtime14 = require("react/jsx-runtime");
|
@@ -796,24 +801,19 @@ var FormLayout = ({ children, ...props }) => {
|
|
796
801
|
{
|
797
802
|
...gridProps,
|
798
803
|
className: (0, import_utils5.cx)("sui-form__layout", props.className),
|
799
|
-
children
|
800
|
-
if (React7.isValidElement(child)) {
|
801
|
-
return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(FormLayoutItem, { children: child });
|
802
|
-
}
|
803
|
-
return child;
|
804
|
-
})
|
804
|
+
children
|
805
805
|
}
|
806
806
|
);
|
807
807
|
};
|
808
808
|
FormLayout.displayName = "FormLayout";
|
809
809
|
|
810
810
|
// src/array-field.tsx
|
811
|
-
var
|
811
|
+
var React8 = __toESM(require("react"));
|
812
812
|
var import_react16 = require("@chakra-ui/react");
|
813
813
|
var import_icons2 = require("@saas-ui/core/icons");
|
814
814
|
|
815
815
|
// src/use-array-field.tsx
|
816
|
-
var
|
816
|
+
var React7 = __toESM(require("react"));
|
817
817
|
var import_react_hook_form4 = require("react-hook-form");
|
818
818
|
var import_react_utils2 = require("@chakra-ui/react-utils");
|
819
819
|
var [ArrayFieldProvider, useArrayFieldContext] = (0, import_react_utils2.createContext)({
|
@@ -846,7 +846,7 @@ var useArrayField = ({
|
|
846
846
|
var useArrayFieldRow = ({ index }) => {
|
847
847
|
const { clearErrors } = useFormContext();
|
848
848
|
const { name, remove, fields } = useArrayFieldContext();
|
849
|
-
|
849
|
+
React7.useEffect(() => {
|
850
850
|
clearErrors(name);
|
851
851
|
}, []);
|
852
852
|
return {
|
@@ -854,7 +854,7 @@ var useArrayFieldRow = ({ index }) => {
|
|
854
854
|
isFirst: index === 0,
|
855
855
|
isLast: index === fields.length - 1,
|
856
856
|
name: `${name}.${index}`,
|
857
|
-
remove:
|
857
|
+
remove: React7.useCallback(() => {
|
858
858
|
clearErrors(name);
|
859
859
|
remove(index);
|
860
860
|
}, [index])
|
@@ -953,7 +953,7 @@ var ArrayFieldRows = ({
|
|
953
953
|
return children(fields);
|
954
954
|
};
|
955
955
|
ArrayFieldRows.displayName = "ArrayFieldRows";
|
956
|
-
var ArrayFieldContainer =
|
956
|
+
var ArrayFieldContainer = React8.forwardRef(
|
957
957
|
({
|
958
958
|
name,
|
959
959
|
defaultValue,
|
@@ -971,7 +971,7 @@ var ArrayFieldContainer = React9.forwardRef(
|
|
971
971
|
min: min || (overrides == null ? void 0 : overrides.min),
|
972
972
|
max: max || (overrides == null ? void 0 : overrides.max)
|
973
973
|
});
|
974
|
-
|
974
|
+
React8.useImperativeHandle(ref, () => context, [ref, context]);
|
975
975
|
return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(ArrayFieldProvider, { value: context, children: /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(BaseField, { name, ...fieldProps, ...overrides, children }) });
|
976
976
|
}
|
977
977
|
);
|
@@ -1036,10 +1036,10 @@ var AutoFields = ({
|
|
1036
1036
|
const context = useFormContext();
|
1037
1037
|
const schema = schemaProp || context.schema;
|
1038
1038
|
const fieldResolver = fieldResolverProp || context.fieldResolver;
|
1039
|
-
const resolver =
|
1040
|
-
const fields =
|
1039
|
+
const resolver = React9.useMemo(() => fieldResolver, [schema, fieldResolver]);
|
1040
|
+
const fields = React9.useMemo(() => resolver == null ? void 0 : resolver.getFields(), [resolver]);
|
1041
1041
|
const form = useFormContext();
|
1042
|
-
|
1042
|
+
React9.useEffect(() => {
|
1043
1043
|
var _a;
|
1044
1044
|
if (focusFirstField && ((_a = fields == null ? void 0 : fields[0]) == null ? void 0 : _a.name)) {
|
1045
1045
|
form.setFocus(fields[0].name);
|
@@ -1060,7 +1060,16 @@ var AutoFields = ({
|
|
1060
1060
|
} else if (type === "object") {
|
1061
1061
|
return /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(ObjectField, { name, ...fieldProps, children: mapNestedFields2(resolver, name) }, name);
|
1062
1062
|
}
|
1063
|
-
return /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
|
1063
|
+
return /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
|
1064
|
+
Field,
|
1065
|
+
{
|
1066
|
+
name,
|
1067
|
+
type,
|
1068
|
+
defaultValue,
|
1069
|
+
...fieldProps
|
1070
|
+
},
|
1071
|
+
name
|
1072
|
+
);
|
1064
1073
|
}
|
1065
1074
|
) });
|
1066
1075
|
};
|
@@ -1124,13 +1133,13 @@ var DisplayIf = ({
|
|
1124
1133
|
DisplayIf.displayName = "DisplayIf";
|
1125
1134
|
|
1126
1135
|
// src/step-form.tsx
|
1127
|
-
var
|
1136
|
+
var React11 = __toESM(require("react"));
|
1128
1137
|
var import_react19 = require("@chakra-ui/react");
|
1129
1138
|
var import_utils9 = require("@chakra-ui/utils");
|
1130
1139
|
var import_core4 = require("@saas-ui/core");
|
1131
1140
|
|
1132
1141
|
// src/use-step-form.tsx
|
1133
|
-
var
|
1142
|
+
var React10 = __toESM(require("react"));
|
1134
1143
|
var import_react_utils3 = require("@chakra-ui/react-utils");
|
1135
1144
|
var import_core3 = require("@saas-ui/core");
|
1136
1145
|
var [StepFormProvider, useStepFormContext] = (0, import_react_utils3.createContext)({
|
@@ -1138,18 +1147,29 @@ var [StepFormProvider, useStepFormContext] = (0, import_react_utils3.createConte
|
|
1138
1147
|
errorMessage: "useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`"
|
1139
1148
|
});
|
1140
1149
|
function useStepForm(props) {
|
1141
|
-
const {
|
1150
|
+
const {
|
1151
|
+
onChange,
|
1152
|
+
steps: stepsOptions,
|
1153
|
+
resolver,
|
1154
|
+
fieldResolver,
|
1155
|
+
...rest
|
1156
|
+
} = props;
|
1142
1157
|
const stepper = (0, import_core3.useStepper)(rest);
|
1143
|
-
const [options, setOptions] =
|
1158
|
+
const [options, setOptions] = React10.useState(stepsOptions);
|
1144
1159
|
const { activeStep, isLastStep, nextStep } = stepper;
|
1145
|
-
const [steps, updateSteps] =
|
1146
|
-
const
|
1160
|
+
const [steps, updateSteps] = React10.useState({});
|
1161
|
+
const mergedData = React10.useRef({});
|
1162
|
+
const onSubmitStep = React10.useCallback(
|
1147
1163
|
async (data) => {
|
1148
1164
|
var _a, _b;
|
1149
1165
|
try {
|
1150
1166
|
const step = steps[activeStep];
|
1167
|
+
mergedData.current = {
|
1168
|
+
...mergedData.current,
|
1169
|
+
...data
|
1170
|
+
};
|
1151
1171
|
if (isLastStep) {
|
1152
|
-
await ((_a = props.onSubmit) == null ? void 0 : _a.call(props,
|
1172
|
+
await ((_a = props.onSubmit) == null ? void 0 : _a.call(props, mergedData.current));
|
1153
1173
|
updateStep({
|
1154
1174
|
...step,
|
1155
1175
|
isCompleted: true
|
@@ -1162,9 +1182,9 @@ function useStepForm(props) {
|
|
1162
1182
|
} catch (e) {
|
1163
1183
|
}
|
1164
1184
|
},
|
1165
|
-
[steps, activeStep, isLastStep]
|
1185
|
+
[steps, activeStep, isLastStep, mergedData]
|
1166
1186
|
);
|
1167
|
-
const getFormProps =
|
1187
|
+
const getFormProps = React10.useCallback(() => {
|
1168
1188
|
const step = steps[activeStep];
|
1169
1189
|
return {
|
1170
1190
|
onSubmit: onSubmitStep,
|
@@ -1172,10 +1192,11 @@ function useStepForm(props) {
|
|
1172
1192
|
resolver: (step == null ? void 0 : step.schema) ? (
|
1173
1193
|
/* @todo fix resolver type */
|
1174
1194
|
resolver == null ? void 0 : resolver(step.schema)
|
1175
|
-
) : void 0
|
1195
|
+
) : void 0,
|
1196
|
+
fieldResolver: (step == null ? void 0 : step.schema) ? fieldResolver == null ? void 0 : fieldResolver(step.schema) : void 0
|
1176
1197
|
};
|
1177
|
-
}, [steps, onSubmitStep, activeStep]);
|
1178
|
-
const updateStep =
|
1198
|
+
}, [steps, onSubmitStep, activeStep, resolver, fieldResolver]);
|
1199
|
+
const updateStep = React10.useCallback(
|
1179
1200
|
(step) => {
|
1180
1201
|
const stepOptions = options == null ? void 0 : options.find((s) => s.name === step.name);
|
1181
1202
|
updateSteps((steps2) => {
|
@@ -1201,7 +1222,7 @@ function useFormStep(props) {
|
|
1201
1222
|
const { name, schema, resolver, onSubmit } = props;
|
1202
1223
|
const step = (0, import_core3.useStep)({ name });
|
1203
1224
|
const { steps, updateStep } = useStepFormContext();
|
1204
|
-
|
1225
|
+
React10.useEffect(() => {
|
1205
1226
|
updateStep({ name, schema, resolver, onSubmit });
|
1206
1227
|
}, [name, schema]);
|
1207
1228
|
return {
|
@@ -1224,8 +1245,8 @@ var FormStepper = (props) => {
|
|
1224
1245
|
render,
|
1225
1246
|
...rest
|
1226
1247
|
} = props;
|
1227
|
-
const elements =
|
1228
|
-
if (
|
1248
|
+
const elements = React11.Children.map(children, (child) => {
|
1249
|
+
if (React11.isValidElement(child) && (child == null ? void 0 : child.type) === FormStep) {
|
1229
1250
|
const { isCompleted } = useFormStep(child.props);
|
1230
1251
|
return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
|
1231
1252
|
import_core4.StepsItem,
|
@@ -1241,7 +1262,7 @@ var FormStepper = (props) => {
|
|
1241
1262
|
}
|
1242
1263
|
return child;
|
1243
1264
|
});
|
1244
|
-
const onChange =
|
1265
|
+
const onChange = React11.useCallback((i) => {
|
1245
1266
|
setIndex(i);
|
1246
1267
|
onChangeProp == null ? void 0 : onChangeProp(i);
|
1247
1268
|
}, []);
|
@@ -1338,7 +1359,7 @@ var WatchField = (props) => {
|
|
1338
1359
|
};
|
1339
1360
|
|
1340
1361
|
// src/form.tsx
|
1341
|
-
var
|
1362
|
+
var React12 = __toESM(require("react"));
|
1342
1363
|
var import_react20 = require("@chakra-ui/react");
|
1343
1364
|
var import_utils11 = require("@chakra-ui/utils");
|
1344
1365
|
var import_react_hook_form8 = require("react-hook-form");
|
@@ -1384,8 +1405,8 @@ var Form = (0, import_react20.forwardRef)(
|
|
1384
1405
|
};
|
1385
1406
|
const methods = (0, import_react_hook_form8.useForm)(form);
|
1386
1407
|
const { handleSubmit } = methods;
|
1387
|
-
|
1388
|
-
|
1408
|
+
React12.useImperativeHandle(formRef, () => methods, [formRef, methods]);
|
1409
|
+
React12.useEffect(() => {
|
1389
1410
|
let subscription;
|
1390
1411
|
if (onChange) {
|
1391
1412
|
subscription = methods.watch(onChange);
|