@saas-ui/forms 1.2.2 → 1.3.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,6 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { FieldValues, UseFormReturn } from 'react-hook-form';
3
- export interface DisplayIfProps<TFieldValues> {
3
+ export interface DisplayIfProps<TFieldValues extends FieldValues = FieldValues> {
4
4
  children: React.ReactElement;
5
5
  name: string;
6
6
  defaultValue?: unknown;
@@ -1 +1 @@
1
- {"version":3,"file":"display-if.d.ts","sourceRoot":"","sources":["../src/display-if.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAGL,WAAW,EACX,aAAa,EACd,MAAM,iBAAiB,CAAA;AAExB,MAAM,WAAW,cAAc,CAAC,YAAY;IAC1C,QAAQ,EAAE,KAAK,CAAC,YAAY,CAAA;IAC5B,IAAI,EAAE,MAAM,CAAA;IACZ,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,CAAC,YAAY,CAAC,KAAK,OAAO,CAAA;CAC9E;AAED,eAAO,MAAM,SAAS;;;CAgBrB,CAAA"}
1
+ {"version":3,"file":"display-if.d.ts","sourceRoot":"","sources":["../src/display-if.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAGL,WAAW,EACX,aAAa,EACd,MAAM,iBAAiB,CAAA;AAExB,MAAM,WAAW,cAAc,CAC7B,YAAY,SAAS,WAAW,GAAG,WAAW;IAE9C,QAAQ,EAAE,KAAK,CAAC,YAAY,CAAA;IAC5B,IAAI,EAAE,MAAM,CAAA;IACZ,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,CAAC,YAAY,CAAC,KAAK,OAAO,CAAA;CAC9E;AAED,eAAO,MAAM,SAAS;;;CAgBrB,CAAA"}
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/display-field.tsx","../src/field.tsx","../src/field-resolver.ts","../src/form.tsx","../src/layout.tsx","../src/utils.ts","../src/use-array-field.tsx","../src/array-field.tsx","../src/object-field.tsx","../src/fields.tsx","../src/submit-button.tsx","../src/auto-form.tsx","../src/display-if.tsx","../src/use-step-form.tsx","../src/step-form.tsx","../src/watch-field.tsx"],"sourcesContent":["import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { useFormContext } from 'react-hook-form'\n\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './field'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n\nexport const DisplayField: React.FC<DisplayFieldProps> = ({\n name,\n label,\n placeholder,\n ...props\n}) => {\n return (\n <FormControl {...props}>\n {label ? <FormLabel htmlFor={name}>{label}</FormLabel> : null}\n <Text fontSize=\"md\">\n <FormValue name={name} />\n </Text>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n DisplayField.displayName = 'DisplayField'\n}\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nif (__DEV__) {\n FormValue.displayName = 'FormValue'\n}\n","import * as React from 'react'\nimport {\n useFormContext,\n FormState,\n Controller,\n get,\n RegisterOptions,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport {\n forwardRef,\n Box,\n FormControl,\n FormControlProps,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n Input,\n Textarea,\n Checkbox,\n Switch,\n useMergeRefs,\n InputGroup,\n InputProps,\n TextareaProps,\n SwitchProps,\n CheckboxProps,\n PinInputField,\n HStack,\n PinInput,\n UsePinInputProps,\n SystemProps,\n} from '@chakra-ui/react'\nimport { __DEV__, FocusableElement, callAllHandlers } from '@chakra-ui/utils'\n\nimport { NumberInput, NumberInputProps } from '@saas-ui/number-input'\nimport { PasswordInput, PasswordInputProps } from '@saas-ui/password-input'\nimport { RadioInput, RadioInputProps } from '@saas-ui/radio'\n\nimport {\n Select,\n SelectProps,\n NativeSelect,\n NativeSelectProps,\n} from '@saas-ui/select'\n\nexport interface Option {\n value: string\n label?: string\n [key: string]: unknown\n}\n\nexport type FieldRules = Pick<\n RegisterOptions,\n 'required' | 'min' | 'max' | 'maxLength' | 'minLength' | 'pattern'\n>\n\nexport interface FieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends Omit<FormControlProps, 'label' | 'type'> {\n /**\n * The field name\n */\n name: TName\n /**\n * The field label\n */\n label?: string\n /**\n * Hide the field label\n */\n hideLabel?: boolean\n /**\n * Field help text\n */\n help?: string\n /**\n * React hook form rules\n */\n rules?: Omit<\n RegisterOptions<TFieldValues, TName>,\n 'valueAsNumber' | 'valueAsDate' | 'setValueAs' | 'disabled'\n >\n /**\n * Build-in types:\n * - text\n * - number\n * - password\n * - textarea\n * - select\n * - native-select\n * - checkbox\n * - radio\n * - switch\n * - pin\n *\n * Will default to a text field if there is no matching type.\n */\n type?: string\n /**\n * The input placeholder\n */\n placeholder?: string\n}\n\nconst inputTypes: Record<string, React.FC<any>> = {}\n\nconst defaultInputType = 'text'\n\nconst getInput = (type: string) => {\n return inputTypes[type] || inputTypes[defaultInputType]\n}\n\nconst getError = (name: string, formState: FormState<{ [x: string]: any }>) => {\n return get(formState.errors, name)\n}\n\nconst isTouched = (\n name: string,\n formState: FormState<{ [x: string]: any }>\n) => {\n return get(formState.touchedFields, name)\n}\n\nexport const BaseField: React.FC<FieldProps> = (props) => {\n const { name, label, help, hideLabel, children, ...controlProps } = props\n\n const { formState } = useFormContext()\n\n const error = getError(name, formState)\n\n return (\n <FormControl {...controlProps} isInvalid={!!error}>\n {label && !hideLabel ? <FormLabel>{label}</FormLabel> : null}\n <Box>\n {children}\n {help && !error?.message ? (\n <FormHelperText>{help}</FormHelperText>\n ) : null}\n {error?.message && (\n <FormErrorMessage>{error?.message}</FormErrorMessage>\n )}\n </Box>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n BaseField.displayName = 'BaseField'\n}\n\nexport type As<Props = any> = React.ElementType<Props>\n\nexport type PropsOf<T extends As> = React.ComponentPropsWithoutRef<T> & {\n type?: FieldTypes\n}\n\n/**\n * Build-in types:\n * - text\n * - number\n * - password\n * - textarea\n * - select\n * - native-select\n * - checkbox\n * - radio\n * - switch\n * - pin\n *\n * Will default to a text field if there is no matching type.\n */\nexport const Field = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues> | FieldTypeProps,\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType } = props\n const InputComponent = getInput(type)\n\n return <InputComponent ref={ref} {...props} />\n }\n) as (<TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> &\n FieldTypeProps & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n\ninterface CreateFieldProps {\n displayName: string\n hideLabel?: boolean\n BaseField: React.FC<any>\n}\n\nconst createField = (\n InputComponent: React.FC<any>,\n { displayName, hideLabel, BaseField }: CreateFieldProps\n) => {\n const Field = forwardRef((props, ref) => {\n const {\n id,\n name,\n label,\n help,\n isDisabled,\n isInvalid,\n isReadOnly,\n isRequired,\n rules,\n ...inputProps\n } = props\n\n const inputRules = {\n required: isRequired,\n ...rules,\n }\n\n return (\n <BaseField\n id={id}\n name={name}\n label={label}\n help={help}\n hideLabel={hideLabel}\n isDisabled={isDisabled}\n isInvalid={isInvalid}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n >\n <InputComponent\n ref={ref}\n id={id}\n name={name}\n label={hideLabel ? label : undefined} // Only pass down the label when it should be inline.\n rules={inputRules}\n {...inputProps}\n />\n </BaseField>\n )\n })\n Field.displayName = displayName\n\n return Field\n}\n\nexport const withControlledInput = (InputComponent: React.FC<any>) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { control } = useFormContext()\n\n return (\n <Controller\n name={name}\n control={control}\n rules={rules}\n render={({ field: { ref: _ref, ...field } }) => (\n <InputComponent\n {...field}\n {...inputProps}\n onChange={callAllHandlers(inputProps.onChange, field.onChange)}\n onBlur={callAllHandlers(inputProps.onBlur, field.onBlur)}\n ref={useMergeRefs(ref, _ref)}\n />\n )}\n />\n )\n }\n )\n}\n\nexport const withUncontrolledInput = (InputComponent: React.FC<any>) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { register } = useFormContext()\n\n const { ref: _ref, ...field } = register(name, rules)\n\n return (\n <InputComponent\n {...field}\n {...inputProps}\n onChange={callAllHandlers(inputProps.onChange, field.onChange)}\n onBlur={callAllHandlers(inputProps.onBlur, field.onBlur)}\n ref={useMergeRefs(ref, _ref)}\n />\n )\n }\n )\n}\n\nexport interface RegisterFieldTypeOptions {\n isControlled?: boolean\n hideLabel?: boolean\n BaseField?: React.FC<any>\n}\n\n/**\n * Register a new field type\n * @param type The name for this field in kebab-case, eg `email` or `array-field`\n * @param component The React component\n * @param options\n * @param options.isControlled Set this to true if this is a controlled field.\n * @param options.hideLabel Hide the field label, for example for the checkbox field.\n */\nexport const registerFieldType = <T extends object>(\n type: string,\n component: React.FC<T>,\n options?: RegisterFieldTypeOptions\n) => {\n let InputComponent\n if (options?.isControlled) {\n InputComponent = withControlledInput(component)\n } else {\n InputComponent = withUncontrolledInput(component)\n }\n\n const Field = createField(InputComponent, {\n displayName: `${type\n .split('-')\n .map((part) => part.charAt(0).toUpperCase() + part.slice(1))\n .join('')}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n }) as React.FC<T & FieldProps>\n\n inputTypes[type] = Field\n\n return Field\n}\n\nexport interface InputFieldProps extends InputProps {\n type?: string\n leftAddon?: React.ReactNode\n rightAddon?: React.ReactNode\n}\n\nexport const InputField = registerFieldType<InputFieldProps>(\n 'text',\n forwardRef(({ type = 'text', leftAddon, rightAddon, size, ...rest }, ref) => {\n const input = <Input type={type} size={size} {...rest} ref={ref} />\n if (leftAddon || rightAddon) {\n return (\n <InputGroup size={size}>\n {leftAddon}\n {input}\n {rightAddon}\n </InputGroup>\n )\n }\n return input\n })\n)\n\nexport interface NumberInputFieldProps extends NumberInputProps {\n type: 'number'\n}\n\nexport const NumberInputField = registerFieldType<NumberInputFieldProps>(\n 'number',\n NumberInput,\n {\n isControlled: true,\n }\n)\n\nexport const PasswordInputField = registerFieldType<PasswordInputProps>(\n 'password',\n forwardRef((props, ref) => <PasswordInput ref={ref} {...props} />)\n)\n\nexport const TextareaField = registerFieldType<TextareaProps>(\n 'textarea',\n Textarea\n)\n\nexport const SwitchField = registerFieldType<SwitchProps>(\n 'switch',\n forwardRef(({ type, ...rest }, ref) => {\n return <Switch {...rest} ref={ref} />\n }),\n {\n isControlled: true,\n }\n)\n\nexport const SelectField = registerFieldType<SelectProps>('select', Select, {\n isControlled: true,\n})\n\nexport const CheckboxField = registerFieldType<CheckboxProps>(\n 'checkbox',\n forwardRef(({ label, type, ...props }, ref) => {\n return (\n <Checkbox ref={ref} {...props}>\n {label}\n </Checkbox>\n )\n }),\n {\n hideLabel: true,\n }\n)\n\nexport const RadioField = registerFieldType<RadioInputProps>(\n 'radio',\n RadioInput,\n {\n isControlled: true,\n }\n)\n\nexport const NativeSelectField = registerFieldType<NativeSelectProps>(\n 'native-select',\n NativeSelect,\n { isControlled: true }\n)\n\nexport interface PinFieldProps extends Omit<UsePinInputProps, 'type'> {\n pinLength?: number\n pinType?: 'alphanumeric' | 'number'\n spacing?: SystemProps['margin']\n}\n\nexport const PinField = registerFieldType<PinFieldProps>(\n 'pin',\n forwardRef((props, ref) => {\n const { pinLength = 4, pinType, spacing, ...inputProps } = props\n\n const inputs: React.ReactNode[] = []\n for (let i = 0; i < pinLength; i++) {\n inputs.push(<PinInputField key={i} ref={ref} />)\n }\n\n return (\n <HStack spacing={spacing}>\n <PinInput {...inputProps} type={pinType}>\n {inputs}\n </PinInput>\n </HStack>\n )\n }),\n {\n isControlled: true,\n }\n)\n\nconst fieldTypes = {\n text: InputField,\n email: InputField,\n url: InputField,\n phone: InputField,\n number: NumberInputField,\n password: PasswordInputField,\n textarea: TextareaField,\n switch: SwitchField,\n checkbox: CheckboxField,\n radio: RadioField,\n pin: PinField,\n select: SelectField,\n 'native-select': NativeSelectField,\n}\n\ntype FieldTypes = typeof fieldTypes\n\ntype FieldType<Props = any> = React.ElementType<Props>\n\ntype TypeProps<P extends FieldType, T> = React.ComponentPropsWithoutRef<P> & {\n type: T\n}\n\ntype FieldTypeProps =\n | {\n [Property in keyof FieldTypes]: TypeProps<FieldTypes[Property], Property>\n }[keyof FieldTypes]\n | { type?: string }\n","import { FieldProps } from './field'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): FieldProps[]\n getNestedFields(name: string): FieldProps[]\n}\n\ninterface SchemaField extends FieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema): FieldProps[] =>\n schema &&\n Object.entries(schema).map(([name, { items, label, title, ...field }]) => {\n return {\n ...field,\n name,\n label: label || title, // json schema compatibility\n }\n })\n\nexport const objectFieldResolver = (schema: ObjectSchema): FieldResolver => {\n const getFields = () => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string) => {\n const field = get(schema, name)\n\n if (!field) return []\n\n if (field.items?.type === 'object') {\n return mapFields(field.items.properties)\n } else if (field.type === 'object') {\n return mapFields(field.properties)\n }\n return [field.items]\n }\n\n return { getFields, getNestedFields }\n}\n","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { cx, MaybeFunction, runIfFn, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n useForm,\n FormProvider,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n ResolverOptions,\n ResolverResult,\n ChangeHandler,\n WatchObserver,\n} from 'react-hook-form'\nimport { objectFieldResolver, FieldResolver } from './field-resolver'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\ninterface FormOptions<TFieldValues extends FieldValues = FieldValues> {\n /**\n * The form schema, currently supports Yup schema only.\n */\n schema?: any\n /**\n * Triggers when any of the field change.\n */\n onChange?: WatchObserver<TFieldValues>\n /**\n * The submit handler.\n */\n onSubmit: SubmitHandler<TFieldValues>\n /**\n * Triggers when there are validation errors.\n */\n onError?: SubmitErrorHandler<TFieldValues>\n /**\n * Ref on the HTMLFormElement.\n */\n formRef?: React.RefObject<HTMLFormElement>\n /**\n * The form children, can be a render prop or a ReactNode.\n */\n children?: MaybeRenderProp<UseFormReturn<TFieldValues>>\n}\n\n// @todo Figure out how to pass down FieldValues to all Field components, if at all possible.\n\nexport interface FormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseFormProps<TFieldValues>,\n Omit<\n HTMLChakraProps<'form'>,\n 'children' | 'onChange' | 'onSubmit' | 'onError'\n >,\n FormOptions<TFieldValues> {}\n\nexport const Form = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const {\n mode = 'all',\n resolver,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n onChange,\n onSubmit,\n onError,\n formRef,\n children,\n ...rest\n } = props\n\n const form = {\n mode,\n resolver,\n defaultValues,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n }\n\n if (schema && !resolver) {\n form.resolver = Form.getResolver?.(schema)\n }\n\n const methods = useForm<TFieldValues>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(ref, () => methods, [ref, methods])\n\n React.useEffect(() => {\n let subscription: any\n if (onChange) {\n subscription = methods.watch(onChange)\n }\n return () => subscription?.unsubscribe()\n }, [methods, onChange])\n\n return (\n <FormProvider {...methods}>\n <chakra.form\n ref={formRef}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('saas-form', props.className)}\n >\n {runIfFn(children, methods)}\n </chakra.form>\n </FormProvider>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: FormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getResolver?: GetResolver\n getFieldResolver: GetFieldResolver\n}\n\nForm.getFieldResolver = objectFieldResolver\n\nif (__DEV__) {\n Form.displayName = 'Form'\n}\n\nexport type GetResolver = (\n schema: any\n) => <TFieldValues extends FieldValues, TContext>(\n values: TFieldValues,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n\nexport type GetFieldResolver = (schema: any) => FieldResolver\n","import * as React from 'react'\n\nimport { chakra, SimpleGrid, SimpleGridProps, useTheme } from '@chakra-ui/react'\nimport { cx, __DEV__ } from '@chakra-ui/utils'\n\nexport type FormLayoutProps = SimpleGridProps\n\ninterface FormLayoutItemProps {\n children: React.ReactNode\n}\n\nconst FormLayoutItem: React.FC<FormLayoutItemProps> = ({ children }) => {\n return <chakra.div>{children}</chakra.div>\n}\n\nif (__DEV__) {\n FormLayoutItem.displayName = 'FormLayoutItem'\n}\n\n/**\n * FormLayout\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.FormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('saas-form__layout', props.className)}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return <FormLayoutItem>{child}</FormLayoutItem>\n }\n return child\n })}\n </SimpleGrid>\n )\n}\n\nif (__DEV__) {\n FormLayout.displayName = 'FormLayout'\n}\n","import * as React from 'react'\n\nexport const mapNestedFields = (name: string, children: React.ReactNode) => {\n return React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child.props.name) {\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${child.props.name}`,\n })\n }\n return child\n })\n}\n","import * as React from 'react'\nimport {\n useFieldArray,\n useFormContext,\n UseFieldArrayReturn,\n} from 'react-hook-form'\n\nimport { createContext } from '@chakra-ui/react-utils'\n\nexport interface UseArrayFieldReturn extends UseFieldArrayReturn {\n /**\n * The array field name\n */\n name: string\n /**\n * The default value for new items\n */\n defaultValue: Record<string, any>\n /**\n * Min amount of items\n */\n min?: number\n /**\n * Max amount of items\n */\n max?: number\n}\n\nexport const [ArrayFieldProvider, useArrayFieldContext] =\n createContext<UseArrayFieldReturn>({\n name: 'ArrayFieldContext',\n })\n\nexport interface UseArrayFieldRowReturn {\n /**\n * Name of the array field including the index, eg 'field.0'\n */\n name: string\n /**\n * The field index\n */\n index: number\n /**\n * Remove this array item\n */\n remove: () => void\n /**\n * True if this is the first item\n */\n isFirst: boolean\n /**\n * True if this is the last item\n */\n isLast: boolean\n}\n\nexport const [ArrayFieldRowProvider, useArrayFieldRowContext] =\n createContext<UseArrayFieldRowReturn>({\n name: 'ArrayFieldRowContext',\n })\n\nexport interface ArrayFieldOptions {\n /**\n * The field name\n */\n name: string\n /**\n * Default value for new values in the array\n */\n defaultValue?: Record<string, any>\n /**\n * Default key name for rows, change this if your data uses a different 'id' field\n * @default \"id\"\n */\n keyName?: string\n min?: number\n max?: number\n}\n\nexport const useArrayField = ({\n name,\n defaultValue = {},\n keyName,\n min,\n max,\n}: ArrayFieldOptions) => {\n const { control } = useFormContext()\n const context = useFieldArray({\n control,\n name,\n keyName,\n })\n\n return {\n ...context,\n name,\n defaultValue,\n min,\n max,\n }\n}\n\nexport interface UseArrayFieldRowProps {\n index: number\n}\n\nexport const useArrayFieldRow = ({ index }: UseArrayFieldRowProps) => {\n const { clearErrors } = useFormContext()\n const { name, remove, fields } = useArrayFieldContext()\n\n React.useEffect(() => {\n // reset errors, to make sure min/max errors reset correctly\n clearErrors(name)\n }, [])\n\n return {\n index,\n isFirst: index === 0,\n isLast: index === fields.length - 1,\n name: `${name}.${index}`,\n remove: React.useCallback(() => {\n clearErrors(name)\n remove(index)\n }, [index]),\n }\n}\n\nexport const useArrayFieldRemoveButton = () => {\n const { isFirst, remove } = useArrayFieldRowContext()\n const { min, fields } = useArrayFieldContext()\n\n const isDisabled = isFirst && !!(min && fields.length <= min)\n\n return {\n onClick: () => remove(),\n isDisabled,\n }\n}\n\nexport const useArrayFieldAddButton = () => {\n const { append, defaultValue, max, fields } = useArrayFieldContext()\n\n const isDisabled = !!(max && fields.length >= max)\n\n return {\n onClick: () =>\n append(defaultValue, {\n shouldFocus: false,\n }),\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport { chakra, ResponsiveValue, forwardRef } from '@chakra-ui/system'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { AddIcon, MinusIcon } from '@chakra-ui/icons'\nimport { IconButton, ButtonProps } from '@saas-ui/button'\n\nimport { FormLayout, FormLayoutProps } from './layout'\nimport { BaseField, FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nimport {\n useArrayField,\n useArrayFieldRow,\n useArrayFieldContext,\n ArrayFieldProvider,\n ArrayFieldOptions,\n ArrayFieldRowProvider,\n useArrayFieldRowContext,\n useArrayFieldRemoveButton,\n useArrayFieldAddButton,\n UseArrayFieldReturn,\n} from './use-array-field'\n\ninterface ArrayField {\n id: string\n [key: string]: unknown\n}\n\ninterface ArrayFieldRowProps extends FormLayoutProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n /**\n * The array index\n */\n index: number\n /**\n * The fields\n */\n children: React.ReactNode\n}\n\nexport const ArrayFieldRow: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n ...rowFieldsProps\n}) => {\n return (\n <ArrayFieldRowContainer index={index}>\n <ArrayFieldRowFields {...rowFieldsProps}>{children}</ArrayFieldRowFields>\n <ArrayFieldRemoveButton />\n </ArrayFieldRowContainer>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRow.displayName = 'ArrayFieldRow'\n}\n\nexport interface ArrayFieldRowFieldsProps extends FormLayoutProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n /**\n * The fields\n */\n children: React.ReactNode\n}\n\nexport const ArrayFieldRowFields: React.FC<ArrayFieldRowFieldsProps> = ({\n children,\n ...layoutProps\n}) => {\n const { name } = useArrayFieldRowContext()\n return (\n <FormLayout flex=\"1\" mr=\"2\" {...layoutProps}>\n {mapNestedFields(name, children)}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n}\n\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n}) => {\n const context = useArrayFieldRow({ index })\n\n const styles = {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'flex-end',\n width: '100%',\n mb: 4,\n }\n\n return (\n <ArrayFieldRowProvider value={context}>\n <chakra.div __css={styles}>{children}</chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n}\n\nexport const ArrayFieldRemoveButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<MinusIcon />}\n aria-label=\"Remove row\"\n {...useArrayFieldRemoveButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n}\n\nexport const ArrayFieldAddButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<AddIcon />}\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n}\n\nexport interface ArrayFieldProps\n extends ArrayFieldOptions,\n Omit<FieldProps, 'defaultValue'> {}\n\nexport const ArrayField = forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>\n {(fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n ))}\n </>\n )}\n </ArrayFieldRows>\n <ArrayFieldAddButton />\n </ArrayFieldContainer>\n )\n }\n) as ((\n props: ArrayFieldProps & {\n ref?: React.ForwardedRef<UseArrayFieldReturn>\n }\n) => React.ReactElement) & {\n displayName: string\n}\n\nif (__DEV__) {\n ArrayField.displayName = 'ArrayField'\n}\n\nexport interface ArrayFieldRowsProps {\n children: (fields: ArrayField[]) => React.ReactElement | null\n}\n\nexport const ArrayFieldRows = ({\n children,\n}: ArrayFieldRowsProps): React.ReactElement | null => {\n const { fields } = useArrayFieldContext()\n return children(fields)\n}\n\nif (__DEV__) {\n ArrayFieldRows.displayName = 'ArrayFieldRows'\n}\n\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min,\n max,\n })\n\n // This exposes the useArrayField api through the forwarded ref\n React.useImperativeHandle(ref, () => context, [ref, context])\n\n return (\n <ArrayFieldProvider value={context}>\n <BaseField name={name} {...fieldProps}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nif (__DEV__) {\n ArrayFieldContainer.displayName = 'ArrayFieldContainer'\n}\n","import * as React from 'react'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyleConfig,\n} from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { FormLayout } from './layout'\nimport { FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nexport interface ObjectFieldProps extends FieldProps {\n name: string\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyleConfig('FormLegend')\n return <FormLabel as=\"legend\" sx={styles} {...props} />\n}\n\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const { name, label, hideLabel, children, columns, spacing, ...fieldProps } =\n props\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps}>\n <FormLegend display={hideLabel ? 'none' : 'block'}>{label}</FormLegend>\n <FormLayout columns={columns} gridGap={spacing}>\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n ObjectField.displayName = 'ObjectField'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form } from './form'\nimport { FormLayout } from './layout'\nimport { Field, FieldProps } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\nimport { useFormContext } from 'react-hook-form'\n\nexport interface FieldsProps {\n schema: any\n fieldResolver?: FieldResolver\n focusFirstField?: boolean\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n ({ name, type, ...nestedFieldProps }: FieldProps, i): React.ReactNode => (\n <Field key={name || i} name={name} type={type} {...nestedFieldProps} />\n )\n )\n}\n\nexport const Fields: React.FC<FieldsProps> = ({\n schema,\n fieldResolver,\n focusFirstField,\n ...props\n}) => {\n const resolver = React.useMemo(\n () => fieldResolver || Form.getFieldResolver(schema),\n [schema, fieldResolver]\n )\n\n const fields = React.useMemo(() => resolver.getFields(), [resolver])\n\n const form = useFormContext()\n\n React.useEffect(() => {\n if (focusFirstField && fields[0]?.name) {\n form.setFocus(fields[0].name)\n }\n }, [schema, fieldResolver, focusFirstField])\n\n return (\n <FormLayout {...props}>\n {fields.map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: FieldProps): React.ReactNode => {\n if (type === 'array') {\n return (\n <ArrayField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ArrayField>\n )\n } else if (type === 'object') {\n return (\n <ObjectField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ObjectField>\n )\n }\n\n return <Field key={name} name={name} type={type} {...fieldProps} />\n }\n )}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n Fields.displayName = 'Fields'\n}\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { __DEV__ } from '@chakra-ui/utils'\n\nexport interface SubmitButtonProps extends ButtonProps {\n /**\n * Disable the submit button if the form is untouched.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfUntouched`\n */\n disableIfUntouched?: boolean\n /**\n * Disable the submit button if the form is invalid.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfInvalid`\n */\n disableIfInvalid?: boolean\n}\n\nexport const SubmitButton = React.forwardRef<\n HTMLButtonElement,\n SubmitButtonProps\n>((props, ref) => {\n const {\n children,\n disableIfUntouched,\n disableIfInvalid,\n isDisabled: isDisabledProp,\n isLoading,\n ...rest\n } = props\n const { formState } = useFormContext()\n\n const isDisabled =\n (disableIfUntouched && !formState.isDirty) ||\n (disableIfInvalid && !formState.isValid) ||\n isDisabledProp\n\n return (\n <Button\n {...rest}\n ref={ref}\n variant=\"primary\"\n type=\"submit\"\n isLoading={formState.isSubmitting || isLoading}\n isDisabled={isDisabled}\n >\n {children}\n </Button>\n )\n})\n\nSubmitButton.defaultProps = {\n label: 'Submit',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nif (__DEV__) {\n SubmitButton.displayName = 'SubmitButton'\n}\n","import * as React from 'react'\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\nimport { forwardRef } from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form, FormProps } from './form'\nimport { FormLayout } from './layout'\nimport { Fields } from './fields'\nimport { SubmitButton } from './submit-button'\nimport { FieldResolver } from '.'\n\ninterface AutoFormOptions {\n /**\n * The submit button label.\n * Pass `null` to render no submit button.\n */\n submitLabel?: React.ReactNode\n /**\n * The schema.\n * Supports object schema, Zod, Yup or Ajv (JSON Schema).\n * @see https://www.saas-ui.dev/docs/forms/auto-form\n */\n schema: any\n /**\n * The field resolver.\n */\n fieldResolver?: any\n}\n\nexport interface AutoFormProps<TFieldValues extends FieldValues>\n extends Omit<FormProps<TFieldValues>, 'schema' | 'children'>,\n AutoFormOptions {\n children?: React.ReactNode\n}\n\nexport const AutoForm = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: AutoFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const {\n schema,\n submitLabel = 'Submit',\n fieldResolver,\n children,\n ...rest\n } = props\n\n return (\n <Form {...rest} schema={schema} ref={ref}>\n <FormLayout>\n {<Fields schema={schema} fieldResolver={fieldResolver} />}\n {submitLabel && <SubmitButton>{submitLabel}</SubmitButton>}\n {children}\n </FormLayout>\n </Form>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: AutoFormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getFieldResolver?: (schema: any) => FieldResolver\n}\n\nif (__DEV__) {\n AutoForm.displayName = 'AutoForm'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport {\n useFormContext,\n useWatch,\n FieldValues,\n UseFormReturn,\n} from 'react-hook-form'\n\nexport interface DisplayIfProps<TFieldValues> {\n children: React.ReactElement\n name: string\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n\nexport const DisplayIf = <TFieldValues extends FieldValues = FieldValues>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues>) => {\n const value = useWatch({\n name,\n defaultValue,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext<TFieldValues>()\n return condition(value, context) ? children : null\n}\n\nif (__DEV__) {\n DisplayIf.displayName = 'DisplayIf'\n}\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext, MaybeRenderProp } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/stepper'\n\nexport interface StepState {\n name: string\n schema?: any\n resolver?: any\n isActive?: boolean\n isCompleted?: boolean\n onSubmit?: FormStepSubmitHandler\n}\n\nexport type FormStepSubmitHandler<\n TFieldValues extends FieldValues = FieldValues\n> = (data: TFieldValues, stepper: UseStepperReturn) => Promise<void>\n\nexport interface StepFormContext extends UseStepperReturn {\n updateStep(state: StepState): void\n steps: Record<string, StepState>\n}\n\nexport const [StepFormProvider, useStepFormContext] =\n createContext<StepFormContext>({\n name: 'StepFormContext',\n errorMessage:\n 'useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`',\n })\n\nimport { FormProps } from './form'\n\nexport interface UseStepFormProps<\n TFieldValues extends FieldValues = FieldValues\n> extends Omit<UseStepperProps, 'onChange'>,\n Omit<FormProps<TFieldValues>, 'children'> {\n children: MaybeRenderProp<UseStepFormReturn<TFieldValues>>\n}\n\nexport interface UseStepFormReturn<\n TFieldValues extends FieldValues = FieldValues\n> extends UseStepperReturn {\n getFormProps(): {\n onSubmit: SubmitHandler<TFieldValues>\n schema?: any\n resolver?: any\n }\n updateStep(step: any): void\n steps: Record<string, any>\n}\n\nexport function useStepForm<TFieldValues extends FieldValues = FieldValues>(\n props: UseStepFormProps<TFieldValues>\n): UseStepFormReturn<TFieldValues> {\n const { onChange, ...rest } = props\n const stepper = useStepper(rest)\n\n const { activeStep, isLastStep, nextStep } = stepper\n\n const [steps, updateSteps] = React.useState<Record<string, StepState>>({})\n\n const onSubmitStep: SubmitHandler<TFieldValues> = React.useCallback(\n async (data) => {\n try {\n const step = steps[activeStep]\n\n if (isLastStep) {\n await props.onSubmit?.(data)\n\n updateStep({\n ...step,\n isCompleted: true,\n })\n\n nextStep() // show completed step\n return\n }\n\n await step.onSubmit?.(data, stepper)\n\n nextStep()\n } catch (e) {\n // Step submission failed.\n }\n },\n [steps, activeStep, isLastStep]\n )\n\n const getFormProps = React.useCallback(() => {\n const step = steps[activeStep]\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.resolver,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: step,\n }\n })\n },\n [steps]\n )\n\n return {\n getFormProps,\n updateStep,\n steps,\n ...stepper,\n }\n}\n\nexport interface UseFormStepProps {\n name: string\n schema?: any\n resolver?: any\n onSubmit?: FormStepSubmitHandler\n}\n\nexport function useFormStep(props: UseFormStepProps): StepState {\n const { name, schema, resolver, onSubmit } = props\n const step = useStep({ name })\n\n const { steps, updateStep } = useStepFormContext()\n\n React.useEffect(() => {\n updateStep({ name, schema, resolver, onSubmit })\n }, [name, schema])\n\n return {\n ...step,\n ...(steps[name] || { name, schema }),\n }\n}\n","import * as React from 'react'\n\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\n\nimport { chakra, HTMLChakraProps, ThemingProps } from '@chakra-ui/system'\n\nimport { callAllHandlers, runIfFn, cx, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n StepperProvider,\n StepperSteps,\n StepperStepsProps,\n StepperStep,\n useStepperContext,\n StepperContainer,\n StepperProps,\n} from '@saas-ui/stepper'\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { Form } from './form'\nimport { SubmitButton } from './submit-button'\n\nimport {\n useStepForm,\n useFormStep,\n StepFormProvider,\n UseStepFormProps,\n FormStepSubmitHandler,\n} from './use-step-form'\n\nexport interface StepFormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseStepFormProps<TFieldValues> {}\n\nexport const StepForm = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: StepFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const { children, ...rest } = props\n\n const stepper = useStepForm<TFieldValues>(props)\n\n const { getFormProps, ...ctx } = stepper\n\n const context = React.useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, stepper)}\n </Form>\n </StepFormProvider>\n </StepperProvider>\n )\n }\n) as <TFieldValues extends FieldValues>(\n props: StepFormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement\n\nexport interface FormStepOptions {\n /**\n * The step name\n */\n name: string\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport interface FormStepperProps\n extends StepperStepsProps,\n ThemingProps<'Stepper'> {}\n\nexport const FormStepper: React.FC<FormStepperProps> = (props) => {\n const { activeIndex, setIndex } = useStepperContext()\n\n const { children, orientation, variant, colorScheme, size, ...rest } = props\n\n const elements = React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child?.type === FormStep) {\n const { isCompleted } = useFormStep(child.props) // Register this step\n return (\n <StepperStep\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n {...rest}\n >\n {child.props.children}\n </StepperStep>\n )\n }\n return child\n })\n\n const onChange = React.useCallback((i: number) => {\n setIndex(i)\n }, [])\n\n return (\n <StepperContainer\n orientation={orientation}\n step={activeIndex}\n variant={variant}\n colorScheme={colorScheme}\n size={size}\n onChange={onChange}\n >\n <StepperSteps mb=\"4\" {...props}>\n {elements}\n </StepperSteps>\n </StepperContainer>\n )\n}\n\nexport interface FormStepProps\n extends FormStepOptions,\n Omit<HTMLChakraProps<'div'>, 'onSubmit'> {\n onSubmit?: FormStepSubmitHandler\n}\n\nexport const FormStep: React.FC<FormStepProps> = (props) => {\n const { name, schema, resolver, children, className, onSubmit, ...rest } =\n props\n const step = useFormStep({ name, schema, resolver, onSubmit })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('saas-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nif (__DEV__) {\n FormStep.displayName = 'FormStep'\n}\n\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n label=\"Back\"\n {...props}\n className={cx('saas-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nif (__DEV__) {\n PrevButton.displayName = 'PrevButton'\n}\n\nexport interface NextButtonProps extends ButtonProps {\n submitLabel?: string\n}\n\nexport const NextButton: React.FC<NextButtonProps> = (props) => {\n const { label = 'Next', submitLabel = 'Complete', ...rest } = props\n const { isLastStep, isCompleted } = useStepperContext()\n\n return (\n <SubmitButton\n {...rest}\n isDisabled={isCompleted}\n className={cx('saas-form__next-button', props.className)}\n >\n {isLastStep || isCompleted ? submitLabel : label}\n </SubmitButton>\n )\n}\n\nif (__DEV__) {\n NextButton.displayName = 'NextButton'\n}\n","import {\n FieldValues,\n useFormContext,\n UseFormReturn,\n useWatch,\n} from 'react-hook-form'\n\nexport interface WatchFieldProps<\n Value = unknown,\n TFieldValues extends FieldValues = FieldValues\n> {\n name: string\n defaultValue?: Value\n isDisabled?: boolean\n isExact?: boolean\n children: (\n value: Value,\n form: UseFormReturn<TFieldValues>\n ) => React.ReactElement | void\n}\n\nexport const WatchField = <\n Value = unknown,\n TFieldValues extends FieldValues = FieldValues\n>(\n props: WatchFieldProps<Value, TFieldValues>\n) => {\n const { name, defaultValue, isDisabled, isExact } = props\n const form = useFormContext<TFieldValues>()\n\n const field = useWatch({\n name,\n defaultValue,\n disabled: isDisabled,\n exact: isExact,\n })\n\n return props.children(field, form) || null\n}\n"],"names":["_excluded","DisplayField","_ref","name","label","props","React","createElement","FormControl","FormLabel","htmlFor","Text","fontSize","FormValue","__DEV__","displayName","_ref2","getValues","useFormContext","_excluded2","_excluded3","_excluded4","_excluded5","_excluded6","_excluded7","_excluded8","_excluded9","_excluded10","inputTypes","BaseField","help","hideLabel","children","controlProps","formState","get","errors","getError","_extends","isInvalid","error","Box","message","FormHelperText","FormErrorMessage","Field","forwardRef","ref","_props$type","type","defaultInputType","withControlledInput","InputComponent","_ref3","rules","inputProps","_objectWithoutPropertiesLoose","Controller","control","render","_ref4","_ref4$field","field","onChange","callAllHandlers","onBlur","useMergeRefs","_ref5","register","_register","registerFieldType","component","options","id","isDisabled","isReadOnly","isRequired","inputRules","required","undefined","createField","isControlled","withUncontrolledInput","split","map","part","charAt","toUpperCase","slice","join","_ref6$type","leftAddon","_ref6","rightAddon","size","rest","input","Input","InputGroup","NumberInputField","NumberInput","PasswordInputField","PasswordInput","TextareaField","Textarea","SwitchField","_ref7","Switch","SelectField","Select","CheckboxField","_ref8","Checkbox","RadioInput","NativeSelectField","NativeSelect","PinField","pinLength","_props$pinLength","pinType","spacing","inputs","i","push","PinInputField","key","HStack","PinInput","schema","Object","entries","title","_ref$","objectFieldResolver","getFields","getNestedFields","_field$items","items","mapFields","properties","Form","mode","_props$mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","defaultValues","onSubmit","onError","formRef","form","getResolver","methods","useForm","handleSubmit","useImperativeHandle","useEffect","subscription","watch","_subscription","unsubscribe","FormProvider","chakra","className","cx","runIfFn","getFieldResolver","FormLayoutItem","div","FormLayout","_theme$components$For","_theme$components","_theme$components$For2","gridProps","theme","useTheme","components","defaultProps","SimpleGrid","Children","child","isValidElement","mapNestedFields","cloneElement","createContext","ArrayFieldProvider","useArrayFieldContext","_createContext","ArrayFieldRowProvider","useArrayFieldRowContext","useArrayField","_ref$defaultValue","defaultValue","keyName","min","max","context","useFieldArray","useArrayFieldRow","index","clearErrors","_useArrayFieldContext","remove","fields","isFirst","isLast","length","useCallback","useArrayFieldRemoveButton","_useArrayFieldRowCont","_useArrayFieldContext2","onClick","append","_useArrayFieldContext3","shouldFocus","ArrayFieldRow","rowFieldsProps","ArrayFieldRowContainer","ArrayFieldRowFields","ArrayFieldRemoveButton","layoutProps","flex","mr","value","__css","display","flexDirection","alignItems","width","mb","IconButton","icon","MinusIcon","ArrayFieldAddButton","AddIcon","float","useArrayFieldAddButton","ArrayField","containerProps","ArrayFieldContainer","ArrayFieldRows","Fragment","fieldProps","FormLegend","styles","useStyleConfig","as","sx","columns","gridGap","ObjectField","_resolver$getNestedFi","nestedFieldProps","Fields","fieldResolver","focusFirstField","useMemo","_fields$","setFocus","SubmitButton","disableIfUntouched","disableIfInvalid","isDisabledProp","isLoading","Button","variant","isSubmitting","isDirty","isValid","AutoForm","submitLabel","_props$submitLabel","DisplayIf","condition","_ref$condition","useWatch","disabled","exact","isExact","errorMessage","StepFormProvider","useStepFormContext","useStepForm","stepper","useStepper","activeStep","isLastStep","nextStep","_React$useState","useState","steps","updateSteps","onSubmitStep","data","step","_temp","then","updateStep","isCompleted","_exit","_temp2","getFormProps","_extends2","useStep","StepForm","ctx","StepperProvider","FormStep","useFormStep","isActive","PrevButton","useStepperContext","prevStep","isFirstStep","_useStepperContext2","NextButton","_props$label","_useStepperContext3","activeIndex","setIndex","_useStepperContext","orientation","colorScheme","elements","StepperStep","_useFormStep","StepperContainer","StepperSteps"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/display-field.tsx","../src/field.tsx","../src/field-resolver.ts","../src/form.tsx","../src/layout.tsx","../src/utils.ts","../src/use-array-field.tsx","../src/array-field.tsx","../src/object-field.tsx","../src/fields.tsx","../src/submit-button.tsx","../src/auto-form.tsx","../src/display-if.tsx","../src/use-step-form.tsx","../src/step-form.tsx","../src/watch-field.tsx"],"sourcesContent":["import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { useFormContext } from 'react-hook-form'\n\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './field'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n\nexport const DisplayField: React.FC<DisplayFieldProps> = ({\n name,\n label,\n placeholder,\n ...props\n}) => {\n return (\n <FormControl {...props}>\n {label ? <FormLabel htmlFor={name}>{label}</FormLabel> : null}\n <Text fontSize=\"md\">\n <FormValue name={name} />\n </Text>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n DisplayField.displayName = 'DisplayField'\n}\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nif (__DEV__) {\n FormValue.displayName = 'FormValue'\n}\n","import * as React from 'react'\nimport {\n useFormContext,\n FormState,\n Controller,\n get,\n RegisterOptions,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport {\n forwardRef,\n Box,\n FormControl,\n FormControlProps,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n Input,\n Textarea,\n Checkbox,\n Switch,\n useMergeRefs,\n InputGroup,\n InputProps,\n TextareaProps,\n SwitchProps,\n CheckboxProps,\n PinInputField,\n HStack,\n PinInput,\n UsePinInputProps,\n SystemProps,\n} from '@chakra-ui/react'\nimport { __DEV__, FocusableElement, callAllHandlers } from '@chakra-ui/utils'\n\nimport { NumberInput, NumberInputProps } from '@saas-ui/number-input'\nimport { PasswordInput, PasswordInputProps } from '@saas-ui/password-input'\nimport { RadioInput, RadioInputProps } from '@saas-ui/radio'\n\nimport {\n Select,\n SelectProps,\n NativeSelect,\n NativeSelectProps,\n} from '@saas-ui/select'\n\nexport interface Option {\n value: string\n label?: string\n [key: string]: unknown\n}\n\nexport type FieldRules = Pick<\n RegisterOptions,\n 'required' | 'min' | 'max' | 'maxLength' | 'minLength' | 'pattern'\n>\n\nexport interface FieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends Omit<FormControlProps, 'label' | 'type'> {\n /**\n * The field name\n */\n name: TName\n /**\n * The field label\n */\n label?: string\n /**\n * Hide the field label\n */\n hideLabel?: boolean\n /**\n * Field help text\n */\n help?: string\n /**\n * React hook form rules\n */\n rules?: Omit<\n RegisterOptions<TFieldValues, TName>,\n 'valueAsNumber' | 'valueAsDate' | 'setValueAs' | 'disabled'\n >\n /**\n * Build-in types:\n * - text\n * - number\n * - password\n * - textarea\n * - select\n * - native-select\n * - checkbox\n * - radio\n * - switch\n * - pin\n *\n * Will default to a text field if there is no matching type.\n */\n type?: string\n /**\n * The input placeholder\n */\n placeholder?: string\n}\n\nconst inputTypes: Record<string, React.FC<any>> = {}\n\nconst defaultInputType = 'text'\n\nconst getInput = (type: string) => {\n return inputTypes[type] || inputTypes[defaultInputType]\n}\n\nconst getError = (name: string, formState: FormState<{ [x: string]: any }>) => {\n return get(formState.errors, name)\n}\n\nconst isTouched = (\n name: string,\n formState: FormState<{ [x: string]: any }>\n) => {\n return get(formState.touchedFields, name)\n}\n\nexport const BaseField: React.FC<FieldProps> = (props) => {\n const { name, label, help, hideLabel, children, ...controlProps } = props\n\n const { formState } = useFormContext()\n\n const error = getError(name, formState)\n\n return (\n <FormControl {...controlProps} isInvalid={!!error}>\n {label && !hideLabel ? <FormLabel>{label}</FormLabel> : null}\n <Box>\n {children}\n {help && !error?.message ? (\n <FormHelperText>{help}</FormHelperText>\n ) : null}\n {error?.message && (\n <FormErrorMessage>{error?.message}</FormErrorMessage>\n )}\n </Box>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n BaseField.displayName = 'BaseField'\n}\n\nexport type As<Props = any> = React.ElementType<Props>\n\nexport type PropsOf<T extends As> = React.ComponentPropsWithoutRef<T> & {\n type?: FieldTypes\n}\n\n/**\n * Build-in types:\n * - text\n * - number\n * - password\n * - textarea\n * - select\n * - native-select\n * - checkbox\n * - radio\n * - switch\n * - pin\n *\n * Will default to a text field if there is no matching type.\n */\nexport const Field = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues> | FieldTypeProps,\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType } = props\n const InputComponent = getInput(type)\n\n return <InputComponent ref={ref} {...props} />\n }\n) as (<TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> &\n FieldTypeProps & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n\ninterface CreateFieldProps {\n displayName: string\n hideLabel?: boolean\n BaseField: React.FC<any>\n}\n\nconst createField = (\n InputComponent: React.FC<any>,\n { displayName, hideLabel, BaseField }: CreateFieldProps\n) => {\n const Field = forwardRef((props, ref) => {\n const {\n id,\n name,\n label,\n help,\n isDisabled,\n isInvalid,\n isReadOnly,\n isRequired,\n rules,\n ...inputProps\n } = props\n\n const inputRules = {\n required: isRequired,\n ...rules,\n }\n\n return (\n <BaseField\n id={id}\n name={name}\n label={label}\n help={help}\n hideLabel={hideLabel}\n isDisabled={isDisabled}\n isInvalid={isInvalid}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n >\n <InputComponent\n ref={ref}\n id={id}\n name={name}\n label={hideLabel ? label : undefined} // Only pass down the label when it should be inline.\n rules={inputRules}\n {...inputProps}\n />\n </BaseField>\n )\n })\n Field.displayName = displayName\n\n return Field\n}\n\nexport const withControlledInput = (InputComponent: React.FC<any>) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { control } = useFormContext()\n\n return (\n <Controller\n name={name}\n control={control}\n rules={rules}\n render={({ field: { ref: _ref, ...field } }) => (\n <InputComponent\n {...field}\n {...inputProps}\n onChange={callAllHandlers(inputProps.onChange, field.onChange)}\n onBlur={callAllHandlers(inputProps.onBlur, field.onBlur)}\n ref={useMergeRefs(ref, _ref)}\n />\n )}\n />\n )\n }\n )\n}\n\nexport const withUncontrolledInput = (InputComponent: React.FC<any>) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { register } = useFormContext()\n\n const { ref: _ref, ...field } = register(name, rules)\n\n return (\n <InputComponent\n {...field}\n {...inputProps}\n onChange={callAllHandlers(inputProps.onChange, field.onChange)}\n onBlur={callAllHandlers(inputProps.onBlur, field.onBlur)}\n ref={useMergeRefs(ref, _ref)}\n />\n )\n }\n )\n}\n\nexport interface RegisterFieldTypeOptions {\n isControlled?: boolean\n hideLabel?: boolean\n BaseField?: React.FC<any>\n}\n\n/**\n * Register a new field type\n * @param type The name for this field in kebab-case, eg `email` or `array-field`\n * @param component The React component\n * @param options\n * @param options.isControlled Set this to true if this is a controlled field.\n * @param options.hideLabel Hide the field label, for example for the checkbox field.\n */\nexport const registerFieldType = <T extends object>(\n type: string,\n component: React.FC<T>,\n options?: RegisterFieldTypeOptions\n) => {\n let InputComponent\n if (options?.isControlled) {\n InputComponent = withControlledInput(component)\n } else {\n InputComponent = withUncontrolledInput(component)\n }\n\n const Field = createField(InputComponent, {\n displayName: `${type\n .split('-')\n .map((part) => part.charAt(0).toUpperCase() + part.slice(1))\n .join('')}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n }) as React.FC<T & FieldProps>\n\n inputTypes[type] = Field\n\n return Field\n}\n\nexport interface InputFieldProps extends InputProps {\n type?: string\n leftAddon?: React.ReactNode\n rightAddon?: React.ReactNode\n}\n\nexport const InputField = registerFieldType<InputFieldProps>(\n 'text',\n forwardRef(({ type = 'text', leftAddon, rightAddon, size, ...rest }, ref) => {\n const input = <Input type={type} size={size} {...rest} ref={ref} />\n if (leftAddon || rightAddon) {\n return (\n <InputGroup size={size}>\n {leftAddon}\n {input}\n {rightAddon}\n </InputGroup>\n )\n }\n return input\n })\n)\n\nexport interface NumberInputFieldProps extends NumberInputProps {\n type: 'number'\n}\n\nexport const NumberInputField = registerFieldType<NumberInputFieldProps>(\n 'number',\n NumberInput,\n {\n isControlled: true,\n }\n)\n\nexport const PasswordInputField = registerFieldType<PasswordInputProps>(\n 'password',\n forwardRef((props, ref) => <PasswordInput ref={ref} {...props} />)\n)\n\nexport const TextareaField = registerFieldType<TextareaProps>(\n 'textarea',\n Textarea\n)\n\nexport const SwitchField = registerFieldType<SwitchProps>(\n 'switch',\n forwardRef(({ type, ...rest }, ref) => {\n return <Switch {...rest} ref={ref} />\n }),\n {\n isControlled: true,\n }\n)\n\nexport const SelectField = registerFieldType<SelectProps>('select', Select, {\n isControlled: true,\n})\n\nexport const CheckboxField = registerFieldType<CheckboxProps>(\n 'checkbox',\n forwardRef(({ label, type, ...props }, ref) => {\n return (\n <Checkbox ref={ref} {...props}>\n {label}\n </Checkbox>\n )\n }),\n {\n hideLabel: true,\n }\n)\n\nexport const RadioField = registerFieldType<RadioInputProps>(\n 'radio',\n RadioInput,\n {\n isControlled: true,\n }\n)\n\nexport const NativeSelectField = registerFieldType<NativeSelectProps>(\n 'native-select',\n NativeSelect,\n { isControlled: true }\n)\n\nexport interface PinFieldProps extends Omit<UsePinInputProps, 'type'> {\n pinLength?: number\n pinType?: 'alphanumeric' | 'number'\n spacing?: SystemProps['margin']\n}\n\nexport const PinField = registerFieldType<PinFieldProps>(\n 'pin',\n forwardRef((props, ref) => {\n const { pinLength = 4, pinType, spacing, ...inputProps } = props\n\n const inputs: React.ReactNode[] = []\n for (let i = 0; i < pinLength; i++) {\n inputs.push(<PinInputField key={i} ref={ref} />)\n }\n\n return (\n <HStack spacing={spacing}>\n <PinInput {...inputProps} type={pinType}>\n {inputs}\n </PinInput>\n </HStack>\n )\n }),\n {\n isControlled: true,\n }\n)\n\nconst fieldTypes = {\n text: InputField,\n email: InputField,\n url: InputField,\n phone: InputField,\n number: NumberInputField,\n password: PasswordInputField,\n textarea: TextareaField,\n switch: SwitchField,\n checkbox: CheckboxField,\n radio: RadioField,\n pin: PinField,\n select: SelectField,\n 'native-select': NativeSelectField,\n}\n\ntype FieldTypes = typeof fieldTypes\n\ntype FieldType<Props = any> = React.ElementType<Props>\n\ntype TypeProps<P extends FieldType, T> = React.ComponentPropsWithoutRef<P> & {\n type: T\n}\n\ntype FieldTypeProps =\n | {\n [Property in keyof FieldTypes]: TypeProps<FieldTypes[Property], Property>\n }[keyof FieldTypes]\n | { type?: string }\n","import { FieldProps } from './field'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): FieldProps[]\n getNestedFields(name: string): FieldProps[]\n}\n\ninterface SchemaField extends FieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema): FieldProps[] =>\n schema &&\n Object.entries(schema).map(([name, { items, label, title, ...field }]) => {\n return {\n ...field,\n name,\n label: label || title, // json schema compatibility\n }\n })\n\nexport const objectFieldResolver = (schema: ObjectSchema): FieldResolver => {\n const getFields = () => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string) => {\n const field = get(schema, name)\n\n if (!field) return []\n\n if (field.items?.type === 'object') {\n return mapFields(field.items.properties)\n } else if (field.type === 'object') {\n return mapFields(field.properties)\n }\n return [field.items]\n }\n\n return { getFields, getNestedFields }\n}\n","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { cx, MaybeFunction, runIfFn, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n useForm,\n FormProvider,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n ResolverOptions,\n ResolverResult,\n ChangeHandler,\n WatchObserver,\n} from 'react-hook-form'\nimport { objectFieldResolver, FieldResolver } from './field-resolver'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\ninterface FormOptions<TFieldValues extends FieldValues = FieldValues> {\n /**\n * The form schema, currently supports Yup schema only.\n */\n schema?: any\n /**\n * Triggers when any of the field change.\n */\n onChange?: WatchObserver<TFieldValues>\n /**\n * The submit handler.\n */\n onSubmit: SubmitHandler<TFieldValues>\n /**\n * Triggers when there are validation errors.\n */\n onError?: SubmitErrorHandler<TFieldValues>\n /**\n * Ref on the HTMLFormElement.\n */\n formRef?: React.RefObject<HTMLFormElement>\n /**\n * The form children, can be a render prop or a ReactNode.\n */\n children?: MaybeRenderProp<UseFormReturn<TFieldValues>>\n}\n\n// @todo Figure out how to pass down FieldValues to all Field components, if at all possible.\n\nexport interface FormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseFormProps<TFieldValues>,\n Omit<\n HTMLChakraProps<'form'>,\n 'children' | 'onChange' | 'onSubmit' | 'onError'\n >,\n FormOptions<TFieldValues> {}\n\nexport const Form = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const {\n mode = 'all',\n resolver,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n onChange,\n onSubmit,\n onError,\n formRef,\n children,\n ...rest\n } = props\n\n const form = {\n mode,\n resolver,\n defaultValues,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n }\n\n if (schema && !resolver) {\n form.resolver = Form.getResolver?.(schema)\n }\n\n const methods = useForm<TFieldValues>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(ref, () => methods, [ref, methods])\n\n React.useEffect(() => {\n let subscription: any\n if (onChange) {\n subscription = methods.watch(onChange)\n }\n return () => subscription?.unsubscribe()\n }, [methods, onChange])\n\n return (\n <FormProvider {...methods}>\n <chakra.form\n ref={formRef}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('saas-form', props.className)}\n >\n {runIfFn(children, methods)}\n </chakra.form>\n </FormProvider>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: FormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getResolver?: GetResolver\n getFieldResolver: GetFieldResolver\n}\n\nForm.getFieldResolver = objectFieldResolver\n\nif (__DEV__) {\n Form.displayName = 'Form'\n}\n\nexport type GetResolver = (\n schema: any\n) => <TFieldValues extends FieldValues, TContext>(\n values: TFieldValues,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n\nexport type GetFieldResolver = (schema: any) => FieldResolver\n","import * as React from 'react'\n\nimport { chakra, SimpleGrid, SimpleGridProps, useTheme } from '@chakra-ui/react'\nimport { cx, __DEV__ } from '@chakra-ui/utils'\n\nexport type FormLayoutProps = SimpleGridProps\n\ninterface FormLayoutItemProps {\n children: React.ReactNode\n}\n\nconst FormLayoutItem: React.FC<FormLayoutItemProps> = ({ children }) => {\n return <chakra.div>{children}</chakra.div>\n}\n\nif (__DEV__) {\n FormLayoutItem.displayName = 'FormLayoutItem'\n}\n\n/**\n * FormLayout\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.FormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('saas-form__layout', props.className)}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return <FormLayoutItem>{child}</FormLayoutItem>\n }\n return child\n })}\n </SimpleGrid>\n )\n}\n\nif (__DEV__) {\n FormLayout.displayName = 'FormLayout'\n}\n","import * as React from 'react'\n\nexport const mapNestedFields = (name: string, children: React.ReactNode) => {\n return React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child.props.name) {\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${child.props.name}`,\n })\n }\n return child\n })\n}\n","import * as React from 'react'\nimport {\n useFieldArray,\n useFormContext,\n UseFieldArrayReturn,\n} from 'react-hook-form'\n\nimport { createContext } from '@chakra-ui/react-utils'\n\nexport interface UseArrayFieldReturn extends UseFieldArrayReturn {\n /**\n * The array field name\n */\n name: string\n /**\n * The default value for new items\n */\n defaultValue: Record<string, any>\n /**\n * Min amount of items\n */\n min?: number\n /**\n * Max amount of items\n */\n max?: number\n}\n\nexport const [ArrayFieldProvider, useArrayFieldContext] =\n createContext<UseArrayFieldReturn>({\n name: 'ArrayFieldContext',\n })\n\nexport interface UseArrayFieldRowReturn {\n /**\n * Name of the array field including the index, eg 'field.0'\n */\n name: string\n /**\n * The field index\n */\n index: number\n /**\n * Remove this array item\n */\n remove: () => void\n /**\n * True if this is the first item\n */\n isFirst: boolean\n /**\n * True if this is the last item\n */\n isLast: boolean\n}\n\nexport const [ArrayFieldRowProvider, useArrayFieldRowContext] =\n createContext<UseArrayFieldRowReturn>({\n name: 'ArrayFieldRowContext',\n })\n\nexport interface ArrayFieldOptions {\n /**\n * The field name\n */\n name: string\n /**\n * Default value for new values in the array\n */\n defaultValue?: Record<string, any>\n /**\n * Default key name for rows, change this if your data uses a different 'id' field\n * @default \"id\"\n */\n keyName?: string\n min?: number\n max?: number\n}\n\nexport const useArrayField = ({\n name,\n defaultValue = {},\n keyName,\n min,\n max,\n}: ArrayFieldOptions) => {\n const { control } = useFormContext()\n const context = useFieldArray({\n control,\n name,\n keyName,\n })\n\n return {\n ...context,\n name,\n defaultValue,\n min,\n max,\n }\n}\n\nexport interface UseArrayFieldRowProps {\n index: number\n}\n\nexport const useArrayFieldRow = ({ index }: UseArrayFieldRowProps) => {\n const { clearErrors } = useFormContext()\n const { name, remove, fields } = useArrayFieldContext()\n\n React.useEffect(() => {\n // reset errors, to make sure min/max errors reset correctly\n clearErrors(name)\n }, [])\n\n return {\n index,\n isFirst: index === 0,\n isLast: index === fields.length - 1,\n name: `${name}.${index}`,\n remove: React.useCallback(() => {\n clearErrors(name)\n remove(index)\n }, [index]),\n }\n}\n\nexport const useArrayFieldRemoveButton = () => {\n const { isFirst, remove } = useArrayFieldRowContext()\n const { min, fields } = useArrayFieldContext()\n\n const isDisabled = isFirst && !!(min && fields.length <= min)\n\n return {\n onClick: () => remove(),\n isDisabled,\n }\n}\n\nexport const useArrayFieldAddButton = () => {\n const { append, defaultValue, max, fields } = useArrayFieldContext()\n\n const isDisabled = !!(max && fields.length >= max)\n\n return {\n onClick: () =>\n append(defaultValue, {\n shouldFocus: false,\n }),\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport { chakra, ResponsiveValue, forwardRef } from '@chakra-ui/system'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { AddIcon, MinusIcon } from '@chakra-ui/icons'\nimport { IconButton, ButtonProps } from '@saas-ui/button'\n\nimport { FormLayout, FormLayoutProps } from './layout'\nimport { BaseField, FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nimport {\n useArrayField,\n useArrayFieldRow,\n useArrayFieldContext,\n ArrayFieldProvider,\n ArrayFieldOptions,\n ArrayFieldRowProvider,\n useArrayFieldRowContext,\n useArrayFieldRemoveButton,\n useArrayFieldAddButton,\n UseArrayFieldReturn,\n} from './use-array-field'\n\ninterface ArrayField {\n id: string\n [key: string]: unknown\n}\n\ninterface ArrayFieldRowProps extends FormLayoutProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n /**\n * The array index\n */\n index: number\n /**\n * The fields\n */\n children: React.ReactNode\n}\n\nexport const ArrayFieldRow: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n ...rowFieldsProps\n}) => {\n return (\n <ArrayFieldRowContainer index={index}>\n <ArrayFieldRowFields {...rowFieldsProps}>{children}</ArrayFieldRowFields>\n <ArrayFieldRemoveButton />\n </ArrayFieldRowContainer>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRow.displayName = 'ArrayFieldRow'\n}\n\nexport interface ArrayFieldRowFieldsProps extends FormLayoutProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n /**\n * The fields\n */\n children: React.ReactNode\n}\n\nexport const ArrayFieldRowFields: React.FC<ArrayFieldRowFieldsProps> = ({\n children,\n ...layoutProps\n}) => {\n const { name } = useArrayFieldRowContext()\n return (\n <FormLayout flex=\"1\" mr=\"2\" {...layoutProps}>\n {mapNestedFields(name, children)}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n}\n\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n}) => {\n const context = useArrayFieldRow({ index })\n\n const styles = {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'flex-end',\n width: '100%',\n mb: 4,\n }\n\n return (\n <ArrayFieldRowProvider value={context}>\n <chakra.div __css={styles}>{children}</chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n}\n\nexport const ArrayFieldRemoveButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<MinusIcon />}\n aria-label=\"Remove row\"\n {...useArrayFieldRemoveButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n}\n\nexport const ArrayFieldAddButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<AddIcon />}\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n}\n\nexport interface ArrayFieldProps\n extends ArrayFieldOptions,\n Omit<FieldProps, 'defaultValue'> {}\n\nexport const ArrayField = forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>\n {(fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n ))}\n </>\n )}\n </ArrayFieldRows>\n <ArrayFieldAddButton />\n </ArrayFieldContainer>\n )\n }\n) as ((\n props: ArrayFieldProps & {\n ref?: React.ForwardedRef<UseArrayFieldReturn>\n }\n) => React.ReactElement) & {\n displayName: string\n}\n\nif (__DEV__) {\n ArrayField.displayName = 'ArrayField'\n}\n\nexport interface ArrayFieldRowsProps {\n children: (fields: ArrayField[]) => React.ReactElement | null\n}\n\nexport const ArrayFieldRows = ({\n children,\n}: ArrayFieldRowsProps): React.ReactElement | null => {\n const { fields } = useArrayFieldContext()\n return children(fields)\n}\n\nif (__DEV__) {\n ArrayFieldRows.displayName = 'ArrayFieldRows'\n}\n\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min,\n max,\n })\n\n // This exposes the useArrayField api through the forwarded ref\n React.useImperativeHandle(ref, () => context, [ref, context])\n\n return (\n <ArrayFieldProvider value={context}>\n <BaseField name={name} {...fieldProps}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nif (__DEV__) {\n ArrayFieldContainer.displayName = 'ArrayFieldContainer'\n}\n","import * as React from 'react'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyleConfig,\n} from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { FormLayout } from './layout'\nimport { FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nexport interface ObjectFieldProps extends FieldProps {\n name: string\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyleConfig('FormLegend')\n return <FormLabel as=\"legend\" sx={styles} {...props} />\n}\n\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const { name, label, hideLabel, children, columns, spacing, ...fieldProps } =\n props\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps}>\n <FormLegend display={hideLabel ? 'none' : 'block'}>{label}</FormLegend>\n <FormLayout columns={columns} gridGap={spacing}>\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n ObjectField.displayName = 'ObjectField'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form } from './form'\nimport { FormLayout } from './layout'\nimport { Field, FieldProps } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\nimport { useFormContext } from 'react-hook-form'\n\nexport interface FieldsProps {\n schema: any\n fieldResolver?: FieldResolver\n focusFirstField?: boolean\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n ({ name, type, ...nestedFieldProps }: FieldProps, i): React.ReactNode => (\n <Field key={name || i} name={name} type={type} {...nestedFieldProps} />\n )\n )\n}\n\nexport const Fields: React.FC<FieldsProps> = ({\n schema,\n fieldResolver,\n focusFirstField,\n ...props\n}) => {\n const resolver = React.useMemo(\n () => fieldResolver || Form.getFieldResolver(schema),\n [schema, fieldResolver]\n )\n\n const fields = React.useMemo(() => resolver.getFields(), [resolver])\n\n const form = useFormContext()\n\n React.useEffect(() => {\n if (focusFirstField && fields[0]?.name) {\n form.setFocus(fields[0].name)\n }\n }, [schema, fieldResolver, focusFirstField])\n\n return (\n <FormLayout {...props}>\n {fields.map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: FieldProps): React.ReactNode => {\n if (type === 'array') {\n return (\n <ArrayField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ArrayField>\n )\n } else if (type === 'object') {\n return (\n <ObjectField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ObjectField>\n )\n }\n\n return <Field key={name} name={name} type={type} {...fieldProps} />\n }\n )}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n Fields.displayName = 'Fields'\n}\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { __DEV__ } from '@chakra-ui/utils'\n\nexport interface SubmitButtonProps extends ButtonProps {\n /**\n * Disable the submit button if the form is untouched.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfUntouched`\n */\n disableIfUntouched?: boolean\n /**\n * Disable the submit button if the form is invalid.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfInvalid`\n */\n disableIfInvalid?: boolean\n}\n\nexport const SubmitButton = React.forwardRef<\n HTMLButtonElement,\n SubmitButtonProps\n>((props, ref) => {\n const {\n children,\n disableIfUntouched,\n disableIfInvalid,\n isDisabled: isDisabledProp,\n isLoading,\n ...rest\n } = props\n const { formState } = useFormContext()\n\n const isDisabled =\n (disableIfUntouched && !formState.isDirty) ||\n (disableIfInvalid && !formState.isValid) ||\n isDisabledProp\n\n return (\n <Button\n {...rest}\n ref={ref}\n variant=\"primary\"\n type=\"submit\"\n isLoading={formState.isSubmitting || isLoading}\n isDisabled={isDisabled}\n >\n {children}\n </Button>\n )\n})\n\nSubmitButton.defaultProps = {\n label: 'Submit',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nif (__DEV__) {\n SubmitButton.displayName = 'SubmitButton'\n}\n","import * as React from 'react'\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\nimport { forwardRef } from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form, FormProps } from './form'\nimport { FormLayout } from './layout'\nimport { Fields } from './fields'\nimport { SubmitButton } from './submit-button'\nimport { FieldResolver } from '.'\n\ninterface AutoFormOptions {\n /**\n * The submit button label.\n * Pass `null` to render no submit button.\n */\n submitLabel?: React.ReactNode\n /**\n * The schema.\n * Supports object schema, Zod, Yup or Ajv (JSON Schema).\n * @see https://www.saas-ui.dev/docs/forms/auto-form\n */\n schema: any\n /**\n * The field resolver.\n */\n fieldResolver?: any\n}\n\nexport interface AutoFormProps<TFieldValues extends FieldValues>\n extends Omit<FormProps<TFieldValues>, 'schema' | 'children'>,\n AutoFormOptions {\n children?: React.ReactNode\n}\n\nexport const AutoForm = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: AutoFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const {\n schema,\n submitLabel = 'Submit',\n fieldResolver,\n children,\n ...rest\n } = props\n\n return (\n <Form {...rest} schema={schema} ref={ref}>\n <FormLayout>\n {<Fields schema={schema} fieldResolver={fieldResolver} />}\n {submitLabel && <SubmitButton>{submitLabel}</SubmitButton>}\n {children}\n </FormLayout>\n </Form>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: AutoFormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getFieldResolver?: (schema: any) => FieldResolver\n}\n\nif (__DEV__) {\n AutoForm.displayName = 'AutoForm'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport {\n useFormContext,\n useWatch,\n FieldValues,\n UseFormReturn,\n} from 'react-hook-form'\n\nexport interface DisplayIfProps<\n TFieldValues extends FieldValues = FieldValues\n> {\n children: React.ReactElement\n name: string\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n\nexport const DisplayIf = <TFieldValues extends FieldValues = FieldValues>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues>) => {\n const value = useWatch({\n name,\n defaultValue,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext<TFieldValues>()\n return condition(value, context) ? children : null\n}\n\nif (__DEV__) {\n DisplayIf.displayName = 'DisplayIf'\n}\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext, MaybeRenderProp } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/stepper'\n\nexport interface StepState {\n name: string\n schema?: any\n resolver?: any\n isActive?: boolean\n isCompleted?: boolean\n onSubmit?: FormStepSubmitHandler\n}\n\nexport type FormStepSubmitHandler<\n TFieldValues extends FieldValues = FieldValues\n> = (data: TFieldValues, stepper: UseStepperReturn) => Promise<void>\n\nexport interface StepFormContext extends UseStepperReturn {\n updateStep(state: StepState): void\n steps: Record<string, StepState>\n}\n\nexport const [StepFormProvider, useStepFormContext] =\n createContext<StepFormContext>({\n name: 'StepFormContext',\n errorMessage:\n 'useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`',\n })\n\nimport { FormProps } from './form'\n\nexport interface UseStepFormProps<\n TFieldValues extends FieldValues = FieldValues\n> extends Omit<UseStepperProps, 'onChange'>,\n Omit<FormProps<TFieldValues>, 'children'> {\n children: MaybeRenderProp<UseStepFormReturn<TFieldValues>>\n}\n\nexport interface UseStepFormReturn<\n TFieldValues extends FieldValues = FieldValues\n> extends UseStepperReturn {\n getFormProps(): {\n onSubmit: SubmitHandler<TFieldValues>\n schema?: any\n resolver?: any\n }\n updateStep(step: any): void\n steps: Record<string, any>\n}\n\nexport function useStepForm<TFieldValues extends FieldValues = FieldValues>(\n props: UseStepFormProps<TFieldValues>\n): UseStepFormReturn<TFieldValues> {\n const { onChange, ...rest } = props\n const stepper = useStepper(rest)\n\n const { activeStep, isLastStep, nextStep } = stepper\n\n const [steps, updateSteps] = React.useState<Record<string, StepState>>({})\n\n const onSubmitStep: SubmitHandler<TFieldValues> = React.useCallback(\n async (data) => {\n try {\n const step = steps[activeStep]\n\n if (isLastStep) {\n await props.onSubmit?.(data)\n\n updateStep({\n ...step,\n isCompleted: true,\n })\n\n nextStep() // show completed step\n return\n }\n\n await step.onSubmit?.(data, stepper)\n\n nextStep()\n } catch (e) {\n // Step submission failed.\n }\n },\n [steps, activeStep, isLastStep]\n )\n\n const getFormProps = React.useCallback(() => {\n const step = steps[activeStep]\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.resolver,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: step,\n }\n })\n },\n [steps]\n )\n\n return {\n getFormProps,\n updateStep,\n steps,\n ...stepper,\n }\n}\n\nexport interface UseFormStepProps {\n name: string\n schema?: any\n resolver?: any\n onSubmit?: FormStepSubmitHandler\n}\n\nexport function useFormStep(props: UseFormStepProps): StepState {\n const { name, schema, resolver, onSubmit } = props\n const step = useStep({ name })\n\n const { steps, updateStep } = useStepFormContext()\n\n React.useEffect(() => {\n updateStep({ name, schema, resolver, onSubmit })\n }, [name, schema])\n\n return {\n ...step,\n ...(steps[name] || { name, schema }),\n }\n}\n","import * as React from 'react'\n\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\n\nimport { chakra, HTMLChakraProps, ThemingProps } from '@chakra-ui/system'\n\nimport { callAllHandlers, runIfFn, cx, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n StepperProvider,\n StepperSteps,\n StepperStepsProps,\n StepperStep,\n useStepperContext,\n StepperContainer,\n StepperProps,\n} from '@saas-ui/stepper'\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { Form } from './form'\nimport { SubmitButton } from './submit-button'\n\nimport {\n useStepForm,\n useFormStep,\n StepFormProvider,\n UseStepFormProps,\n FormStepSubmitHandler,\n} from './use-step-form'\n\nexport interface StepFormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseStepFormProps<TFieldValues> {}\n\nexport const StepForm = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: StepFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const { children, ...rest } = props\n\n const stepper = useStepForm<TFieldValues>(props)\n\n const { getFormProps, ...ctx } = stepper\n\n const context = React.useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, stepper)}\n </Form>\n </StepFormProvider>\n </StepperProvider>\n )\n }\n) as <TFieldValues extends FieldValues>(\n props: StepFormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement\n\nexport interface FormStepOptions {\n /**\n * The step name\n */\n name: string\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport interface FormStepperProps\n extends StepperStepsProps,\n ThemingProps<'Stepper'> {}\n\nexport const FormStepper: React.FC<FormStepperProps> = (props) => {\n const { activeIndex, setIndex } = useStepperContext()\n\n const { children, orientation, variant, colorScheme, size, ...rest } = props\n\n const elements = React.Children.map(children, (child) => {\n if (\n React.isValidElement<FormStepProps>(child) &&\n child?.type === FormStep\n ) {\n const { isCompleted } = useFormStep(child.props) // Register this step\n return (\n <StepperStep\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n {...rest}\n >\n {child.props.children}\n </StepperStep>\n )\n }\n return child\n })\n\n const onChange = React.useCallback((i: number) => {\n setIndex(i)\n }, [])\n\n return (\n <StepperContainer\n orientation={orientation}\n step={activeIndex}\n variant={variant}\n colorScheme={colorScheme}\n size={size}\n onChange={onChange}\n >\n <StepperSteps mb=\"4\" {...props}>\n {elements}\n </StepperSteps>\n </StepperContainer>\n )\n}\n\nexport interface FormStepProps\n extends FormStepOptions,\n Omit<HTMLChakraProps<'div'>, 'onSubmit'> {\n onSubmit?: FormStepSubmitHandler\n}\n\nexport const FormStep: React.FC<FormStepProps> = (props) => {\n const { name, schema, resolver, children, className, onSubmit, ...rest } =\n props\n const step = useFormStep({ name, schema, resolver, onSubmit })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('saas-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nif (__DEV__) {\n FormStep.displayName = 'FormStep'\n}\n\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n label=\"Back\"\n {...props}\n className={cx('saas-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nif (__DEV__) {\n PrevButton.displayName = 'PrevButton'\n}\n\nexport interface NextButtonProps extends ButtonProps {\n submitLabel?: string\n}\n\nexport const NextButton: React.FC<NextButtonProps> = (props) => {\n const { label = 'Next', submitLabel = 'Complete', ...rest } = props\n const { isLastStep, isCompleted } = useStepperContext()\n\n return (\n <SubmitButton\n {...rest}\n isDisabled={isCompleted}\n className={cx('saas-form__next-button', props.className)}\n >\n {isLastStep || isCompleted ? submitLabel : label}\n </SubmitButton>\n )\n}\n\nif (__DEV__) {\n NextButton.displayName = 'NextButton'\n}\n","import {\n FieldValues,\n useFormContext,\n UseFormReturn,\n useWatch,\n} from 'react-hook-form'\n\nexport interface WatchFieldProps<\n Value = unknown,\n TFieldValues extends FieldValues = FieldValues\n> {\n name: string\n defaultValue?: Value\n isDisabled?: boolean\n isExact?: boolean\n children: (\n value: Value,\n form: UseFormReturn<TFieldValues>\n ) => React.ReactElement | void\n}\n\nexport const WatchField = <\n Value = unknown,\n TFieldValues extends FieldValues = FieldValues\n>(\n props: WatchFieldProps<Value, TFieldValues>\n) => {\n const { name, defaultValue, isDisabled, isExact } = props\n const form = useFormContext<TFieldValues>()\n\n const field = useWatch({\n name,\n defaultValue,\n disabled: isDisabled,\n exact: isExact,\n })\n\n return props.children(field, form) || null\n}\n"],"names":["_excluded","DisplayField","_ref","name","label","props","React","createElement","FormControl","FormLabel","htmlFor","Text","fontSize","FormValue","__DEV__","displayName","_ref2","getValues","useFormContext","_excluded2","_excluded3","_excluded4","_excluded5","_excluded6","_excluded7","_excluded8","_excluded9","_excluded10","inputTypes","BaseField","help","hideLabel","children","controlProps","formState","get","errors","getError","_extends","isInvalid","error","Box","message","FormHelperText","FormErrorMessage","Field","forwardRef","ref","_props$type","type","defaultInputType","withControlledInput","InputComponent","_ref3","rules","inputProps","_objectWithoutPropertiesLoose","Controller","control","render","_ref4","_ref4$field","field","onChange","callAllHandlers","onBlur","useMergeRefs","_ref5","register","_register","registerFieldType","component","options","id","isDisabled","isReadOnly","isRequired","inputRules","required","undefined","createField","isControlled","withUncontrolledInput","split","map","part","charAt","toUpperCase","slice","join","_ref6$type","leftAddon","_ref6","rightAddon","size","rest","input","Input","InputGroup","NumberInputField","NumberInput","PasswordInputField","PasswordInput","TextareaField","Textarea","SwitchField","_ref7","Switch","SelectField","Select","CheckboxField","_ref8","Checkbox","RadioInput","NativeSelectField","NativeSelect","PinField","pinLength","_props$pinLength","pinType","spacing","inputs","i","push","PinInputField","key","HStack","PinInput","schema","Object","entries","title","_ref$","objectFieldResolver","getFields","getNestedFields","_field$items","items","mapFields","properties","Form","mode","_props$mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","defaultValues","onSubmit","onError","formRef","form","getResolver","methods","useForm","handleSubmit","useImperativeHandle","useEffect","subscription","watch","_subscription","unsubscribe","FormProvider","chakra","className","cx","runIfFn","getFieldResolver","FormLayoutItem","div","FormLayout","_theme$components$For","_theme$components","_theme$components$For2","gridProps","theme","useTheme","components","defaultProps","SimpleGrid","Children","child","isValidElement","mapNestedFields","cloneElement","createContext","ArrayFieldProvider","useArrayFieldContext","_createContext","ArrayFieldRowProvider","useArrayFieldRowContext","useArrayField","_ref$defaultValue","defaultValue","keyName","min","max","context","useFieldArray","useArrayFieldRow","index","clearErrors","_useArrayFieldContext","remove","fields","isFirst","isLast","length","useCallback","useArrayFieldRemoveButton","_useArrayFieldRowCont","_useArrayFieldContext2","onClick","append","_useArrayFieldContext3","shouldFocus","ArrayFieldRow","rowFieldsProps","ArrayFieldRowContainer","ArrayFieldRowFields","ArrayFieldRemoveButton","layoutProps","flex","mr","value","__css","display","flexDirection","alignItems","width","mb","IconButton","icon","MinusIcon","ArrayFieldAddButton","AddIcon","float","useArrayFieldAddButton","ArrayField","containerProps","ArrayFieldContainer","ArrayFieldRows","Fragment","fieldProps","FormLegend","styles","useStyleConfig","as","sx","columns","gridGap","ObjectField","_resolver$getNestedFi","nestedFieldProps","Fields","fieldResolver","focusFirstField","useMemo","_fields$","setFocus","SubmitButton","disableIfUntouched","disableIfInvalid","isDisabledProp","isLoading","Button","variant","isSubmitting","isDirty","isValid","AutoForm","submitLabel","_props$submitLabel","DisplayIf","condition","_ref$condition","useWatch","disabled","exact","isExact","errorMessage","StepFormProvider","useStepFormContext","useStepForm","stepper","useStepper","activeStep","isLastStep","nextStep","_React$useState","useState","steps","updateSteps","onSubmitStep","data","step","_temp","then","updateStep","isCompleted","_exit","_temp2","getFormProps","_extends2","useStep","StepForm","ctx","StepperProvider","FormStep","useFormStep","isActive","PrevButton","useStepperContext","prevStep","isFirstStep","_useStepperContext2","NextButton","_props$label","_useStepperContext3","activeIndex","setIndex","_useStepperContext","orientation","colorScheme","elements","StepperStep","_useFormStep","StepperContainer","StepperSteps"],"mappings":"okCAAA,IAAAA,EAAA,CAAA,OAAA,QAAA,eAiByBC,EAAgC,SAAAC,GACvDC,IAAAA,EAAAA,EAAAA,KACAC,EAAAA,EAAAA,MAEGC,sBAEH,OACEC,EAAAC,cAACC,EAADA,YAAiBH,EACdD,eAAQE,EAACC,cAAAE,EAADA,UAAW,CAAAC,QAASP,GAAOC,GAAqB,kBACzDE,EAAAC,cAACI,EAADA,KAAA,CAAMC,SAAS,mBACbN,EAACC,cAAAM,EAAU,CAAAV,KAAMA,KAIxB,EAEGW,EAAAA,UACFb,EAAac,YAAc,gBAGhBF,MAAwC,SAAAG,GAAGb,IAAAA,EAAAA,EAAAA,KAEtD,OAAOc,EADeC,EAAcA,iBAA5BD,WACSd,IAAS,IAC3B,EAEGW,EAAAA,UACFD,EAAUE,YAAc,aC3C1B,IAAAf,EAAA,CAAA,OAAA,QAAA,OAAA,YAAA,YAAAmB,EAAA,CAAA,KAAA,OAAA,QAAA,OAAA,aAAA,YAAA,aAAA,aAAA,SAAAC,EAAA,CAAA,OAAA,SAAAC,EAAA,CAAA,OAAAC,EAAA,CAAA,OAAA,SAAAC,EAAA,CAAA,OAAAC,EAAA,CAAA,OAAA,YAAA,aAAA,QAAAC,EAAA,CAAA,QAAAC,EAAA,CAAA,QAAA,QAAAC,EAAA,CAAA,YAAA,UAAA,WA4GMC,EAA4C,CAAA,EAmB5BC,EAAyB,SAACxB,GAC9C,IAAQF,EAA4DE,EAA5DF,KAAMC,EAAsDC,EAAtDD,MAAO0B,EAA+CzB,EAA/CyB,KAAMC,EAAyC1B,EAAzC0B,UAAWC,EAA8B3B,EAA9B2B,SAAaC,EAAiB5B,EAAAA,OAZrD,SAACF,EAAc+B,GAC9B,OAAOC,MAAID,EAAUE,OAAQjC,EAC9B,CAcekC,CAASlC,EAFDe,mBAAdgB,wBAIR,OACE5B,gBAACE,cAAD8B,EAAA,CAAA,EAAiBL,EAAjB,CAA+BM,YAAaC,IACzCpC,IAAU2B,eAAYzB,EAACC,cAAAE,EAAAA,UAAWL,KAAAA,GAAqB,kBACxDE,EAAAC,cAACkC,MACET,KAAAA,GACAF,GAASU,MAAAA,GAAAA,EAAOE,QAEb,kBADFpC,EAAAC,cAACoC,EAADA,eAAiBb,KAAAA,IAEb,MAALU,SAAAA,EAAOE,uBACNpC,gBAACsC,EAAAA,iBAAD,KAAA,MAAmBJ,OAAnB,EAAmBA,EAAOE,UAKnC,EAEG5B,YACFe,EAAUd,YAAc,aAwBb8B,MAAQvC,EAAMwC,WACzB,SACEzC,EACA0C,GAEA,IAAAC,EAAoC3C,EAA5B4C,kBAGR,OAAO3C,gBAtEQsB,OAmEAsB,IAAAA,EAtEM,WAGItB,EAAU,KAsE5BU,EAAA,CAAgBS,IAAKA,GAAS1C,GACtC,GAmE6B8C,EAAG,SAACC,GAClC,OAAON,EAAAA,WACL,SAAAO,EAAiCN,GAAO,IAAA5C,EAAAkD,EAArClD,KAAMmD,EAAAA,EAAAA,MAAUC,EAAqBC,EAAAH,EAAAjC,GAClBF,EAAAA,EAAAA,8BAEpB,OACEZ,EAAAC,cAACkD,EAADA,WAAA,CACEtD,KAAMA,EACNuD,QALIA,EAAAA,QAMJJ,MAAOA,EACPK,OAAQ,SAAAC,GAAA,IAAAC,EAAAD,EAAGE,MAAc5D,EAAL6C,EAAAA,IAAce,EAA1BN,EAAAK,EAAAxC,gBAAA,OACNf,EAACC,cAAA6C,OACKU,EACAP,EAFN,CAGEQ,SAAUC,EAAeA,gBAACT,EAAWQ,SAAUD,EAAMC,UACrDE,OAAQD,EAAAA,gBAAgBT,EAAWU,OAAQH,EAAMG,QACjDlB,IAAKmB,EAAYA,aAACnB,EAAK7C,KANnB,GAWb,EAEJ,IAEoC,SAACkD,GACpC,OAAiBN,EAAAA,WACf,SAAiCC,EAAAA,GAA9B5C,IAAAA,EAAAA,EAAAA,KAAMmD,EAA+Ba,EAA/Bb,MAAUC,EACjBC,EAAAW,EAAA7C,MAEgC8C,EAFXlD,EAAAA,iBAAbkD,UAEiCjE,EAAMmD,GAAlCpD,EAAbmE,EAAQtB,IAAce,EAEtBN,EAAAa,EAAA9C,gBAAA,OACEjB,gBAAC8C,EAADd,EAAA,CAAA,EACMwB,EACAP,EACJ,CAAAQ,SAAUC,EAAeA,gBAACT,EAAWQ,SAAUD,EAAMC,UACrDE,OAAQD,EAAAA,gBAAgBT,EAAWU,OAAQH,EAAMG,QACjDlB,IAAKmB,eAAanB,EAAK7C,KAG5B,EAEJ,EAgB6BoE,EAAG,SAC/BrB,EACAsB,EACAC,GAEA,IAOW3B,EA1HO,SAClBO,EADkBpC,OAGhBD,EAAAC,EADAD,YAAagB,EAAAA,EAAAA,UAAWF,IAAAA,UAEpBgB,EAAQC,aAAW,SAACzC,EAAO0C,GAC/B,MAWI1C,EAVFoE,GACAtE,EASEE,EATFF,KACAC,EAQEC,EARFD,MACA0B,EAOEzB,EAPFyB,KACA4C,EAMErE,EANFqE,WACAnC,EAKElC,EALFkC,UACAoC,EAIEtE,EAJFsE,WACAC,EAGEvE,EAHFuE,WACAtB,EAEEjD,EAFFiD,MACGC,IACDlD,EAXJc,GAaM0D,KACJC,SAAUF,GACPtB,gBAGL,OACEhD,EAAAC,cAACsB,EACC,CAAA4C,GAAIA,EACJtE,KAAMA,EACNC,MAAOA,EACP0B,KAAMA,EACNC,UAAWA,EACX2C,WAAYA,EACZnC,UAAWA,EACXoC,WAAYA,EACZC,WAAYA,gBAEZtE,EAACC,cAAA6C,KACCL,IAAKA,EACL0B,GAAIA,EACJtE,KAAMA,EACNC,MAAO2B,EAAY3B,OAAQ2E,EAC3BzB,MAAOuB,GACHtB,IAIX,GAGD,OAFAV,EAAM9B,YAAcA,EAGrB8B,CAAA,CAyEemC,OANVR,GAAAA,EAASS,aACM9B,EAAoBoB,GAEpBW,EAAsBX,GAGC,CACxCxD,YAAgBkC,EACbkC,MAAM,KACNC,IAAI,SAACC,GAAD,OAAcA,EAACC,OAAO,GAAGC,cAAgBF,EAAKG,MAAM,EAApD,GACJC,KAAK,IAJgC,QAKxC1D,UAAWyC,MAAAA,OAAAA,EAAAA,EAASzC,UACpBF,WAAkB,MAAP2C,OAAAA,EAAAA,EAAS3C,YAAaA,IAKnC,OAFAD,EAAWqB,GAAQJ,GAGpB,IAQyByB,EACxB,OACAxB,aAAW,SAA0DC,EAAAA,GAAvDE,IAAAA,EAAAA,EAAAA,KAAAA,aAAO,OAAuDyC,EAA/CC,EAA+CC,EAA/CD,UAAWE,EAAAA,EAAAA,WAAYC,EAAwBF,EAAxBE,KAASC,EAC3DvC,EAAAoC,EAAApE,GAAWwE,eAAG1F,gBAAC2F,QAAD3D,EAAA,CAAOW,KAAMA,EAAM6C,KAAMA,GAAUC,EAAnC,CAAyChD,IAAKA,KAC5D,OAAI4C,GAAaE,eAEbvF,gBAAC4F,aAAD,CAAYJ,KAAMA,GACfH,EACAK,EACAH,IAKR,IAOUM,EAAmB7B,EAC9B,SACA8B,cACA,CACEnB,cAAc,IAILoB,EAAqB/B,EAChC,WACAxB,aAAW,SAACzC,EAAO0C,uBAAQzC,EAACC,cAAA+F,EAADA,cAAehE,EAAA,CAAAS,IAAKA,GAAS1C,GAA7C,IAGakG,EAAGjC,EAC3B,WACAkC,YAGWC,EAAcnC,EACzB,SACAxB,aAAW,WAAoBC,GAAjBE,IAAS8C,EAAevC,EAAAkD,EAAAjF,gBACpC,OAAOnB,EAACC,cAAAoG,EAAAA,OAAWZ,EAAAA,GAAAA,GAAMhD,IAAKA,IAC/B,GACD,CACEkC,cAAc,IAIL2B,EAActC,EAA+B,SAAUuC,SAAQ,CAC1E5B,cAAc,IAGH6B,EAAgBxC,EAC3B,WACAxB,aAAW,SAAAiE,EAA4BhE,GAAzB3C,IAAgCA,EAAA2G,EAAhC3G,MAAgBC,sBAC5B,OACEC,EAAAC,cAACyG,EAADA,SAAA1E,EAAA,CAAUS,IAAKA,GAAS1C,GACrBD,EAGN,GACD,CACE2B,WAAW,MAIWuC,EACxB,QACA2C,aACA,CACEhC,cAAc,IAILiC,EAAoB5C,EAC/B,gBACA6C,eACA,CAAElC,cAAc,IASLmC,EAAW9C,EACtB,MACAxB,aAAW,SAACzC,EAAO0C,GAIjB,IAHA,IAA2D1C,EAAAA,EAAnDgH,UAAAA,OAAR,IAAAC,EAAoB,EAAGC,EAAAA,EAAoClH,EAApCkH,QAASC,EAA2BnH,EAA3BmH,QAAYjE,IAAelD,EAA3DsB,GAEM8F,EAA4B,KACrB,EAAGC,EAAIL,EAAWK,IAC7BD,EAAOE,kBAAKrH,EAACC,cAAAqH,EAAAA,cAAc,CAAAC,IAAKH,EAAG3E,IAAKA,kBAG1C,OACEzC,gBAACwH,SAAD,CAAQN,QAASA,gBACflH,EAAAC,cAACwH,WAADzF,EAAA,CAAA,EAAciB,EAAY,CAAAN,KAAMsE,IAC7BE,GAIR,GACD,CACExC,cAAc,IC9blBjF,EAAA,CAAA,QAAA,QAAA,WAckB,SAACgI,GACjBA,OAAAA,GACAC,OAAOC,QAAQF,GAAQ5C,IAAI,SAAAlF,GAAEC,IAAAA,cAAeC,EAAAA,EAAAA,MAAO+H,EAAsBC,EAAtBD,MACjD,OAAA7F,EAAA,CAAA,EAAAkB,EAAA4E,EAAApI,GAEEG,CAAAA,KAAAA,EACAC,MAAOA,GAAS+H,GAEnB,EARe,EAULE,EAAsB,SAACL,GAiBlC,MAAO,CAAEM,UAhBS,WAChB,SAAiBN,EAClB,EAcmBO,gBAbI,SAACpI,GACvB,IAAAqI,EAAW1E,EAAG3B,MAAI6F,EAAQ7H,GAE1B,OAAK2D,EAEqB,YAATb,OAAbuF,EAAA1E,EAAM2E,YAAOxF,EAAAA,EAAAA,MACRyF,EAAU5E,EAAM2E,MAAME,YACL,WAAf7E,EAAMb,OACEa,EAAM6E,YAElB,CAAC7E,EAAM2E,OAPK,EAQpB,EAGF,EC5CDzI,EAAA,CAAA,OAAA,WAAA,iBAAA,mBAAA,mBAAA,4BAAA,eAAA,aAAA,SAAA,gBAAA,WAAA,WAAA,UAAA,UAAA,YA4DiB4I,EAAG9F,aAClB,SACEzC,EACA0C,GAEA,IAiBI1C,EAAAA,EAhBFwI,KAAAA,OADF,IAAAC,EACS,MACPC,EAAAA,EAeE1I,EAfF0I,SACAC,EAcE3I,EAdF2I,eACAC,EAaE5I,EAbF4I,iBACAC,EAYE7I,EAZF6I,iBACAC,EAWE9I,EAXF8I,0BACAC,EAUE/I,EAVF+I,aACAC,EASEhJ,EATFgJ,WACArB,EAQE3H,EARF2H,OACAsB,EAOEjJ,EAPFiJ,cACAvF,EAME1D,EANF0D,SACAwF,EAKElJ,EALFkJ,SACAC,EAIEnJ,EAJFmJ,QACAC,EAGEpJ,EAHFoJ,QACAzH,EAEE3B,EAFF2B,SACG+D,EAhBLvC,EAiBInD,EAEJL,KAAa,CACX6I,KAAAA,EACAE,SAAAA,EACAO,cAAAA,EACAN,eAAAA,EACAC,iBAAAA,EACAC,iBAAAA,EACAC,0BAAAA,EACAC,aAAAA,EACAC,WAAAA,GAGErB,IAAWe,IACbW,EAAKX,SAAWH,MAAAA,EAAKe,iBAALf,EAAAA,EAAKe,YAAc3B,IAGrC,IAAM4B,EAAUC,EAAAA,QAAsBH,GAC9BI,EAAiBF,EAAjBE,aAaR,OAVAxJ,EAAMyJ,oBAAoBhH,EAAK,WAAM6G,OAAAA,CAAN,EAAe,CAAC7G,EAAK6G,IAEpDtJ,EAAM0J,UAAU,WACd,IAAIC,EAIJ,OAHIlG,IACFkG,EAAeL,EAAQM,MAAMnG,IAExB,WAAA,IAAAoG,EAAA,OAAM,OAANA,EAAMF,QAAA,EAAAE,EAAcC,aAApB,CACR,EAAE,CAACR,EAAS7F,iBAGXzD,EAAAC,cAAC8J,eAAiBT,eAChBtJ,EAAAC,cAAC+J,EAAAA,OAAOZ,KACNpH,EAAA,CAAAS,IAAK0G,EACLF,SAAUO,EAAaP,EAAUC,IAC7BzD,EAHN,CAIEwE,UAAWC,KAAG,YAAanK,EAAMkK,aAEhCE,EAAAA,QAAQzI,EAAU4H,IAI1B,GAWHhB,EAAK8B,iBAAmBrC,EAEpBvH,EAAJA,UACE8H,EAAK7H,YAAc,QC5IrB,IAAAf,EAAA,CAAA,YAWM2K,EAAgD,SAAiBzK,gBACrE,OAAOI,EAACC,cAAA+J,EAAAA,OAAOM,IAAR,KAD8D1K,EAAd8B,SAExD,EAEGlB,YACF6J,EAAe5J,YAAc,kBASlB8J,IAAAA,GAAa,SAA4C7J,GAAA,IAAA8J,EAAAC,EAAAC,IAAzChJ,EAAAA,SAAa3B,SAOzB4K,EAAA3I,EAAA,GAJoD,OAA9C4I,EAAH,OAAGA,EAFPC,EAAQA,WAEKC,oBAATJ,EAAGD,EAAkBF,iBAArB,EAAGG,EAA8BK,cAAgBP,EAAA,CACjEtD,QAAS,GAKNnH,gBAGL,OACEC,EAAAC,cAAC+K,EAADA,WACML,EAAAA,CAAAA,EAAAA,EACJ,CAAAV,UAAWC,EAAAA,GAAG,oBAAqBnK,EAAMkK,aAExCjK,EAAMiL,SAASnG,IAAIpD,EAAU,SAACwJ,GAC7B,OAAIlL,EAAMmL,eAAeD,gBAChBlL,EAACC,cAAAoK,EAAgBa,KAAAA,GAG3BA,CAAA,GAGN,EAEG1K,EAAJA,UACE+J,GAAW9J,YAAc,cCnDpB,IAAqB2K,GAAG,SAACvL,EAAc6B,GAC5C,OAAY1B,EAACiL,SAASnG,IAAIpD,EAAU,SAACwJ,GACnC,OAAIlL,EAAMmL,eAAeD,IAAUA,EAAMnL,MAAMF,KACtCG,EAAMqL,aAAaH,OACrBA,EAAMnL,MADJ,CAELF,KAASA,EAAL,IAAaqL,EAAMnL,MAAMF,QAIlCqL,CAAA,EACF,KCiBCI,EAAaA,cAAsB,CACjCzL,KAAM,sBAFI0L,SAAoBC,GAA3BC,GAAA,GA6BLH,GAAAA,EAAAA,cAAsC,CACpCzL,KAAM,yBAFI6L,GAAuBC,GAAAA,GAAAA,SAuBXC,GAAG,SAAAhM,GAC3BC,IAAAA,IAAAA,KAKsBgM,EAAAjM,EAJtBkM,aAAAA,aAAe,CAAA,EAIOD,EAHtBE,EAGsBnM,EAHtBmM,QACAC,IAAAA,IACAC,EAAAA,EAAAA,IAEoBrL,EAAAA,EAAcA,iBAOlC,OACKsL,EAAAA,CAAAA,EAPWC,EAAAA,cAAc,CAC5B/I,UAFMA,QAGNvD,KAAAA,EACAkM,QAAAA,KAKAlM,KAAAA,EACAiM,aAAAA,EACAE,IAAAA,EACAC,IAAAA,GAEH,EAM4BG,GAAG,SAAA1L,GAAG2L,IAAAA,IAAAA,MACzBC,EAAgB1L,EAAcA,iBAA9B0L,cACyBd,KAAzB3L,EAAR0M,EAAQ1M,KAAM2M,EAAAA,EAAAA,OAAQC,EAAtBF,EAAsBE,OAOtB,OALAzM,EAAM0J,UAAU,WAEd4C,EAAYzM,EACb,EAAE,IAEI,CACLwM,MAAAA,EACAK,QAAmB,IAAVL,EACTM,OAAQN,IAAUI,EAAOG,OAAS,EAClC/M,KAASA,EAAL,IAAawM,EACjBG,OAAQxM,EAAM6M,YAAY,WACxBP,EAAYzM,GACZ2M,EAAOH,EACR,EAAE,CAACA,IAEP,EAEqCS,GAAG,WACvC,IAAAC,EAA4BpB,KAApBe,EAAAA,EAAAA,QAASF,IAAAA,SACOhB,KAAhBQ,EAARgB,EAAQhB,IAIR,MAAO,CACLiB,QAAS,WAAMT,OAAAA,GAAN,EACTpI,WAJiBsI,MAAcV,KAFpBS,OAEkCG,QAAUZ,GAM1D,KAEqC,WACpC,MAA8CR,KAAtC0B,EAARC,EAAQD,OAAQpB,IAAAA,aAAcG,EAA9BkB,EAA8BlB,IAI9B,MAAO,CACLgB,QAAS,WAAA,SACAnB,EAAc,CACnBsB,aAAa,GAFR,EAIThJ,cAPoB6H,KAFaQ,OAECG,QAAUX,GAS/C,ECvJDvM,GAAA,CAAA,WAAA,SAAAmB,GAAA,CAAA,YAAAC,GAAA,CAAA,YAAAC,GAAA,CAAA,OAAA,eAAA,UAAA,MAAA,MAAA,YAiD0BsM,GAAiC,SAAAzN,GACzD8B,IAAAA,EAAAA,EAAAA,SACA2K,IAAAA,MACGiB,EACApK,EAAAtD,EAAAF,iBACH,OACEM,EAAAC,cAACsN,GAAD,CAAwBlB,MAAOA,gBAC7BrM,EAAAC,cAACuN,GAAwBF,EAAiB5L,gBAC1C1B,EAACC,cAAAwN,GAFH,MAKH,EAEGjN,EAAJA,UACE6M,GAAc5M,YAAc,iBAkBjB+M,IAAmBA,GAAuC,SAGlE9M,GAAA,MAFHgB,EAAAA,SACGgM,EAEHxK,EAAAxC,EAAAG,IAAQhB,EAAS8L,KAAT9L,kBACR,OACEG,EAAAC,cAACsK,GAADvI,EAAA,CAAY2L,KAAK,IAAIC,GAAG,KAAQF,GAC7BtC,GAAgBvL,EAAM6B,GAG5B,EAEGlB,EAAJA,UACEgN,GAAoB/M,YAAc,uBAGvB8M,IAAAA,GAAuD,SAAAxK,OAG/DrB,EAAAqB,EAFHrB,SAGawK,EAAGE,GAAiB,CAAEC,MADhCtJ,EADHsJ,qBAYA,OACErM,EAAAC,cAACyL,GAAD,CAAuBmC,MAAO3B,gBAC5BlM,gBAACgK,EAADA,OAAQM,IAAR,CAAYwD,MAVD,CACbC,QAAS,OACTC,cAAe,MACfC,WAAY,WACZC,MAAO,OACPC,GAAI,IAK0BzM,GAGjC,EAEGlB,EAAAA,UACF+M,GAAuB9M,YAAc,0BAG1BgN,IAAAA,GAAgD,SAAC1N,gBAC5D,OACEC,EAAAC,cAACmO,aACCpM,EAAA,CAAAqM,kBAAMrO,EAAAC,cAACqO,EAAAA,UAAD,MACN,aAAW,cACPxB,KACA/M,GAGT,EAEGS,YACFiN,GAAuBhN,YAAc,0BAG1B8N,IAAmBA,GAA0B,SAACxO,gBACzD,OACEC,EAACC,cAAAmO,aACCpM,EAAA,CAAAqM,kBAAMrO,EAAAC,cAACuO,UADT,MAEE,aAAW,UACXC,MAAM,SACFC,KACA3O,GAGT,EAEGS,YACF+N,GAAoB9N,YAAc,uBAOvBkO,IAAUA,GAAGnM,aACxB,SAACzC,EAAwB0C,GACvB,IAAAf,EAAwC3B,EAAhC2B,SAAakN,EAAmB7O,EAAAA,EAExCe,iBAAA,OACEd,EAACC,cAAA4O,GAAoB7M,EAAA,CAAAS,IAAKA,GAASmM,gBACjC5O,EAACC,cAAA6O,GACE,KAAA,SAACrC,gBACA,OAAAzM,EAAAC,cAAAD,EAAA+O,SAAA,KACGtC,EAAO3H,IAAI,SAASuH,EAAAA,gBAAT,OACVrM,EAACC,cAAAoN,GAAc,CAAA9F,IADLjE,EAAGa,GACWkI,MAAOA,GAC5B3K,EAFO,GAFf,gBAUH1B,EAAAC,cAACsO,GAAD,MAGL,GASC/N,EAAJA,UACEmO,GAAWlO,YAAc,cAOdqO,IAAcA,GAAG,SAAAjL,GAI5B,OAAOnC,EAHPA,EAAAA,UAEmB8J,KAAXiB,OAET,EAEGjM,EAAAA,UACFsO,GAAerO,YAAc,kBAGlBoO,IAAAA,GAAsB7O,EAAMwC,WACvC,SAUEC,EAAAA,GACE,MATA5C,EAAAA,KACAiM,EAAAA,EAAAA,aACAC,IAAAA,QACAC,EAMA1G,EANA0G,IACAC,EAKA3G,EALA2G,IACAvK,EAAAA,EAAAA,SACGsN,EAIL9L,EAAAoC,EAAAvE,MAAgB6K,GAAc,CAC5B/L,KAAAA,EACAiM,aAAAA,EACAC,QAAAA,EACAC,IAAAA,EACAC,IAAAA,IAMF,OAFAjM,EAAMyJ,oBAAoBhH,EAAK,WAAA,OAAAyJ,CAAA,EAAe,CAACzJ,EAAKyJ,iBAGlDlM,EAAAC,cAACsL,GAAmB,CAAAsC,MAAO3B,gBACzBlM,EAAAC,cAACsB,EAADS,EAAA,CAAWnC,KAAMA,GAAUmP,GACxBtN,GAIR,GAGClB,YACFqO,GAAoBpO,YAAc,uBChPpC,IAAAf,GAAA,CAAA,OAAA,QAAA,YAAA,WAAA,UAAA,WAsBauP,GAAa,SAAClP,GACzB,IAAMmP,EAASC,EAAcA,eAAC,2BAC9B,OAAOnP,EAAAC,cAACE,EAAAA,UAAU6B,EAAA,CAAAoN,GAAG,SAASC,GAAIH,GAAYnP,GAC/C,KAEsD,SAACA,GACtD,IAAAF,EACEE,EADMF,KAAMC,EACZC,EADYD,MAAO2B,EACnB1B,EADmB0B,UAAWC,EAC9B3B,EAD8B2B,SAAU4N,EACxCvP,EADwCuP,QAASpI,EACjDnH,EADiDmH,QAAY8H,EAA/D9L,EACEnD,EAEFL,iBAAA,OACEM,gBAACE,EAADA,YAAA8B,EAAA,CAAanC,KAAMA,EAAMuP,GAAG,YAAeJ,gBACzChP,EAAAC,cAACgP,GAAD,CAAYlB,QAAStM,EAAY,OAAS,SAAU3B,gBACpDE,gBAACuK,GAAD,CAAY+E,QAASA,EAASC,QAASrI,GACpCkE,GAAgBvL,EAAM6B,IAI9B,EAEGlB,YACFgP,GAAY/O,YAAc,eC1C5B,IAAAf,GAAA,CAAA,OAAA,QAAAmB,GAAA,CAAA,SAAA,gBAAA,mBAAAC,GAAA,CAAA,OAAA,OAAA,mBAkBwB,SAAC2H,EAAyB5I,GAAgB,IAAA4P,EAChE,OAAA,SAAOhH,EACJR,gBAAgBpI,SADnB,EAAO4P,EAEH3K,IACA,SAAkDsC,EAAAA,GAA/CvH,IAAAA,IAAAA,KAAM8C,EAAT/C,EAAS+C,KAAS+M,8BAChB1P,EAACC,cAAAsC,KAAMgF,IAAK1H,GAAQuH,EAAGvH,KAAMA,EAAM8C,KAAMA,GAAU+M,GADrD,EAIL,EAEkBC,GAA0B,SAAAjP,GAC3CgH,IAAAA,IAAAA,OACAkI,EAGGlP,EAHHkP,cACAC,IAAAA,gBACG9P,EAEHmD,EAAAxC,EAAAG,IAAc4H,EAAGzI,EAAM8P,QACrB,WAAA,UAAuBxH,EAAK8B,iBAAiB1C,EAA7C,EACA,CAACA,EAAQkI,IAGCnD,EAAGzM,EAAM8P,QAAQ,WAAA,SAAe9H,WAAf,EAA4B,CAACS,IAEhDW,EAAGxI,EAAcA,iBAQ3B,OANAZ,EAAM0J,UAAU,WACd,IAAAqG,EAAIF,GAAe,OAAAE,EAAItD,EAAO,KAAPsD,EAAWlQ,MAChCuJ,EAAK4G,SAASvD,EAAO,GAAG5M,KAE3B,EAAE,CAAC6H,EAAQkI,EAAeC,iBAGzB7P,EAACC,cAAAsK,GAAexK,EACb0M,EAAO3H,IACN,YACEjF,IAAAA,EAAAA,EAAAA,KACA8C,EAGgCI,EAHhCJ,KAEGqM,UAEH,MAAa,UAATrM,eAEA3C,EAAAC,cAAC0O,GAAD3M,EAAA,CAAYuF,IAAK1H,EAAMA,KAAMA,GAAUmP,GACpC5D,GAAgB3C,EAAU5I,IAGb,WAAT8C,eAEP3C,EAACC,cAAAuP,GAAYxN,EAAA,CAAAuF,IAAK1H,EAAMA,KAAMA,GAAUmP,GACrC5D,GAAgB3C,EAAU5I,iBAK1BG,EAAAC,cAACsC,EAADP,EAAA,CAAOuF,IAAK1H,EAAMA,KAAMA,EAAM8C,KAAMA,GAAUqM,GACtD,GAIR,EAEGxO,EAAJA,UACEmP,GAAOlP,YAAc,UChFvB,IAAAf,GAAA,CAAA,WAAA,qBAAA,mBAAA,aAAA,aAyBauQ,GAAejQ,EAAMwC,WAGhC,SAACzC,EAAO0C,GACR,MAOI1C,EANF2B,SACAwO,EAKEnQ,EALFmQ,mBACAC,EAIEpQ,EAJFoQ,iBACYC,EAGVrQ,EAHFqE,WACAiM,EAEEtQ,EAFFsQ,UACG5K,EACD1F,EAAAA,EACJL,IAAQkC,EAAchB,mBAAdgB,uBAOR,OACE5B,EAAAC,cAACqQ,EAADA,OAAAtO,EAAA,GACMyD,EACJ,CAAAhD,IAAKA,EACL8N,QAAQ,UACR5N,KAAK,SACL0N,UAAWzO,EAAU4O,cAAgBH,EACrCjM,WAXD8L,IAAuBtO,EAAU6O,SACjCN,IAAqBvO,EAAU8O,SAChCN,IAWG1O,EAGN,GAEDuO,GAAalF,aAAe,CAC1BjL,MAAO,SACPoQ,oBAAoB,EACpBC,kBAAkB,GAGhB3P,YACFyP,GAAaxP,YAAc,gBCjE7B,IAAAf,GAAA,CAAA,SAAA,cAAA,gBAAA,YAmCqBiR,GAAGnO,EAAAA,WACtB,SACEzC,EACA0C,GAEA,IACEiF,EAKE3H,EALF2H,OAKE3H,EAAAA,EAJF6Q,YAAAA,OAAc,IAAAC,EAAA,WACdjB,EAGE7P,EAHF6P,cACAlO,EAEE3B,EAFF2B,SACG+D,EALLvC,EAMInD,EANJL,iBAQA,OACEM,EAAAC,cAACqI,EAADtG,EAAA,GAAUyD,EAAV,CAAgBiC,OAAQA,EAAQjF,IAAKA,iBACnCzC,EAACC,cAAAsK,qBACEvK,EAACC,cAAA0P,GAAO,CAAAjI,OAAQA,EAAQkI,cAAeA,IACvCgB,gBAAe5Q,EAACC,cAAAgQ,QAAcW,GAC9BlP,GAIR,GAUClB,EAAAA,UACFmQ,GAASlQ,YAAc,YChDZqQ,IAAAA,GAAY,YACvBpP,IAAAA,EAAAA,EAAAA,SAKAqP,EAAAA,EAAAA,UASA,YATY,IAAAC,EAAA,SAACnD,GAAU,QAAEA,CAAb,EACqBmD,GACnBC,EAAQA,SAAC,CACrBpR,OAPFA,KAQEiM,aAPFA,EAAAA,aAQEoF,SAJ+BtR,EAHjCwE,WAQE+M,MAL+BvR,EAFjCwR,UASgBxQ,EAAcA,kBACKc,EAAW,IAC/C,EAEGlB,EAAAA,UACFsQ,GAAUrQ,YAAc,iCCVxB6K,GAAAA,gBAA+B,CAC7BzL,KAAM,kBACNwR,aACE,gHAJQC,SAAkBC,GAAzB9F,GAAA,GA4BD,SAAA+F,GACJzR,GAEQ0D,IAAagC,EAArBvC,EAA8BnD,EAA9BL,IACM+R,EAAUC,EAAAA,WAAWjM,GAE3BkM,EAA6CF,EAArCE,WAAYC,EAAyBH,EAAzBG,WAAYC,EAAaJ,EAAbI,SAEhCC,EAA6B9R,EAAM+R,SAAoC,CAA1C,GAAtBC,EAAPF,EAAA,GAAcG,EAAdH,EAAA,GAEMI,EAA4ClS,EAAM6M,YAAN,SACzCsF,mEAgBGC,SAAAA,EAAAA,GAAAA,OAAAA,EAAAA,EAAAA,QAAAA,QAAAA,MAAAA,EAAKnJ,cAALmJ,EAAAA,EAAKnJ,SAAWkJ,EAAMV,IAE5BI,KAAAA,WAAAA,GAjBE,EAAA,CACF,IAAMO,EAAOJ,EAAML,GADjBU,EAAA,WAAA,GAGET,EACI7R,OAAAA,QAAAA,QAAAA,MAAAA,EAAMkJ,cAANlJ,EAAAA,EAAMkJ,SAAWkJ,IAJvBG,KAAA,WAMAC,EACKH,EAAAA,CAAAA,EAAAA,EACHI,CAAAA,aAAa,KAGfX,IAXAY,EAAA,CAAA,EAAA,CAAA,GAAA,OAAAJ,GAAAA,EAAAC,KAAAD,EAAAC,KAAAI,GAAAA,EAAAL,EAkBH,mDAnBY,mBAsBd,EACD,CAACL,EAAOL,EAAYC,IAGhBe,EAAe3S,EAAM6M,YAAY,WACrC,IAAUuF,EAAGJ,EAAML,GACnB,MAAO,CACL1I,SAAUiJ,EACVxK,OAAQ0K,MAAAA,OAAAA,EAAAA,EAAM1K,OACde,SAAQ,MAAE2J,OAAF,EAAEA,EAAM3J,SAEnB,EAAE,CAACuJ,EAAOE,EAAcP,IAEnBY,EAAavS,EAAM6M,YACvB,SAACuF,GACCH,EAAY,SAACD,GAAS,IAAAY,EACpB,OACKZ,EAAAA,CAAAA,EAAAA,UACFI,EAAKvS,MAAOuS,EAFfQ,GAID,EACF,EACD,CAACZ,IAGH,OACEW,EAAAA,CAAAA,aAAAA,EACAJ,WAAAA,EACAP,MAAAA,GACGP,EAEN,CASK,YAAsB1R,GAC1B,MAA6CA,EAArCF,KAAM6H,EAA+B3H,EAA/B2H,OAAQe,EAAuB1I,EAAvB0I,SAAUQ,EAAalJ,EAAbkJ,SAC1BmJ,EAAOS,EAAAA,QAAQ,CAAEhT,KAAAA,IAEO0R,EAAAA,KAAtBS,EAAAA,EAAAA,MAAOO,EAAAA,EAAAA,WAMf,OAJAvS,EAAM0J,UAAU,WACd6I,EAAW,CAAE1S,KAAAA,EAAM6H,OAAAA,EAAQe,SAAAA,EAAUQ,SAAAA,GACtC,EAAE,CAACpJ,EAAM6H,IAEV1F,EAAA,CAAA,EACKoQ,EACCJ,EAAMnS,IAAS,CAAEA,KAAAA,EAAM6H,OAAAA,GAE9B,CC/ID,IAAAhI,GAAA,CAAA,YAAAmB,GAAA,CAAA,gBAAAC,GAAA,CAAA,WAAA,cAAA,UAAA,cAAA,QAAAC,GAAA,CAAA,OAAA,SAAA,WAAA,WAAA,YAAA,YAAAC,GAAA,CAAA,QAAA,eAiCqB8R,GAAG9S,EAAMwC,WAC5B,SACEzC,EACA0C,GAEA,IAAQf,EAAsB3B,EAAtB2B,SAAa+D,EAAS1F,EAAAA,EAE9BL,MAAgB8R,GAA0BzR,GAE1C4S,EAAiClB,EAAzBkB,aAAiBI,IAAQtB,EAAjC5Q,IAEMqL,EAAUlM,EAAM8P,QAAQ,kBAAAiD,CAAA,EAAW,CAACA,iBAE1C,OACE/S,gBAACgT,EAADA,gBAAA,CAAiBnF,MAAO3B,gBACtBlM,EAAAC,cAACqR,GAAD,CAAkBzD,MAAO3B,gBACvBlM,EAAAC,cAACqI,EAAKtG,EAAA,CAAAS,IAAKA,GAASgD,EAAUkN,KAC3BxI,EAAAA,QAAQzI,EAAU+P,KAK5B,GA6EkBwB,GAA4B,SAAClT,GAChD,IAAQF,EACNE,EADMF,KAAM6H,EACZ3H,EADY2H,OAAQe,EACpB1I,EADoB0I,SAAU/G,EAC9B3B,EAD8B2B,SAAUuI,EACxClK,EADwCkK,UAAWhB,EACnDlJ,EADmDkJ,SAAaxD,EAAlEvC,EACEnD,EACFgB,IAIA,OAJamS,GAAY,CAAErT,KAAAA,EAAM6H,OAAAA,EAAQe,SAAAA,EAAUQ,SAAAA,IAE3CkK,sBAGNnT,EAACC,cAAA+J,EAADA,OAAQM,SAAQ7E,EAAhB,CAAsBwE,UAAWC,EAAAA,GAAG,kBAAmBD,KACpDvI,GAED,IACL,EAEGlB,EAAAA,UACFyS,GAASxS,YAAc,YAGZ2S,OAAoC,SAACrT,GAChD,IAA+CsT,EAAAA,EAAAA,oBAAbC,EAAAA,EAAAA,sBAElC,OACEtT,gBAACsQ,EAAAA,OAADtO,EAAA,CACEoC,WAJImP,EAAAA,aAARC,EAAqBhB,YAKjB1S,MAAM,QACFC,EAHN,CAIEkK,UAAWC,EAAAA,GAAG,yBAA0BnK,EAAMkK,WAC9CgD,QAASvJ,EAAeA,gBAAC3D,EAAMkN,QAASqG,KAG7C,EAEG9S,EAAAA,UACF4S,GAAW3S,YAAc,cAOdgT,IAAUA,GAA8B,SAAC1T,GACpD,IAAA2T,EAA8D3T,EAAtDD,MAAAA,aAAQ,OAAhB4T,EAAA7C,EAA8D9Q,EAAtC6Q,YAAAA,OAAc,IAAAC,EAAA,aAAepL,EAArDvC,EAA8DnD,EAA9DiB,MACoCqS,EAAiBA,oBAA7CzB,IAAAA,WAAYY,EAApBmB,EAAoBnB,yBAEpB,OACExS,EAACC,cAAAgQ,QACKxK,EADN,CAEErB,WAAYoO,EACZvI,UAAWC,KAAG,yBAA0BnK,EAAMkK,aAE7C2H,GAAcY,EAAc5B,EAAc9Q,EAGhD,EAEGU,YACFiT,GAAWhT,YAAc,85CA3G4B,SAACV,GACtD,IAAkCsT,EAAAA,EAAAA,oBAA1BO,EAAAA,EAAAA,YAAaC,EAArBC,EAAqBD,SAErBnS,EAAuE3B,EAA/D2B,SAAUqS,EAAqDhU,EAArDgU,YAAaxD,EAAwCxQ,EAAxCwQ,QAASyD,EAA+BjU,EAA/BiU,YAAaxO,EAAkBzF,EAAlByF,KAASC,EAA9DvC,EAAuEnD,EAAvEe,IAEcmT,EAAGjU,EAAMiL,SAASnG,IAAIpD,EAAU,SAACwJ,GAC7C,GACElL,EAAMmL,eAA8BD,KAC/B,MAALA,SAAAA,EAAOvI,QAASsQ,GAChB,CACA,IAAwBC,EAAAA,GAAYhI,EAAMnL,oBAC1C,OACEC,EAACC,cAAAiU,EAAAA,YACClS,EAAA,CAAAnC,KAAMqL,EAAMnL,MAAMF,KAClBgI,MAAOqD,EAAMnL,MAAM8H,MACnB2K,YALJ2B,EAAQ3B,aAMA/M,GAEHyF,EAAMnL,MAAM2B,SAGlB,CACD,OAAOwJ,CACR,GAEKzH,EAAWzD,EAAM6M,YAAY,SAACzF,GAClCyM,EAASzM,EACV,EAAE,iBAEH,OACEpH,EAAAC,cAACmU,EAAAA,iBAAD,CACEL,YAAaA,EACb3B,KAAMwB,EACNrD,QAASA,EACTyD,YAAaA,EACbxO,KAAMA,EACN/B,SAAUA,gBAEVzD,EAAAC,cAACoU,EAAAA,aAADrS,EAAA,CAAcmM,GAAG,KAAQpO,GACtBkU,GAIR,yYCvGyB,SAIxBlU,GAEA,IAAAF,EAAoDE,EAA5CF,KAAMiM,EAAsC/L,EAAtC+L,aAAc1H,EAAwBrE,EAAxBqE,WAAYgN,EAAYrR,EAAZqR,UAC3BxQ,EAAcA,iBAEhB4C,EAAGyN,WAAS,CACrBpR,KAAAA,EACAiM,aAAAA,EACAoF,SAAU9M,EACV+M,MAAOC,IAGT,OAAYrR,EAAC2B,SAAS8B,EAAO4F,IAAS,IACvC"}