@saas-ui/forms 2.0.3 → 2.0.5

Sign up to get free protection for your applications and to get access to all the features.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,19 @@
1
1
  # @saas-ui/forms
2
2
 
3
+ ## 2.0.5
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies [493a548a]
8
+ - Updated dependencies [9e848077]
9
+ - @saas-ui/core@2.0.3
10
+
11
+ ## 2.0.4
12
+
13
+ ### Patch Changes
14
+
15
+ - 3b5567c6: Fixed issue where StepForm would not render custom fields
16
+
3
17
  ## 2.0.3
4
18
 
5
19
  ### Patch Changes
package/dist/index.js CHANGED
@@ -1236,7 +1236,7 @@ function createStepForm({ fields, resolver, fieldResolver } = {}) {
1236
1236
  });
1237
1237
  const { getFormProps, ...ctx } = stepper;
1238
1238
  const context = React11.useMemo(() => ctx, [ctx]);
1239
- return /* @__PURE__ */ jsxRuntime.jsx(core.StepperProvider, { value: context, children: /* @__PURE__ */ jsxRuntime.jsx(StepFormProvider, { value: context, children: /* @__PURE__ */ jsxRuntime.jsx(FieldsProvider, { value: fields || {}, children: /* @__PURE__ */ jsxRuntime.jsx(Form2, { ref, ...rest, ...getFormProps(), children: utils.runIfFn(children, {
1239
+ return /* @__PURE__ */ jsxRuntime.jsx(core.StepperProvider, { value: context, children: /* @__PURE__ */ jsxRuntime.jsx(StepFormProvider, { value: context, children: /* @__PURE__ */ jsxRuntime.jsx(FieldsProvider, { value: fields || {}, children: /* @__PURE__ */ jsxRuntime.jsx(Form, { ref, ...rest, ...getFormProps(), children: utils.runIfFn(children, {
1240
1240
  ...stepper,
1241
1241
  Field,
1242
1242
  FormStep,
@@ -1245,7 +1245,7 @@ function createStepForm({ fields, resolver, fieldResolver } = {}) {
1245
1245
  ObjectField
1246
1246
  }) }) }) }) });
1247
1247
  });
1248
- StepForm2.displayName = `Step${Form2.displayName || Form2.name}`;
1248
+ StepForm2.displayName = `Step${Form.displayName || Form.name}`;
1249
1249
  return StepForm2;
1250
1250
  }
1251
1251
  var Form2 = createForm();
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/form-context.tsx","../src/display-field.tsx","../src/field.tsx","../src/fields-context.tsx","../src/default-fields.tsx","../src/number-input/number-input.tsx","../src/password-input/password-input.tsx","../src/input-right-button/input-right-button.tsx","../src/radio/radio-input.tsx","../src/utils.ts","../src/select/select.tsx","../src/select/select-context.tsx","../src/select/native-select.tsx","../src/create-field.tsx","../src/base-field.tsx","../src/fields.tsx","../src/layout.tsx","../src/array-field.tsx","../src/use-array-field.tsx","../src/object-field.tsx","../src/submit-button.tsx","../src/display-if.tsx","../src/step-form.tsx","../src/use-step-form.tsx","../src/field-resolver.ts","../src/watch-field.tsx","../src/form.tsx","../src/create-form.tsx","../src/create-step-form.tsx","../src/index.ts"],"names":["jsx","React","forwardRef","Input","InputGroup","jsxs","Button","ChevronDownIcon","createContext","value","FormControl","FormLabel","BaseField","Field","NumberInputField","chakra","cx","mapNestedFields","name","useFormContext","callAllHandlers","steps","get","useWatch","useMemo","runIfFn","StepForm","Form","useFieldArray","useForm","Controller"],"mappings":"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","sourcesContent":["import * as React from 'react'\nimport {\n FormProvider as HookFormProvider,\n FormProviderProps as HookFormProviderProps,\n useFormContext as useHookFormContext,\n FieldValues,\n} from 'react-hook-form'\nimport { FieldResolver } from './field-resolver'\nimport { BaseFieldProps, FieldProps } from './types'\n\nexport type FormContextValue<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nexport type FormProviderProps<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = HookFormProviderProps<TFieldValues, TContext> & {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nconst FormContext = React.createContext<FormContextValue | null>(null)\n\nexport const useFormContext = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>() => {\n const context = React.useContext(FormContext)\n const hookContext = useHookFormContext()\n\n if (!context) {\n throw new Error('FormProvider must be used within a Form component')\n }\n\n return {\n ...hookContext,\n ...context,\n }\n}\n\nexport const useFieldProps = <TFieldValues extends FieldValues = FieldValues>(\n name: string\n): BaseFieldProps<TFieldValues> | undefined => {\n const parsedName = name?.replace(/\\.[0-9]/g, '.$')\n const context = useFormContext()\n return (context?.fields?.[parsedName] as any) || {}\n}\n\nexport type UseFormReturn<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = ReturnType<typeof useFormContext>\n\nexport const FormProvider = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>(\n props: FormProviderProps<TFieldValues, TContext, TSchema>\n) => {\n const { children, fieldResolver, schema, fields, ...rest } = props\n return (\n <HookFormProvider {...rest}>\n <FormContext.Provider value={{ fieldResolver, schema, fields }}>\n {children}\n </FormContext.Provider>\n </HookFormProvider>\n )\n}\n","import * as React from 'react'\nimport { useFormContext } from './form-context'\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './types'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n/**\n *\n *\n * @see Docs https://saas-ui.dev/\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\nDisplayField.displayName = 'DisplayField'\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nFormValue.displayName = 'FormValue'\n","import * as React from 'react'\nimport { RegisterOptions, FieldValues } from 'react-hook-form'\n\nimport { FocusableElement } from '@chakra-ui/utils'\nimport { useField } from './fields-context'\nimport { FieldProps } from './types'\nimport { useFieldProps } from './form-context'\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\nconst defaultInputType = 'text'\n\n/**\n * Form field component.\n * \n * Build-in types:\n * text, number, password, textarea, select, native-select, checkbox, radio, switch, pin\n *\n * Will default to a text field if there is no matching type.\n\n * @see Docs https://saas-ui.dev/docs/components/forms/field\n */\nexport const Field = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues>,\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType, name } = props\n const overrides = useFieldProps(name)\n const InputComponent = useField(overrides?.type || type)\n\n return <InputComponent ref={ref} {...props} {...overrides} />\n }\n) as (<TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n","import React from 'react'\nimport { defaultFieldTypes, InputField } from './default-fields'\n\nconst FieldsContext = React.createContext<Record<string, React.FC<any>> | null>(\n null\n)\n\nexport const FieldsProvider: React.FC<{\n value: Record<string, React.FC<any>>\n children: React.ReactNode\n}> = (props) => {\n const fields = { ...defaultFieldTypes, ...props.value }\n return (\n <FieldsContext.Provider value={fields}>\n {props.children}\n </FieldsContext.Provider>\n )\n}\n\nexport const useField = (type: string): React.FC<any> => {\n const context = React.useContext(FieldsContext)\n return context?.[type] || InputField\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Input,\n Textarea,\n Checkbox,\n Switch,\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'\n\nimport { NumberInput, NumberInputProps } from './number-input'\nimport { PasswordInput, PasswordInputProps } from './password-input'\nimport { RadioInput, RadioInputProps } from './radio'\n\nimport {\n Select,\n SelectButton,\n SelectList,\n SelectProps,\n NativeSelect,\n NativeSelectProps,\n} from './select'\n\nimport { createField } from './create-field'\nimport { ObjectField } from './object-field'\nimport { ArrayField } from './array-field'\n\nexport interface InputFieldProps extends InputProps {\n type?: string\n leftAddon?: React.ReactNode\n rightAddon?: React.ReactNode\n}\n\nexport const InputField = createField<InputFieldProps>(\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 = createField<NumberInputFieldProps>(\n NumberInput,\n {\n isControlled: true,\n }\n)\n\nexport const PasswordInputField = createField<PasswordInputProps>(\n forwardRef((props, ref) => <PasswordInput ref={ref} {...props} />)\n)\n\nexport const TextareaField = createField<TextareaProps>(Textarea)\n\nexport const SwitchField = createField<SwitchProps>(\n forwardRef(({ type, value, ...rest }, ref) => {\n return <Switch isChecked={!!value} {...rest} ref={ref} />\n }),\n {\n isControlled: true,\n }\n)\n\nexport const SelectField = createField<SelectProps>(\n forwardRef((props, ref) => {\n return (\n <Select ref={ref} {...props}>\n <SelectButton />\n <SelectList />\n </Select>\n )\n }),\n {\n isControlled: true,\n }\n)\n\nexport const CheckboxField = createField<CheckboxProps>(\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 = createField<RadioInputProps>(RadioInput, {\n isControlled: true,\n})\n\nexport const NativeSelectField = createField<NativeSelectProps>(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 = createField<PinFieldProps>(\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\nexport const defaultFieldTypes = {\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 select: SelectField,\n checkbox: CheckboxField,\n radio: RadioField,\n pin: PinField,\n 'native-select': NativeSelectField,\n}\n\nexport type DefaultFields = typeof defaultFieldTypes\n","import * as React from 'react'\n\nimport {\n forwardRef,\n NumberInput as ChakraNumberInput,\n NumberInputField,\n NumberInputStepper,\n NumberIncrementStepper,\n NumberDecrementStepper,\n NumberInputProps as ChakraNumberInputProps,\n} from '@chakra-ui/react'\n\nimport { ChevronDownIcon, ChevronUpIcon } from '@saas-ui/core'\n\ninterface NumberInputOptions {\n /**\n * Hide the stepper.\n */\n hideStepper?: boolean\n /**\n * Render a custom increment icon.\n */\n incrementIcon?: React.ReactNode\n /**\n * Render a custom decrement icon.\n */\n decrementIcon?: React.ReactNode\n}\n\nexport interface NumberInputProps\n extends ChakraNumberInputProps,\n NumberInputOptions {}\n\nexport const NumberInput = forwardRef<NumberInputProps, 'div'>((props, ref) => {\n const {\n hideStepper,\n incrementIcon = <ChevronUpIcon />,\n decrementIcon = <ChevronDownIcon />,\n ...rest\n } = props\n\n return (\n <ChakraNumberInput {...rest} ref={ref}>\n <NumberInputField />\n\n {!hideStepper && (\n <NumberInputStepper>\n <NumberIncrementStepper children={incrementIcon} />\n <NumberDecrementStepper children={decrementIcon} />\n </NumberInputStepper>\n )}\n </ChakraNumberInput>\n )\n})\n\nNumberInput.defaultProps = {\n hideStepper: false,\n}\n\nNumberInput.displayName = 'NumberInput'\n","import React, { useState } from 'react'\n\nimport { forwardRef, InputGroup, Input, InputProps } from '@chakra-ui/react'\n\nimport { ViewIcon, ViewOffIcon } from '@saas-ui/core/icons'\n\nimport { InputRightButton } from '../input-right-button'\n\ninterface PasswordOptions {\n viewIcon?: React.ReactNode\n viewOffIcon?: React.ReactNode\n leftAddon?: React.ReactNode\n}\n\nexport interface PasswordInputProps extends InputProps, PasswordOptions {}\n\nexport const PasswordInput = forwardRef<PasswordInputProps, 'div'>(\n (props, ref) => {\n const {\n viewIcon,\n viewOffIcon,\n autoComplete,\n w,\n width,\n size,\n variant,\n leftAddon,\n ...inputProps\n } = props\n const [show, setShow] = useState(false)\n const handleClick = () => setShow(!show)\n\n const label = show ? 'Hide password' : 'Show password'\n\n let icon\n if (show) {\n icon = viewIcon || <ViewIcon />\n } else {\n icon = viewOffIcon || <ViewOffIcon />\n }\n\n const groupProps = {\n width: w || width,\n size,\n variant,\n }\n\n return (\n <InputGroup {...groupProps}>\n {leftAddon}\n <Input\n {...inputProps}\n ref={ref}\n type={show ? 'text' : 'password'}\n autoComplete={show ? 'off' : autoComplete}\n />\n <InputRightButton\n onClick={handleClick}\n aria-label={label}\n variant=\"ghost\"\n >\n {icon}\n </InputRightButton>\n </InputGroup>\n )\n }\n)\n\nPasswordInput.displayName = 'PasswordInput'\n","import * as React from 'react'\n\nimport {\n Button,\n ButtonProps,\n forwardRef,\n InputRightElement,\n} from '@chakra-ui/react'\n\nexport type InputRightButtonProps = ButtonProps\n\nexport const InputRightButton = forwardRef<InputRightButtonProps, 'div'>(\n (props, ref) => {\n return (\n <InputRightElement w=\"auto\" px=\"1\" py=\"1\" alignItems=\"stretch\">\n <Button ref={ref} height=\"auto\" {...props} />\n </InputRightElement>\n )\n }\n)\n\nInputRightButton.id = 'InputRightElement'\n\nInputRightButton.displayName = 'InputRightButton'\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Stack,\n RadioGroup,\n RadioGroupProps,\n Radio,\n RadioProps,\n SystemProps,\n StackDirection,\n} from '@chakra-ui/react'\nimport { FieldOptions, FieldOption } from '../types'\nimport { mapOptions } from '../utils'\n\nexport interface RadioOption\n extends Omit<RadioProps, 'value' | 'label'>,\n FieldOption {}\n\nexport type RadioOptions = FieldOptions<RadioOption>\n\ninterface RadioInputOptions {\n options: RadioOptions\n spacing?: SystemProps['margin']\n direction?: StackDirection\n}\n\nexport interface RadioInputProps\n extends Omit<RadioGroupProps, 'children'>,\n RadioInputOptions {}\n\nexport const RadioInput = forwardRef<RadioInputProps, 'div'>(\n ({ options: optionsProp, spacing, direction, ...props }, ref) => {\n const { onBlur, onChange, ...groupProps } = props\n\n const options = mapOptions(optionsProp)\n\n return (\n <RadioGroup onChange={onChange} {...groupProps}>\n <Stack spacing={spacing} direction={direction}>\n {options.map(({ value, label, ...radioProps }, i) => {\n return (\n <Radio\n key={i}\n onBlur={onBlur}\n value={value}\n ref={ref}\n {...radioProps}\n >\n {label || value}\n </Radio>\n )\n })}\n </Stack>\n </RadioGroup>\n )\n }\n)\n\nRadioInput.displayName = 'RadioInput'\n","import * as React from 'react'\nimport { FieldOption, FieldOptions } from './types'\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 let childName = child.props.name\n if (childName.includes('.')) {\n childName = childName.replace(/^.*\\.(.*)/, '$1')\n } else if (childName.includes('.$')) {\n childName = childName.replace(/^.*\\.\\$(.*)/, '$1')\n }\n\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${childName}`,\n })\n }\n return child\n })\n}\n\nexport const mapOptions = <TOption extends FieldOption = FieldOption>(\n options: FieldOptions<TOption>\n) => {\n return options.map((option) => {\n if (typeof option === 'string') {\n return {\n label: option,\n value: option,\n }\n }\n return option\n })\n}\n","import * as React from 'react'\n\nimport {\n chakra,\n forwardRef,\n Menu,\n MenuProps,\n MenuList,\n MenuListProps,\n MenuItemOption,\n MenuOptionGroup,\n Button,\n ButtonProps,\n omitThemingProps,\n useMultiStyleConfig,\n MenuItemOptionProps,\n useFormControlContext,\n ThemingProps,\n useMenuButton,\n} from '@chakra-ui/react'\nimport { cx, dataAttr } from '@chakra-ui/utils'\nimport { ChevronDownIcon } from '@saas-ui/core'\n\nimport { FieldOption } from '../types'\n\nimport {\n SelectOptions,\n SelectProvider,\n SelectStylesProvider,\n useSelect,\n useSelectContext,\n useSelectStyles,\n} from './select-context'\n\nexport interface SelectOption\n extends Omit<MenuItemOptionProps, 'value'>,\n FieldOption {}\n\nexport interface SelectProps\n extends Omit<MenuProps, 'children' | 'variant' | 'size'>,\n ThemingProps<'SuiSelect'>,\n SelectOptions {}\n\nexport interface SelectButtonProps\n extends Omit<ButtonProps, 'size' | 'variant'> {}\n\n/**\n * Button that opens the select menu and displays the selected value.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectButton = forwardRef<SelectButtonProps, 'button'>(\n (props, ref) => {\n const {\n displayValue,\n renderValue,\n placeholder,\n isDisabled: isSelectDisabled,\n } = useSelectContext()\n\n const context = useFormControlContext()\n\n const styles = useSelectStyles()\n\n const {\n isInvalid,\n isReadOnly,\n isDisabled,\n isFocused,\n isRequired,\n id,\n onBlur,\n onFocus,\n } = context || {}\n\n const { rightIcon = <ChevronDownIcon />, ...rest } = props\n\n /* @ts-ignore */\n const focusStyles = styles.field?._focusVisible\n /* @ts-ignore */\n const readOnlyStyles = styles.field?._readOnly\n /* @ts-ignore */\n const invalid = styles.field?._invalid\n\n const height = styles.field?.h || styles.field?.height\n\n const buttonStyles: any = {\n fontWeight: 'normal',\n textAlign: 'left',\n color: 'inherit',\n _active: {\n bg: 'transparent',\n },\n minH: height,\n _focus: focusStyles,\n _expanded: focusStyles,\n _readOnly: readOnlyStyles,\n _invalid: invalid,\n minW: 0,\n ...styles.field,\n h: 'auto',\n }\n\n const buttonProps = useMenuButton(rest, ref)\n\n // Using a Button, so we can simply use leftIcon and rightIcon\n return (\n <Button\n {...buttonProps}\n {...buttonStyles}\n id={id || buttonProps.id}\n {...rest}\n onFocus={onFocus}\n onBlur={onBlur}\n isDisabled={isDisabled || isSelectDisabled}\n data-invalid={dataAttr(isInvalid)}\n data-read-only={dataAttr(isReadOnly)}\n data-focus={dataAttr(isFocused)}\n data-required={dataAttr(isRequired)}\n rightIcon={rightIcon}\n >\n <chakra.span\n __css={{\n display: 'block',\n pointerEvents: 'none',\n flex: '1 1 auto',\n minW: 0,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }}\n >\n {renderValue(displayValue) || placeholder}\n </chakra.span>\n </Button>\n )\n }\n)\n\nSelectButton.displayName = 'SelectButton'\n\n/**\n * Allow users to select a value from a list of options.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const Select = forwardRef<SelectProps, 'select'>((props, ref) => {\n const { name, children, isDisabled, multiple, ...rest } = props\n\n const styles = useMultiStyleConfig('SuiSelect', props)\n\n const menuProps = omitThemingProps(rest)\n\n const context = useSelect(props)\n\n const { value, controlProps } = context\n\n return (\n <SelectProvider value={context}>\n <SelectStylesProvider value={styles}>\n <Menu {...menuProps} closeOnSelect={!multiple}>\n <chakra.div className={cx('sui-select')}>\n {children}\n <chakra.input\n {...controlProps}\n ref={ref}\n name={name}\n type=\"hidden\"\n value={value || ''}\n className=\"saas-select__input\"\n />\n </chakra.div>\n </Menu>\n </SelectStylesProvider>\n </SelectProvider>\n )\n})\n\nexport interface SelectListProps extends MenuListProps {}\n\n/**\n * The list of options to choose from.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectList: React.FC<SelectListProps> = (props) => {\n const { defaultValue, value, options, multiple, onChange } =\n useSelectContext()\n\n return (\n <MenuList maxH=\"100vh\" overflowY=\"auto\" {...props}>\n <MenuOptionGroup\n defaultValue={(defaultValue || value) as string | string[] | undefined}\n value={value}\n onChange={onChange}\n type={multiple ? 'checkbox' : 'radio'}\n >\n {options\n ? options.map(({ value, label, ...rest }, i) => (\n <SelectOption key={i} value={value} {...rest}>\n {label || value}\n </SelectOption>\n ))\n : props.children}\n </MenuOptionGroup>\n </MenuList>\n )\n}\n\nSelect.displayName = 'Select'\n\n/**\n * An option in a select list\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectOption = forwardRef<MenuItemOptionProps, 'button'>(\n (props, ref) => {\n return <MenuItemOption ref={ref} {...props} />\n }\n)\nSelectOption.id = 'MenuItemOption'\nSelectOption.displayName = 'SelectOption'\n","import {\n HTMLChakraProps,\n createStylesContext,\n useControllableState,\n useFormControl,\n} from '@chakra-ui/react'\nimport { createContext } from '@chakra-ui/react-utils'\nimport React from 'react'\nimport { FieldOptions } from '../types'\nimport { mapOptions } from '../utils'\nimport { SelectOption } from './select'\n\nexport const [SelectStylesProvider, useSelectStyles] =\n createStylesContext('SuiSelect')\n\nexport const [SelectProvider, useSelectContext] = createContext<\n ReturnType<typeof useSelect>\n>({\n strict: true,\n})\n\nexport interface SelectOptions {\n /**\n * The name of the input field in a native form.\n */\n name: string\n /**\n * The value of the select field.\n */\n value?: string | string[]\n /**\n * The initial value of the select field.\n */\n defaultValue?: string | string[]\n /**\n * The callback invoked when the value of the select field changes.\n * @param value The value of the select field.\n */\n onChange?: (value: string | string[]) => void\n /**\n * The placeholder text when there's no value.\n */\n placeholder?: string\n /**\n * If `true`, the select will be disabled.\n */\n isDisabled?: boolean\n /**\n * An array of options\n * If you leave this empty the children prop will be rendered.\n */\n options?: FieldOptions<SelectOption>\n /**\n * Enable multiple select.\n */\n multiple?: boolean\n /**\n * The function used to render the value of the select field.\n * @param value The value of the select field.\n * @returns The rendered value.\n */\n renderValue?: (value: string | string[]) => React.ReactNode\n}\n\nexport const useSelect = (props: SelectOptions) => {\n const {\n name,\n value,\n defaultValue,\n onChange,\n multiple,\n placeholder,\n options: optionsProp,\n isDisabled,\n renderValue = (value) =>\n typeof value === 'string' ? value : value?.join(', '),\n } = props\n const [currentValue, setCurrentValue] = useControllableState({\n value,\n defaultValue,\n onChange,\n })\n\n const controlProps = useFormControl({ name } as HTMLChakraProps<'input'>)\n\n const options = React.useMemo(\n () => optionsProp && mapOptions(optionsProp),\n [optionsProp]\n )\n\n const handleChange = (value: string | string[]) => {\n setCurrentValue(value)\n }\n\n const getDisplayValue = React.useCallback(\n (value: string) => {\n if (!options) {\n return value\n }\n\n for (const option of options) {\n if (option.value === value) {\n return option.label || option.value\n }\n }\n\n return value\n },\n [options]\n )\n\n const displayValue = React.useMemo(\n () =>\n currentValue\n ? (Array.isArray(currentValue) ? currentValue : [currentValue]).map(\n getDisplayValue\n )\n : [],\n [currentValue, getDisplayValue]\n )\n\n return {\n defaultValue,\n value: currentValue,\n displayValue,\n renderValue,\n onChange: handleChange,\n options,\n multiple,\n controlProps,\n placeholder,\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Select as ChakraSelect,\n SelectProps as ChakraSelectProps,\n} from '@chakra-ui/react'\n\ninterface Option {\n value: string\n label?: string\n}\n\ninterface NativeSelectOptions {\n options?: Option[]\n}\n\nexport interface NativeSelectProps\n extends ChakraSelectProps,\n NativeSelectOptions {}\n\nexport const NativeSelect = forwardRef<NativeSelectProps, 'select'>(\n ({ options, children, ...props }, ref) => {\n return (\n <ChakraSelect ref={ref} {...props}>\n {children ||\n options?.map(({ value, label }) => {\n return (\n <option key={value} value={value}>\n {label || value}\n </option>\n )\n })}\n </ChakraSelect>\n )\n }\n)\n\nNativeSelect.displayName = 'NativeSelect'\n","import * as React from 'react'\nimport { Controller } from 'react-hook-form'\n\nimport { forwardRef, useMergeRefs } from '@chakra-ui/react'\nimport { callAllHandlers } from '@chakra-ui/utils'\nimport { BaseFieldProps, FieldProps } from './types'\nimport { BaseField } from './base-field'\nimport { useFormContext } from './form-context'\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\n Field.displayName = displayName\n\n return Field\n}\n\nconst 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\nconst 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 CreateFieldOptions {\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 createField = <TProps extends object>(\n component: React.FC<TProps>,\n options?: CreateFieldOptions\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: `${component.displayName ?? 'Custom'}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n }) as React.FC<TProps & BaseFieldProps>\n\n return Field\n}\n","import * as React from 'react'\nimport { FormState, get } from 'react-hook-form'\n\nimport {\n Box,\n FormControl,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n} from '@chakra-ui/react'\n\nimport { useFormContext } from './form-context'\n\nimport { BaseFieldProps, FieldProps } from './types'\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\n/**\n * The default BaseField component\n * Composes the Chakra UI FormControl component, with FormLabel, FormHelperText and FormErrorMessage.\n */\nexport const BaseField: React.FC<BaseFieldProps> = (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\nBaseField.displayName = 'BaseField'\n","import * as React from 'react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\nimport { Field } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\nimport { useFormContext } from './form-context'\n\nexport interface FieldsProps<TSchema = any> {\n schema?: TSchema\n fieldResolver?: FieldResolver\n focusFirstField?: boolean\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n (\n { name, type, ...nestedFieldProps }: BaseFieldProps,\n i\n ): React.ReactNode => (\n <Field\n key={name || i}\n name={name}\n type={type as any}\n {...nestedFieldProps}\n />\n )\n )\n}\n\nexport const AutoFields: React.FC<FieldsProps> = ({\n schema: schemaProp,\n fieldResolver: fieldResolverProp,\n focusFirstField,\n ...props\n}) => {\n const context = useFormContext()\n const schema = schemaProp || context.schema\n const fieldResolver = fieldResolverProp || context.fieldResolver\n const resolver = React.useMemo(() => fieldResolver, [schema, fieldResolver])\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 if (!resolver) {\n return null\n }\n\n return (\n <FormLayout {...props}>\n {fields?.map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: BaseFieldProps): 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 (\n <Field key={name} name={name} type={type as any} {...fieldProps} />\n )\n }\n )}\n </FormLayout>\n )\n}\n\nAutoFields.displayName = 'Fields'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n SimpleGrid,\n SimpleGridProps,\n useTheme,\n} from '@chakra-ui/react'\nimport { cx } from '@chakra-ui/utils'\n\nexport interface FormLayoutProps extends 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\nFormLayoutItem.displayName = 'FormLayoutItem'\n\n/**\n * Create consistent field spacing and positioning.\n *\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n *\n * @see https://saas-ui.dev/docs/components/forms/form\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.SuiFormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('sui-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\nFormLayout.displayName = 'FormLayout'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n forwardRef,\n Button,\n ButtonProps,\n} from '@chakra-ui/react'\nimport { PlusIcon, MinusIcon } from '@saas-ui/core/icons'\n\nimport { FormLayout, FormLayoutProps } from './layout'\nimport { BaseField } from './base-field'\nimport { BaseFieldProps } from './types'\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'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { isFunction } from '@chakra-ui/utils'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\nimport { useFieldProps } from './form-context'\n\nexport interface ArrayFieldButtonProps extends ButtonProps {}\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/**\n * Render prop component, to get access to the internal fields state. Must be a child of ArrayFieldContainer.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRow.displayName = 'ArrayFieldRow'\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/**\n * Add the name prefix to the fields and acts as a horizontal form layout by default.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n\n/**\n * The row container component providers row context.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n ...rest\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 {...rest} __css={styles}>\n {children}\n </chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n\n/**\n * The default remove button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRemoveButton: React.FC<ArrayFieldButtonProps> = (\n props\n) => {\n return (\n <Button aria-label=\"Remove row\" {...useArrayFieldRemoveButton()} {...props}>\n {props.children || <MinusIcon />}\n </Button>\n )\n}\n\nArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n\n/**\n * The default add button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldAddButton: React.FC<ArrayFieldButtonProps> = (props) => {\n return (\n <Button\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n >\n {props.children || <PlusIcon />}\n </Button>\n )\n}\n\nArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n\nexport interface ArrayFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends ArrayFieldOptions<TFieldValues, TName>,\n Omit<\n BaseFieldProps<TFieldValues, TName>,\n 'name' | 'defaultValue' | 'children'\n > {\n children: MaybeRenderProp<ArrayField[]>\n}\n\n/**\n * The wrapper component that composes the default ArrayField functionality.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayField = forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n const rowFn = isFunction(children)\n ? children\n : (fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n )) || null}\n </>\n )\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>{rowFn as any}</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\nArrayField.displayName = 'ArrayField'\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\nArrayFieldRows.displayName = 'ArrayFieldRows'\n\nexport interface ArrayFieldContainerProps\n extends Omit<ArrayFieldProps, 'children'> {\n children: React.ReactNode\n}\n\n/**\n * The container component provides context and state management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldContainerProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const overrides = useFieldProps(name)\n\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min: min || (overrides as any)?.min,\n max: max || (overrides as any)?.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} {...overrides}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nArrayFieldContainer.displayName = 'ArrayFieldContainer'\n","import * as React from 'react'\nimport {\n useFieldArray,\n UseFieldArrayReturn,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\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 TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n /**\n * The field name\n */\n name: TName\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'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyleConfig,\n} from '@chakra-ui/react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\n\nimport { mapNestedFields } from './utils'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { useFieldProps } from './form-context'\n\nexport interface ObjectFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends BaseFieldProps {\n name: TName\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyleConfig('SuiFormLegend')\n return <FormLabel as=\"legend\" sx={styles} {...props} />\n}\n/**\n * The object field component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/object-field\n */\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const {\n name,\n label,\n hideLabel: hideLabelProp,\n children,\n columns: columnsProp,\n spacing: spacingProp,\n ...fieldProps\n } = props\n\n const { hideLabel, columns, spacing, ...overrides } = useFieldProps(\n name\n ) as Omit<ObjectFieldProps, 'name'>\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps} {...overrides}>\n <FormLegend display={hideLabelProp || hideLabel ? 'none' : 'block'}>\n {label}\n </FormLegend>\n <FormLayout\n columns={columnsProp || columns}\n gridGap={spacingProp || spacing}\n >\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nObjectField.displayName = 'ObjectField'\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps, forwardRef } from '@chakra-ui/react'\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/**\n * A button with type submit and default color scheme primary and isLoading state when the form is submitting.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const SubmitButton = forwardRef<SubmitButtonProps, 'button'>(\n (props, ref) => {\n const {\n children = 'Submit',\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 type=\"submit\"\n isLoading={formState.isSubmitting || isLoading}\n isDisabled={isDisabled}\n >\n {children}\n </Button>\n )\n }\n)\n\nSubmitButton.defaultProps = {\n variant: 'primary',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nSubmitButton.displayName = 'SubmitButton'\n","import * as React from 'react'\nimport {\n useWatch,\n FieldValues,\n UseFormReturn,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\n\nexport interface DisplayIfProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n children: React.ReactElement\n name: TName\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n/**\n * Conditionally render parts of a form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const DisplayIf = <\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues, TName>) => {\n const value = useWatch<TFieldValues>({\n name,\n defaultValue: defaultValue as any,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext() as any\n return condition(value, context) ? children : null\n}\n\nDisplayIf.displayName = 'DisplayIf'\n","import * as React from 'react'\n\nimport { FieldValues } from 'react-hook-form'\n\nimport {\n chakra,\n Button,\n ButtonProps,\n HTMLChakraProps,\n ThemingProps,\n} from '@chakra-ui/react'\n\nimport { callAllHandlers, cx } from '@chakra-ui/utils'\n\nimport {\n Steps,\n StepsItem,\n StepsItemProps,\n StepsProps,\n useStepperContext,\n} from '@saas-ui/core'\n\nimport { SubmitButton } from './submit-button'\n\nimport {\n useFormStep,\n UseStepFormProps,\n FormStepSubmitHandler,\n} from './use-step-form'\n\nexport type StepsOptions<TSchema, TName extends string = string> = {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: TSchema\n}[]\n\nexport interface StepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends UseStepFormProps<TSteps, TFieldValues, TContext> {}\n\nexport interface FormStepOptions<TName extends string = string> {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport interface FormStepperProps extends StepsProps, ThemingProps<'Stepper'> {\n render?: StepsItemProps['render']\n}\n\n/**\n * Renders a stepper that displays progress above the form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStepper: React.FC<FormStepperProps> = (props) => {\n const { activeIndex, setIndex } = useStepperContext()\n\n const {\n children,\n orientation,\n variant,\n colorScheme,\n size,\n onChange: onChangeProp,\n render,\n ...rest\n } = 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 <StepsItem\n render={render}\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n {...rest}\n >\n {child.props.children}\n </StepsItem>\n )\n }\n return child\n })\n\n const onChange = React.useCallback((i: number) => {\n setIndex(i)\n onChangeProp?.(i)\n }, [])\n\n return (\n <Steps\n orientation={orientation}\n step={activeIndex}\n variant={variant}\n colorScheme={colorScheme}\n size={size}\n onChange={onChange}\n >\n {elements}\n </Steps>\n )\n}\n\nexport interface FormStepProps<TName extends string = string>\n extends FormStepOptions<TName>,\n Omit<HTMLChakraProps<'div'>, 'onSubmit'> {\n onSubmit?: FormStepSubmitHandler\n}\n/**\n * The form step containing fields for a specific step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStep = <TName extends string = string>(\n props: FormStepProps<TName>\n) => {\n const { name, children, className, onSubmit, ...rest } = props\n const step = useFormStep({ name, onSubmit })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('sui-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nFormStep.displayName = 'FormStep'\n\n/**\n * A button that this opens the previous step when clicked. Disabled on the first step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n children=\"Back\"\n {...props}\n className={cx('sui-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nPrevButton.displayName = 'PrevButton'\n\nexport interface NextButtonProps extends Omit<ButtonProps, 'children'> {\n submitLabel?: string\n label?: string\n}\n\n/**\n * A button that submits the active step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\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('sui-form__next-button', props.className)}\n >\n {isLastStep || isCompleted ? submitLabel : label}\n </SubmitButton>\n )\n}\n\nNextButton.displayName = 'NextButton'\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/core'\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 { FocusableElement } from '@chakra-ui/utils'\nimport { FormProps } from './form'\nimport { FormStepProps, StepsOptions } from './step-form'\nimport { FieldProps, StepFormChildren } from './types'\nimport { DisplayIfProps } from './display-if'\nimport { ArrayFieldProps } from './array-field'\nimport { UseArrayFieldReturn } from './use-array-field'\nimport { ObjectFieldProps } from './object-field'\n\ntype StepName<T extends { [k: number]: { readonly name: string } }> =\n T[number]['name']\n\nexport interface StepFormRenderContext<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseStepFormReturn<TFieldValues> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n FormStep: React.FC<FormStepProps<StepName<TSteps>>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\nexport interface UseStepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends Omit<UseStepperProps, 'onChange'>,\n Omit<FormProps<any, TFieldValues, TContext>, 'children'> {\n steps?: TSteps\n children: StepFormChildren<any, TSteps, TFieldValues, TContext>\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<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: UseStepFormProps<TSteps, TFieldValues, TContext>\n): UseStepFormReturn<TFieldValues> {\n const { onChange, steps: stepsOptions, resolver, ...rest } = props\n const stepper = useStepper(rest)\n\n const [options, setOptions] = React.useState<TSteps | undefined>(stepsOptions)\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\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.schema\n ? /* @todo fix resolver type */ (resolver as any)?.(step.schema)\n : undefined,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n const stepOptions = options?.find((s) => s.name === step.name)\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: {\n ...step,\n schema: stepOptions?.schema,\n },\n }\n })\n },\n [steps, options]\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 { BaseFieldProps } from './types'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): BaseFieldProps[]\n getNestedFields(name: string): BaseFieldProps[]\n}\n\nexport type GetFieldResolver<TSchema = any> = (schema: TSchema) => FieldResolver\n\ninterface SchemaField extends BaseFieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema): BaseFieldProps[] =>\n schema &&\n Object.entries(schema).map(([name, { items, label, title, ...field }]) => {\n return {\n ...field,\n name,\n label: label || title || name, // json schema compatibility\n }\n })\n\nexport const objectFieldResolver: GetFieldResolver<ObjectSchema> = (schema) => {\n const getFields = (): BaseFieldProps[] => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string): BaseFieldProps[] => {\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 { FieldValues, useWatch } from 'react-hook-form'\nimport { useFormContext, UseFormReturn } from './form-context'\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","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { FocusableElement, cx, runIfFn } from '@chakra-ui/utils'\n\nimport {\n useForm,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n ResolverOptions,\n ResolverResult,\n WatchObserver,\n} from 'react-hook-form'\nimport { FormProvider } from './form-context'\nimport { FieldResolver } from './field-resolver'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\nimport { FieldProps, DefaultFieldOverrides } from './types'\n\nimport { Field as DefaultField } from './field'\nimport { FormLayout } from './layout'\nimport { AutoFields } from './fields'\nimport { SubmitButton } from './submit-button'\nimport { DisplayIf, DisplayIfProps } from './display-if'\nimport { ArrayField, ArrayFieldProps } from './array-field'\nimport { ObjectField, ObjectFieldProps } from './object-field'\nimport { UseArrayFieldReturn } from './use-array-field'\n\nexport interface FormRenderContext<\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormReturn<TFieldValues, TContext> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\ninterface FormOptions<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> {\n /**\n * The form schema.\n */\n schema?: TSchema\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 * The Hook Form state ref.\n */\n formRef?: React.RefObject<UseFormReturn<TFieldValues, TContext>>\n /**\n * The form children, can be a render prop or a ReactNode.\n */\n children?: MaybeRenderProp<\n FormRenderContext<TFieldValues, TContext, TFieldTypes>\n >\n /**\n * The field resolver, used to resolve the fields from schemas.\n */\n fieldResolver?: FieldResolver\n /**\n * Field overrides\n */\n fields?: DefaultFieldOverrides\n}\n\nexport interface FormProps<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormProps<TFieldValues, TContext>,\n Omit<\n HTMLChakraProps<'form'>,\n 'children' | 'onChange' | 'onSubmit' | 'onError'\n >,\n FormOptions<TSchema, TFieldValues, TContext, TFieldTypes> {}\n\n/**\n * The wrapper component provides context, state, and focus management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n >(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes>,\n ref: React.ForwardedRef<HTMLFormElement>\n ) => {\n const {\n mode = 'all',\n resolver,\n fieldResolver,\n fields,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n values,\n context,\n resetOptions,\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 values,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n context,\n resetOptions,\n }\n\n const methods = useForm<TFieldValues, TContext>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(formRef, () => methods, [formRef, 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 let _children = children\n if (!_children && fieldResolver) {\n _children = (\n <FormLayout>\n <AutoFields />\n <SubmitButton {...fields?.submit} />\n </FormLayout>\n )\n }\n\n return (\n <FormProvider\n {...methods}\n schema={schema}\n fieldResolver={fieldResolver}\n fields={fields}\n >\n <chakra.form\n ref={ref}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('sui-form', props.className)}\n >\n {runIfFn(_children, {\n Field: DefaultField as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n ...methods,\n })}\n </chakra.form>\n </FormProvider>\n )\n }\n) as FormComponent\n\nexport type FormComponent = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes> & {\n ref?: React.ForwardedRef<HTMLFormElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n\nForm.displayName = 'Form'\n\nexport type GetResolver = <\n TFieldValues extends FieldValues,\n TContext extends object\n>(\n schema: unknown\n) => (\n values: TFieldValues,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n","import React, { ForwardedRef } from 'react'\nimport { FieldsProvider } from './fields-context'\nimport { Form, FieldValues, FormProps, GetResolver } from './form'\nimport { DefaultFieldOverrides, WithFields } from './types'\nimport { objectFieldResolver } from './field-resolver'\nimport { GetFieldResolver } from './field-resolver'\nimport { forwardRef } from '@chakra-ui/react'\n\nexport interface CreateFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport type FormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: WithFields<\n FormProps<TSchema, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport function createForm<FieldDefs>({\n resolver,\n fieldResolver = objectFieldResolver,\n fields,\n}: CreateFormProps<FieldDefs> = {}) {\n const DefaultForm = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n >(\n props: WithFields<FormProps<TSchema, TFieldValues, TContext>, FieldDefs>,\n ref: ForwardedRef<HTMLFormElement>\n ) => {\n const { schema, ...rest } = props\n return (\n <FieldsProvider value={fields || {}}>\n <Form\n ref={ref}\n resolver={resolver?.(props.schema)}\n fieldResolver={fieldResolver?.(schema)}\n {...rest}\n />\n </FieldsProvider>\n )\n }\n ) as FormType<FieldDefs>\n\n DefaultForm.displayName = 'Form'\n DefaultForm.id = 'Form'\n\n return DefaultForm\n}\n","import React, { useMemo } from 'react'\nimport { forwardRef } from '@chakra-ui/react'\nimport {\n ArrayField,\n DisplayIf,\n FieldProps,\n FieldValues,\n FieldsProvider,\n Form,\n GetFieldResolver,\n ObjectField,\n} from './'\nimport { Field } from './field'\nimport { FormStep, StepsOptions } from './step-form'\nimport {\n StepFormProvider,\n UseStepFormProps,\n useStepForm,\n} from './use-step-form'\nimport { StepperProvider } from '@saas-ui/core'\nimport { runIfFn } from '@chakra-ui/utils'\nimport { GetResolver } from './form'\nimport { WithStepFields } from './types'\n\nexport type StepFormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: WithStepFields<\n UseStepFormProps<TSteps, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport interface CreateStepFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport function createStepForm<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n>({ fields, resolver, fieldResolver }: CreateStepFormProps<FieldDefs> = {}) {\n const StepForm = forwardRef<any, 'div'>((props, ref) => {\n const { children, steps, ...rest } = props\n\n const stepper = useStepForm({\n resolver,\n fieldResolver,\n ...props,\n })\n\n const { getFormProps, ...ctx } = stepper\n\n const context = useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <FieldsProvider value={fields || {}}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, {\n ...stepper,\n Field: Field as any,\n FormStep: FormStep as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n })}\n </Form>\n </FieldsProvider>\n </StepFormProvider>\n </StepperProvider>\n )\n }) as StepFormType<FieldDefs, ExtraProps, ExtraOverrides>\n\n StepForm.displayName = `Step${Form.displayName || Form.name}`\n\n return StepForm\n}\n","export * from './display-field'\nexport * from './field'\nexport * from './fields'\nexport * from './fields-context'\nexport * from './layout'\nexport * from './submit-button'\nexport * from './array-field'\nexport * from './use-array-field'\nexport * from './object-field'\nexport * from './display-if'\nexport * from './step-form'\nexport * from './use-step-form'\nexport * from './field-resolver'\nexport * from './watch-field'\nexport * from './input-right-button'\nexport * from './select'\nexport * from './password-input'\nexport * from './radio'\n\nexport * from './base-field'\n\nexport {\n CheckboxField,\n InputField,\n NativeSelectField,\n NumberInputField,\n PasswordInputField,\n PinField,\n RadioField,\n SelectField,\n SwitchField,\n TextareaField,\n defaultFieldTypes,\n type DefaultFields,\n type InputFieldProps,\n type NumberInputFieldProps,\n type PinFieldProps,\n} from './default-fields'\n\nexport type {\n FieldProps,\n WithFields,\n BaseFieldProps,\n FieldOptions,\n DefaultFieldOverrides,\n WithStepFields,\n} from './types'\n\nexport { createForm, type CreateFormProps, type FormType } from './create-form'\nexport { createField, type CreateFieldOptions } from './create-field'\n\nexport { Form as BaseForm } from './form'\nexport type { FormProps, FormRenderContext, FormComponent } from './form'\n\nexport { FormProvider, useFormContext } from './form-context'\n\nimport { createForm } from './create-form'\nimport { createStepForm } from './create-step-form'\n\n/**\n * Form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = createForm()\n\nexport { createStepForm, type CreateStepFormProps } from './create-step-form'\n\n/**\n * Multi-step form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const StepForm = createStepForm()\n\nexport type {\n BatchFieldArrayUpdate,\n ChangeHandler,\n Control,\n ControllerFieldState,\n ControllerProps,\n ControllerRenderProps,\n CriteriaMode,\n CustomElement,\n DeepMap,\n DeepPartial,\n DeepPartialSkipArrayKey,\n DefaultValues,\n DelayCallback,\n EmptyObject,\n ErrorOption,\n EventType,\n Field as FieldDef,\n FieldArray,\n FieldArrayMethodProps,\n FieldArrayWithId,\n FieldElement,\n FieldError,\n FieldErrors,\n FieldName,\n FieldNamesMarkedBoolean,\n FieldRefs,\n FieldValue,\n FieldValues,\n FormProviderProps,\n FormState,\n FormStateProxy,\n FormStateSubjectRef,\n GetIsDirty,\n InternalFieldErrors,\n InternalFieldName,\n InternalNameSet,\n IsAny,\n IsFlatObject,\n KeepStateOptions,\n LiteralUnion,\n Message,\n Mode,\n MultipleFieldErrors,\n Names,\n NativeFieldValue,\n NestedValue,\n NonUndefined,\n Noop,\n Primitive,\n ReadFormState,\n Ref,\n RefCallBack,\n RegisterOptions,\n Resolver,\n ResolverError,\n ResolverOptions,\n ResolverResult,\n ResolverSuccess,\n SetFieldValue,\n SetValueConfig,\n Subjects,\n SubmitErrorHandler,\n SubmitHandler,\n TriggerConfig,\n UnpackNestedValue,\n UseControllerProps,\n UseControllerReturn,\n UseFieldArrayProps,\n UseFieldArrayReturn,\n UseFormClearErrors,\n UseFormGetValues,\n UseFormHandleSubmit,\n UseFormProps,\n UseFormRegister,\n UseFormRegisterReturn,\n UseFormReset,\n UseFormResetField,\n UseFormReturn,\n UseFormSetError,\n UseFormSetFocus,\n UseFormSetValue,\n UseFormStateProps,\n UseFormStateReturn,\n UseFormTrigger,\n UseFormUnregister,\n UseFormWatch,\n UseWatchProps,\n Validate,\n ValidateResult,\n ValidationMode,\n ValidationRule,\n ValidationValue,\n ValidationValueMessage,\n WatchInternal,\n WatchObserver,\n} from 'react-hook-form'\n\nexport {\n appendErrors,\n useController,\n useFieldArray,\n useForm,\n useFormState,\n useWatch,\n Controller,\n} from 'react-hook-form'\n"]}
1
+ {"version":3,"sources":["../src/form-context.tsx","../src/display-field.tsx","../src/field.tsx","../src/fields-context.tsx","../src/default-fields.tsx","../src/number-input/number-input.tsx","../src/password-input/password-input.tsx","../src/input-right-button/input-right-button.tsx","../src/radio/radio-input.tsx","../src/utils.ts","../src/select/select.tsx","../src/select/select-context.tsx","../src/select/native-select.tsx","../src/create-field.tsx","../src/base-field.tsx","../src/fields.tsx","../src/layout.tsx","../src/array-field.tsx","../src/use-array-field.tsx","../src/object-field.tsx","../src/submit-button.tsx","../src/display-if.tsx","../src/step-form.tsx","../src/use-step-form.tsx","../src/field-resolver.ts","../src/watch-field.tsx","../src/form.tsx","../src/create-form.tsx","../src/create-step-form.tsx","../src/index.ts"],"names":["jsx","React","forwardRef","Input","InputGroup","jsxs","Button","ChevronDownIcon","createContext","value","FormControl","FormLabel","BaseField","Field","NumberInputField","chakra","cx","mapNestedFields","name","useFormContext","callAllHandlers","steps","get","useWatch","useMemo","runIfFn","StepForm","useFieldArray","useForm","Controller","Form"],"mappings":"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","sourcesContent":["import * as React from 'react'\nimport {\n FormProvider as HookFormProvider,\n FormProviderProps as HookFormProviderProps,\n useFormContext as useHookFormContext,\n FieldValues,\n} from 'react-hook-form'\nimport { FieldResolver } from './field-resolver'\nimport { BaseFieldProps, FieldProps } from './types'\n\nexport type FormContextValue<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nexport type FormProviderProps<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = HookFormProviderProps<TFieldValues, TContext> & {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nconst FormContext = React.createContext<FormContextValue | null>(null)\n\nexport const useFormContext = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>() => {\n const context = React.useContext(FormContext)\n const hookContext = useHookFormContext()\n\n if (!context) {\n throw new Error('FormProvider must be used within a Form component')\n }\n\n return {\n ...hookContext,\n ...context,\n }\n}\n\nexport const useFieldProps = <TFieldValues extends FieldValues = FieldValues>(\n name: string\n): BaseFieldProps<TFieldValues> | undefined => {\n const parsedName = name?.replace(/\\.[0-9]/g, '.$')\n const context = useFormContext()\n return (context?.fields?.[parsedName] as any) || {}\n}\n\nexport type UseFormReturn<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = ReturnType<typeof useFormContext>\n\nexport const FormProvider = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>(\n props: FormProviderProps<TFieldValues, TContext, TSchema>\n) => {\n const { children, fieldResolver, schema, fields, ...rest } = props\n return (\n <HookFormProvider {...rest}>\n <FormContext.Provider value={{ fieldResolver, schema, fields }}>\n {children}\n </FormContext.Provider>\n </HookFormProvider>\n )\n}\n","import * as React from 'react'\nimport { useFormContext } from './form-context'\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './types'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n/**\n *\n *\n * @see Docs https://saas-ui.dev/\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\nDisplayField.displayName = 'DisplayField'\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nFormValue.displayName = 'FormValue'\n","import * as React from 'react'\nimport { RegisterOptions, FieldValues } from 'react-hook-form'\n\nimport { FocusableElement } from '@chakra-ui/utils'\nimport { useField } from './fields-context'\nimport { FieldProps } from './types'\nimport { useFieldProps } from './form-context'\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\nconst defaultInputType = 'text'\n\n/**\n * Form field component.\n * \n * Build-in types:\n * text, number, password, textarea, select, native-select, checkbox, radio, switch, pin\n *\n * Will default to a text field if there is no matching type.\n\n * @see Docs https://saas-ui.dev/docs/components/forms/field\n */\nexport const Field = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues>,\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType, name } = props\n const overrides = useFieldProps(name)\n const InputComponent = useField(overrides?.type || type)\n\n return <InputComponent ref={ref} {...props} {...overrides} />\n }\n) as (<TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n","import React from 'react'\nimport { defaultFieldTypes, InputField } from './default-fields'\n\nconst FieldsContext = React.createContext<Record<string, React.FC<any>> | null>(\n null\n)\n\nexport const FieldsProvider: React.FC<{\n value: Record<string, React.FC<any>>\n children: React.ReactNode\n}> = (props) => {\n const fields = { ...defaultFieldTypes, ...props.value }\n return (\n <FieldsContext.Provider value={fields}>\n {props.children}\n </FieldsContext.Provider>\n )\n}\n\nexport const useField = (type: string): React.FC<any> => {\n const context = React.useContext(FieldsContext)\n return context?.[type] || InputField\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Input,\n Textarea,\n Checkbox,\n Switch,\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'\n\nimport { NumberInput, NumberInputProps } from './number-input'\nimport { PasswordInput, PasswordInputProps } from './password-input'\nimport { RadioInput, RadioInputProps } from './radio'\n\nimport {\n Select,\n SelectButton,\n SelectList,\n SelectProps,\n NativeSelect,\n NativeSelectProps,\n} from './select'\n\nimport { createField } from './create-field'\nimport { ObjectField } from './object-field'\nimport { ArrayField } from './array-field'\n\nexport interface InputFieldProps extends InputProps {\n type?: string\n leftAddon?: React.ReactNode\n rightAddon?: React.ReactNode\n}\n\nexport const InputField = createField<InputFieldProps>(\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 = createField<NumberInputFieldProps>(\n NumberInput,\n {\n isControlled: true,\n }\n)\n\nexport const PasswordInputField = createField<PasswordInputProps>(\n forwardRef((props, ref) => <PasswordInput ref={ref} {...props} />)\n)\n\nexport const TextareaField = createField<TextareaProps>(Textarea)\n\nexport const SwitchField = createField<SwitchProps>(\n forwardRef(({ type, value, ...rest }, ref) => {\n return <Switch isChecked={!!value} {...rest} ref={ref} />\n }),\n {\n isControlled: true,\n }\n)\n\nexport const SelectField = createField<SelectProps>(\n forwardRef((props, ref) => {\n return (\n <Select ref={ref} {...props}>\n <SelectButton />\n <SelectList />\n </Select>\n )\n }),\n {\n isControlled: true,\n }\n)\n\nexport const CheckboxField = createField<CheckboxProps>(\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 = createField<RadioInputProps>(RadioInput, {\n isControlled: true,\n})\n\nexport const NativeSelectField = createField<NativeSelectProps>(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 = createField<PinFieldProps>(\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\nexport const defaultFieldTypes = {\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 select: SelectField,\n checkbox: CheckboxField,\n radio: RadioField,\n pin: PinField,\n 'native-select': NativeSelectField,\n}\n\nexport type DefaultFields = typeof defaultFieldTypes\n","import * as React from 'react'\n\nimport {\n forwardRef,\n NumberInput as ChakraNumberInput,\n NumberInputField,\n NumberInputStepper,\n NumberIncrementStepper,\n NumberDecrementStepper,\n NumberInputProps as ChakraNumberInputProps,\n} from '@chakra-ui/react'\n\nimport { ChevronDownIcon, ChevronUpIcon } from '@saas-ui/core'\n\ninterface NumberInputOptions {\n /**\n * Hide the stepper.\n */\n hideStepper?: boolean\n /**\n * Render a custom increment icon.\n */\n incrementIcon?: React.ReactNode\n /**\n * Render a custom decrement icon.\n */\n decrementIcon?: React.ReactNode\n}\n\nexport interface NumberInputProps\n extends ChakraNumberInputProps,\n NumberInputOptions {}\n\nexport const NumberInput = forwardRef<NumberInputProps, 'div'>((props, ref) => {\n const {\n hideStepper,\n incrementIcon = <ChevronUpIcon />,\n decrementIcon = <ChevronDownIcon />,\n ...rest\n } = props\n\n return (\n <ChakraNumberInput {...rest} ref={ref}>\n <NumberInputField />\n\n {!hideStepper && (\n <NumberInputStepper>\n <NumberIncrementStepper children={incrementIcon} />\n <NumberDecrementStepper children={decrementIcon} />\n </NumberInputStepper>\n )}\n </ChakraNumberInput>\n )\n})\n\nNumberInput.defaultProps = {\n hideStepper: false,\n}\n\nNumberInput.displayName = 'NumberInput'\n","import React, { useState } from 'react'\n\nimport { forwardRef, InputGroup, Input, InputProps } from '@chakra-ui/react'\n\nimport { ViewIcon, ViewOffIcon } from '@saas-ui/core/icons'\n\nimport { InputRightButton } from '../input-right-button'\n\ninterface PasswordOptions {\n viewIcon?: React.ReactNode\n viewOffIcon?: React.ReactNode\n leftAddon?: React.ReactNode\n}\n\nexport interface PasswordInputProps extends InputProps, PasswordOptions {}\n\nexport const PasswordInput = forwardRef<PasswordInputProps, 'div'>(\n (props, ref) => {\n const {\n viewIcon,\n viewOffIcon,\n autoComplete,\n w,\n width,\n size,\n variant,\n leftAddon,\n ...inputProps\n } = props\n const [show, setShow] = useState(false)\n const handleClick = () => setShow(!show)\n\n const label = show ? 'Hide password' : 'Show password'\n\n let icon\n if (show) {\n icon = viewIcon || <ViewIcon />\n } else {\n icon = viewOffIcon || <ViewOffIcon />\n }\n\n const groupProps = {\n width: w || width,\n size,\n variant,\n }\n\n return (\n <InputGroup {...groupProps}>\n {leftAddon}\n <Input\n {...inputProps}\n ref={ref}\n type={show ? 'text' : 'password'}\n autoComplete={show ? 'off' : autoComplete}\n />\n <InputRightButton\n onClick={handleClick}\n aria-label={label}\n variant=\"ghost\"\n >\n {icon}\n </InputRightButton>\n </InputGroup>\n )\n }\n)\n\nPasswordInput.displayName = 'PasswordInput'\n","import * as React from 'react'\n\nimport {\n Button,\n ButtonProps,\n forwardRef,\n InputRightElement,\n} from '@chakra-ui/react'\n\nexport type InputRightButtonProps = ButtonProps\n\nexport const InputRightButton = forwardRef<InputRightButtonProps, 'div'>(\n (props, ref) => {\n return (\n <InputRightElement w=\"auto\" px=\"1\" py=\"1\" alignItems=\"stretch\">\n <Button ref={ref} height=\"auto\" {...props} />\n </InputRightElement>\n )\n }\n)\n\nInputRightButton.id = 'InputRightElement'\n\nInputRightButton.displayName = 'InputRightButton'\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Stack,\n RadioGroup,\n RadioGroupProps,\n Radio,\n RadioProps,\n SystemProps,\n StackDirection,\n} from '@chakra-ui/react'\nimport { FieldOptions, FieldOption } from '../types'\nimport { mapOptions } from '../utils'\n\nexport interface RadioOption\n extends Omit<RadioProps, 'value' | 'label'>,\n FieldOption {}\n\nexport type RadioOptions = FieldOptions<RadioOption>\n\ninterface RadioInputOptions {\n options: RadioOptions\n spacing?: SystemProps['margin']\n direction?: StackDirection\n}\n\nexport interface RadioInputProps\n extends Omit<RadioGroupProps, 'children'>,\n RadioInputOptions {}\n\nexport const RadioInput = forwardRef<RadioInputProps, 'div'>(\n ({ options: optionsProp, spacing, direction, ...props }, ref) => {\n const { onBlur, onChange, ...groupProps } = props\n\n const options = mapOptions(optionsProp)\n\n return (\n <RadioGroup onChange={onChange} {...groupProps}>\n <Stack spacing={spacing} direction={direction}>\n {options.map(({ value, label, ...radioProps }, i) => {\n return (\n <Radio\n key={i}\n onBlur={onBlur}\n value={value}\n ref={ref}\n {...radioProps}\n >\n {label || value}\n </Radio>\n )\n })}\n </Stack>\n </RadioGroup>\n )\n }\n)\n\nRadioInput.displayName = 'RadioInput'\n","import * as React from 'react'\nimport { FieldOption, FieldOptions } from './types'\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 let childName = child.props.name\n if (childName.includes('.')) {\n childName = childName.replace(/^.*\\.(.*)/, '$1')\n } else if (childName.includes('.$')) {\n childName = childName.replace(/^.*\\.\\$(.*)/, '$1')\n }\n\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${childName}`,\n })\n }\n return child\n })\n}\n\nexport const mapOptions = <TOption extends FieldOption = FieldOption>(\n options: FieldOptions<TOption>\n) => {\n return options.map((option) => {\n if (typeof option === 'string') {\n return {\n label: option,\n value: option,\n }\n }\n return option\n })\n}\n","import * as React from 'react'\n\nimport {\n chakra,\n forwardRef,\n Menu,\n MenuProps,\n MenuList,\n MenuListProps,\n MenuItemOption,\n MenuOptionGroup,\n Button,\n ButtonProps,\n omitThemingProps,\n useMultiStyleConfig,\n MenuItemOptionProps,\n useFormControlContext,\n ThemingProps,\n useMenuButton,\n} from '@chakra-ui/react'\nimport { cx, dataAttr } from '@chakra-ui/utils'\nimport { ChevronDownIcon } from '@saas-ui/core'\n\nimport { FieldOption } from '../types'\n\nimport {\n SelectOptions,\n SelectProvider,\n SelectStylesProvider,\n useSelect,\n useSelectContext,\n useSelectStyles,\n} from './select-context'\n\nexport interface SelectOption\n extends Omit<MenuItemOptionProps, 'value'>,\n FieldOption {}\n\nexport interface SelectProps\n extends Omit<MenuProps, 'children' | 'variant' | 'size'>,\n ThemingProps<'SuiSelect'>,\n SelectOptions {}\n\nexport interface SelectButtonProps\n extends Omit<ButtonProps, 'size' | 'variant'> {}\n\n/**\n * Button that opens the select menu and displays the selected value.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectButton = forwardRef<SelectButtonProps, 'button'>(\n (props, ref) => {\n const {\n displayValue,\n renderValue,\n placeholder,\n isDisabled: isSelectDisabled,\n } = useSelectContext()\n\n const context = useFormControlContext()\n\n const styles = useSelectStyles()\n\n const {\n isInvalid,\n isReadOnly,\n isDisabled,\n isFocused,\n isRequired,\n id,\n onBlur,\n onFocus,\n } = context || {}\n\n const { rightIcon = <ChevronDownIcon />, ...rest } = props\n\n /* @ts-ignore */\n const focusStyles = styles.field?._focusVisible\n /* @ts-ignore */\n const readOnlyStyles = styles.field?._readOnly\n /* @ts-ignore */\n const invalid = styles.field?._invalid\n\n const height = styles.field?.h || styles.field?.height\n\n const buttonStyles: any = {\n fontWeight: 'normal',\n textAlign: 'left',\n color: 'inherit',\n _active: {\n bg: 'transparent',\n },\n minH: height,\n _focus: focusStyles,\n _expanded: focusStyles,\n _readOnly: readOnlyStyles,\n _invalid: invalid,\n minW: 0,\n ...styles.field,\n h: 'auto',\n }\n\n const buttonProps = useMenuButton(rest, ref)\n\n // Using a Button, so we can simply use leftIcon and rightIcon\n return (\n <Button\n {...buttonProps}\n {...buttonStyles}\n id={id || buttonProps.id}\n {...rest}\n onFocus={onFocus}\n onBlur={onBlur}\n isDisabled={isDisabled || isSelectDisabled}\n data-invalid={dataAttr(isInvalid)}\n data-read-only={dataAttr(isReadOnly)}\n data-focus={dataAttr(isFocused)}\n data-required={dataAttr(isRequired)}\n rightIcon={rightIcon}\n >\n <chakra.span\n __css={{\n display: 'block',\n pointerEvents: 'none',\n flex: '1 1 auto',\n minW: 0,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }}\n >\n {renderValue(displayValue) || placeholder}\n </chakra.span>\n </Button>\n )\n }\n)\n\nSelectButton.displayName = 'SelectButton'\n\n/**\n * Allow users to select a value from a list of options.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const Select = forwardRef<SelectProps, 'select'>((props, ref) => {\n const { name, children, isDisabled, multiple, ...rest } = props\n\n const styles = useMultiStyleConfig('SuiSelect', props)\n\n const menuProps = omitThemingProps(rest)\n\n const context = useSelect(props)\n\n const { value, controlProps } = context\n\n return (\n <SelectProvider value={context}>\n <SelectStylesProvider value={styles}>\n <Menu {...menuProps} closeOnSelect={!multiple}>\n <chakra.div className={cx('sui-select')}>\n {children}\n <chakra.input\n {...controlProps}\n ref={ref}\n name={name}\n type=\"hidden\"\n value={value || ''}\n className=\"saas-select__input\"\n />\n </chakra.div>\n </Menu>\n </SelectStylesProvider>\n </SelectProvider>\n )\n})\n\nexport interface SelectListProps extends MenuListProps {}\n\n/**\n * The list of options to choose from.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectList: React.FC<SelectListProps> = (props) => {\n const { defaultValue, value, options, multiple, onChange } =\n useSelectContext()\n\n return (\n <MenuList maxH=\"100vh\" overflowY=\"auto\" {...props}>\n <MenuOptionGroup\n defaultValue={(defaultValue || value) as string | string[] | undefined}\n value={value}\n onChange={onChange}\n type={multiple ? 'checkbox' : 'radio'}\n >\n {options\n ? options.map(({ value, label, ...rest }, i) => (\n <SelectOption key={i} value={value} {...rest}>\n {label || value}\n </SelectOption>\n ))\n : props.children}\n </MenuOptionGroup>\n </MenuList>\n )\n}\n\nSelect.displayName = 'Select'\n\n/**\n * An option in a select list\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectOption = forwardRef<MenuItemOptionProps, 'button'>(\n (props, ref) => {\n return <MenuItemOption ref={ref} {...props} />\n }\n)\nSelectOption.id = 'MenuItemOption'\nSelectOption.displayName = 'SelectOption'\n","import {\n HTMLChakraProps,\n createStylesContext,\n useControllableState,\n useFormControl,\n} from '@chakra-ui/react'\nimport { createContext } from '@chakra-ui/react-utils'\nimport React from 'react'\nimport { FieldOptions } from '../types'\nimport { mapOptions } from '../utils'\nimport { SelectOption } from './select'\n\nexport const [SelectStylesProvider, useSelectStyles] =\n createStylesContext('SuiSelect')\n\nexport const [SelectProvider, useSelectContext] = createContext<\n ReturnType<typeof useSelect>\n>({\n strict: true,\n})\n\nexport interface SelectOptions {\n /**\n * The name of the input field in a native form.\n */\n name: string\n /**\n * The value of the select field.\n */\n value?: string | string[]\n /**\n * The initial value of the select field.\n */\n defaultValue?: string | string[]\n /**\n * The callback invoked when the value of the select field changes.\n * @param value The value of the select field.\n */\n onChange?: (value: string | string[]) => void\n /**\n * The placeholder text when there's no value.\n */\n placeholder?: string\n /**\n * If `true`, the select will be disabled.\n */\n isDisabled?: boolean\n /**\n * An array of options\n * If you leave this empty the children prop will be rendered.\n */\n options?: FieldOptions<SelectOption>\n /**\n * Enable multiple select.\n */\n multiple?: boolean\n /**\n * The function used to render the value of the select field.\n * @param value The value of the select field.\n * @returns The rendered value.\n */\n renderValue?: (value: string | string[]) => React.ReactNode\n}\n\nexport const useSelect = (props: SelectOptions) => {\n const {\n name,\n value,\n defaultValue,\n onChange,\n multiple,\n placeholder,\n options: optionsProp,\n isDisabled,\n renderValue = (value) =>\n typeof value === 'string' ? value : value?.join(', '),\n } = props\n const [currentValue, setCurrentValue] = useControllableState({\n value,\n defaultValue,\n onChange,\n })\n\n const controlProps = useFormControl({ name } as HTMLChakraProps<'input'>)\n\n const options = React.useMemo(\n () => optionsProp && mapOptions(optionsProp),\n [optionsProp]\n )\n\n const handleChange = (value: string | string[]) => {\n setCurrentValue(value)\n }\n\n const getDisplayValue = React.useCallback(\n (value: string) => {\n if (!options) {\n return value\n }\n\n for (const option of options) {\n if (option.value === value) {\n return option.label || option.value\n }\n }\n\n return value\n },\n [options]\n )\n\n const displayValue = React.useMemo(\n () =>\n currentValue\n ? (Array.isArray(currentValue) ? currentValue : [currentValue]).map(\n getDisplayValue\n )\n : [],\n [currentValue, getDisplayValue]\n )\n\n return {\n defaultValue,\n value: currentValue,\n displayValue,\n renderValue,\n onChange: handleChange,\n options,\n multiple,\n controlProps,\n placeholder,\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Select as ChakraSelect,\n SelectProps as ChakraSelectProps,\n} from '@chakra-ui/react'\n\ninterface Option {\n value: string\n label?: string\n}\n\ninterface NativeSelectOptions {\n options?: Option[]\n}\n\nexport interface NativeSelectProps\n extends ChakraSelectProps,\n NativeSelectOptions {}\n\nexport const NativeSelect = forwardRef<NativeSelectProps, 'select'>(\n ({ options, children, ...props }, ref) => {\n return (\n <ChakraSelect ref={ref} {...props}>\n {children ||\n options?.map(({ value, label }) => {\n return (\n <option key={value} value={value}>\n {label || value}\n </option>\n )\n })}\n </ChakraSelect>\n )\n }\n)\n\nNativeSelect.displayName = 'NativeSelect'\n","import * as React from 'react'\nimport { Controller } from 'react-hook-form'\n\nimport { forwardRef, useMergeRefs } from '@chakra-ui/react'\nimport { callAllHandlers } from '@chakra-ui/utils'\nimport { BaseFieldProps, FieldProps } from './types'\nimport { BaseField } from './base-field'\nimport { useFormContext } from './form-context'\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\n Field.displayName = displayName\n\n return Field\n}\n\nconst 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\nconst 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 CreateFieldOptions {\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 createField = <TProps extends object>(\n component: React.FC<TProps>,\n options?: CreateFieldOptions\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: `${component.displayName ?? 'Custom'}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n }) as React.FC<TProps & BaseFieldProps>\n\n return Field\n}\n","import * as React from 'react'\nimport { FormState, get } from 'react-hook-form'\n\nimport {\n Box,\n FormControl,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n} from '@chakra-ui/react'\n\nimport { useFormContext } from './form-context'\n\nimport { BaseFieldProps, FieldProps } from './types'\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\n/**\n * The default BaseField component\n * Composes the Chakra UI FormControl component, with FormLabel, FormHelperText and FormErrorMessage.\n */\nexport const BaseField: React.FC<BaseFieldProps> = (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\nBaseField.displayName = 'BaseField'\n","import * as React from 'react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\nimport { Field } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\nimport { useFormContext } from './form-context'\n\nexport interface FieldsProps<TSchema = any> {\n schema?: TSchema\n fieldResolver?: FieldResolver\n focusFirstField?: boolean\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n (\n { name, type, ...nestedFieldProps }: BaseFieldProps,\n i\n ): React.ReactNode => (\n <Field\n key={name || i}\n name={name}\n type={type as any}\n {...nestedFieldProps}\n />\n )\n )\n}\n\nexport const AutoFields: React.FC<FieldsProps> = ({\n schema: schemaProp,\n fieldResolver: fieldResolverProp,\n focusFirstField,\n ...props\n}) => {\n const context = useFormContext()\n const schema = schemaProp || context.schema\n const fieldResolver = fieldResolverProp || context.fieldResolver\n const resolver = React.useMemo(() => fieldResolver, [schema, fieldResolver])\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 if (!resolver) {\n return null\n }\n\n return (\n <FormLayout {...props}>\n {fields?.map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: BaseFieldProps): 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 (\n <Field key={name} name={name} type={type as any} {...fieldProps} />\n )\n }\n )}\n </FormLayout>\n )\n}\n\nAutoFields.displayName = 'Fields'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n SimpleGrid,\n SimpleGridProps,\n useTheme,\n} from '@chakra-ui/react'\nimport { cx } from '@chakra-ui/utils'\n\nexport interface FormLayoutProps extends 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\nFormLayoutItem.displayName = 'FormLayoutItem'\n\n/**\n * Create consistent field spacing and positioning.\n *\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n *\n * @see https://saas-ui.dev/docs/components/forms/form\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.SuiFormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('sui-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\nFormLayout.displayName = 'FormLayout'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n forwardRef,\n Button,\n ButtonProps,\n} from '@chakra-ui/react'\nimport { PlusIcon, MinusIcon } from '@saas-ui/core/icons'\n\nimport { FormLayout, FormLayoutProps } from './layout'\nimport { BaseField } from './base-field'\nimport { BaseFieldProps } from './types'\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'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { isFunction } from '@chakra-ui/utils'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\nimport { useFieldProps } from './form-context'\n\nexport interface ArrayFieldButtonProps extends ButtonProps {}\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/**\n * Render prop component, to get access to the internal fields state. Must be a child of ArrayFieldContainer.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRow.displayName = 'ArrayFieldRow'\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/**\n * Add the name prefix to the fields and acts as a horizontal form layout by default.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n\n/**\n * The row container component providers row context.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n ...rest\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 {...rest} __css={styles}>\n {children}\n </chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n\n/**\n * The default remove button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRemoveButton: React.FC<ArrayFieldButtonProps> = (\n props\n) => {\n return (\n <Button aria-label=\"Remove row\" {...useArrayFieldRemoveButton()} {...props}>\n {props.children || <MinusIcon />}\n </Button>\n )\n}\n\nArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n\n/**\n * The default add button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldAddButton: React.FC<ArrayFieldButtonProps> = (props) => {\n return (\n <Button\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n >\n {props.children || <PlusIcon />}\n </Button>\n )\n}\n\nArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n\nexport interface ArrayFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends ArrayFieldOptions<TFieldValues, TName>,\n Omit<\n BaseFieldProps<TFieldValues, TName>,\n 'name' | 'defaultValue' | 'children'\n > {\n children: MaybeRenderProp<ArrayField[]>\n}\n\n/**\n * The wrapper component that composes the default ArrayField functionality.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayField = forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n const rowFn = isFunction(children)\n ? children\n : (fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n )) || null}\n </>\n )\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>{rowFn as any}</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\nArrayField.displayName = 'ArrayField'\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\nArrayFieldRows.displayName = 'ArrayFieldRows'\n\nexport interface ArrayFieldContainerProps\n extends Omit<ArrayFieldProps, 'children'> {\n children: React.ReactNode\n}\n\n/**\n * The container component provides context and state management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldContainerProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const overrides = useFieldProps(name)\n\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min: min || (overrides as any)?.min,\n max: max || (overrides as any)?.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} {...overrides}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nArrayFieldContainer.displayName = 'ArrayFieldContainer'\n","import * as React from 'react'\nimport {\n useFieldArray,\n UseFieldArrayReturn,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\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 TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n /**\n * The field name\n */\n name: TName\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'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyleConfig,\n} from '@chakra-ui/react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\n\nimport { mapNestedFields } from './utils'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { useFieldProps } from './form-context'\n\nexport interface ObjectFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends BaseFieldProps {\n name: TName\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyleConfig('SuiFormLegend')\n return <FormLabel as=\"legend\" sx={styles} {...props} />\n}\n/**\n * The object field component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/object-field\n */\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const {\n name,\n label,\n hideLabel: hideLabelProp,\n children,\n columns: columnsProp,\n spacing: spacingProp,\n ...fieldProps\n } = props\n\n const { hideLabel, columns, spacing, ...overrides } = useFieldProps(\n name\n ) as Omit<ObjectFieldProps, 'name'>\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps} {...overrides}>\n <FormLegend display={hideLabelProp || hideLabel ? 'none' : 'block'}>\n {label}\n </FormLegend>\n <FormLayout\n columns={columnsProp || columns}\n gridGap={spacingProp || spacing}\n >\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nObjectField.displayName = 'ObjectField'\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps, forwardRef } from '@chakra-ui/react'\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/**\n * A button with type submit and default color scheme primary and isLoading state when the form is submitting.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const SubmitButton = forwardRef<SubmitButtonProps, 'button'>(\n (props, ref) => {\n const {\n children = 'Submit',\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 type=\"submit\"\n isLoading={formState.isSubmitting || isLoading}\n isDisabled={isDisabled}\n >\n {children}\n </Button>\n )\n }\n)\n\nSubmitButton.defaultProps = {\n variant: 'primary',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nSubmitButton.displayName = 'SubmitButton'\n","import * as React from 'react'\nimport {\n useWatch,\n FieldValues,\n UseFormReturn,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\n\nexport interface DisplayIfProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n children: React.ReactElement\n name: TName\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n/**\n * Conditionally render parts of a form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const DisplayIf = <\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues, TName>) => {\n const value = useWatch<TFieldValues>({\n name,\n defaultValue: defaultValue as any,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext() as any\n return condition(value, context) ? children : null\n}\n\nDisplayIf.displayName = 'DisplayIf'\n","import * as React from 'react'\n\nimport { FieldValues } from 'react-hook-form'\n\nimport {\n chakra,\n Button,\n ButtonProps,\n HTMLChakraProps,\n ThemingProps,\n} from '@chakra-ui/react'\n\nimport { callAllHandlers, cx } from '@chakra-ui/utils'\n\nimport {\n Steps,\n StepsItem,\n StepsItemProps,\n StepsProps,\n useStepperContext,\n} from '@saas-ui/core'\n\nimport { SubmitButton } from './submit-button'\n\nimport {\n useFormStep,\n UseStepFormProps,\n FormStepSubmitHandler,\n} from './use-step-form'\n\nexport type StepsOptions<TSchema, TName extends string = string> = {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: TSchema\n}[]\n\nexport interface StepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends UseStepFormProps<TSteps, TFieldValues, TContext> {}\n\nexport interface FormStepOptions<TName extends string = string> {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport interface FormStepperProps extends StepsProps, ThemingProps<'Stepper'> {\n render?: StepsItemProps['render']\n}\n\n/**\n * Renders a stepper that displays progress above the form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStepper: React.FC<FormStepperProps> = (props) => {\n const { activeIndex, setIndex } = useStepperContext()\n\n const {\n children,\n orientation,\n variant,\n colorScheme,\n size,\n onChange: onChangeProp,\n render,\n ...rest\n } = 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 <StepsItem\n render={render}\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n {...rest}\n >\n {child.props.children}\n </StepsItem>\n )\n }\n return child\n })\n\n const onChange = React.useCallback((i: number) => {\n setIndex(i)\n onChangeProp?.(i)\n }, [])\n\n return (\n <Steps\n orientation={orientation}\n step={activeIndex}\n variant={variant}\n colorScheme={colorScheme}\n size={size}\n onChange={onChange}\n >\n {elements}\n </Steps>\n )\n}\n\nexport interface FormStepProps<TName extends string = string>\n extends FormStepOptions<TName>,\n Omit<HTMLChakraProps<'div'>, 'onSubmit'> {\n onSubmit?: FormStepSubmitHandler\n}\n/**\n * The form step containing fields for a specific step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStep = <TName extends string = string>(\n props: FormStepProps<TName>\n) => {\n const { name, children, className, onSubmit, ...rest } = props\n const step = useFormStep({ name, onSubmit })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('sui-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nFormStep.displayName = 'FormStep'\n\n/**\n * A button that this opens the previous step when clicked. Disabled on the first step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n children=\"Back\"\n {...props}\n className={cx('sui-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nPrevButton.displayName = 'PrevButton'\n\nexport interface NextButtonProps extends Omit<ButtonProps, 'children'> {\n submitLabel?: string\n label?: string\n}\n\n/**\n * A button that submits the active step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\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('sui-form__next-button', props.className)}\n >\n {isLastStep || isCompleted ? submitLabel : label}\n </SubmitButton>\n )\n}\n\nNextButton.displayName = 'NextButton'\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/core'\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 { FocusableElement } from '@chakra-ui/utils'\nimport { FormProps } from './form'\nimport { FormStepProps, StepsOptions } from './step-form'\nimport { FieldProps, StepFormChildren } from './types'\nimport { DisplayIfProps } from './display-if'\nimport { ArrayFieldProps } from './array-field'\nimport { UseArrayFieldReturn } from './use-array-field'\nimport { ObjectFieldProps } from './object-field'\n\ntype StepName<T extends { [k: number]: { readonly name: string } }> =\n T[number]['name']\n\nexport interface StepFormRenderContext<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseStepFormReturn<TFieldValues> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n FormStep: React.FC<FormStepProps<StepName<TSteps>>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\nexport interface UseStepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends Omit<UseStepperProps, 'onChange'>,\n Omit<FormProps<any, TFieldValues, TContext>, 'children'> {\n steps?: TSteps\n children: StepFormChildren<any, TSteps, TFieldValues, TContext>\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<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: UseStepFormProps<TSteps, TFieldValues, TContext>\n): UseStepFormReturn<TFieldValues> {\n const { onChange, steps: stepsOptions, resolver, ...rest } = props\n const stepper = useStepper(rest)\n\n const [options, setOptions] = React.useState<TSteps | undefined>(stepsOptions)\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\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.schema\n ? /* @todo fix resolver type */ (resolver as any)?.(step.schema)\n : undefined,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n const stepOptions = options?.find((s) => s.name === step.name)\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: {\n ...step,\n schema: stepOptions?.schema,\n },\n }\n })\n },\n [steps, options]\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 { BaseFieldProps } from './types'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): BaseFieldProps[]\n getNestedFields(name: string): BaseFieldProps[]\n}\n\nexport type GetFieldResolver<TSchema = any> = (schema: TSchema) => FieldResolver\n\ninterface SchemaField extends BaseFieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema): BaseFieldProps[] =>\n schema &&\n Object.entries(schema).map(([name, { items, label, title, ...field }]) => {\n return {\n ...field,\n name,\n label: label || title || name, // json schema compatibility\n }\n })\n\nexport const objectFieldResolver: GetFieldResolver<ObjectSchema> = (schema) => {\n const getFields = (): BaseFieldProps[] => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string): BaseFieldProps[] => {\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 { FieldValues, useWatch } from 'react-hook-form'\nimport { useFormContext, UseFormReturn } from './form-context'\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","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { FocusableElement, cx, runIfFn } from '@chakra-ui/utils'\n\nimport {\n useForm,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n ResolverOptions,\n ResolverResult,\n WatchObserver,\n} from 'react-hook-form'\nimport { FormProvider } from './form-context'\nimport { FieldResolver } from './field-resolver'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\nimport { FieldProps, DefaultFieldOverrides } from './types'\n\nimport { Field as DefaultField } from './field'\nimport { FormLayout } from './layout'\nimport { AutoFields } from './fields'\nimport { SubmitButton } from './submit-button'\nimport { DisplayIf, DisplayIfProps } from './display-if'\nimport { ArrayField, ArrayFieldProps } from './array-field'\nimport { ObjectField, ObjectFieldProps } from './object-field'\nimport { UseArrayFieldReturn } from './use-array-field'\n\nexport interface FormRenderContext<\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormReturn<TFieldValues, TContext> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\ninterface FormOptions<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> {\n /**\n * The form schema.\n */\n schema?: TSchema\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 * The Hook Form state ref.\n */\n formRef?: React.RefObject<UseFormReturn<TFieldValues, TContext>>\n /**\n * The form children, can be a render prop or a ReactNode.\n */\n children?: MaybeRenderProp<\n FormRenderContext<TFieldValues, TContext, TFieldTypes>\n >\n /**\n * The field resolver, used to resolve the fields from schemas.\n */\n fieldResolver?: FieldResolver\n /**\n * Field overrides\n */\n fields?: DefaultFieldOverrides\n}\n\nexport interface FormProps<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormProps<TFieldValues, TContext>,\n Omit<\n HTMLChakraProps<'form'>,\n 'children' | 'onChange' | 'onSubmit' | 'onError'\n >,\n FormOptions<TSchema, TFieldValues, TContext, TFieldTypes> {}\n\n/**\n * The wrapper component provides context, state, and focus management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n >(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes>,\n ref: React.ForwardedRef<HTMLFormElement>\n ) => {\n const {\n mode = 'all',\n resolver,\n fieldResolver,\n fields,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n values,\n context,\n resetOptions,\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 values,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n context,\n resetOptions,\n }\n\n const methods = useForm<TFieldValues, TContext>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(formRef, () => methods, [formRef, 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 let _children = children\n if (!_children && fieldResolver) {\n _children = (\n <FormLayout>\n <AutoFields />\n <SubmitButton {...fields?.submit} />\n </FormLayout>\n )\n }\n\n return (\n <FormProvider\n {...methods}\n schema={schema}\n fieldResolver={fieldResolver}\n fields={fields}\n >\n <chakra.form\n ref={ref}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('sui-form', props.className)}\n >\n {runIfFn(_children, {\n Field: DefaultField as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n ...methods,\n })}\n </chakra.form>\n </FormProvider>\n )\n }\n) as FormComponent\n\nexport type FormComponent = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes> & {\n ref?: React.ForwardedRef<HTMLFormElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n\nForm.displayName = 'Form'\n\nexport type GetResolver = <\n TFieldValues extends FieldValues,\n TContext extends object\n>(\n schema: unknown\n) => (\n values: TFieldValues,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n","import React, { ForwardedRef } from 'react'\nimport { FieldsProvider } from './fields-context'\nimport { Form, FieldValues, FormProps, GetResolver } from './form'\nimport { DefaultFieldOverrides, WithFields } from './types'\nimport { objectFieldResolver } from './field-resolver'\nimport { GetFieldResolver } from './field-resolver'\nimport { forwardRef } from '@chakra-ui/react'\n\nexport interface CreateFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport type FormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: WithFields<\n FormProps<TSchema, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport function createForm<FieldDefs>({\n resolver,\n fieldResolver = objectFieldResolver,\n fields,\n}: CreateFormProps<FieldDefs> = {}) {\n const DefaultForm = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n >(\n props: WithFields<FormProps<TSchema, TFieldValues, TContext>, FieldDefs>,\n ref: ForwardedRef<HTMLFormElement>\n ) => {\n const { schema, ...rest } = props\n return (\n <FieldsProvider value={fields || {}}>\n <Form\n ref={ref}\n resolver={resolver?.(props.schema)}\n fieldResolver={fieldResolver?.(schema)}\n {...rest}\n />\n </FieldsProvider>\n )\n }\n ) as FormType<FieldDefs>\n\n DefaultForm.displayName = 'Form'\n DefaultForm.id = 'Form'\n\n return DefaultForm\n}\n","import React, { useMemo } from 'react'\nimport { forwardRef } from '@chakra-ui/react'\nimport {\n ArrayField,\n DisplayIf,\n FieldProps,\n FieldValues,\n FieldsProvider,\n GetFieldResolver,\n ObjectField,\n} from './'\nimport { Form } from './form'\nimport { Field } from './field'\nimport { FormStep, StepsOptions } from './step-form'\nimport {\n StepFormProvider,\n UseStepFormProps,\n useStepForm,\n} from './use-step-form'\nimport { StepperProvider } from '@saas-ui/core'\nimport { runIfFn } from '@chakra-ui/utils'\nimport { GetResolver } from './form'\nimport { WithStepFields } from './types'\n\nexport type StepFormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: WithStepFields<\n UseStepFormProps<TSteps, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport interface CreateStepFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport function createStepForm<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n>({ fields, resolver, fieldResolver }: CreateStepFormProps<FieldDefs> = {}) {\n const StepForm = forwardRef<any, 'div'>((props, ref) => {\n const { children, steps, ...rest } = props\n\n const stepper = useStepForm({\n resolver,\n fieldResolver,\n ...props,\n })\n\n const { getFormProps, ...ctx } = stepper\n\n const context = useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <FieldsProvider value={fields || {}}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, {\n ...stepper,\n Field: Field as any,\n FormStep: FormStep as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n })}\n </Form>\n </FieldsProvider>\n </StepFormProvider>\n </StepperProvider>\n )\n }) as StepFormType<FieldDefs, ExtraProps, ExtraOverrides>\n\n StepForm.displayName = `Step${Form.displayName || Form.name}`\n\n return StepForm\n}\n","export * from './display-field'\nexport * from './field'\nexport * from './fields'\nexport * from './fields-context'\nexport * from './layout'\nexport * from './submit-button'\nexport * from './array-field'\nexport * from './use-array-field'\nexport * from './object-field'\nexport * from './display-if'\nexport * from './step-form'\nexport * from './use-step-form'\nexport * from './field-resolver'\nexport * from './watch-field'\nexport * from './input-right-button'\nexport * from './select'\nexport * from './password-input'\nexport * from './radio'\n\nexport * from './base-field'\n\nexport {\n CheckboxField,\n InputField,\n NativeSelectField,\n NumberInputField,\n PasswordInputField,\n PinField,\n RadioField,\n SelectField,\n SwitchField,\n TextareaField,\n defaultFieldTypes,\n type DefaultFields,\n type InputFieldProps,\n type NumberInputFieldProps,\n type PinFieldProps,\n} from './default-fields'\n\nexport type {\n FieldProps,\n WithFields,\n BaseFieldProps,\n FieldOptions,\n DefaultFieldOverrides,\n WithStepFields,\n} from './types'\n\nexport { createForm, type CreateFormProps, type FormType } from './create-form'\nexport { createField, type CreateFieldOptions } from './create-field'\n\nexport { Form as BaseForm } from './form'\nexport type { FormProps, FormRenderContext, FormComponent } from './form'\n\nexport { FormProvider, useFormContext } from './form-context'\n\nimport { createForm } from './create-form'\nimport { createStepForm } from './create-step-form'\n\n/**\n * Form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = createForm()\n\nexport { createStepForm, type CreateStepFormProps } from './create-step-form'\n\n/**\n * Multi-step form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const StepForm = createStepForm()\n\nexport type {\n BatchFieldArrayUpdate,\n ChangeHandler,\n Control,\n ControllerFieldState,\n ControllerProps,\n ControllerRenderProps,\n CriteriaMode,\n CustomElement,\n DeepMap,\n DeepPartial,\n DeepPartialSkipArrayKey,\n DefaultValues,\n DelayCallback,\n EmptyObject,\n ErrorOption,\n EventType,\n Field as FieldDef,\n FieldArray,\n FieldArrayMethodProps,\n FieldArrayWithId,\n FieldElement,\n FieldError,\n FieldErrors,\n FieldName,\n FieldNamesMarkedBoolean,\n FieldRefs,\n FieldValue,\n FieldValues,\n FormProviderProps,\n FormState,\n FormStateProxy,\n FormStateSubjectRef,\n GetIsDirty,\n InternalFieldErrors,\n InternalFieldName,\n InternalNameSet,\n IsAny,\n IsFlatObject,\n KeepStateOptions,\n LiteralUnion,\n Message,\n Mode,\n MultipleFieldErrors,\n Names,\n NativeFieldValue,\n NestedValue,\n NonUndefined,\n Noop,\n Primitive,\n ReadFormState,\n Ref,\n RefCallBack,\n RegisterOptions,\n Resolver,\n ResolverError,\n ResolverOptions,\n ResolverResult,\n ResolverSuccess,\n SetFieldValue,\n SetValueConfig,\n Subjects,\n SubmitErrorHandler,\n SubmitHandler,\n TriggerConfig,\n UnpackNestedValue,\n UseControllerProps,\n UseControllerReturn,\n UseFieldArrayProps,\n UseFieldArrayReturn,\n UseFormClearErrors,\n UseFormGetValues,\n UseFormHandleSubmit,\n UseFormProps,\n UseFormRegister,\n UseFormRegisterReturn,\n UseFormReset,\n UseFormResetField,\n UseFormReturn,\n UseFormSetError,\n UseFormSetFocus,\n UseFormSetValue,\n UseFormStateProps,\n UseFormStateReturn,\n UseFormTrigger,\n UseFormUnregister,\n UseFormWatch,\n UseWatchProps,\n Validate,\n ValidateResult,\n ValidationMode,\n ValidationRule,\n ValidationValue,\n ValidationValueMessage,\n WatchInternal,\n WatchObserver,\n} from 'react-hook-form'\n\nexport {\n appendErrors,\n useController,\n useFieldArray,\n useForm,\n useFormState,\n useWatch,\n Controller,\n} from 'react-hook-form'\n"]}
package/dist/index.mjs CHANGED
@@ -1216,7 +1216,7 @@ function createStepForm({ fields, resolver, fieldResolver } = {}) {
1216
1216
  });
1217
1217
  const { getFormProps, ...ctx } = stepper;
1218
1218
  const context = useMemo(() => ctx, [ctx]);
1219
- return /* @__PURE__ */ jsx(StepperProvider, { value: context, children: /* @__PURE__ */ jsx(StepFormProvider, { value: context, children: /* @__PURE__ */ jsx(FieldsProvider, { value: fields || {}, children: /* @__PURE__ */ jsx(Form2, { ref, ...rest, ...getFormProps(), children: runIfFn(children, {
1219
+ return /* @__PURE__ */ jsx(StepperProvider, { value: context, children: /* @__PURE__ */ jsx(StepFormProvider, { value: context, children: /* @__PURE__ */ jsx(FieldsProvider, { value: fields || {}, children: /* @__PURE__ */ jsx(Form, { ref, ...rest, ...getFormProps(), children: runIfFn(children, {
1220
1220
  ...stepper,
1221
1221
  Field,
1222
1222
  FormStep,
@@ -1225,7 +1225,7 @@ function createStepForm({ fields, resolver, fieldResolver } = {}) {
1225
1225
  ObjectField
1226
1226
  }) }) }) }) });
1227
1227
  });
1228
- StepForm2.displayName = `Step${Form2.displayName || Form2.name}`;
1228
+ StepForm2.displayName = `Step${Form.displayName || Form.name}`;
1229
1229
  return StepForm2;
1230
1230
  }
1231
1231
  var Form2 = createForm();
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/form-context.tsx","../src/display-field.tsx","../src/field.tsx","../src/fields-context.tsx","../src/default-fields.tsx","../src/number-input/number-input.tsx","../src/password-input/password-input.tsx","../src/input-right-button/input-right-button.tsx","../src/radio/radio-input.tsx","../src/utils.ts","../src/select/select.tsx","../src/select/select-context.tsx","../src/select/native-select.tsx","../src/create-field.tsx","../src/base-field.tsx","../src/fields.tsx","../src/layout.tsx","../src/array-field.tsx","../src/use-array-field.tsx","../src/object-field.tsx","../src/submit-button.tsx","../src/display-if.tsx","../src/step-form.tsx","../src/use-step-form.tsx","../src/field-resolver.ts","../src/watch-field.tsx","../src/form.tsx","../src/create-form.tsx","../src/create-step-form.tsx","../src/index.ts"],"names":["jsx","React","forwardRef","Input","InputGroup","jsxs","Button","ChevronDownIcon","createContext","value","FormControl","FormLabel","BaseField","Field","NumberInputField","chakra","cx","mapNestedFields","name","useFormContext","callAllHandlers","steps","get","useWatch","useMemo","runIfFn","StepForm","Form","useFieldArray","useForm","Controller"],"mappings":"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","sourcesContent":["import * as React from 'react'\nimport {\n FormProvider as HookFormProvider,\n FormProviderProps as HookFormProviderProps,\n useFormContext as useHookFormContext,\n FieldValues,\n} from 'react-hook-form'\nimport { FieldResolver } from './field-resolver'\nimport { BaseFieldProps, FieldProps } from './types'\n\nexport type FormContextValue<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nexport type FormProviderProps<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = HookFormProviderProps<TFieldValues, TContext> & {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nconst FormContext = React.createContext<FormContextValue | null>(null)\n\nexport const useFormContext = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>() => {\n const context = React.useContext(FormContext)\n const hookContext = useHookFormContext()\n\n if (!context) {\n throw new Error('FormProvider must be used within a Form component')\n }\n\n return {\n ...hookContext,\n ...context,\n }\n}\n\nexport const useFieldProps = <TFieldValues extends FieldValues = FieldValues>(\n name: string\n): BaseFieldProps<TFieldValues> | undefined => {\n const parsedName = name?.replace(/\\.[0-9]/g, '.$')\n const context = useFormContext()\n return (context?.fields?.[parsedName] as any) || {}\n}\n\nexport type UseFormReturn<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = ReturnType<typeof useFormContext>\n\nexport const FormProvider = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>(\n props: FormProviderProps<TFieldValues, TContext, TSchema>\n) => {\n const { children, fieldResolver, schema, fields, ...rest } = props\n return (\n <HookFormProvider {...rest}>\n <FormContext.Provider value={{ fieldResolver, schema, fields }}>\n {children}\n </FormContext.Provider>\n </HookFormProvider>\n )\n}\n","import * as React from 'react'\nimport { useFormContext } from './form-context'\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './types'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n/**\n *\n *\n * @see Docs https://saas-ui.dev/\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\nDisplayField.displayName = 'DisplayField'\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nFormValue.displayName = 'FormValue'\n","import * as React from 'react'\nimport { RegisterOptions, FieldValues } from 'react-hook-form'\n\nimport { FocusableElement } from '@chakra-ui/utils'\nimport { useField } from './fields-context'\nimport { FieldProps } from './types'\nimport { useFieldProps } from './form-context'\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\nconst defaultInputType = 'text'\n\n/**\n * Form field component.\n * \n * Build-in types:\n * text, number, password, textarea, select, native-select, checkbox, radio, switch, pin\n *\n * Will default to a text field if there is no matching type.\n\n * @see Docs https://saas-ui.dev/docs/components/forms/field\n */\nexport const Field = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues>,\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType, name } = props\n const overrides = useFieldProps(name)\n const InputComponent = useField(overrides?.type || type)\n\n return <InputComponent ref={ref} {...props} {...overrides} />\n }\n) as (<TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n","import React from 'react'\nimport { defaultFieldTypes, InputField } from './default-fields'\n\nconst FieldsContext = React.createContext<Record<string, React.FC<any>> | null>(\n null\n)\n\nexport const FieldsProvider: React.FC<{\n value: Record<string, React.FC<any>>\n children: React.ReactNode\n}> = (props) => {\n const fields = { ...defaultFieldTypes, ...props.value }\n return (\n <FieldsContext.Provider value={fields}>\n {props.children}\n </FieldsContext.Provider>\n )\n}\n\nexport const useField = (type: string): React.FC<any> => {\n const context = React.useContext(FieldsContext)\n return context?.[type] || InputField\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Input,\n Textarea,\n Checkbox,\n Switch,\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'\n\nimport { NumberInput, NumberInputProps } from './number-input'\nimport { PasswordInput, PasswordInputProps } from './password-input'\nimport { RadioInput, RadioInputProps } from './radio'\n\nimport {\n Select,\n SelectButton,\n SelectList,\n SelectProps,\n NativeSelect,\n NativeSelectProps,\n} from './select'\n\nimport { createField } from './create-field'\nimport { ObjectField } from './object-field'\nimport { ArrayField } from './array-field'\n\nexport interface InputFieldProps extends InputProps {\n type?: string\n leftAddon?: React.ReactNode\n rightAddon?: React.ReactNode\n}\n\nexport const InputField = createField<InputFieldProps>(\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 = createField<NumberInputFieldProps>(\n NumberInput,\n {\n isControlled: true,\n }\n)\n\nexport const PasswordInputField = createField<PasswordInputProps>(\n forwardRef((props, ref) => <PasswordInput ref={ref} {...props} />)\n)\n\nexport const TextareaField = createField<TextareaProps>(Textarea)\n\nexport const SwitchField = createField<SwitchProps>(\n forwardRef(({ type, value, ...rest }, ref) => {\n return <Switch isChecked={!!value} {...rest} ref={ref} />\n }),\n {\n isControlled: true,\n }\n)\n\nexport const SelectField = createField<SelectProps>(\n forwardRef((props, ref) => {\n return (\n <Select ref={ref} {...props}>\n <SelectButton />\n <SelectList />\n </Select>\n )\n }),\n {\n isControlled: true,\n }\n)\n\nexport const CheckboxField = createField<CheckboxProps>(\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 = createField<RadioInputProps>(RadioInput, {\n isControlled: true,\n})\n\nexport const NativeSelectField = createField<NativeSelectProps>(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 = createField<PinFieldProps>(\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\nexport const defaultFieldTypes = {\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 select: SelectField,\n checkbox: CheckboxField,\n radio: RadioField,\n pin: PinField,\n 'native-select': NativeSelectField,\n}\n\nexport type DefaultFields = typeof defaultFieldTypes\n","import * as React from 'react'\n\nimport {\n forwardRef,\n NumberInput as ChakraNumberInput,\n NumberInputField,\n NumberInputStepper,\n NumberIncrementStepper,\n NumberDecrementStepper,\n NumberInputProps as ChakraNumberInputProps,\n} from '@chakra-ui/react'\n\nimport { ChevronDownIcon, ChevronUpIcon } from '@saas-ui/core'\n\ninterface NumberInputOptions {\n /**\n * Hide the stepper.\n */\n hideStepper?: boolean\n /**\n * Render a custom increment icon.\n */\n incrementIcon?: React.ReactNode\n /**\n * Render a custom decrement icon.\n */\n decrementIcon?: React.ReactNode\n}\n\nexport interface NumberInputProps\n extends ChakraNumberInputProps,\n NumberInputOptions {}\n\nexport const NumberInput = forwardRef<NumberInputProps, 'div'>((props, ref) => {\n const {\n hideStepper,\n incrementIcon = <ChevronUpIcon />,\n decrementIcon = <ChevronDownIcon />,\n ...rest\n } = props\n\n return (\n <ChakraNumberInput {...rest} ref={ref}>\n <NumberInputField />\n\n {!hideStepper && (\n <NumberInputStepper>\n <NumberIncrementStepper children={incrementIcon} />\n <NumberDecrementStepper children={decrementIcon} />\n </NumberInputStepper>\n )}\n </ChakraNumberInput>\n )\n})\n\nNumberInput.defaultProps = {\n hideStepper: false,\n}\n\nNumberInput.displayName = 'NumberInput'\n","import React, { useState } from 'react'\n\nimport { forwardRef, InputGroup, Input, InputProps } from '@chakra-ui/react'\n\nimport { ViewIcon, ViewOffIcon } from '@saas-ui/core/icons'\n\nimport { InputRightButton } from '../input-right-button'\n\ninterface PasswordOptions {\n viewIcon?: React.ReactNode\n viewOffIcon?: React.ReactNode\n leftAddon?: React.ReactNode\n}\n\nexport interface PasswordInputProps extends InputProps, PasswordOptions {}\n\nexport const PasswordInput = forwardRef<PasswordInputProps, 'div'>(\n (props, ref) => {\n const {\n viewIcon,\n viewOffIcon,\n autoComplete,\n w,\n width,\n size,\n variant,\n leftAddon,\n ...inputProps\n } = props\n const [show, setShow] = useState(false)\n const handleClick = () => setShow(!show)\n\n const label = show ? 'Hide password' : 'Show password'\n\n let icon\n if (show) {\n icon = viewIcon || <ViewIcon />\n } else {\n icon = viewOffIcon || <ViewOffIcon />\n }\n\n const groupProps = {\n width: w || width,\n size,\n variant,\n }\n\n return (\n <InputGroup {...groupProps}>\n {leftAddon}\n <Input\n {...inputProps}\n ref={ref}\n type={show ? 'text' : 'password'}\n autoComplete={show ? 'off' : autoComplete}\n />\n <InputRightButton\n onClick={handleClick}\n aria-label={label}\n variant=\"ghost\"\n >\n {icon}\n </InputRightButton>\n </InputGroup>\n )\n }\n)\n\nPasswordInput.displayName = 'PasswordInput'\n","import * as React from 'react'\n\nimport {\n Button,\n ButtonProps,\n forwardRef,\n InputRightElement,\n} from '@chakra-ui/react'\n\nexport type InputRightButtonProps = ButtonProps\n\nexport const InputRightButton = forwardRef<InputRightButtonProps, 'div'>(\n (props, ref) => {\n return (\n <InputRightElement w=\"auto\" px=\"1\" py=\"1\" alignItems=\"stretch\">\n <Button ref={ref} height=\"auto\" {...props} />\n </InputRightElement>\n )\n }\n)\n\nInputRightButton.id = 'InputRightElement'\n\nInputRightButton.displayName = 'InputRightButton'\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Stack,\n RadioGroup,\n RadioGroupProps,\n Radio,\n RadioProps,\n SystemProps,\n StackDirection,\n} from '@chakra-ui/react'\nimport { FieldOptions, FieldOption } from '../types'\nimport { mapOptions } from '../utils'\n\nexport interface RadioOption\n extends Omit<RadioProps, 'value' | 'label'>,\n FieldOption {}\n\nexport type RadioOptions = FieldOptions<RadioOption>\n\ninterface RadioInputOptions {\n options: RadioOptions\n spacing?: SystemProps['margin']\n direction?: StackDirection\n}\n\nexport interface RadioInputProps\n extends Omit<RadioGroupProps, 'children'>,\n RadioInputOptions {}\n\nexport const RadioInput = forwardRef<RadioInputProps, 'div'>(\n ({ options: optionsProp, spacing, direction, ...props }, ref) => {\n const { onBlur, onChange, ...groupProps } = props\n\n const options = mapOptions(optionsProp)\n\n return (\n <RadioGroup onChange={onChange} {...groupProps}>\n <Stack spacing={spacing} direction={direction}>\n {options.map(({ value, label, ...radioProps }, i) => {\n return (\n <Radio\n key={i}\n onBlur={onBlur}\n value={value}\n ref={ref}\n {...radioProps}\n >\n {label || value}\n </Radio>\n )\n })}\n </Stack>\n </RadioGroup>\n )\n }\n)\n\nRadioInput.displayName = 'RadioInput'\n","import * as React from 'react'\nimport { FieldOption, FieldOptions } from './types'\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 let childName = child.props.name\n if (childName.includes('.')) {\n childName = childName.replace(/^.*\\.(.*)/, '$1')\n } else if (childName.includes('.$')) {\n childName = childName.replace(/^.*\\.\\$(.*)/, '$1')\n }\n\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${childName}`,\n })\n }\n return child\n })\n}\n\nexport const mapOptions = <TOption extends FieldOption = FieldOption>(\n options: FieldOptions<TOption>\n) => {\n return options.map((option) => {\n if (typeof option === 'string') {\n return {\n label: option,\n value: option,\n }\n }\n return option\n })\n}\n","import * as React from 'react'\n\nimport {\n chakra,\n forwardRef,\n Menu,\n MenuProps,\n MenuList,\n MenuListProps,\n MenuItemOption,\n MenuOptionGroup,\n Button,\n ButtonProps,\n omitThemingProps,\n useMultiStyleConfig,\n MenuItemOptionProps,\n useFormControlContext,\n ThemingProps,\n useMenuButton,\n} from '@chakra-ui/react'\nimport { cx, dataAttr } from '@chakra-ui/utils'\nimport { ChevronDownIcon } from '@saas-ui/core'\n\nimport { FieldOption } from '../types'\n\nimport {\n SelectOptions,\n SelectProvider,\n SelectStylesProvider,\n useSelect,\n useSelectContext,\n useSelectStyles,\n} from './select-context'\n\nexport interface SelectOption\n extends Omit<MenuItemOptionProps, 'value'>,\n FieldOption {}\n\nexport interface SelectProps\n extends Omit<MenuProps, 'children' | 'variant' | 'size'>,\n ThemingProps<'SuiSelect'>,\n SelectOptions {}\n\nexport interface SelectButtonProps\n extends Omit<ButtonProps, 'size' | 'variant'> {}\n\n/**\n * Button that opens the select menu and displays the selected value.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectButton = forwardRef<SelectButtonProps, 'button'>(\n (props, ref) => {\n const {\n displayValue,\n renderValue,\n placeholder,\n isDisabled: isSelectDisabled,\n } = useSelectContext()\n\n const context = useFormControlContext()\n\n const styles = useSelectStyles()\n\n const {\n isInvalid,\n isReadOnly,\n isDisabled,\n isFocused,\n isRequired,\n id,\n onBlur,\n onFocus,\n } = context || {}\n\n const { rightIcon = <ChevronDownIcon />, ...rest } = props\n\n /* @ts-ignore */\n const focusStyles = styles.field?._focusVisible\n /* @ts-ignore */\n const readOnlyStyles = styles.field?._readOnly\n /* @ts-ignore */\n const invalid = styles.field?._invalid\n\n const height = styles.field?.h || styles.field?.height\n\n const buttonStyles: any = {\n fontWeight: 'normal',\n textAlign: 'left',\n color: 'inherit',\n _active: {\n bg: 'transparent',\n },\n minH: height,\n _focus: focusStyles,\n _expanded: focusStyles,\n _readOnly: readOnlyStyles,\n _invalid: invalid,\n minW: 0,\n ...styles.field,\n h: 'auto',\n }\n\n const buttonProps = useMenuButton(rest, ref)\n\n // Using a Button, so we can simply use leftIcon and rightIcon\n return (\n <Button\n {...buttonProps}\n {...buttonStyles}\n id={id || buttonProps.id}\n {...rest}\n onFocus={onFocus}\n onBlur={onBlur}\n isDisabled={isDisabled || isSelectDisabled}\n data-invalid={dataAttr(isInvalid)}\n data-read-only={dataAttr(isReadOnly)}\n data-focus={dataAttr(isFocused)}\n data-required={dataAttr(isRequired)}\n rightIcon={rightIcon}\n >\n <chakra.span\n __css={{\n display: 'block',\n pointerEvents: 'none',\n flex: '1 1 auto',\n minW: 0,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }}\n >\n {renderValue(displayValue) || placeholder}\n </chakra.span>\n </Button>\n )\n }\n)\n\nSelectButton.displayName = 'SelectButton'\n\n/**\n * Allow users to select a value from a list of options.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const Select = forwardRef<SelectProps, 'select'>((props, ref) => {\n const { name, children, isDisabled, multiple, ...rest } = props\n\n const styles = useMultiStyleConfig('SuiSelect', props)\n\n const menuProps = omitThemingProps(rest)\n\n const context = useSelect(props)\n\n const { value, controlProps } = context\n\n return (\n <SelectProvider value={context}>\n <SelectStylesProvider value={styles}>\n <Menu {...menuProps} closeOnSelect={!multiple}>\n <chakra.div className={cx('sui-select')}>\n {children}\n <chakra.input\n {...controlProps}\n ref={ref}\n name={name}\n type=\"hidden\"\n value={value || ''}\n className=\"saas-select__input\"\n />\n </chakra.div>\n </Menu>\n </SelectStylesProvider>\n </SelectProvider>\n )\n})\n\nexport interface SelectListProps extends MenuListProps {}\n\n/**\n * The list of options to choose from.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectList: React.FC<SelectListProps> = (props) => {\n const { defaultValue, value, options, multiple, onChange } =\n useSelectContext()\n\n return (\n <MenuList maxH=\"100vh\" overflowY=\"auto\" {...props}>\n <MenuOptionGroup\n defaultValue={(defaultValue || value) as string | string[] | undefined}\n value={value}\n onChange={onChange}\n type={multiple ? 'checkbox' : 'radio'}\n >\n {options\n ? options.map(({ value, label, ...rest }, i) => (\n <SelectOption key={i} value={value} {...rest}>\n {label || value}\n </SelectOption>\n ))\n : props.children}\n </MenuOptionGroup>\n </MenuList>\n )\n}\n\nSelect.displayName = 'Select'\n\n/**\n * An option in a select list\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectOption = forwardRef<MenuItemOptionProps, 'button'>(\n (props, ref) => {\n return <MenuItemOption ref={ref} {...props} />\n }\n)\nSelectOption.id = 'MenuItemOption'\nSelectOption.displayName = 'SelectOption'\n","import {\n HTMLChakraProps,\n createStylesContext,\n useControllableState,\n useFormControl,\n} from '@chakra-ui/react'\nimport { createContext } from '@chakra-ui/react-utils'\nimport React from 'react'\nimport { FieldOptions } from '../types'\nimport { mapOptions } from '../utils'\nimport { SelectOption } from './select'\n\nexport const [SelectStylesProvider, useSelectStyles] =\n createStylesContext('SuiSelect')\n\nexport const [SelectProvider, useSelectContext] = createContext<\n ReturnType<typeof useSelect>\n>({\n strict: true,\n})\n\nexport interface SelectOptions {\n /**\n * The name of the input field in a native form.\n */\n name: string\n /**\n * The value of the select field.\n */\n value?: string | string[]\n /**\n * The initial value of the select field.\n */\n defaultValue?: string | string[]\n /**\n * The callback invoked when the value of the select field changes.\n * @param value The value of the select field.\n */\n onChange?: (value: string | string[]) => void\n /**\n * The placeholder text when there's no value.\n */\n placeholder?: string\n /**\n * If `true`, the select will be disabled.\n */\n isDisabled?: boolean\n /**\n * An array of options\n * If you leave this empty the children prop will be rendered.\n */\n options?: FieldOptions<SelectOption>\n /**\n * Enable multiple select.\n */\n multiple?: boolean\n /**\n * The function used to render the value of the select field.\n * @param value The value of the select field.\n * @returns The rendered value.\n */\n renderValue?: (value: string | string[]) => React.ReactNode\n}\n\nexport const useSelect = (props: SelectOptions) => {\n const {\n name,\n value,\n defaultValue,\n onChange,\n multiple,\n placeholder,\n options: optionsProp,\n isDisabled,\n renderValue = (value) =>\n typeof value === 'string' ? value : value?.join(', '),\n } = props\n const [currentValue, setCurrentValue] = useControllableState({\n value,\n defaultValue,\n onChange,\n })\n\n const controlProps = useFormControl({ name } as HTMLChakraProps<'input'>)\n\n const options = React.useMemo(\n () => optionsProp && mapOptions(optionsProp),\n [optionsProp]\n )\n\n const handleChange = (value: string | string[]) => {\n setCurrentValue(value)\n }\n\n const getDisplayValue = React.useCallback(\n (value: string) => {\n if (!options) {\n return value\n }\n\n for (const option of options) {\n if (option.value === value) {\n return option.label || option.value\n }\n }\n\n return value\n },\n [options]\n )\n\n const displayValue = React.useMemo(\n () =>\n currentValue\n ? (Array.isArray(currentValue) ? currentValue : [currentValue]).map(\n getDisplayValue\n )\n : [],\n [currentValue, getDisplayValue]\n )\n\n return {\n defaultValue,\n value: currentValue,\n displayValue,\n renderValue,\n onChange: handleChange,\n options,\n multiple,\n controlProps,\n placeholder,\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Select as ChakraSelect,\n SelectProps as ChakraSelectProps,\n} from '@chakra-ui/react'\n\ninterface Option {\n value: string\n label?: string\n}\n\ninterface NativeSelectOptions {\n options?: Option[]\n}\n\nexport interface NativeSelectProps\n extends ChakraSelectProps,\n NativeSelectOptions {}\n\nexport const NativeSelect = forwardRef<NativeSelectProps, 'select'>(\n ({ options, children, ...props }, ref) => {\n return (\n <ChakraSelect ref={ref} {...props}>\n {children ||\n options?.map(({ value, label }) => {\n return (\n <option key={value} value={value}>\n {label || value}\n </option>\n )\n })}\n </ChakraSelect>\n )\n }\n)\n\nNativeSelect.displayName = 'NativeSelect'\n","import * as React from 'react'\nimport { Controller } from 'react-hook-form'\n\nimport { forwardRef, useMergeRefs } from '@chakra-ui/react'\nimport { callAllHandlers } from '@chakra-ui/utils'\nimport { BaseFieldProps, FieldProps } from './types'\nimport { BaseField } from './base-field'\nimport { useFormContext } from './form-context'\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\n Field.displayName = displayName\n\n return Field\n}\n\nconst 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\nconst 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 CreateFieldOptions {\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 createField = <TProps extends object>(\n component: React.FC<TProps>,\n options?: CreateFieldOptions\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: `${component.displayName ?? 'Custom'}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n }) as React.FC<TProps & BaseFieldProps>\n\n return Field\n}\n","import * as React from 'react'\nimport { FormState, get } from 'react-hook-form'\n\nimport {\n Box,\n FormControl,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n} from '@chakra-ui/react'\n\nimport { useFormContext } from './form-context'\n\nimport { BaseFieldProps, FieldProps } from './types'\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\n/**\n * The default BaseField component\n * Composes the Chakra UI FormControl component, with FormLabel, FormHelperText and FormErrorMessage.\n */\nexport const BaseField: React.FC<BaseFieldProps> = (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\nBaseField.displayName = 'BaseField'\n","import * as React from 'react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\nimport { Field } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\nimport { useFormContext } from './form-context'\n\nexport interface FieldsProps<TSchema = any> {\n schema?: TSchema\n fieldResolver?: FieldResolver\n focusFirstField?: boolean\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n (\n { name, type, ...nestedFieldProps }: BaseFieldProps,\n i\n ): React.ReactNode => (\n <Field\n key={name || i}\n name={name}\n type={type as any}\n {...nestedFieldProps}\n />\n )\n )\n}\n\nexport const AutoFields: React.FC<FieldsProps> = ({\n schema: schemaProp,\n fieldResolver: fieldResolverProp,\n focusFirstField,\n ...props\n}) => {\n const context = useFormContext()\n const schema = schemaProp || context.schema\n const fieldResolver = fieldResolverProp || context.fieldResolver\n const resolver = React.useMemo(() => fieldResolver, [schema, fieldResolver])\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 if (!resolver) {\n return null\n }\n\n return (\n <FormLayout {...props}>\n {fields?.map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: BaseFieldProps): 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 (\n <Field key={name} name={name} type={type as any} {...fieldProps} />\n )\n }\n )}\n </FormLayout>\n )\n}\n\nAutoFields.displayName = 'Fields'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n SimpleGrid,\n SimpleGridProps,\n useTheme,\n} from '@chakra-ui/react'\nimport { cx } from '@chakra-ui/utils'\n\nexport interface FormLayoutProps extends 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\nFormLayoutItem.displayName = 'FormLayoutItem'\n\n/**\n * Create consistent field spacing and positioning.\n *\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n *\n * @see https://saas-ui.dev/docs/components/forms/form\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.SuiFormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('sui-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\nFormLayout.displayName = 'FormLayout'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n forwardRef,\n Button,\n ButtonProps,\n} from '@chakra-ui/react'\nimport { PlusIcon, MinusIcon } from '@saas-ui/core/icons'\n\nimport { FormLayout, FormLayoutProps } from './layout'\nimport { BaseField } from './base-field'\nimport { BaseFieldProps } from './types'\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'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { isFunction } from '@chakra-ui/utils'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\nimport { useFieldProps } from './form-context'\n\nexport interface ArrayFieldButtonProps extends ButtonProps {}\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/**\n * Render prop component, to get access to the internal fields state. Must be a child of ArrayFieldContainer.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRow.displayName = 'ArrayFieldRow'\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/**\n * Add the name prefix to the fields and acts as a horizontal form layout by default.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n\n/**\n * The row container component providers row context.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n ...rest\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 {...rest} __css={styles}>\n {children}\n </chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n\n/**\n * The default remove button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRemoveButton: React.FC<ArrayFieldButtonProps> = (\n props\n) => {\n return (\n <Button aria-label=\"Remove row\" {...useArrayFieldRemoveButton()} {...props}>\n {props.children || <MinusIcon />}\n </Button>\n )\n}\n\nArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n\n/**\n * The default add button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldAddButton: React.FC<ArrayFieldButtonProps> = (props) => {\n return (\n <Button\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n >\n {props.children || <PlusIcon />}\n </Button>\n )\n}\n\nArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n\nexport interface ArrayFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends ArrayFieldOptions<TFieldValues, TName>,\n Omit<\n BaseFieldProps<TFieldValues, TName>,\n 'name' | 'defaultValue' | 'children'\n > {\n children: MaybeRenderProp<ArrayField[]>\n}\n\n/**\n * The wrapper component that composes the default ArrayField functionality.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayField = forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n const rowFn = isFunction(children)\n ? children\n : (fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n )) || null}\n </>\n )\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>{rowFn as any}</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\nArrayField.displayName = 'ArrayField'\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\nArrayFieldRows.displayName = 'ArrayFieldRows'\n\nexport interface ArrayFieldContainerProps\n extends Omit<ArrayFieldProps, 'children'> {\n children: React.ReactNode\n}\n\n/**\n * The container component provides context and state management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldContainerProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const overrides = useFieldProps(name)\n\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min: min || (overrides as any)?.min,\n max: max || (overrides as any)?.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} {...overrides}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nArrayFieldContainer.displayName = 'ArrayFieldContainer'\n","import * as React from 'react'\nimport {\n useFieldArray,\n UseFieldArrayReturn,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\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 TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n /**\n * The field name\n */\n name: TName\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'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyleConfig,\n} from '@chakra-ui/react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\n\nimport { mapNestedFields } from './utils'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { useFieldProps } from './form-context'\n\nexport interface ObjectFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends BaseFieldProps {\n name: TName\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyleConfig('SuiFormLegend')\n return <FormLabel as=\"legend\" sx={styles} {...props} />\n}\n/**\n * The object field component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/object-field\n */\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const {\n name,\n label,\n hideLabel: hideLabelProp,\n children,\n columns: columnsProp,\n spacing: spacingProp,\n ...fieldProps\n } = props\n\n const { hideLabel, columns, spacing, ...overrides } = useFieldProps(\n name\n ) as Omit<ObjectFieldProps, 'name'>\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps} {...overrides}>\n <FormLegend display={hideLabelProp || hideLabel ? 'none' : 'block'}>\n {label}\n </FormLegend>\n <FormLayout\n columns={columnsProp || columns}\n gridGap={spacingProp || spacing}\n >\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nObjectField.displayName = 'ObjectField'\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps, forwardRef } from '@chakra-ui/react'\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/**\n * A button with type submit and default color scheme primary and isLoading state when the form is submitting.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const SubmitButton = forwardRef<SubmitButtonProps, 'button'>(\n (props, ref) => {\n const {\n children = 'Submit',\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 type=\"submit\"\n isLoading={formState.isSubmitting || isLoading}\n isDisabled={isDisabled}\n >\n {children}\n </Button>\n )\n }\n)\n\nSubmitButton.defaultProps = {\n variant: 'primary',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nSubmitButton.displayName = 'SubmitButton'\n","import * as React from 'react'\nimport {\n useWatch,\n FieldValues,\n UseFormReturn,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\n\nexport interface DisplayIfProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n children: React.ReactElement\n name: TName\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n/**\n * Conditionally render parts of a form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const DisplayIf = <\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues, TName>) => {\n const value = useWatch<TFieldValues>({\n name,\n defaultValue: defaultValue as any,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext() as any\n return condition(value, context) ? children : null\n}\n\nDisplayIf.displayName = 'DisplayIf'\n","import * as React from 'react'\n\nimport { FieldValues } from 'react-hook-form'\n\nimport {\n chakra,\n Button,\n ButtonProps,\n HTMLChakraProps,\n ThemingProps,\n} from '@chakra-ui/react'\n\nimport { callAllHandlers, cx } from '@chakra-ui/utils'\n\nimport {\n Steps,\n StepsItem,\n StepsItemProps,\n StepsProps,\n useStepperContext,\n} from '@saas-ui/core'\n\nimport { SubmitButton } from './submit-button'\n\nimport {\n useFormStep,\n UseStepFormProps,\n FormStepSubmitHandler,\n} from './use-step-form'\n\nexport type StepsOptions<TSchema, TName extends string = string> = {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: TSchema\n}[]\n\nexport interface StepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends UseStepFormProps<TSteps, TFieldValues, TContext> {}\n\nexport interface FormStepOptions<TName extends string = string> {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport interface FormStepperProps extends StepsProps, ThemingProps<'Stepper'> {\n render?: StepsItemProps['render']\n}\n\n/**\n * Renders a stepper that displays progress above the form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStepper: React.FC<FormStepperProps> = (props) => {\n const { activeIndex, setIndex } = useStepperContext()\n\n const {\n children,\n orientation,\n variant,\n colorScheme,\n size,\n onChange: onChangeProp,\n render,\n ...rest\n } = 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 <StepsItem\n render={render}\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n {...rest}\n >\n {child.props.children}\n </StepsItem>\n )\n }\n return child\n })\n\n const onChange = React.useCallback((i: number) => {\n setIndex(i)\n onChangeProp?.(i)\n }, [])\n\n return (\n <Steps\n orientation={orientation}\n step={activeIndex}\n variant={variant}\n colorScheme={colorScheme}\n size={size}\n onChange={onChange}\n >\n {elements}\n </Steps>\n )\n}\n\nexport interface FormStepProps<TName extends string = string>\n extends FormStepOptions<TName>,\n Omit<HTMLChakraProps<'div'>, 'onSubmit'> {\n onSubmit?: FormStepSubmitHandler\n}\n/**\n * The form step containing fields for a specific step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStep = <TName extends string = string>(\n props: FormStepProps<TName>\n) => {\n const { name, children, className, onSubmit, ...rest } = props\n const step = useFormStep({ name, onSubmit })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('sui-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nFormStep.displayName = 'FormStep'\n\n/**\n * A button that this opens the previous step when clicked. Disabled on the first step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n children=\"Back\"\n {...props}\n className={cx('sui-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nPrevButton.displayName = 'PrevButton'\n\nexport interface NextButtonProps extends Omit<ButtonProps, 'children'> {\n submitLabel?: string\n label?: string\n}\n\n/**\n * A button that submits the active step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\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('sui-form__next-button', props.className)}\n >\n {isLastStep || isCompleted ? submitLabel : label}\n </SubmitButton>\n )\n}\n\nNextButton.displayName = 'NextButton'\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/core'\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 { FocusableElement } from '@chakra-ui/utils'\nimport { FormProps } from './form'\nimport { FormStepProps, StepsOptions } from './step-form'\nimport { FieldProps, StepFormChildren } from './types'\nimport { DisplayIfProps } from './display-if'\nimport { ArrayFieldProps } from './array-field'\nimport { UseArrayFieldReturn } from './use-array-field'\nimport { ObjectFieldProps } from './object-field'\n\ntype StepName<T extends { [k: number]: { readonly name: string } }> =\n T[number]['name']\n\nexport interface StepFormRenderContext<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseStepFormReturn<TFieldValues> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n FormStep: React.FC<FormStepProps<StepName<TSteps>>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\nexport interface UseStepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends Omit<UseStepperProps, 'onChange'>,\n Omit<FormProps<any, TFieldValues, TContext>, 'children'> {\n steps?: TSteps\n children: StepFormChildren<any, TSteps, TFieldValues, TContext>\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<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: UseStepFormProps<TSteps, TFieldValues, TContext>\n): UseStepFormReturn<TFieldValues> {\n const { onChange, steps: stepsOptions, resolver, ...rest } = props\n const stepper = useStepper(rest)\n\n const [options, setOptions] = React.useState<TSteps | undefined>(stepsOptions)\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\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.schema\n ? /* @todo fix resolver type */ (resolver as any)?.(step.schema)\n : undefined,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n const stepOptions = options?.find((s) => s.name === step.name)\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: {\n ...step,\n schema: stepOptions?.schema,\n },\n }\n })\n },\n [steps, options]\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 { BaseFieldProps } from './types'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): BaseFieldProps[]\n getNestedFields(name: string): BaseFieldProps[]\n}\n\nexport type GetFieldResolver<TSchema = any> = (schema: TSchema) => FieldResolver\n\ninterface SchemaField extends BaseFieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema): BaseFieldProps[] =>\n schema &&\n Object.entries(schema).map(([name, { items, label, title, ...field }]) => {\n return {\n ...field,\n name,\n label: label || title || name, // json schema compatibility\n }\n })\n\nexport const objectFieldResolver: GetFieldResolver<ObjectSchema> = (schema) => {\n const getFields = (): BaseFieldProps[] => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string): BaseFieldProps[] => {\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 { FieldValues, useWatch } from 'react-hook-form'\nimport { useFormContext, UseFormReturn } from './form-context'\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","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { FocusableElement, cx, runIfFn } from '@chakra-ui/utils'\n\nimport {\n useForm,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n ResolverOptions,\n ResolverResult,\n WatchObserver,\n} from 'react-hook-form'\nimport { FormProvider } from './form-context'\nimport { FieldResolver } from './field-resolver'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\nimport { FieldProps, DefaultFieldOverrides } from './types'\n\nimport { Field as DefaultField } from './field'\nimport { FormLayout } from './layout'\nimport { AutoFields } from './fields'\nimport { SubmitButton } from './submit-button'\nimport { DisplayIf, DisplayIfProps } from './display-if'\nimport { ArrayField, ArrayFieldProps } from './array-field'\nimport { ObjectField, ObjectFieldProps } from './object-field'\nimport { UseArrayFieldReturn } from './use-array-field'\n\nexport interface FormRenderContext<\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormReturn<TFieldValues, TContext> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\ninterface FormOptions<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> {\n /**\n * The form schema.\n */\n schema?: TSchema\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 * The Hook Form state ref.\n */\n formRef?: React.RefObject<UseFormReturn<TFieldValues, TContext>>\n /**\n * The form children, can be a render prop or a ReactNode.\n */\n children?: MaybeRenderProp<\n FormRenderContext<TFieldValues, TContext, TFieldTypes>\n >\n /**\n * The field resolver, used to resolve the fields from schemas.\n */\n fieldResolver?: FieldResolver\n /**\n * Field overrides\n */\n fields?: DefaultFieldOverrides\n}\n\nexport interface FormProps<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormProps<TFieldValues, TContext>,\n Omit<\n HTMLChakraProps<'form'>,\n 'children' | 'onChange' | 'onSubmit' | 'onError'\n >,\n FormOptions<TSchema, TFieldValues, TContext, TFieldTypes> {}\n\n/**\n * The wrapper component provides context, state, and focus management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n >(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes>,\n ref: React.ForwardedRef<HTMLFormElement>\n ) => {\n const {\n mode = 'all',\n resolver,\n fieldResolver,\n fields,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n values,\n context,\n resetOptions,\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 values,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n context,\n resetOptions,\n }\n\n const methods = useForm<TFieldValues, TContext>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(formRef, () => methods, [formRef, 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 let _children = children\n if (!_children && fieldResolver) {\n _children = (\n <FormLayout>\n <AutoFields />\n <SubmitButton {...fields?.submit} />\n </FormLayout>\n )\n }\n\n return (\n <FormProvider\n {...methods}\n schema={schema}\n fieldResolver={fieldResolver}\n fields={fields}\n >\n <chakra.form\n ref={ref}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('sui-form', props.className)}\n >\n {runIfFn(_children, {\n Field: DefaultField as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n ...methods,\n })}\n </chakra.form>\n </FormProvider>\n )\n }\n) as FormComponent\n\nexport type FormComponent = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes> & {\n ref?: React.ForwardedRef<HTMLFormElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n\nForm.displayName = 'Form'\n\nexport type GetResolver = <\n TFieldValues extends FieldValues,\n TContext extends object\n>(\n schema: unknown\n) => (\n values: TFieldValues,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n","import React, { ForwardedRef } from 'react'\nimport { FieldsProvider } from './fields-context'\nimport { Form, FieldValues, FormProps, GetResolver } from './form'\nimport { DefaultFieldOverrides, WithFields } from './types'\nimport { objectFieldResolver } from './field-resolver'\nimport { GetFieldResolver } from './field-resolver'\nimport { forwardRef } from '@chakra-ui/react'\n\nexport interface CreateFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport type FormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: WithFields<\n FormProps<TSchema, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport function createForm<FieldDefs>({\n resolver,\n fieldResolver = objectFieldResolver,\n fields,\n}: CreateFormProps<FieldDefs> = {}) {\n const DefaultForm = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n >(\n props: WithFields<FormProps<TSchema, TFieldValues, TContext>, FieldDefs>,\n ref: ForwardedRef<HTMLFormElement>\n ) => {\n const { schema, ...rest } = props\n return (\n <FieldsProvider value={fields || {}}>\n <Form\n ref={ref}\n resolver={resolver?.(props.schema)}\n fieldResolver={fieldResolver?.(schema)}\n {...rest}\n />\n </FieldsProvider>\n )\n }\n ) as FormType<FieldDefs>\n\n DefaultForm.displayName = 'Form'\n DefaultForm.id = 'Form'\n\n return DefaultForm\n}\n","import React, { useMemo } from 'react'\nimport { forwardRef } from '@chakra-ui/react'\nimport {\n ArrayField,\n DisplayIf,\n FieldProps,\n FieldValues,\n FieldsProvider,\n Form,\n GetFieldResolver,\n ObjectField,\n} from './'\nimport { Field } from './field'\nimport { FormStep, StepsOptions } from './step-form'\nimport {\n StepFormProvider,\n UseStepFormProps,\n useStepForm,\n} from './use-step-form'\nimport { StepperProvider } from '@saas-ui/core'\nimport { runIfFn } from '@chakra-ui/utils'\nimport { GetResolver } from './form'\nimport { WithStepFields } from './types'\n\nexport type StepFormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: WithStepFields<\n UseStepFormProps<TSteps, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport interface CreateStepFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport function createStepForm<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n>({ fields, resolver, fieldResolver }: CreateStepFormProps<FieldDefs> = {}) {\n const StepForm = forwardRef<any, 'div'>((props, ref) => {\n const { children, steps, ...rest } = props\n\n const stepper = useStepForm({\n resolver,\n fieldResolver,\n ...props,\n })\n\n const { getFormProps, ...ctx } = stepper\n\n const context = useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <FieldsProvider value={fields || {}}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, {\n ...stepper,\n Field: Field as any,\n FormStep: FormStep as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n })}\n </Form>\n </FieldsProvider>\n </StepFormProvider>\n </StepperProvider>\n )\n }) as StepFormType<FieldDefs, ExtraProps, ExtraOverrides>\n\n StepForm.displayName = `Step${Form.displayName || Form.name}`\n\n return StepForm\n}\n","export * from './display-field'\nexport * from './field'\nexport * from './fields'\nexport * from './fields-context'\nexport * from './layout'\nexport * from './submit-button'\nexport * from './array-field'\nexport * from './use-array-field'\nexport * from './object-field'\nexport * from './display-if'\nexport * from './step-form'\nexport * from './use-step-form'\nexport * from './field-resolver'\nexport * from './watch-field'\nexport * from './input-right-button'\nexport * from './select'\nexport * from './password-input'\nexport * from './radio'\n\nexport * from './base-field'\n\nexport {\n CheckboxField,\n InputField,\n NativeSelectField,\n NumberInputField,\n PasswordInputField,\n PinField,\n RadioField,\n SelectField,\n SwitchField,\n TextareaField,\n defaultFieldTypes,\n type DefaultFields,\n type InputFieldProps,\n type NumberInputFieldProps,\n type PinFieldProps,\n} from './default-fields'\n\nexport type {\n FieldProps,\n WithFields,\n BaseFieldProps,\n FieldOptions,\n DefaultFieldOverrides,\n WithStepFields,\n} from './types'\n\nexport { createForm, type CreateFormProps, type FormType } from './create-form'\nexport { createField, type CreateFieldOptions } from './create-field'\n\nexport { Form as BaseForm } from './form'\nexport type { FormProps, FormRenderContext, FormComponent } from './form'\n\nexport { FormProvider, useFormContext } from './form-context'\n\nimport { createForm } from './create-form'\nimport { createStepForm } from './create-step-form'\n\n/**\n * Form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = createForm()\n\nexport { createStepForm, type CreateStepFormProps } from './create-step-form'\n\n/**\n * Multi-step form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const StepForm = createStepForm()\n\nexport type {\n BatchFieldArrayUpdate,\n ChangeHandler,\n Control,\n ControllerFieldState,\n ControllerProps,\n ControllerRenderProps,\n CriteriaMode,\n CustomElement,\n DeepMap,\n DeepPartial,\n DeepPartialSkipArrayKey,\n DefaultValues,\n DelayCallback,\n EmptyObject,\n ErrorOption,\n EventType,\n Field as FieldDef,\n FieldArray,\n FieldArrayMethodProps,\n FieldArrayWithId,\n FieldElement,\n FieldError,\n FieldErrors,\n FieldName,\n FieldNamesMarkedBoolean,\n FieldRefs,\n FieldValue,\n FieldValues,\n FormProviderProps,\n FormState,\n FormStateProxy,\n FormStateSubjectRef,\n GetIsDirty,\n InternalFieldErrors,\n InternalFieldName,\n InternalNameSet,\n IsAny,\n IsFlatObject,\n KeepStateOptions,\n LiteralUnion,\n Message,\n Mode,\n MultipleFieldErrors,\n Names,\n NativeFieldValue,\n NestedValue,\n NonUndefined,\n Noop,\n Primitive,\n ReadFormState,\n Ref,\n RefCallBack,\n RegisterOptions,\n Resolver,\n ResolverError,\n ResolverOptions,\n ResolverResult,\n ResolverSuccess,\n SetFieldValue,\n SetValueConfig,\n Subjects,\n SubmitErrorHandler,\n SubmitHandler,\n TriggerConfig,\n UnpackNestedValue,\n UseControllerProps,\n UseControllerReturn,\n UseFieldArrayProps,\n UseFieldArrayReturn,\n UseFormClearErrors,\n UseFormGetValues,\n UseFormHandleSubmit,\n UseFormProps,\n UseFormRegister,\n UseFormRegisterReturn,\n UseFormReset,\n UseFormResetField,\n UseFormReturn,\n UseFormSetError,\n UseFormSetFocus,\n UseFormSetValue,\n UseFormStateProps,\n UseFormStateReturn,\n UseFormTrigger,\n UseFormUnregister,\n UseFormWatch,\n UseWatchProps,\n Validate,\n ValidateResult,\n ValidationMode,\n ValidationRule,\n ValidationValue,\n ValidationValueMessage,\n WatchInternal,\n WatchObserver,\n} from 'react-hook-form'\n\nexport {\n appendErrors,\n useController,\n useFieldArray,\n useForm,\n useFormState,\n useWatch,\n Controller,\n} from 'react-hook-form'\n"]}
1
+ {"version":3,"sources":["../src/form-context.tsx","../src/display-field.tsx","../src/field.tsx","../src/fields-context.tsx","../src/default-fields.tsx","../src/number-input/number-input.tsx","../src/password-input/password-input.tsx","../src/input-right-button/input-right-button.tsx","../src/radio/radio-input.tsx","../src/utils.ts","../src/select/select.tsx","../src/select/select-context.tsx","../src/select/native-select.tsx","../src/create-field.tsx","../src/base-field.tsx","../src/fields.tsx","../src/layout.tsx","../src/array-field.tsx","../src/use-array-field.tsx","../src/object-field.tsx","../src/submit-button.tsx","../src/display-if.tsx","../src/step-form.tsx","../src/use-step-form.tsx","../src/field-resolver.ts","../src/watch-field.tsx","../src/form.tsx","../src/create-form.tsx","../src/create-step-form.tsx","../src/index.ts"],"names":["jsx","React","forwardRef","Input","InputGroup","jsxs","Button","ChevronDownIcon","createContext","value","FormControl","FormLabel","BaseField","Field","NumberInputField","chakra","cx","mapNestedFields","name","useFormContext","callAllHandlers","steps","get","useWatch","useMemo","runIfFn","StepForm","useFieldArray","useForm","Controller","Form"],"mappings":";AAAA,YAAY,WAAW;AACvB;AAAA,EACE,gBAAgB;AAAA,EAEhB,kBAAkB;AAAA,OAEb;AAwED;AA5CN,IAAM,cAAoB,oBAAuC,IAAI;AAE9D,IAAM,iBAAiB,MAIvB;AACL,QAAM,UAAgB,iBAAW,WAAW;AAC5C,QAAM,cAAc,mBAAmB;AAEvC,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,mDAAmD;AAAA,EACrE;AAEA,SAAO;AAAA,IACL,GAAG;AAAA,IACH,GAAG;AAAA,EACL;AACF;AAEO,IAAM,gBAAgB,CAC3B,SAC6C;AAxD/C;AAyDE,QAAM,aAAa,6BAAM,QAAQ,YAAY;AAC7C,QAAM,UAAU,eAAe;AAC/B,WAAQ,wCAAS,WAAT,mBAAkB,gBAAuB,CAAC;AACpD;AAQO,IAAM,eAAe,CAK1B,UACG;AACH,QAAM,EAAE,UAAU,eAAe,QAAQ,QAAQ,GAAG,KAAK,IAAI;AAC7D,SACE,oBAAC,oBAAkB,GAAG,MACpB,8BAAC,YAAY,UAAZ,EAAqB,OAAO,EAAE,eAAe,QAAQ,OAAO,GAC1D,UACH,GACF;AAEJ;;;ACjFA;AAAA,EACE;AAAA,EACA;AAAA,EAEA;AAAA,OACK;AAmBH,SACW,OAAAA,MADX;AAPG,IAAM,eAA4C,CAAC;AAAA,EACxD;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,SACE,qBAAC,eAAa,GAAG,OACd;AAAA,YAAQ,gBAAAA,KAAC,aAAU,SAAS,MAAO,iBAAM,IAAe;AAAA,IACzD,gBAAAA,KAAC,QAAK,UAAS,MACb,0BAAAA,KAAC,aAAU,MAAY,GACzB;AAAA,KACF;AAEJ;AAEA,aAAa,cAAc;AAEpB,IAAM,YAAwC,CAAC,EAAE,KAAK,MAAM;AACjE,QAAM,EAAE,UAAU,IAAI,eAAe;AACrC,SAAO,UAAU,IAAI,KAAK;AAC5B;AAEA,UAAU,cAAc;;;AC1CxB,YAAYC,YAAW;;;ACAvB,OAAOA,YAAW;;;ACElB;AAAA,EACE,cAAAC;AAAA,EACA,SAAAC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAAC;AAAA,EAKA;AAAA,EACA;AAAA,EACA;AAAA,OAGK;;;AChBP;AAAA,EACE;AAAA,EACA,eAAe;AAAA,EACf;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OAEK;AAEP,SAAS,iBAAiB,qBAAqB;AAwB3B,gBAAAJ,MAUZ,QAAAK,aAVY;AAHb,IAAM,cAAc,WAAoC,CAAC,OAAO,QAAQ;AAC7E,QAAM;AAAA,IACJ;AAAA,IACA,gBAAgB,gBAAAL,KAAC,iBAAc;AAAA,IAC/B,gBAAgB,gBAAAA,KAAC,mBAAgB;AAAA,IACjC,GAAG;AAAA,EACL,IAAI;AAEJ,SACE,gBAAAK,MAAC,qBAAmB,GAAG,MAAM,KAC3B;AAAA,oBAAAL,KAAC,oBAAiB;AAAA,IAEjB,CAAC,eACA,gBAAAK,MAAC,sBACC;AAAA,sBAAAL,KAAC,0BAAuB,UAAU,eAAe;AAAA,MACjD,gBAAAA,KAAC,0BAAuB,UAAU,eAAe;AAAA,OACnD;AAAA,KAEJ;AAEJ,CAAC;AAED,YAAY,eAAe;AAAA,EACzB,aAAa;AACf;AAEA,YAAY,cAAc;;;AC3D1B,SAAgB,gBAAgB;AAEhC,SAAS,cAAAE,aAAY,YAAY,aAAyB;AAE1D,SAAS,UAAU,mBAAmB;;;ACFtC;AAAA,EACE;AAAA,EAEA,cAAAA;AAAA,EACA;AAAA,OACK;AAQC,gBAAAF,YAAA;AAJD,IAAM,mBAAmBE;AAAA,EAC9B,CAAC,OAAO,QAAQ;AACd,WACE,gBAAAF,KAAC,qBAAkB,GAAE,QAAO,IAAG,KAAI,IAAG,KAAI,YAAW,WACnD,0BAAAA,KAAC,UAAO,KAAU,QAAO,QAAQ,GAAG,OAAO,GAC7C;AAAA,EAEJ;AACF;AAEA,iBAAiB,KAAK;AAEtB,iBAAiB,cAAc;;;ADaN,gBAAAA,MAYnB,QAAAK,aAZmB;AApBlB,IAAM,gBAAgBH;AAAA,EAC3B,CAAC,OAAO,QAAQ;AACd,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL,IAAI;AACJ,UAAM,CAAC,MAAM,OAAO,IAAI,SAAS,KAAK;AACtC,UAAM,cAAc,MAAM,QAAQ,CAAC,IAAI;AAEvC,UAAM,QAAQ,OAAO,kBAAkB;AAEvC,QAAI;AACJ,QAAI,MAAM;AACR,aAAO,YAAY,gBAAAF,KAAC,YAAS;AAAA,IAC/B,OAAO;AACL,aAAO,eAAe,gBAAAA,KAAC,eAAY;AAAA,IACrC;AAEA,UAAM,aAAa;AAAA,MACjB,OAAO,KAAK;AAAA,MACZ;AAAA,MACA;AAAA,IACF;AAEA,WACE,gBAAAK,MAAC,cAAY,GAAG,YACb;AAAA;AAAA,MACD,gBAAAL;AAAA,QAAC;AAAA;AAAA,UACE,GAAG;AAAA,UACJ;AAAA,UACA,MAAM,OAAO,SAAS;AAAA,UACtB,cAAc,OAAO,QAAQ;AAAA;AAAA,MAC/B;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA;AAAA,UACC,SAAS;AAAA,UACT,cAAY;AAAA,UACZ,SAAQ;AAAA,UAEP;AAAA;AAAA,MACH;AAAA,OACF;AAAA,EAEJ;AACF;AAEA,cAAc,cAAc;;;AElE5B;AAAA,EACE,cAAAE;AAAA,EACA;AAAA,EACA;AAAA,EAEA;AAAA,OAIK;;;ACXP,YAAYD,YAAW;AAGhB,IAAM,kBAAkB,CAAC,MAAc,aAA8B;AAC1E,SAAa,gBAAS,IAAI,UAAU,CAAC,UAAU;AAC7C,QAAU,sBAAe,KAAK,KAAK,MAAM,MAAM,MAAM;AACnD,UAAI,YAAY,MAAM,MAAM;AAC5B,UAAI,UAAU,SAAS,GAAG,GAAG;AAC3B,oBAAY,UAAU,QAAQ,aAAa,IAAI;AAAA,MACjD,WAAW,UAAU,SAAS,IAAI,GAAG;AACnC,oBAAY,UAAU,QAAQ,eAAe,IAAI;AAAA,MACnD;AAEA,aAAa,oBAAa,OAAO;AAAA,QAC/B,GAAG,MAAM;AAAA,QACT,MAAM,GAAG,QAAQ;AAAA,MACnB,CAAC;AAAA,IACH;AACA,WAAO;AAAA,EACT,CAAC;AACH;AAEO,IAAM,aAAa,CACxB,YACG;AACH,SAAO,QAAQ,IAAI,CAAC,WAAW;AAC7B,QAAI,OAAO,WAAW,UAAU;AAC9B,aAAO;AAAA,QACL,OAAO;AAAA,QACP,OAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,EACT,CAAC;AACH;;;ADQc,gBAAAD,YAAA;AAXP,IAAM,aAAaE;AAAA,EACxB,CAAC,EAAE,SAAS,aAAa,SAAS,WAAW,GAAG,MAAM,GAAG,QAAQ;AAC/D,UAAM,EAAE,QAAQ,UAAU,GAAG,WAAW,IAAI;AAE5C,UAAM,UAAU,WAAW,WAAW;AAEtC,WACE,gBAAAF,KAAC,cAAW,UAAqB,GAAG,YAClC,0BAAAA,KAAC,SAAM,SAAkB,WACtB,kBAAQ,IAAI,CAAC,EAAE,OAAO,OAAO,GAAG,WAAW,GAAG,MAAM;AACnD,aACE,gBAAAA;AAAA,QAAC;AAAA;AAAA,UAEC;AAAA,UACA;AAAA,UACA;AAAA,UACC,GAAG;AAAA,UAEH,mBAAS;AAAA;AAAA,QANL;AAAA,MAOP;AAAA,IAEJ,CAAC,GACH,GACF;AAAA,EAEJ;AACF;AAEA,WAAW,cAAc;;;AEzDzB;AAAA,EACE;AAAA,EACA,cAAAE;AAAA,EACA;AAAA,EAEA;AAAA,EAEA;AAAA,EACA;AAAA,EACA,UAAAI;AAAA,EAEA;AAAA,EACA;AAAA,EAEA;AAAA,EAEA;AAAA,OACK;AACP,SAAS,IAAI,gBAAgB;AAC7B,SAAS,mBAAAC,wBAAuB;;;ACrBhC;AAAA,EAEE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,iBAAAC,sBAAqB;AAC9B,OAAOP,YAAW;AAKX,IAAM,CAAC,sBAAsB,eAAe,IACjD,oBAAoB,WAAW;AAE1B,IAAM,CAAC,gBAAgB,gBAAgB,IAAIO,eAEhD;AAAA,EACA,QAAQ;AACV,CAAC;AA6CM,IAAM,YAAY,CAAC,UAAyB;AACjD,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT;AAAA,IACA,cAAc,CAACC,WACb,OAAOA,WAAU,WAAWA,SAAQA,UAAA,gBAAAA,OAAO,KAAK;AAAA,EACpD,IAAI;AACJ,QAAM,CAAC,cAAc,eAAe,IAAI,qBAAqB;AAAA,IAC3D;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,QAAM,eAAe,eAAe,EAAE,KAAK,CAA6B;AAExE,QAAM,UAAUR,OAAM;AAAA,IACpB,MAAM,eAAe,WAAW,WAAW;AAAA,IAC3C,CAAC,WAAW;AAAA,EACd;AAEA,QAAM,eAAe,CAACQ,WAA6B;AACjD,oBAAgBA,MAAK;AAAA,EACvB;AAEA,QAAM,kBAAkBR,OAAM;AAAA,IAC5B,CAACQ,WAAkB;AACjB,UAAI,CAAC,SAAS;AACZ,eAAOA;AAAA,MACT;AAEA,iBAAW,UAAU,SAAS;AAC5B,YAAI,OAAO,UAAUA,QAAO;AAC1B,iBAAO,OAAO,SAAS,OAAO;AAAA,QAChC;AAAA,MACF;AAEA,aAAOA;AAAA,IACT;AAAA,IACA,CAAC,OAAO;AAAA,EACV;AAEA,QAAM,eAAeR,OAAM;AAAA,IACzB,MACE,gBACK,MAAM,QAAQ,YAAY,IAAI,eAAe,CAAC,YAAY,GAAG;AAAA,MAC5D;AAAA,IACF,IACA,CAAC;AAAA,IACP,CAAC,cAAc,eAAe;AAAA,EAChC;AAEA,SAAO;AAAA,IACL;AAAA,IACA,OAAO;AAAA,IACP;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;;;AD1DwB,gBAAAD,MAqFd,QAAAK,aArFc;AAxBjB,IAAM,eAAeH;AAAA,EAC1B,CAAC,OAAO,QAAQ;AApDlB;AAqDI,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA,YAAY;AAAA,IACd,IAAI,iBAAiB;AAErB,UAAM,UAAU,sBAAsB;AAEtC,UAAM,SAAS,gBAAgB;AAE/B,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF,IAAI,WAAW,CAAC;AAEhB,UAAM,EAAE,YAAY,gBAAAF,KAACO,kBAAA,EAAgB,GAAI,GAAG,KAAK,IAAI;AAGrD,UAAM,eAAc,YAAO,UAAP,mBAAc;AAElC,UAAM,kBAAiB,YAAO,UAAP,mBAAc;AAErC,UAAM,WAAU,YAAO,UAAP,mBAAc;AAE9B,UAAM,WAAS,YAAO,UAAP,mBAAc,QAAK,YAAO,UAAP,mBAAc;AAEhD,UAAM,eAAoB;AAAA,MACxB,YAAY;AAAA,MACZ,WAAW;AAAA,MACX,OAAO;AAAA,MACP,SAAS;AAAA,QACP,IAAI;AAAA,MACN;AAAA,MACA,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,WAAW;AAAA,MACX,WAAW;AAAA,MACX,UAAU;AAAA,MACV,MAAM;AAAA,MACN,GAAG,OAAO;AAAA,MACV,GAAG;AAAA,IACL;AAEA,UAAM,cAAc,cAAc,MAAM,GAAG;AAG3C,WACE,gBAAAP;AAAA,MAACM;AAAA,MAAA;AAAA,QACE,GAAG;AAAA,QACH,GAAG;AAAA,QACJ,IAAI,MAAM,YAAY;AAAA,QACrB,GAAG;AAAA,QACJ;AAAA,QACA;AAAA,QACA,YAAY,cAAc;AAAA,QAC1B,gBAAc,SAAS,SAAS;AAAA,QAChC,kBAAgB,SAAS,UAAU;AAAA,QACnC,cAAY,SAAS,SAAS;AAAA,QAC9B,iBAAe,SAAS,UAAU;AAAA,QAClC;AAAA,QAEA,0BAAAN;AAAA,UAAC,OAAO;AAAA,UAAP;AAAA,YACC,OAAO;AAAA,cACL,SAAS;AAAA,cACT,eAAe;AAAA,cACf,MAAM;AAAA,cACN,MAAM;AAAA,cACN,UAAU;AAAA,cACV,cAAc;AAAA,YAChB;AAAA,YAEC,sBAAY,YAAY,KAAK;AAAA;AAAA,QAChC;AAAA;AAAA,IACF;AAAA,EAEJ;AACF;AAEA,aAAa,cAAc;AAOpB,IAAM,SAASE,YAAkC,CAAC,OAAO,QAAQ;AACtE,QAAM,EAAE,MAAM,UAAU,YAAY,UAAU,GAAG,KAAK,IAAI;AAE1D,QAAM,SAAS,oBAAoB,aAAa,KAAK;AAErD,QAAM,YAAY,iBAAiB,IAAI;AAEvC,QAAM,UAAU,UAAU,KAAK;AAE/B,QAAM,EAAE,OAAO,aAAa,IAAI;AAEhC,SACE,gBAAAF,KAAC,kBAAe,OAAO,SACrB,0BAAAA,KAAC,wBAAqB,OAAO,QAC3B,0BAAAA,KAAC,QAAM,GAAG,WAAW,eAAe,CAAC,UACnC,0BAAAK,MAAC,OAAO,KAAP,EAAW,WAAW,GAAG,YAAY,GACnC;AAAA;AAAA,IACD,gBAAAL;AAAA,MAAC,OAAO;AAAA,MAAP;AAAA,QACE,GAAG;AAAA,QACJ;AAAA,QACA;AAAA,QACA,MAAK;AAAA,QACL,OAAO,SAAS;AAAA,QAChB,WAAU;AAAA;AAAA,IACZ;AAAA,KACF,GACF,GACF,GACF;AAEJ,CAAC;AASM,IAAM,aAAwC,CAAC,UAAU;AAC9D,QAAM,EAAE,cAAc,OAAO,SAAS,UAAU,SAAS,IACvD,iBAAiB;AAEnB,SACE,gBAAAA,KAAC,YAAS,MAAK,SAAQ,WAAU,QAAQ,GAAG,OAC1C,0BAAAA;AAAA,IAAC;AAAA;AAAA,MACC,cAAe,gBAAgB;AAAA,MAC/B;AAAA,MACA;AAAA,MACA,MAAM,WAAW,aAAa;AAAA,MAE7B,oBACG,QAAQ,IAAI,CAAC,EAAE,OAAAS,QAAO,OAAO,GAAG,KAAK,GAAG,MACtC,gBAAAT,KAAC,gBAAqB,OAAOS,QAAQ,GAAG,MACrC,mBAASA,UADO,CAEnB,CACD,IACD,MAAM;AAAA;AAAA,EACZ,GACF;AAEJ;AAEA,OAAO,cAAc;AAOd,IAAM,eAAeP;AAAA,EAC1B,CAAC,OAAO,QAAQ;AACd,WAAO,gBAAAF,KAAC,kBAAe,KAAW,GAAG,OAAO;AAAA,EAC9C;AACF;AACA,aAAa,KAAK;AAClB,aAAa,cAAc;;;AE3N3B;AAAA,EACE,cAAAE;AAAA,EACA,UAAU;AAAA,OAEL;AAsBO,gBAAAF,YAAA;AAPP,IAAM,eAAeE;AAAA,EAC1B,CAAC,EAAE,SAAS,UAAU,GAAG,MAAM,GAAG,QAAQ;AACxC,WACE,gBAAAF,KAAC,gBAAa,KAAW,GAAG,OACzB,uBACC,mCAAS,IAAI,CAAC,EAAE,OAAO,MAAM,MAAM;AACjC,aACE,gBAAAA,KAAC,YAAmB,OACjB,mBAAS,SADC,KAEb;AAAA,IAEJ,KACJ;AAAA,EAEJ;AACF;AAEA,aAAa,cAAc;;;ACrC3B,SAAS,kBAAkB;AAE3B,SAAS,cAAAE,aAAY,oBAAoB;AACzC,SAAS,uBAAuB;;;ACHhC,SAAoB,WAAW;AAE/B;AAAA,EACE;AAAA,EACA,eAAAQ;AAAA,EACA,aAAAC;AAAA,EACA;AAAA,EACA;AAAA,OACK;AA8BsB,gBAAAX,MACvB,QAAAK,aADuB;AAxB7B,IAAM,WAAW,CAAC,MAAc,cAA+C;AAC7E,SAAO,IAAI,UAAU,QAAQ,IAAI;AACnC;AAaO,IAAM,YAAsC,CAAC,UAAU;AAC5D,QAAM,EAAE,MAAM,OAAO,MAAM,WAAW,UAAU,GAAG,aAAa,IAAI;AAEpE,QAAM,EAAE,UAAU,IAAI,eAAe;AAErC,QAAM,QAAQ,SAAS,MAAM,SAAS;AAEtC,SACE,gBAAAA,MAACK,cAAA,EAAa,GAAG,cAAc,WAAW,CAAC,CAAC,OACzC;AAAA,aAAS,CAAC,YAAY,gBAAAV,KAACW,YAAA,EAAW,iBAAM,IAAe;AAAA,IACxD,gBAAAN,MAAC,OACE;AAAA;AAAA,MACA,QAAQ,EAAC,+BAAO,WACf,gBAAAL,KAAC,kBAAgB,gBAAK,IACpB;AAAA,OACH,+BAAO,YACN,gBAAAA,KAAC,oBAAkB,yCAAO,SAAQ;AAAA,OAEtC;AAAA,KACF;AAEJ;AAEA,UAAU,cAAc;;;ADHhB,gBAAAA,aAAA;AAnCR,IAAM,eAAe,CACnB,gBACA,EAAE,aAAa,WAAW,WAAAY,WAAU,MACjC;AACH,QAAMC,SAAQX,YAAW,CAAC,OAAO,QAAQ;AACvC,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL,IAAI;AAEJ,UAAM,aAAa;AAAA,MACjB,UAAU;AAAA,MACV,GAAG;AAAA,IACL;AAEA,WACE,gBAAAF;AAAA,MAACY;AAAA,MAAA;AAAA,QACC;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QAEA,0BAAAZ;AAAA,UAAC;AAAA;AAAA,YACC;AAAA,YACA;AAAA,YACA;AAAA,YACA,OAAO,YAAY,QAAQ;AAAA,YAC3B,OAAO;AAAA,YACN,GAAG;AAAA;AAAA,QACN;AAAA;AAAA,IACF;AAAA,EAEJ,CAAC;AAED,EAAAa,OAAM,cAAc;AAEpB,SAAOA;AACT;AAEA,IAAM,sBAAsB,CAAC,mBAAkC;AAC7D,SAAOX;AAAA,IACL,CAAC,EAAE,MAAM,OAAO,GAAG,WAAW,GAAG,QAAQ;AACvC,YAAM,EAAE,QAAQ,IAAI,eAAe;AAEnC,aACE,gBAAAF;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA,QAAQ,CAAC,EAAE,OAAO,EAAE,KAAK,MAAM,GAAG,MAAM,EAAE,MACxC,gBAAAA;AAAA,YAAC;AAAA;AAAA,cACE,GAAG;AAAA,cACH,GAAG;AAAA,cACJ,UAAU,gBAAgB,WAAW,UAAU,MAAM,QAAQ;AAAA,cAC7D,QAAQ,gBAAgB,WAAW,QAAQ,MAAM,MAAM;AAAA,cACvD,KAAK,aAAa,KAAK,IAAI;AAAA;AAAA,UAC7B;AAAA;AAAA,MAEJ;AAAA,IAEJ;AAAA,EACF;AACF;AAEA,IAAM,wBAAwB,CAAC,mBAAkC;AAC/D,SAAOE;AAAA,IACL,CAAC,EAAE,MAAM,OAAO,GAAG,WAAW,GAAG,QAAQ;AACvC,YAAM,EAAE,SAAS,IAAI,eAAe;AAEpC,YAAM,EAAE,KAAK,MAAM,GAAG,MAAM,IAAI,SAAS,MAAM,KAAK;AAEpD,aACE,gBAAAF;AAAA,QAAC;AAAA;AAAA,UACE,GAAG;AAAA,UACH,GAAG;AAAA,UACJ,UAAU,gBAAgB,WAAW,UAAU,MAAM,QAAQ;AAAA,UAC7D,QAAQ,gBAAgB,WAAW,QAAQ,MAAM,MAAM;AAAA,UACvD,KAAK,aAAa,KAAK,IAAI;AAAA;AAAA,MAC7B;AAAA,IAEJ;AAAA,EACF;AACF;AAgBO,IAAM,cAAc,CACzB,WACA,YACG;AAjIL;AAkIE,MAAI;AACJ,MAAI,mCAAS,cAAc;AACzB,qBAAiB,oBAAoB,SAAS;AAAA,EAChD,OAAO;AACL,qBAAiB,sBAAsB,SAAS;AAAA,EAClD;AAEA,QAAMa,SAAQ,aAAa,gBAAgB;AAAA,IACzC,aAAa,IAAG,eAAU,gBAAV,YAAyB;AAAA,IACzC,WAAW,mCAAS;AAAA,IACpB,YAAW,mCAAS,cAAa;AAAA,EACnC,CAAC;AAED,SAAOA;AACT;;;ATnGkB,gBAAAb,OAGV,QAAAK,aAHU;AAFX,IAAM,aAAa;AAAA,EACxBH,YAAW,CAAC,EAAE,OAAO,QAAQ,WAAW,YAAY,MAAM,GAAG,KAAK,GAAG,QAAQ;AAC3E,UAAM,QAAQ,gBAAAF,MAACG,QAAA,EAAM,MAAY,MAAa,GAAG,MAAM,KAAU;AACjE,QAAI,aAAa,YAAY;AAC3B,aACE,gBAAAE,MAACD,aAAA,EAAW,MACT;AAAA;AAAA,QACA;AAAA,QACA;AAAA,SACH;AAAA,IAEJ;AACA,WAAO;AAAA,EACT,CAAC;AACH;AAMO,IAAMU,oBAAmB;AAAA,EAC9B;AAAA,EACA;AAAA,IACE,cAAc;AAAA,EAChB;AACF;AAEO,IAAM,qBAAqB;AAAA,EAChCZ,YAAW,CAAC,OAAO,QAAQ,gBAAAF,MAAC,iBAAc,KAAW,GAAG,OAAO,CAAE;AACnE;AAEO,IAAM,gBAAgB,YAA2B,QAAQ;AAEzD,IAAM,cAAc;AAAA,EACzBE,YAAW,CAAC,EAAE,MAAM,OAAO,GAAG,KAAK,GAAG,QAAQ;AAC5C,WAAO,gBAAAF,MAAC,UAAO,WAAW,CAAC,CAAC,OAAQ,GAAG,MAAM,KAAU;AAAA,EACzD,CAAC;AAAA,EACD;AAAA,IACE,cAAc;AAAA,EAChB;AACF;AAEO,IAAM,cAAc;AAAA,EACzBE,YAAW,CAAC,OAAO,QAAQ;AACzB,WACE,gBAAAG,MAAC,UAAO,KAAW,GAAG,OACpB;AAAA,sBAAAL,MAAC,gBAAa;AAAA,MACd,gBAAAA,MAAC,cAAW;AAAA,OACd;AAAA,EAEJ,CAAC;AAAA,EACD;AAAA,IACE,cAAc;AAAA,EAChB;AACF;AAEO,IAAM,gBAAgB;AAAA,EAC3BE,YAAW,CAAC,EAAE,OAAO,MAAM,GAAG,MAAM,GAAG,QAAQ;AAC7C,WACE,gBAAAF,MAAC,YAAS,KAAW,GAAG,OACrB,iBACH;AAAA,EAEJ,CAAC;AAAA,EACD;AAAA,IACE,WAAW;AAAA,EACb;AACF;AAEO,IAAM,aAAa,YAA6B,YAAY;AAAA,EACjE,cAAc;AAChB,CAAC;AAEM,IAAM,oBAAoB,YAA+B,cAAc;AAAA,EAC5E,cAAc;AAChB,CAAC;AAQM,IAAM,WAAW;AAAA,EACtBE,YAAW,CAAC,OAAO,QAAQ;AACzB,UAAM,EAAE,YAAY,GAAG,SAAS,SAAS,GAAG,WAAW,IAAI;AAE3D,UAAM,SAA4B,CAAC;AACnC,aAAS,IAAI,GAAG,IAAI,WAAW,KAAK;AAClC,aAAO,KAAK,gBAAAF,MAAC,iBAAsB,OAAH,CAAa,CAAE;AAAA,IACjD;AAEA,WACE,gBAAAA,MAAC,UAAO,SACN,0BAAAA,MAAC,YAAU,GAAG,YAAY,MAAM,SAC7B,kBACH,GACF;AAAA,EAEJ,CAAC;AAAA,EACD;AAAA,IACE,cAAc;AAAA,EAChB;AACF;AAEO,IAAM,oBAAoB;AAAA,EAC/B,MAAM;AAAA,EACN,OAAO;AAAA,EACP,KAAK;AAAA,EACL,OAAO;AAAA,EACP,QAAQc;AAAA,EACR,UAAU;AAAA,EACV,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,OAAO;AAAA,EACP,KAAK;AAAA,EACL,iBAAiB;AACnB;;;ADrJI,gBAAAd,aAAA;AAVJ,IAAM,gBAAgBC,OAAM;AAAA,EAC1B;AACF;AAEO,IAAM,iBAGR,CAAC,UAAU;AACd,QAAM,SAAS,EAAE,GAAG,mBAAmB,GAAG,MAAM,MAAM;AACtD,SACE,gBAAAD,MAAC,cAAc,UAAd,EAAuB,OAAO,QAC5B,gBAAM,UACT;AAEJ;AAEO,IAAM,WAAW,CAAC,SAAgC;AACvD,QAAM,UAAUC,OAAM,WAAW,aAAa;AAC9C,UAAO,mCAAU,UAAS;AAC5B;;;ADkBW,gBAAAD,aAAA;AArBX,IAAM,mBAAmB;AAYlB,IAAM,QAAc;AAAA,EACzB,CACE,OACA,QACG;AACH,UAAM,EAAE,OAAO,kBAAkB,KAAK,IAAI;AAC1C,UAAM,YAAY,cAAc,IAAI;AACpC,UAAM,iBAAiB,UAAS,uCAAW,SAAQ,IAAI;AAEvD,WAAO,gBAAAA,MAAC,kBAAe,KAAW,GAAG,OAAQ,GAAG,WAAW;AAAA,EAC7D;AACF;;;Aa1CA,YAAYC,aAAW;;;ACAvB,YAAYA,YAAW;AAEvB;AAAA,EACE,UAAAc;AAAA,EAEA;AAAA,EAEA;AAAA,OACK;AACP,SAAS,MAAAC,WAAU;AASV,gBAAAhB,aAAA;AADT,IAAM,iBAAgD,CAAC,EAAE,SAAS,MAAM;AACtE,SAAO,gBAAAA,MAACe,QAAO,KAAP,EAAY,UAAS;AAC/B;AAEA,eAAe,cAAc;AAWtB,IAAM,aAAa,CAAC,EAAE,UAAU,GAAG,MAAM,MAAuB;AAhCvE;AAiCE,QAAM,QAAQ,SAAS;AAEvB,QAAM,gBAAe,uBAAM,eAAN,mBAAkB,kBAAlB,mBAAiC,iBAAjC,YAAiD;AAAA,IACpE,SAAS;AAAA,EACX;AAEA,QAAM,YAAY;AAAA,IAChB,GAAG;AAAA,IACH,GAAG;AAAA,EACL;AAEA,SACE,gBAAAf;AAAA,IAAC;AAAA;AAAA,MACE,GAAG;AAAA,MACJ,WAAWgB,IAAG,oBAAoB,MAAM,SAAS;AAAA,MAEhD,UAAM,gBAAS,IAAI,UAAU,CAAC,UAAU;AACvC,YAAU,sBAAe,KAAK,GAAG;AAC/B,iBAAO,gBAAAhB,MAAC,kBAAgB,iBAAM;AAAA,QAChC;AACA,eAAO;AAAA,MACT,CAAC;AAAA;AAAA,EACH;AAEJ;AAEA,WAAW,cAAc;;;AC3DzB,YAAYC,YAAW;AAEvB;AAAA,EACE,UAAAc;AAAA,EAEA,cAAAb;AAAA,EACA,UAAAI;AAAA,OAEK;AACP,SAAS,UAAU,iBAAiB;;;ACTpC,YAAYL,YAAW;AACvB;AAAA,EACE;AAAA,OAIK;AAIP,SAAS,iBAAAO,sBAAqB;AAqBvB,IAAM,CAAC,oBAAoB,oBAAoB,IACpDA,eAAmC;AAAA,EACjC,MAAM;AACR,CAAC;AAyBI,IAAM,CAAC,uBAAuB,uBAAuB,IAC1DA,eAAsC;AAAA,EACpC,MAAM;AACR,CAAC;AAuBI,IAAM,gBAAgB,CAAC;AAAA,EAC5B;AAAA,EACA,eAAe,CAAC;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AACF,MAAyB;AACvB,QAAM,EAAE,QAAQ,IAAI,eAAe;AACnC,QAAM,UAAU,cAAc;AAAA,IAC5B;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,SAAO;AAAA,IACL,GAAG;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAMO,IAAM,mBAAmB,CAAC,EAAE,MAAM,MAA6B;AACpE,QAAM,EAAE,YAAY,IAAI,eAAe;AACvC,QAAM,EAAE,MAAM,QAAQ,OAAO,IAAI,qBAAqB;AAEtD,EAAM,iBAAU,MAAM;AAEpB,gBAAY,IAAI;AAAA,EAClB,GAAG,CAAC,CAAC;AAEL,SAAO;AAAA,IACL;AAAA,IACA,SAAS,UAAU;AAAA,IACnB,QAAQ,UAAU,OAAO,SAAS;AAAA,IAClC,MAAM,GAAG,QAAQ;AAAA,IACjB,QAAc,mBAAY,MAAM;AAC9B,kBAAY,IAAI;AAChB,aAAO,KAAK;AAAA,IACd,GAAG,CAAC,KAAK,CAAC;AAAA,EACZ;AACF;AAEO,IAAM,4BAA4B,MAAM;AAC7C,QAAM,EAAE,SAAS,OAAO,IAAI,wBAAwB;AACpD,QAAM,EAAE,KAAK,OAAO,IAAI,qBAAqB;AAE7C,QAAM,aAAa,WAAW,CAAC,EAAE,OAAO,OAAO,UAAU;AAEzD,SAAO;AAAA,IACL,SAAS,MAAM,OAAO;AAAA,IACtB;AAAA,EACF;AACF;AAEO,IAAM,yBAAyB,MAAM;AAC1C,QAAM,EAAE,QAAQ,cAAc,KAAK,OAAO,IAAI,qBAAqB;AAEnE,QAAM,aAAa,CAAC,EAAE,OAAO,OAAO,UAAU;AAE9C,SAAO;AAAA,IACL,SAAS,MACP,OAAO,cAAc;AAAA,MACnB,aAAa;AAAA,IACf,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AD/HA,SAAS,kBAAkB;AAwCvB,SAqIM,UApIJ,OAAAR,OADF,QAAAK,aAAA;AANG,IAAM,gBAA8C,CAAC;AAAA,EAC1D;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,SACE,gBAAAA,MAAC,0BAAuB,OACtB;AAAA,oBAAAL,MAAC,uBAAqB,GAAG,gBAAiB,UAAS;AAAA,IACnD,gBAAAA,MAAC,0BAAuB;AAAA,KAC1B;AAEJ;AAEA,cAAc,cAAc;AAqBrB,IAAM,sBAA0D,CAAC;AAAA,EACtE;AAAA,EACA,GAAG;AACL,MAAM;AACJ,QAAM,EAAE,KAAK,IAAI,wBAAwB;AACzC,SACE,gBAAAA,MAAC,cAAW,MAAK,KAAI,IAAG,KAAK,GAAG,aAC7B,0BAAgB,MAAM,QAAQ,GACjC;AAEJ;AAEA,oBAAoB,cAAc;AAO3B,IAAM,yBAAuD,CAAC;AAAA,EACnE;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,QAAM,UAAU,iBAAiB,EAAE,MAAM,CAAC;AAE1C,QAAM,SAAS;AAAA,IACb,SAAS;AAAA,IACT,eAAe;AAAA,IACf,YAAY;AAAA,IACZ,OAAO;AAAA,IACP,IAAI;AAAA,EACN;AAEA,SACE,gBAAAA,MAAC,yBAAsB,OAAO,SAC5B,0BAAAA,MAACe,QAAO,KAAP,EAAY,GAAG,MAAM,OAAO,QAC1B,UACH,GACF;AAEJ;AAEA,uBAAuB,cAAc;AAO9B,IAAM,yBAA0D,CACrE,UACG;AACH,SACE,gBAAAf,MAACM,SAAA,EAAO,cAAW,cAAc,GAAG,0BAA0B,GAAI,GAAG,OAClE,gBAAM,YAAY,gBAAAN,MAAC,aAAU,GAChC;AAEJ;AAEA,uBAAuB,cAAc;AAO9B,IAAM,sBAAuD,CAAC,UAAU;AAC7E,SACE,gBAAAA;AAAA,IAACM;AAAA,IAAA;AAAA,MACC,cAAW;AAAA,MACX,OAAM;AAAA,MACL,GAAG,uBAAuB;AAAA,MAC1B,GAAG;AAAA,MAEH,gBAAM,YAAY,gBAAAN,MAAC,YAAS;AAAA;AAAA,EAC/B;AAEJ;AAEA,oBAAoB,cAAc;AAkB3B,IAAM,aAAaE;AAAA,EACxB,CAAC,OAAwB,QAAiD;AACxE,UAAM,EAAE,UAAU,GAAG,eAAe,IAAI;AAExC,UAAM,QAAQ,WAAW,QAAQ,IAC7B,WACA,CAAC,WACC,gBAAAF,MAAA,YACG,iBAAO,IAAI,CAAC,EAAE,GAAG,GAAG,UACnB,gBAAAA,MAAC,iBAAuB,OACrB,YADiB,EAEpB,CACD,KAAK,MACR;AAGN,WACE,gBAAAK,MAAC,uBAAoB,KAAW,GAAG,gBACjC;AAAA,sBAAAL,MAAC,kBAAgB,iBAAa;AAAA,MAC9B,gBAAAA,MAAC,uBAAoB;AAAA,OACvB;AAAA,EAEJ;AACF;AAQA,WAAW,cAAc;AAMlB,IAAM,iBAAiB,CAAC;AAAA,EAC7B;AACF,MAAsD;AACpD,QAAM,EAAE,OAAO,IAAI,qBAAqB;AACxC,SAAO,SAAS,MAAM;AACxB;AAEA,eAAe,cAAc;AAYtB,IAAM,sBAA4B;AAAA,EACvC,CACE;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EACL,GACA,QACG;AACH,UAAM,YAAY,cAAc,IAAI;AAEpC,UAAM,UAAU,cAAc;AAAA,MAC5B;AAAA,MACA;AAAA,MACA;AAAA,MACA,KAAK,QAAQ,uCAAmB;AAAA,MAChC,KAAK,QAAQ,uCAAmB;AAAA,IAClC,CAAC;AAGD,IAAM,2BAAoB,KAAK,MAAM,SAAS,CAAC,KAAK,OAAO,CAAC;AAE5D,WACE,gBAAAA,MAAC,sBAAmB,OAAO,SACzB,0BAAAA,MAAC,aAAU,MAAa,GAAG,YAAa,GAAG,WACxC,UACH,GACF;AAAA,EAEJ;AACF;AAEA,oBAAoB,cAAc;;;AE/RlC;AAAA,EACE,eAAAU;AAAA,EACA,aAAAC;AAAA,EAGA;AAAA,OACK;AAqBE,gBAAAX,OAuBL,QAAAK,aAvBK;AAFF,IAAM,aAAa,CAAC,UAA0B;AACnD,QAAM,SAAS,eAAe,eAAe;AAC7C,SAAO,gBAAAL,MAACW,YAAA,EAAU,IAAG,UAAS,IAAI,QAAS,GAAG,OAAO;AACvD;AAMO,IAAM,cAA0C,CAAC,UAAU;AAChE,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA,WAAW;AAAA,IACX;AAAA,IACA,SAAS;AAAA,IACT,SAAS;AAAA,IACT,GAAG;AAAA,EACL,IAAI;AAEJ,QAAM,EAAE,WAAW,SAAS,SAAS,GAAG,UAAU,IAAI;AAAA,IACpD;AAAA,EACF;AAEA,SACE,gBAAAN,MAACK,cAAA,EAAY,MAAY,IAAG,YAAY,GAAG,YAAa,GAAG,WACzD;AAAA,oBAAAV,MAAC,cAAW,SAAS,iBAAiB,YAAY,SAAS,SACxD,iBACH;AAAA,IACA,gBAAAA;AAAA,MAAC;AAAA;AAAA,QACC,SAAS,eAAe;AAAA,QACxB,SAAS,eAAe;AAAA,QAEvB,0BAAgB,MAAM,QAAQ;AAAA;AAAA,IACjC;AAAA,KACF;AAEJ;AAEA,YAAY,cAAc;;;AJxClB,gBAAAA,aAAA;AARR,IAAMiB,mBAAkB,CAAC,UAAyB,SAAiB;AAjBnE;AAkBE,UAAO,cACJ,gBAAgB,IAAI,MADhB,mBAEH;AAAA,IACA,CACE,EAAE,MAAAC,OAAM,MAAM,GAAG,iBAAiB,GAClC,MAEA,gBAAAlB;AAAA,MAAC;AAAA;AAAA,QAEC,MAAMkB;AAAA,QACN;AAAA,QACC,GAAG;AAAA;AAAA,MAHCA,SAAQ;AAAA,IAIf;AAAA;AAGR;AAEO,IAAM,aAAoC,CAAC;AAAA,EAChD,QAAQ;AAAA,EACR,eAAe;AAAA,EACf;AAAA,EACA,GAAG;AACL,MAAM;AACJ,QAAM,UAAU,eAAe;AAC/B,QAAM,SAAS,cAAc,QAAQ;AACrC,QAAM,gBAAgB,qBAAqB,QAAQ;AACnD,QAAM,WAAiB,gBAAQ,MAAM,eAAe,CAAC,QAAQ,aAAa,CAAC;AAE3E,QAAM,SAAe,gBAAQ,MAAM,qCAAU,aAAa,CAAC,QAAQ,CAAC;AAEpE,QAAM,OAAO,eAAe;AAE5B,EAAM,kBAAU,MAAM;AAlDxB;AAmDI,QAAI,qBAAmB,sCAAS,OAAT,mBAAa,OAAM;AACxC,WAAK,SAAS,OAAO,CAAC,EAAE,IAAI;AAAA,IAC9B;AAAA,EACF,GAAG,CAAC,QAAQ,eAAe,eAAe,CAAC;AAE3C,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SACE,gBAAAlB,MAAC,cAAY,GAAG,OACb,2CAAQ;AAAA,IACP,CAAC;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL,MAAuC;AACrC,UAAI,SAAS,SAAS;AACpB,eACE,gBAAAA,MAAC,cAAsB,MAAa,GAAG,YACpC,UAAAiB,iBAAgB,UAAU,IAAI,KADhB,IAEjB;AAAA,MAEJ,WAAW,SAAS,UAAU;AAC5B,eACE,gBAAAjB,MAAC,eAAuB,MAAa,GAAG,YACrC,UAAAiB,iBAAgB,UAAU,IAAI,KADf,IAElB;AAAA,MAEJ;AAEA,aACE,gBAAAjB,MAAC,SAAiB,MAAY,MAAoB,GAAG,cAAzC,IAAqD;AAAA,IAErE;AAAA,KAEJ;AAEJ;AAEA,WAAW,cAAc;;;AK1FzB,SAAS,kBAAAmB,uBAAsB;AAE/B,SAAS,UAAAb,SAAqB,cAAAJ,oBAAkB;AAyC1C,gBAAAF,aAAA;AAlBC,IAAM,eAAeE;AAAA,EAC1B,CAAC,OAAO,QAAQ;AACd,UAAM;AAAA,MACJ,WAAW;AAAA,MACX;AAAA,MACA;AAAA,MACA,YAAY;AAAA,MACZ;AAAA,MACA,GAAG;AAAA,IACL,IAAI;AACJ,UAAM,EAAE,UAAU,IAAIiB,gBAAe;AAErC,UAAM,aACH,sBAAsB,CAAC,UAAU,WACjC,oBAAoB,CAAC,UAAU,WAChC;AAEF,WACE,gBAAAnB;AAAA,MAACM;AAAA,MAAA;AAAA,QACE,GAAG;AAAA,QACJ;AAAA,QACA,MAAK;AAAA,QACL,WAAW,UAAU,gBAAgB;AAAA,QACrC;AAAA,QAEC;AAAA;AAAA,IACH;AAAA,EAEJ;AACF;AAEA,aAAa,eAAe;AAAA,EAC1B,SAAS;AAAA,EACT,oBAAoB;AAAA,EACpB,kBAAkB;AACpB;AAEA,aAAa,cAAc;;;AC/D3B;AAAA,EACE;AAAA,OAIK;AAoBA,IAAM,YAAY,CAGvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY,CAAC,UAAU,CAAC,CAAC;AAC3B,MAA2C;AACzC,QAAM,QAAQ,SAAuB;AAAA,IACnC;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,CAAC;AACD,QAAM,UAAU,eAAe;AAC/B,SAAO,UAAU,OAAO,OAAO,IAAI,WAAW;AAChD;AAEA,UAAU,cAAc;;;AC/CxB,YAAYL,aAAW;AAIvB;AAAA,EACE,UAAAc;AAAA,EACA,UAAAT;AAAA,OAIK;AAEP,SAAS,mBAAAc,kBAAiB,MAAAJ,WAAU;AAEpC;AAAA,EACE;AAAA,EACA;AAAA,EAGA;AAAA,OACK;;;ACpBP,YAAYf,aAAW;AAEvB,SAAS,iBAAAO,sBAAqB;AAC9B;AAAA,EACE;AAAA,EACA;AAAA,OAGK;AAoBA,IAAM,CAAC,kBAAkB,kBAAkB,IAChDA,eAA+B;AAAA,EAC7B,MAAM;AAAA,EACN,cACE;AACJ,CAAC;AAmDI,SAAS,YAKd,OACiC;AACjC,QAAM,EAAE,UAAU,OAAO,cAAc,UAAU,GAAG,KAAK,IAAI;AAC7D,QAAM,UAAU,WAAW,IAAI;AAE/B,QAAM,CAAC,SAAS,UAAU,IAAU,iBAA6B,YAAY;AAE7E,QAAM,EAAE,YAAY,YAAY,SAAS,IAAI;AAE7C,QAAM,CAAC,OAAO,WAAW,IAAU,iBAAoC,CAAC,CAAC;AAEzE,QAAM,eAAkD;AAAA,IACtD,OAAO,SAAS;AArGpB;AAsGM,UAAI;AACF,cAAM,OAAO,MAAM,UAAU;AAE7B,YAAI,YAAY;AACd,kBAAM,WAAM,aAAN,+BAAiB;AAEvB,qBAAW;AAAA,YACT,GAAG;AAAA,YACH,aAAa;AAAA,UACf,CAAC;AAED,mBAAS;AACT;AAAA,QACF;AAEA,gBAAM,UAAK,aAAL,8BAAgB,MAAM;AAE5B,iBAAS;AAAA,MACX,SAAS,GAAP;AAAA,MAEF;AAAA,IACF;AAAA,IACA,CAAC,OAAO,YAAY,UAAU;AAAA,EAChC;AAEA,QAAM,eAAqB,oBAAY,MAAM;AAC3C,UAAM,OAAO,MAAM,UAAU;AAE7B,WAAO;AAAA,MACL,UAAU;AAAA,MACV,QAAQ,6BAAM;AAAA,MACd,WAAU,6BAAM;AAAA;AAAA,QACmB,qCAAmB,KAAK;AAAA,UACvD;AAAA,IACN;AAAA,EACF,GAAG,CAAC,OAAO,cAAc,UAAU,CAAC;AAEpC,QAAM,aAAmB;AAAA,IACvB,CAAC,SAAoB;AACnB,YAAM,cAAc,mCAAS,KAAK,CAAC,MAAM,EAAE,SAAS,KAAK;AACzD,kBAAY,CAACa,WAAU;AACrB,eAAO;AAAA,UACL,GAAGA;AAAA,UACH,CAAC,KAAK,IAAI,GAAG;AAAA,YACX,GAAG;AAAA,YACH,QAAQ,2CAAa;AAAA,UACvB;AAAA,QACF;AAAA,MACF,CAAC;AAAA,IACH;AAAA,IACA,CAAC,OAAO,OAAO;AAAA,EACjB;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EACL;AACF;AASO,SAAS,YAAY,OAAoC;AAC9D,QAAM,EAAE,MAAM,QAAQ,UAAU,SAAS,IAAI;AAC7C,QAAM,OAAO,QAAQ,EAAE,KAAK,CAAC;AAE7B,QAAM,EAAE,OAAO,WAAW,IAAI,mBAAmB;AAEjD,EAAM,kBAAU,MAAM;AACpB,eAAW,EAAE,MAAM,QAAQ,UAAU,SAAS,CAAC;AAAA,EACjD,GAAG,CAAC,MAAM,MAAM,CAAC;AAEjB,SAAO;AAAA,IACL,GAAG;AAAA,IACH,GAAI,MAAM,IAAI,KAAK,EAAE,MAAM,OAAO;AAAA,EACpC;AACF;;;AD5FQ,gBAAArB,aAAA;AArBD,IAAM,cAA0C,CAAC,UAAU;AAChE,QAAM,EAAE,aAAa,SAAS,IAAI,kBAAkB;AAEpD,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA,GAAG;AAAA,EACL,IAAI;AAEJ,QAAM,WAAiB,iBAAS,IAAI,UAAU,CAAC,UAAU;AACvD,QACQ,uBAA8B,KAAK,MACzC,+BAAO,UAAS,UAChB;AACA,YAAM,EAAE,YAAY,IAAI,YAAY,MAAM,KAAK;AAC/C,aACE,gBAAAA;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA,MAAM,MAAM,MAAM;AAAA,UAClB,OAAO,MAAM,MAAM;AAAA,UACnB;AAAA,UACC,GAAG;AAAA,UAEH,gBAAM,MAAM;AAAA;AAAA,MACf;AAAA,IAEJ;AACA,WAAO;AAAA,EACT,CAAC;AAED,QAAM,WAAiB,oBAAY,CAAC,MAAc;AAChD,aAAS,CAAC;AACV,iDAAe;AAAA,EACjB,GAAG,CAAC,CAAC;AAEL,SACE,gBAAAA;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA,MAAM;AAAA,MACN;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MAEC;AAAA;AAAA,EACH;AAEJ;AAYO,IAAM,WAAW,CACtB,UACG;AACH,QAAM,EAAE,MAAM,UAAU,WAAW,UAAU,GAAG,KAAK,IAAI;AACzD,QAAM,OAAO,YAAY,EAAE,MAAM,SAAS,CAAC;AAE3C,QAAM,EAAE,SAAS,IAAI;AAErB,SAAO,WACL,gBAAAA,MAACe,QAAO,KAAP,EAAY,GAAG,MAAM,WAAWC,IAAG,kBAAkB,SAAS,GAC5D,UACH,IACE;AACN;AAEA,SAAS,cAAc;AAOhB,IAAM,aAAoC,CAAC,UAAU;AAC1D,QAAM,EAAE,aAAa,aAAa,SAAS,IAAI,kBAAkB;AAEjE,SACE,gBAAAhB;AAAA,IAACM;AAAA,IAAA;AAAA,MACC,YAAY,eAAe;AAAA,MAC3B,UAAS;AAAA,MACR,GAAG;AAAA,MACJ,WAAWU,IAAG,yBAAyB,MAAM,SAAS;AAAA,MACtD,SAASI,iBAAgB,MAAM,SAAS,QAAQ;AAAA;AAAA,EAClD;AAEJ;AAEA,WAAW,cAAc;AAYlB,IAAM,aAAwC,CAAC,UAAU;AAC9D,QAAM,EAAE,QAAQ,QAAQ,cAAc,YAAY,GAAG,KAAK,IAAI;AAC9D,QAAM,EAAE,YAAY,YAAY,IAAI,kBAAkB;AAEtD,SACE,gBAAApB;AAAA,IAAC;AAAA;AAAA,MACE,GAAG;AAAA,MACJ,YAAY;AAAA,MACZ,WAAWgB,IAAG,yBAAyB,MAAM,SAAS;AAAA,MAErD,wBAAc,cAAc,cAAc;AAAA;AAAA,EAC7C;AAEJ;AAEA,WAAW,cAAc;;;AEpMzB,SAAS,OAAAM,YAAW;AAgBpB,IAAM,YAAY,CAAC,WACjB,UACA,OAAO,QAAQ,MAAM,EAAE,IAAI,CAAC,CAAC,MAAM,EAAE,OAAO,OAAO,OAAO,GAAG,MAAM,CAAC,MAAM;AACxE,SAAO;AAAA,IACL,GAAG;AAAA,IACH;AAAA,IACA,OAAO,SAAS,SAAS;AAAA;AAAA,EAC3B;AACF,CAAC;AAEI,IAAM,sBAAsD,CAAC,WAAW;AAC7E,QAAM,YAAY,MAAwB;AACxC,WAAO,UAAU,MAAM;AAAA,EACzB;AACA,QAAM,kBAAkB,CAAC,SAAmC;AAhC9D;AAiCI,UAAM,QAAQA,KAAI,QAAQ,IAAI;AAE9B,QAAI,CAAC;AAAO,aAAO,CAAC;AAEpB,UAAI,WAAM,UAAN,mBAAa,UAAS,UAAU;AAClC,aAAO,UAAU,MAAM,MAAM,UAAU;AAAA,IACzC,WAAW,MAAM,SAAS,UAAU;AAClC,aAAO,UAAU,MAAM,UAAU;AAAA,IACnC;AACA,WAAO,CAAC,MAAM,KAAK;AAAA,EACrB;AAEA,SAAO,EAAE,WAAW,gBAAgB;AACtC;;;AC9CA,SAAsB,YAAAC,iBAAgB;AAiB/B,IAAM,aAAa,CAIxB,UACG;AACH,QAAM,EAAE,MAAM,cAAc,YAAY,QAAQ,IAAI;AACpD,QAAM,OAAO,eAA6B;AAE1C,QAAM,QAAQA,UAAS;AAAA,IACrB;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV,OAAO;AAAA,EACT,CAAC;AAED,SAAO,MAAM,SAAS,OAAO,IAAI,KAAK;AACxC;;;AClCA,YAAYtB,aAAW;AAEvB,SAAS,UAAAc,SAAyB,cAAAb,oBAAkB;AACpD,SAA2B,MAAAc,KAAI,eAAe;AAE9C;AAAA,EACE;AAAA,OASK;AA4JC,SACE,OAAAhB,OADF,QAAAK,aAAA;AAlED,IAAM,OAAOH;AAAA,EAClB,CAME,OACA,QACG;AACH,UAAM;AAAA,MACJ,OAAO;AAAA,MACP;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL,IAAI;AAEJ,UAAM,OAAO;AAAA,MACX;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAEA,UAAM,UAAU,QAAgC,IAAI;AACpD,UAAM,EAAE,aAAa,IAAI;AAGzB,IAAM,4BAAoB,SAAS,MAAM,SAAS,CAAC,SAAS,OAAO,CAAC;AAEpE,IAAM,kBAAU,MAAM;AACpB,UAAI;AACJ,UAAI,UAAU;AACZ,uBAAe,QAAQ,MAAM,QAAQ;AAAA,MACvC;AACA,aAAO,MAAM,6CAAc;AAAA,IAC7B,GAAG,CAAC,SAAS,QAAQ,CAAC;AAEtB,QAAI,YAAY;AAChB,QAAI,CAAC,aAAa,eAAe;AAC/B,kBACE,gBAAAG,MAAC,cACC;AAAA,wBAAAL,MAAC,cAAW;AAAA,QACZ,gBAAAA,MAAC,gBAAc,GAAG,iCAAQ,QAAQ;AAAA,SACpC;AAAA,IAEJ;AAEA,WACE,gBAAAA;AAAA,MAAC;AAAA;AAAA,QACE,GAAG;AAAA,QACJ;AAAA,QACA;AAAA,QACA;AAAA,QAEA,0BAAAA;AAAA,UAACe,QAAO;AAAA,UAAP;AAAA,YACC;AAAA,YACA,UAAU,aAAa,UAAU,OAAO;AAAA,YACvC,GAAG;AAAA,YACJ,WAAWC,IAAG,YAAY,MAAM,SAAS;AAAA,YAExC,kBAAQ,WAAW;AAAA,cAClB;AAAA,cACA;AAAA,cACA;AAAA,cACA;AAAA,cACA,GAAG;AAAA,YACL,CAAC;AAAA;AAAA,QACH;AAAA;AAAA,IACF;AAAA,EAEJ;AACF;AAeA,KAAK,cAAc;;;ACnNnB,SAAS,cAAAd,oBAAkB;AA8CjB,gBAAAF,aAAA;AAjBH,SAAS,WAAsB;AAAA,EACpC;AAAA,EACA,gBAAgB;AAAA,EAChB;AACF,IAAgC,CAAC,GAAG;AAClC,QAAM,cAAcE;AAAA,IAClB,CAKE,OACA,QACG;AACH,YAAM,EAAE,QAAQ,GAAG,KAAK,IAAI;AAC5B,aACE,gBAAAF,MAAC,kBAAe,OAAO,UAAU,CAAC,GAChC,0BAAAA;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA,UAAU,qCAAW,MAAM;AAAA,UAC3B,eAAe,+CAAgB;AAAA,UAC9B,GAAG;AAAA;AAAA,MACN,GACF;AAAA,IAEJ;AAAA,EACF;AAEA,cAAY,cAAc;AAC1B,cAAY,KAAK;AAEjB,SAAO;AACT;;;ACnEA,SAAgB,WAAAwB,gBAAe;AAC/B,SAAS,cAAAtB,oBAAkB;AAkB3B,SAAS,uBAAuB;AAChC,SAAS,WAAAuB,gBAAe;AAsDZ,gBAAAzB,aAAA;AAtBL,SAAS,eAId,EAAE,QAAQ,UAAU,cAAc,IAAoC,CAAC,GAAG;AAC1E,QAAM0B,YAAWxB,aAAuB,CAAC,OAAO,QAAQ;AACtD,UAAM,EAAE,UAAU,OAAO,GAAG,KAAK,IAAI;AAErC,UAAM,UAAU,YAAY;AAAA,MAC1B;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL,CAAC;AAED,UAAM,EAAE,cAAc,GAAG,IAAI,IAAI;AAEjC,UAAM,UAAUsB,SAAQ,MAAM,KAAK,CAAC,GAAG,CAAC;AAExC,WACE,gBAAAxB,MAAC,mBAAgB,OAAO,SACtB,0BAAAA,MAAC,oBAAiB,OAAO,SACvB,0BAAAA,MAAC,kBAAe,OAAO,UAAU,CAAC,GAChC,0BAAAA,MAAC,QAAK,KAAW,GAAG,MAAO,GAAG,aAAa,GACxC,UAAAyB,SAAQ,UAAU;AAAA,MACjB,GAAG;AAAA,MACH;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF,CAAC,GACH,GACF,GACF,GACF;AAAA,EAEJ,CAAC;AAED,EAAAC,UAAS,cAAc,OAAO,KAAK,eAAe,KAAK;AAEvD,SAAOA;AACT;;;ACgFA;AAAA,EACE;AAAA,EACA;AAAA,EACA,iBAAAC;AAAA,EACA,WAAAC;AAAA,EACA;AAAA,EACA,YAAAL;AAAA,EACA,cAAAM;AAAA,OACK;AArHA,IAAMC,QAAO,WAAW;AASxB,IAAM,WAAW,eAAe","sourcesContent":["import * as React from 'react'\nimport {\n FormProvider as HookFormProvider,\n FormProviderProps as HookFormProviderProps,\n useFormContext as useHookFormContext,\n FieldValues,\n} from 'react-hook-form'\nimport { FieldResolver } from './field-resolver'\nimport { BaseFieldProps, FieldProps } from './types'\n\nexport type FormContextValue<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nexport type FormProviderProps<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = HookFormProviderProps<TFieldValues, TContext> & {\n fieldResolver?: FieldResolver\n schema?: TSchema\n fields?: {\n [key: string]: unknown\n }\n}\n\nconst FormContext = React.createContext<FormContextValue | null>(null)\n\nexport const useFormContext = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>() => {\n const context = React.useContext(FormContext)\n const hookContext = useHookFormContext()\n\n if (!context) {\n throw new Error('FormProvider must be used within a Form component')\n }\n\n return {\n ...hookContext,\n ...context,\n }\n}\n\nexport const useFieldProps = <TFieldValues extends FieldValues = FieldValues>(\n name: string\n): BaseFieldProps<TFieldValues> | undefined => {\n const parsedName = name?.replace(/\\.[0-9]/g, '.$')\n const context = useFormContext()\n return (context?.fields?.[parsedName] as any) || {}\n}\n\nexport type UseFormReturn<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n> = ReturnType<typeof useFormContext>\n\nexport const FormProvider = <\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n TSchema = any\n>(\n props: FormProviderProps<TFieldValues, TContext, TSchema>\n) => {\n const { children, fieldResolver, schema, fields, ...rest } = props\n return (\n <HookFormProvider {...rest}>\n <FormContext.Provider value={{ fieldResolver, schema, fields }}>\n {children}\n </FormContext.Provider>\n </HookFormProvider>\n )\n}\n","import * as React from 'react'\nimport { useFormContext } from './form-context'\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './types'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n/**\n *\n *\n * @see Docs https://saas-ui.dev/\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\nDisplayField.displayName = 'DisplayField'\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nFormValue.displayName = 'FormValue'\n","import * as React from 'react'\nimport { RegisterOptions, FieldValues } from 'react-hook-form'\n\nimport { FocusableElement } from '@chakra-ui/utils'\nimport { useField } from './fields-context'\nimport { FieldProps } from './types'\nimport { useFieldProps } from './form-context'\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\nconst defaultInputType = 'text'\n\n/**\n * Form field component.\n * \n * Build-in types:\n * text, number, password, textarea, select, native-select, checkbox, radio, switch, pin\n *\n * Will default to a text field if there is no matching type.\n\n * @see Docs https://saas-ui.dev/docs/components/forms/field\n */\nexport const Field = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues>,\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType, name } = props\n const overrides = useFieldProps(name)\n const InputComponent = useField(overrides?.type || type)\n\n return <InputComponent ref={ref} {...props} {...overrides} />\n }\n) as (<TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n","import React from 'react'\nimport { defaultFieldTypes, InputField } from './default-fields'\n\nconst FieldsContext = React.createContext<Record<string, React.FC<any>> | null>(\n null\n)\n\nexport const FieldsProvider: React.FC<{\n value: Record<string, React.FC<any>>\n children: React.ReactNode\n}> = (props) => {\n const fields = { ...defaultFieldTypes, ...props.value }\n return (\n <FieldsContext.Provider value={fields}>\n {props.children}\n </FieldsContext.Provider>\n )\n}\n\nexport const useField = (type: string): React.FC<any> => {\n const context = React.useContext(FieldsContext)\n return context?.[type] || InputField\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Input,\n Textarea,\n Checkbox,\n Switch,\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'\n\nimport { NumberInput, NumberInputProps } from './number-input'\nimport { PasswordInput, PasswordInputProps } from './password-input'\nimport { RadioInput, RadioInputProps } from './radio'\n\nimport {\n Select,\n SelectButton,\n SelectList,\n SelectProps,\n NativeSelect,\n NativeSelectProps,\n} from './select'\n\nimport { createField } from './create-field'\nimport { ObjectField } from './object-field'\nimport { ArrayField } from './array-field'\n\nexport interface InputFieldProps extends InputProps {\n type?: string\n leftAddon?: React.ReactNode\n rightAddon?: React.ReactNode\n}\n\nexport const InputField = createField<InputFieldProps>(\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 = createField<NumberInputFieldProps>(\n NumberInput,\n {\n isControlled: true,\n }\n)\n\nexport const PasswordInputField = createField<PasswordInputProps>(\n forwardRef((props, ref) => <PasswordInput ref={ref} {...props} />)\n)\n\nexport const TextareaField = createField<TextareaProps>(Textarea)\n\nexport const SwitchField = createField<SwitchProps>(\n forwardRef(({ type, value, ...rest }, ref) => {\n return <Switch isChecked={!!value} {...rest} ref={ref} />\n }),\n {\n isControlled: true,\n }\n)\n\nexport const SelectField = createField<SelectProps>(\n forwardRef((props, ref) => {\n return (\n <Select ref={ref} {...props}>\n <SelectButton />\n <SelectList />\n </Select>\n )\n }),\n {\n isControlled: true,\n }\n)\n\nexport const CheckboxField = createField<CheckboxProps>(\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 = createField<RadioInputProps>(RadioInput, {\n isControlled: true,\n})\n\nexport const NativeSelectField = createField<NativeSelectProps>(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 = createField<PinFieldProps>(\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\nexport const defaultFieldTypes = {\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 select: SelectField,\n checkbox: CheckboxField,\n radio: RadioField,\n pin: PinField,\n 'native-select': NativeSelectField,\n}\n\nexport type DefaultFields = typeof defaultFieldTypes\n","import * as React from 'react'\n\nimport {\n forwardRef,\n NumberInput as ChakraNumberInput,\n NumberInputField,\n NumberInputStepper,\n NumberIncrementStepper,\n NumberDecrementStepper,\n NumberInputProps as ChakraNumberInputProps,\n} from '@chakra-ui/react'\n\nimport { ChevronDownIcon, ChevronUpIcon } from '@saas-ui/core'\n\ninterface NumberInputOptions {\n /**\n * Hide the stepper.\n */\n hideStepper?: boolean\n /**\n * Render a custom increment icon.\n */\n incrementIcon?: React.ReactNode\n /**\n * Render a custom decrement icon.\n */\n decrementIcon?: React.ReactNode\n}\n\nexport interface NumberInputProps\n extends ChakraNumberInputProps,\n NumberInputOptions {}\n\nexport const NumberInput = forwardRef<NumberInputProps, 'div'>((props, ref) => {\n const {\n hideStepper,\n incrementIcon = <ChevronUpIcon />,\n decrementIcon = <ChevronDownIcon />,\n ...rest\n } = props\n\n return (\n <ChakraNumberInput {...rest} ref={ref}>\n <NumberInputField />\n\n {!hideStepper && (\n <NumberInputStepper>\n <NumberIncrementStepper children={incrementIcon} />\n <NumberDecrementStepper children={decrementIcon} />\n </NumberInputStepper>\n )}\n </ChakraNumberInput>\n )\n})\n\nNumberInput.defaultProps = {\n hideStepper: false,\n}\n\nNumberInput.displayName = 'NumberInput'\n","import React, { useState } from 'react'\n\nimport { forwardRef, InputGroup, Input, InputProps } from '@chakra-ui/react'\n\nimport { ViewIcon, ViewOffIcon } from '@saas-ui/core/icons'\n\nimport { InputRightButton } from '../input-right-button'\n\ninterface PasswordOptions {\n viewIcon?: React.ReactNode\n viewOffIcon?: React.ReactNode\n leftAddon?: React.ReactNode\n}\n\nexport interface PasswordInputProps extends InputProps, PasswordOptions {}\n\nexport const PasswordInput = forwardRef<PasswordInputProps, 'div'>(\n (props, ref) => {\n const {\n viewIcon,\n viewOffIcon,\n autoComplete,\n w,\n width,\n size,\n variant,\n leftAddon,\n ...inputProps\n } = props\n const [show, setShow] = useState(false)\n const handleClick = () => setShow(!show)\n\n const label = show ? 'Hide password' : 'Show password'\n\n let icon\n if (show) {\n icon = viewIcon || <ViewIcon />\n } else {\n icon = viewOffIcon || <ViewOffIcon />\n }\n\n const groupProps = {\n width: w || width,\n size,\n variant,\n }\n\n return (\n <InputGroup {...groupProps}>\n {leftAddon}\n <Input\n {...inputProps}\n ref={ref}\n type={show ? 'text' : 'password'}\n autoComplete={show ? 'off' : autoComplete}\n />\n <InputRightButton\n onClick={handleClick}\n aria-label={label}\n variant=\"ghost\"\n >\n {icon}\n </InputRightButton>\n </InputGroup>\n )\n }\n)\n\nPasswordInput.displayName = 'PasswordInput'\n","import * as React from 'react'\n\nimport {\n Button,\n ButtonProps,\n forwardRef,\n InputRightElement,\n} from '@chakra-ui/react'\n\nexport type InputRightButtonProps = ButtonProps\n\nexport const InputRightButton = forwardRef<InputRightButtonProps, 'div'>(\n (props, ref) => {\n return (\n <InputRightElement w=\"auto\" px=\"1\" py=\"1\" alignItems=\"stretch\">\n <Button ref={ref} height=\"auto\" {...props} />\n </InputRightElement>\n )\n }\n)\n\nInputRightButton.id = 'InputRightElement'\n\nInputRightButton.displayName = 'InputRightButton'\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Stack,\n RadioGroup,\n RadioGroupProps,\n Radio,\n RadioProps,\n SystemProps,\n StackDirection,\n} from '@chakra-ui/react'\nimport { FieldOptions, FieldOption } from '../types'\nimport { mapOptions } from '../utils'\n\nexport interface RadioOption\n extends Omit<RadioProps, 'value' | 'label'>,\n FieldOption {}\n\nexport type RadioOptions = FieldOptions<RadioOption>\n\ninterface RadioInputOptions {\n options: RadioOptions\n spacing?: SystemProps['margin']\n direction?: StackDirection\n}\n\nexport interface RadioInputProps\n extends Omit<RadioGroupProps, 'children'>,\n RadioInputOptions {}\n\nexport const RadioInput = forwardRef<RadioInputProps, 'div'>(\n ({ options: optionsProp, spacing, direction, ...props }, ref) => {\n const { onBlur, onChange, ...groupProps } = props\n\n const options = mapOptions(optionsProp)\n\n return (\n <RadioGroup onChange={onChange} {...groupProps}>\n <Stack spacing={spacing} direction={direction}>\n {options.map(({ value, label, ...radioProps }, i) => {\n return (\n <Radio\n key={i}\n onBlur={onBlur}\n value={value}\n ref={ref}\n {...radioProps}\n >\n {label || value}\n </Radio>\n )\n })}\n </Stack>\n </RadioGroup>\n )\n }\n)\n\nRadioInput.displayName = 'RadioInput'\n","import * as React from 'react'\nimport { FieldOption, FieldOptions } from './types'\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 let childName = child.props.name\n if (childName.includes('.')) {\n childName = childName.replace(/^.*\\.(.*)/, '$1')\n } else if (childName.includes('.$')) {\n childName = childName.replace(/^.*\\.\\$(.*)/, '$1')\n }\n\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${childName}`,\n })\n }\n return child\n })\n}\n\nexport const mapOptions = <TOption extends FieldOption = FieldOption>(\n options: FieldOptions<TOption>\n) => {\n return options.map((option) => {\n if (typeof option === 'string') {\n return {\n label: option,\n value: option,\n }\n }\n return option\n })\n}\n","import * as React from 'react'\n\nimport {\n chakra,\n forwardRef,\n Menu,\n MenuProps,\n MenuList,\n MenuListProps,\n MenuItemOption,\n MenuOptionGroup,\n Button,\n ButtonProps,\n omitThemingProps,\n useMultiStyleConfig,\n MenuItemOptionProps,\n useFormControlContext,\n ThemingProps,\n useMenuButton,\n} from '@chakra-ui/react'\nimport { cx, dataAttr } from '@chakra-ui/utils'\nimport { ChevronDownIcon } from '@saas-ui/core'\n\nimport { FieldOption } from '../types'\n\nimport {\n SelectOptions,\n SelectProvider,\n SelectStylesProvider,\n useSelect,\n useSelectContext,\n useSelectStyles,\n} from './select-context'\n\nexport interface SelectOption\n extends Omit<MenuItemOptionProps, 'value'>,\n FieldOption {}\n\nexport interface SelectProps\n extends Omit<MenuProps, 'children' | 'variant' | 'size'>,\n ThemingProps<'SuiSelect'>,\n SelectOptions {}\n\nexport interface SelectButtonProps\n extends Omit<ButtonProps, 'size' | 'variant'> {}\n\n/**\n * Button that opens the select menu and displays the selected value.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectButton = forwardRef<SelectButtonProps, 'button'>(\n (props, ref) => {\n const {\n displayValue,\n renderValue,\n placeholder,\n isDisabled: isSelectDisabled,\n } = useSelectContext()\n\n const context = useFormControlContext()\n\n const styles = useSelectStyles()\n\n const {\n isInvalid,\n isReadOnly,\n isDisabled,\n isFocused,\n isRequired,\n id,\n onBlur,\n onFocus,\n } = context || {}\n\n const { rightIcon = <ChevronDownIcon />, ...rest } = props\n\n /* @ts-ignore */\n const focusStyles = styles.field?._focusVisible\n /* @ts-ignore */\n const readOnlyStyles = styles.field?._readOnly\n /* @ts-ignore */\n const invalid = styles.field?._invalid\n\n const height = styles.field?.h || styles.field?.height\n\n const buttonStyles: any = {\n fontWeight: 'normal',\n textAlign: 'left',\n color: 'inherit',\n _active: {\n bg: 'transparent',\n },\n minH: height,\n _focus: focusStyles,\n _expanded: focusStyles,\n _readOnly: readOnlyStyles,\n _invalid: invalid,\n minW: 0,\n ...styles.field,\n h: 'auto',\n }\n\n const buttonProps = useMenuButton(rest, ref)\n\n // Using a Button, so we can simply use leftIcon and rightIcon\n return (\n <Button\n {...buttonProps}\n {...buttonStyles}\n id={id || buttonProps.id}\n {...rest}\n onFocus={onFocus}\n onBlur={onBlur}\n isDisabled={isDisabled || isSelectDisabled}\n data-invalid={dataAttr(isInvalid)}\n data-read-only={dataAttr(isReadOnly)}\n data-focus={dataAttr(isFocused)}\n data-required={dataAttr(isRequired)}\n rightIcon={rightIcon}\n >\n <chakra.span\n __css={{\n display: 'block',\n pointerEvents: 'none',\n flex: '1 1 auto',\n minW: 0,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }}\n >\n {renderValue(displayValue) || placeholder}\n </chakra.span>\n </Button>\n )\n }\n)\n\nSelectButton.displayName = 'SelectButton'\n\n/**\n * Allow users to select a value from a list of options.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const Select = forwardRef<SelectProps, 'select'>((props, ref) => {\n const { name, children, isDisabled, multiple, ...rest } = props\n\n const styles = useMultiStyleConfig('SuiSelect', props)\n\n const menuProps = omitThemingProps(rest)\n\n const context = useSelect(props)\n\n const { value, controlProps } = context\n\n return (\n <SelectProvider value={context}>\n <SelectStylesProvider value={styles}>\n <Menu {...menuProps} closeOnSelect={!multiple}>\n <chakra.div className={cx('sui-select')}>\n {children}\n <chakra.input\n {...controlProps}\n ref={ref}\n name={name}\n type=\"hidden\"\n value={value || ''}\n className=\"saas-select__input\"\n />\n </chakra.div>\n </Menu>\n </SelectStylesProvider>\n </SelectProvider>\n )\n})\n\nexport interface SelectListProps extends MenuListProps {}\n\n/**\n * The list of options to choose from.\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectList: React.FC<SelectListProps> = (props) => {\n const { defaultValue, value, options, multiple, onChange } =\n useSelectContext()\n\n return (\n <MenuList maxH=\"100vh\" overflowY=\"auto\" {...props}>\n <MenuOptionGroup\n defaultValue={(defaultValue || value) as string | string[] | undefined}\n value={value}\n onChange={onChange}\n type={multiple ? 'checkbox' : 'radio'}\n >\n {options\n ? options.map(({ value, label, ...rest }, i) => (\n <SelectOption key={i} value={value} {...rest}>\n {label || value}\n </SelectOption>\n ))\n : props.children}\n </MenuOptionGroup>\n </MenuList>\n )\n}\n\nSelect.displayName = 'Select'\n\n/**\n * An option in a select list\n *\n * @see https://saas-ui.dev/docs/components/forms/select\n */\nexport const SelectOption = forwardRef<MenuItemOptionProps, 'button'>(\n (props, ref) => {\n return <MenuItemOption ref={ref} {...props} />\n }\n)\nSelectOption.id = 'MenuItemOption'\nSelectOption.displayName = 'SelectOption'\n","import {\n HTMLChakraProps,\n createStylesContext,\n useControllableState,\n useFormControl,\n} from '@chakra-ui/react'\nimport { createContext } from '@chakra-ui/react-utils'\nimport React from 'react'\nimport { FieldOptions } from '../types'\nimport { mapOptions } from '../utils'\nimport { SelectOption } from './select'\n\nexport const [SelectStylesProvider, useSelectStyles] =\n createStylesContext('SuiSelect')\n\nexport const [SelectProvider, useSelectContext] = createContext<\n ReturnType<typeof useSelect>\n>({\n strict: true,\n})\n\nexport interface SelectOptions {\n /**\n * The name of the input field in a native form.\n */\n name: string\n /**\n * The value of the select field.\n */\n value?: string | string[]\n /**\n * The initial value of the select field.\n */\n defaultValue?: string | string[]\n /**\n * The callback invoked when the value of the select field changes.\n * @param value The value of the select field.\n */\n onChange?: (value: string | string[]) => void\n /**\n * The placeholder text when there's no value.\n */\n placeholder?: string\n /**\n * If `true`, the select will be disabled.\n */\n isDisabled?: boolean\n /**\n * An array of options\n * If you leave this empty the children prop will be rendered.\n */\n options?: FieldOptions<SelectOption>\n /**\n * Enable multiple select.\n */\n multiple?: boolean\n /**\n * The function used to render the value of the select field.\n * @param value The value of the select field.\n * @returns The rendered value.\n */\n renderValue?: (value: string | string[]) => React.ReactNode\n}\n\nexport const useSelect = (props: SelectOptions) => {\n const {\n name,\n value,\n defaultValue,\n onChange,\n multiple,\n placeholder,\n options: optionsProp,\n isDisabled,\n renderValue = (value) =>\n typeof value === 'string' ? value : value?.join(', '),\n } = props\n const [currentValue, setCurrentValue] = useControllableState({\n value,\n defaultValue,\n onChange,\n })\n\n const controlProps = useFormControl({ name } as HTMLChakraProps<'input'>)\n\n const options = React.useMemo(\n () => optionsProp && mapOptions(optionsProp),\n [optionsProp]\n )\n\n const handleChange = (value: string | string[]) => {\n setCurrentValue(value)\n }\n\n const getDisplayValue = React.useCallback(\n (value: string) => {\n if (!options) {\n return value\n }\n\n for (const option of options) {\n if (option.value === value) {\n return option.label || option.value\n }\n }\n\n return value\n },\n [options]\n )\n\n const displayValue = React.useMemo(\n () =>\n currentValue\n ? (Array.isArray(currentValue) ? currentValue : [currentValue]).map(\n getDisplayValue\n )\n : [],\n [currentValue, getDisplayValue]\n )\n\n return {\n defaultValue,\n value: currentValue,\n displayValue,\n renderValue,\n onChange: handleChange,\n options,\n multiple,\n controlProps,\n placeholder,\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport {\n forwardRef,\n Select as ChakraSelect,\n SelectProps as ChakraSelectProps,\n} from '@chakra-ui/react'\n\ninterface Option {\n value: string\n label?: string\n}\n\ninterface NativeSelectOptions {\n options?: Option[]\n}\n\nexport interface NativeSelectProps\n extends ChakraSelectProps,\n NativeSelectOptions {}\n\nexport const NativeSelect = forwardRef<NativeSelectProps, 'select'>(\n ({ options, children, ...props }, ref) => {\n return (\n <ChakraSelect ref={ref} {...props}>\n {children ||\n options?.map(({ value, label }) => {\n return (\n <option key={value} value={value}>\n {label || value}\n </option>\n )\n })}\n </ChakraSelect>\n )\n }\n)\n\nNativeSelect.displayName = 'NativeSelect'\n","import * as React from 'react'\nimport { Controller } from 'react-hook-form'\n\nimport { forwardRef, useMergeRefs } from '@chakra-ui/react'\nimport { callAllHandlers } from '@chakra-ui/utils'\nimport { BaseFieldProps, FieldProps } from './types'\nimport { BaseField } from './base-field'\nimport { useFormContext } from './form-context'\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\n Field.displayName = displayName\n\n return Field\n}\n\nconst 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\nconst 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 CreateFieldOptions {\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 createField = <TProps extends object>(\n component: React.FC<TProps>,\n options?: CreateFieldOptions\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: `${component.displayName ?? 'Custom'}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n }) as React.FC<TProps & BaseFieldProps>\n\n return Field\n}\n","import * as React from 'react'\nimport { FormState, get } from 'react-hook-form'\n\nimport {\n Box,\n FormControl,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n} from '@chakra-ui/react'\n\nimport { useFormContext } from './form-context'\n\nimport { BaseFieldProps, FieldProps } from './types'\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\n/**\n * The default BaseField component\n * Composes the Chakra UI FormControl component, with FormLabel, FormHelperText and FormErrorMessage.\n */\nexport const BaseField: React.FC<BaseFieldProps> = (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\nBaseField.displayName = 'BaseField'\n","import * as React from 'react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\nimport { Field } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\nimport { useFormContext } from './form-context'\n\nexport interface FieldsProps<TSchema = any> {\n schema?: TSchema\n fieldResolver?: FieldResolver\n focusFirstField?: boolean\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n (\n { name, type, ...nestedFieldProps }: BaseFieldProps,\n i\n ): React.ReactNode => (\n <Field\n key={name || i}\n name={name}\n type={type as any}\n {...nestedFieldProps}\n />\n )\n )\n}\n\nexport const AutoFields: React.FC<FieldsProps> = ({\n schema: schemaProp,\n fieldResolver: fieldResolverProp,\n focusFirstField,\n ...props\n}) => {\n const context = useFormContext()\n const schema = schemaProp || context.schema\n const fieldResolver = fieldResolverProp || context.fieldResolver\n const resolver = React.useMemo(() => fieldResolver, [schema, fieldResolver])\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 if (!resolver) {\n return null\n }\n\n return (\n <FormLayout {...props}>\n {fields?.map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: BaseFieldProps): 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 (\n <Field key={name} name={name} type={type as any} {...fieldProps} />\n )\n }\n )}\n </FormLayout>\n )\n}\n\nAutoFields.displayName = 'Fields'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n SimpleGrid,\n SimpleGridProps,\n useTheme,\n} from '@chakra-ui/react'\nimport { cx } from '@chakra-ui/utils'\n\nexport interface FormLayoutProps extends 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\nFormLayoutItem.displayName = 'FormLayoutItem'\n\n/**\n * Create consistent field spacing and positioning.\n *\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n *\n * @see https://saas-ui.dev/docs/components/forms/form\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.SuiFormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('sui-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\nFormLayout.displayName = 'FormLayout'\n","import * as React from 'react'\n\nimport {\n chakra,\n ResponsiveValue,\n forwardRef,\n Button,\n ButtonProps,\n} from '@chakra-ui/react'\nimport { PlusIcon, MinusIcon } from '@saas-ui/core/icons'\n\nimport { FormLayout, FormLayoutProps } from './layout'\nimport { BaseField } from './base-field'\nimport { BaseFieldProps } from './types'\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'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { isFunction } from '@chakra-ui/utils'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\nimport { useFieldProps } from './form-context'\n\nexport interface ArrayFieldButtonProps extends ButtonProps {}\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/**\n * Render prop component, to get access to the internal fields state. Must be a child of ArrayFieldContainer.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRow.displayName = 'ArrayFieldRow'\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/**\n * Add the name prefix to the fields and acts as a horizontal form layout by default.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\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\nArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n\n/**\n * The row container component providers row context.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n ...rest\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 {...rest} __css={styles}>\n {children}\n </chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n\n/**\n * The default remove button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldRemoveButton: React.FC<ArrayFieldButtonProps> = (\n props\n) => {\n return (\n <Button aria-label=\"Remove row\" {...useArrayFieldRemoveButton()} {...props}>\n {props.children || <MinusIcon />}\n </Button>\n )\n}\n\nArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n\n/**\n * The default add button.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldAddButton: React.FC<ArrayFieldButtonProps> = (props) => {\n return (\n <Button\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n >\n {props.children || <PlusIcon />}\n </Button>\n )\n}\n\nArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n\nexport interface ArrayFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends ArrayFieldOptions<TFieldValues, TName>,\n Omit<\n BaseFieldProps<TFieldValues, TName>,\n 'name' | 'defaultValue' | 'children'\n > {\n children: MaybeRenderProp<ArrayField[]>\n}\n\n/**\n * The wrapper component that composes the default ArrayField functionality.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayField = forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n const rowFn = isFunction(children)\n ? children\n : (fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n )) || null}\n </>\n )\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>{rowFn as any}</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\nArrayField.displayName = 'ArrayField'\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\nArrayFieldRows.displayName = 'ArrayFieldRows'\n\nexport interface ArrayFieldContainerProps\n extends Omit<ArrayFieldProps, 'children'> {\n children: React.ReactNode\n}\n\n/**\n * The container component provides context and state management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/array-field\n */\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldContainerProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const overrides = useFieldProps(name)\n\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min: min || (overrides as any)?.min,\n max: max || (overrides as any)?.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} {...overrides}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nArrayFieldContainer.displayName = 'ArrayFieldContainer'\n","import * as React from 'react'\nimport {\n useFieldArray,\n UseFieldArrayReturn,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\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 TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n /**\n * The field name\n */\n name: TName\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'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyleConfig,\n} from '@chakra-ui/react'\n\nimport { FormLayout } from './layout'\nimport { BaseFieldProps } from './types'\n\nimport { mapNestedFields } from './utils'\nimport { FieldPath, FieldValues } from 'react-hook-form'\nimport { useFieldProps } from './form-context'\n\nexport interface ObjectFieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends BaseFieldProps {\n name: TName\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyleConfig('SuiFormLegend')\n return <FormLabel as=\"legend\" sx={styles} {...props} />\n}\n/**\n * The object field component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/object-field\n */\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const {\n name,\n label,\n hideLabel: hideLabelProp,\n children,\n columns: columnsProp,\n spacing: spacingProp,\n ...fieldProps\n } = props\n\n const { hideLabel, columns, spacing, ...overrides } = useFieldProps(\n name\n ) as Omit<ObjectFieldProps, 'name'>\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps} {...overrides}>\n <FormLegend display={hideLabelProp || hideLabel ? 'none' : 'block'}>\n {label}\n </FormLegend>\n <FormLayout\n columns={columnsProp || columns}\n gridGap={spacingProp || spacing}\n >\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nObjectField.displayName = 'ObjectField'\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps, forwardRef } from '@chakra-ui/react'\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/**\n * A button with type submit and default color scheme primary and isLoading state when the form is submitting.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const SubmitButton = forwardRef<SubmitButtonProps, 'button'>(\n (props, ref) => {\n const {\n children = 'Submit',\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 type=\"submit\"\n isLoading={formState.isSubmitting || isLoading}\n isDisabled={isDisabled}\n >\n {children}\n </Button>\n )\n }\n)\n\nSubmitButton.defaultProps = {\n variant: 'primary',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nSubmitButton.displayName = 'SubmitButton'\n","import * as React from 'react'\nimport {\n useWatch,\n FieldValues,\n UseFormReturn,\n FieldPath,\n} from 'react-hook-form'\n\nimport { useFormContext } from './form-context'\n\nexport interface DisplayIfProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> {\n children: React.ReactElement\n name: TName\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n/**\n * Conditionally render parts of a form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const DisplayIf = <\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues, TName>) => {\n const value = useWatch<TFieldValues>({\n name,\n defaultValue: defaultValue as any,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext() as any\n return condition(value, context) ? children : null\n}\n\nDisplayIf.displayName = 'DisplayIf'\n","import * as React from 'react'\n\nimport { FieldValues } from 'react-hook-form'\n\nimport {\n chakra,\n Button,\n ButtonProps,\n HTMLChakraProps,\n ThemingProps,\n} from '@chakra-ui/react'\n\nimport { callAllHandlers, cx } from '@chakra-ui/utils'\n\nimport {\n Steps,\n StepsItem,\n StepsItemProps,\n StepsProps,\n useStepperContext,\n} from '@saas-ui/core'\n\nimport { SubmitButton } from './submit-button'\n\nimport {\n useFormStep,\n UseStepFormProps,\n FormStepSubmitHandler,\n} from './use-step-form'\n\nexport type StepsOptions<TSchema, TName extends string = string> = {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: TSchema\n}[]\n\nexport interface StepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends UseStepFormProps<TSteps, TFieldValues, TContext> {}\n\nexport interface FormStepOptions<TName extends string = string> {\n /**\n * The step name\n */\n name: TName\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport interface FormStepperProps extends StepsProps, ThemingProps<'Stepper'> {\n render?: StepsItemProps['render']\n}\n\n/**\n * Renders a stepper that displays progress above the form.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStepper: React.FC<FormStepperProps> = (props) => {\n const { activeIndex, setIndex } = useStepperContext()\n\n const {\n children,\n orientation,\n variant,\n colorScheme,\n size,\n onChange: onChangeProp,\n render,\n ...rest\n } = 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 <StepsItem\n render={render}\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n {...rest}\n >\n {child.props.children}\n </StepsItem>\n )\n }\n return child\n })\n\n const onChange = React.useCallback((i: number) => {\n setIndex(i)\n onChangeProp?.(i)\n }, [])\n\n return (\n <Steps\n orientation={orientation}\n step={activeIndex}\n variant={variant}\n colorScheme={colorScheme}\n size={size}\n onChange={onChange}\n >\n {elements}\n </Steps>\n )\n}\n\nexport interface FormStepProps<TName extends string = string>\n extends FormStepOptions<TName>,\n Omit<HTMLChakraProps<'div'>, 'onSubmit'> {\n onSubmit?: FormStepSubmitHandler\n}\n/**\n * The form step containing fields for a specific step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const FormStep = <TName extends string = string>(\n props: FormStepProps<TName>\n) => {\n const { name, children, className, onSubmit, ...rest } = props\n const step = useFormStep({ name, onSubmit })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('sui-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nFormStep.displayName = 'FormStep'\n\n/**\n * A button that this opens the previous step when clicked. Disabled on the first step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n children=\"Back\"\n {...props}\n className={cx('sui-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nPrevButton.displayName = 'PrevButton'\n\nexport interface NextButtonProps extends Omit<ButtonProps, 'children'> {\n submitLabel?: string\n label?: string\n}\n\n/**\n * A button that submits the active step.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\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('sui-form__next-button', props.className)}\n >\n {isLastStep || isCompleted ? submitLabel : label}\n </SubmitButton>\n )\n}\n\nNextButton.displayName = 'NextButton'\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/core'\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 { FocusableElement } from '@chakra-ui/utils'\nimport { FormProps } from './form'\nimport { FormStepProps, StepsOptions } from './step-form'\nimport { FieldProps, StepFormChildren } from './types'\nimport { DisplayIfProps } from './display-if'\nimport { ArrayFieldProps } from './array-field'\nimport { UseArrayFieldReturn } from './use-array-field'\nimport { ObjectFieldProps } from './object-field'\n\ntype StepName<T extends { [k: number]: { readonly name: string } }> =\n T[number]['name']\n\nexport interface StepFormRenderContext<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseStepFormReturn<TFieldValues> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n FormStep: React.FC<FormStepProps<StepName<TSteps>>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\nexport interface UseStepFormProps<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n> extends Omit<UseStepperProps, 'onChange'>,\n Omit<FormProps<any, TFieldValues, TContext>, 'children'> {\n steps?: TSteps\n children: StepFormChildren<any, TSteps, TFieldValues, TContext>\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<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: UseStepFormProps<TSteps, TFieldValues, TContext>\n): UseStepFormReturn<TFieldValues> {\n const { onChange, steps: stepsOptions, resolver, ...rest } = props\n const stepper = useStepper(rest)\n\n const [options, setOptions] = React.useState<TSteps | undefined>(stepsOptions)\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\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.schema\n ? /* @todo fix resolver type */ (resolver as any)?.(step.schema)\n : undefined,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n const stepOptions = options?.find((s) => s.name === step.name)\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: {\n ...step,\n schema: stepOptions?.schema,\n },\n }\n })\n },\n [steps, options]\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 { BaseFieldProps } from './types'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): BaseFieldProps[]\n getNestedFields(name: string): BaseFieldProps[]\n}\n\nexport type GetFieldResolver<TSchema = any> = (schema: TSchema) => FieldResolver\n\ninterface SchemaField extends BaseFieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema): BaseFieldProps[] =>\n schema &&\n Object.entries(schema).map(([name, { items, label, title, ...field }]) => {\n return {\n ...field,\n name,\n label: label || title || name, // json schema compatibility\n }\n })\n\nexport const objectFieldResolver: GetFieldResolver<ObjectSchema> = (schema) => {\n const getFields = (): BaseFieldProps[] => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string): BaseFieldProps[] => {\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 { FieldValues, useWatch } from 'react-hook-form'\nimport { useFormContext, UseFormReturn } from './form-context'\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","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { FocusableElement, cx, runIfFn } from '@chakra-ui/utils'\n\nimport {\n useForm,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n ResolverOptions,\n ResolverResult,\n WatchObserver,\n} from 'react-hook-form'\nimport { FormProvider } from './form-context'\nimport { FieldResolver } from './field-resolver'\nimport { MaybeRenderProp } from '@chakra-ui/react-utils'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\nimport { FieldProps, DefaultFieldOverrides } from './types'\n\nimport { Field as DefaultField } from './field'\nimport { FormLayout } from './layout'\nimport { AutoFields } from './fields'\nimport { SubmitButton } from './submit-button'\nimport { DisplayIf, DisplayIfProps } from './display-if'\nimport { ArrayField, ArrayFieldProps } from './array-field'\nimport { ObjectField, ObjectFieldProps } from './object-field'\nimport { UseArrayFieldReturn } from './use-array-field'\n\nexport interface FormRenderContext<\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormReturn<TFieldValues, TContext> {\n Field: React.FC<TFieldTypes & React.RefAttributes<FocusableElement>>\n DisplayIf: React.FC<DisplayIfProps<TFieldValues>>\n ArrayField: React.FC<\n ArrayFieldProps<TFieldValues> & React.RefAttributes<UseArrayFieldReturn>\n >\n ObjectField: React.FC<ObjectFieldProps<TFieldValues>>\n}\n\ninterface FormOptions<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> {\n /**\n * The form schema.\n */\n schema?: TSchema\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 * The Hook Form state ref.\n */\n formRef?: React.RefObject<UseFormReturn<TFieldValues, TContext>>\n /**\n * The form children, can be a render prop or a ReactNode.\n */\n children?: MaybeRenderProp<\n FormRenderContext<TFieldValues, TContext, TFieldTypes>\n >\n /**\n * The field resolver, used to resolve the fields from schemas.\n */\n fieldResolver?: FieldResolver\n /**\n * Field overrides\n */\n fields?: DefaultFieldOverrides\n}\n\nexport interface FormProps<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n> extends UseFormProps<TFieldValues, TContext>,\n Omit<\n HTMLChakraProps<'form'>,\n 'children' | 'onChange' | 'onSubmit' | 'onError'\n >,\n FormOptions<TSchema, TFieldValues, TContext, TFieldTypes> {}\n\n/**\n * The wrapper component provides context, state, and focus management.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n >(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes>,\n ref: React.ForwardedRef<HTMLFormElement>\n ) => {\n const {\n mode = 'all',\n resolver,\n fieldResolver,\n fields,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n values,\n context,\n resetOptions,\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 values,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n context,\n resetOptions,\n }\n\n const methods = useForm<TFieldValues, TContext>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(formRef, () => methods, [formRef, 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 let _children = children\n if (!_children && fieldResolver) {\n _children = (\n <FormLayout>\n <AutoFields />\n <SubmitButton {...fields?.submit} />\n </FormLayout>\n )\n }\n\n return (\n <FormProvider\n {...methods}\n schema={schema}\n fieldResolver={fieldResolver}\n fields={fields}\n >\n <chakra.form\n ref={ref}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('sui-form', props.className)}\n >\n {runIfFn(_children, {\n Field: DefaultField as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n ...methods,\n })}\n </chakra.form>\n </FormProvider>\n )\n }\n) as FormComponent\n\nexport type FormComponent = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: FormProps<TSchema, TFieldValues, TContext, TFieldTypes> & {\n ref?: React.ForwardedRef<HTMLFormElement>\n }\n) => React.ReactElement) & {\n displayName?: string\n}\n\nForm.displayName = 'Form'\n\nexport type GetResolver = <\n TFieldValues extends FieldValues,\n TContext extends object\n>(\n schema: unknown\n) => (\n values: TFieldValues,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n","import React, { ForwardedRef } from 'react'\nimport { FieldsProvider } from './fields-context'\nimport { Form, FieldValues, FormProps, GetResolver } from './form'\nimport { DefaultFieldOverrides, WithFields } from './types'\nimport { objectFieldResolver } from './field-resolver'\nimport { GetFieldResolver } from './field-resolver'\nimport { forwardRef } from '@chakra-ui/react'\n\nexport interface CreateFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport type FormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSchema = unknown,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n>(\n props: WithFields<\n FormProps<TSchema, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport function createForm<FieldDefs>({\n resolver,\n fieldResolver = objectFieldResolver,\n fields,\n}: CreateFormProps<FieldDefs> = {}) {\n const DefaultForm = forwardRef(\n <\n TSchema = any,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object\n >(\n props: WithFields<FormProps<TSchema, TFieldValues, TContext>, FieldDefs>,\n ref: ForwardedRef<HTMLFormElement>\n ) => {\n const { schema, ...rest } = props\n return (\n <FieldsProvider value={fields || {}}>\n <Form\n ref={ref}\n resolver={resolver?.(props.schema)}\n fieldResolver={fieldResolver?.(schema)}\n {...rest}\n />\n </FieldsProvider>\n )\n }\n ) as FormType<FieldDefs>\n\n DefaultForm.displayName = 'Form'\n DefaultForm.id = 'Form'\n\n return DefaultForm\n}\n","import React, { useMemo } from 'react'\nimport { forwardRef } from '@chakra-ui/react'\nimport {\n ArrayField,\n DisplayIf,\n FieldProps,\n FieldValues,\n FieldsProvider,\n GetFieldResolver,\n ObjectField,\n} from './'\nimport { Form } from './form'\nimport { Field } from './field'\nimport { FormStep, StepsOptions } from './step-form'\nimport {\n StepFormProvider,\n UseStepFormProps,\n useStepForm,\n} from './use-step-form'\nimport { StepperProvider } from '@saas-ui/core'\nimport { runIfFn } from '@chakra-ui/utils'\nimport { GetResolver } from './form'\nimport { WithStepFields } from './types'\n\nexport type StepFormType<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n> = (<\n TSteps extends StepsOptions<any> = StepsOptions<any>,\n TFieldValues extends FieldValues = FieldValues,\n TContext extends object = object,\n TFieldTypes = FieldProps<TFieldValues>\n>(\n props: WithStepFields<\n UseStepFormProps<TSteps, TFieldValues, TContext>,\n FieldDefs,\n ExtraOverrides\n > & {\n ref?: React.ForwardedRef<HTMLFormElement>\n } & ExtraProps\n) => React.ReactElement) & {\n displayName?: string\n id?: string\n}\n\nexport interface CreateStepFormProps<FieldDefs> {\n resolver?: GetResolver\n fieldResolver?: GetFieldResolver\n fields?: FieldDefs extends Record<string, React.FC<any>> ? FieldDefs : never\n}\n\nexport function createStepForm<\n FieldDefs,\n ExtraProps = object,\n ExtraOverrides = object\n>({ fields, resolver, fieldResolver }: CreateStepFormProps<FieldDefs> = {}) {\n const StepForm = forwardRef<any, 'div'>((props, ref) => {\n const { children, steps, ...rest } = props\n\n const stepper = useStepForm({\n resolver,\n fieldResolver,\n ...props,\n })\n\n const { getFormProps, ...ctx } = stepper\n\n const context = useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <FieldsProvider value={fields || {}}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, {\n ...stepper,\n Field: Field as any,\n FormStep: FormStep as any,\n DisplayIf: DisplayIf as any,\n ArrayField: ArrayField as any,\n ObjectField: ObjectField as any,\n })}\n </Form>\n </FieldsProvider>\n </StepFormProvider>\n </StepperProvider>\n )\n }) as StepFormType<FieldDefs, ExtraProps, ExtraOverrides>\n\n StepForm.displayName = `Step${Form.displayName || Form.name}`\n\n return StepForm\n}\n","export * from './display-field'\nexport * from './field'\nexport * from './fields'\nexport * from './fields-context'\nexport * from './layout'\nexport * from './submit-button'\nexport * from './array-field'\nexport * from './use-array-field'\nexport * from './object-field'\nexport * from './display-if'\nexport * from './step-form'\nexport * from './use-step-form'\nexport * from './field-resolver'\nexport * from './watch-field'\nexport * from './input-right-button'\nexport * from './select'\nexport * from './password-input'\nexport * from './radio'\n\nexport * from './base-field'\n\nexport {\n CheckboxField,\n InputField,\n NativeSelectField,\n NumberInputField,\n PasswordInputField,\n PinField,\n RadioField,\n SelectField,\n SwitchField,\n TextareaField,\n defaultFieldTypes,\n type DefaultFields,\n type InputFieldProps,\n type NumberInputFieldProps,\n type PinFieldProps,\n} from './default-fields'\n\nexport type {\n FieldProps,\n WithFields,\n BaseFieldProps,\n FieldOptions,\n DefaultFieldOverrides,\n WithStepFields,\n} from './types'\n\nexport { createForm, type CreateFormProps, type FormType } from './create-form'\nexport { createField, type CreateFieldOptions } from './create-field'\n\nexport { Form as BaseForm } from './form'\nexport type { FormProps, FormRenderContext, FormComponent } from './form'\n\nexport { FormProvider, useFormContext } from './form-context'\n\nimport { createForm } from './create-form'\nimport { createStepForm } from './create-step-form'\n\n/**\n * Form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/form\n */\nexport const Form = createForm()\n\nexport { createStepForm, type CreateStepFormProps } from './create-step-form'\n\n/**\n * Multi-step form component.\n *\n * @see Docs https://saas-ui.dev/docs/components/forms/step-form\n */\nexport const StepForm = createStepForm()\n\nexport type {\n BatchFieldArrayUpdate,\n ChangeHandler,\n Control,\n ControllerFieldState,\n ControllerProps,\n ControllerRenderProps,\n CriteriaMode,\n CustomElement,\n DeepMap,\n DeepPartial,\n DeepPartialSkipArrayKey,\n DefaultValues,\n DelayCallback,\n EmptyObject,\n ErrorOption,\n EventType,\n Field as FieldDef,\n FieldArray,\n FieldArrayMethodProps,\n FieldArrayWithId,\n FieldElement,\n FieldError,\n FieldErrors,\n FieldName,\n FieldNamesMarkedBoolean,\n FieldRefs,\n FieldValue,\n FieldValues,\n FormProviderProps,\n FormState,\n FormStateProxy,\n FormStateSubjectRef,\n GetIsDirty,\n InternalFieldErrors,\n InternalFieldName,\n InternalNameSet,\n IsAny,\n IsFlatObject,\n KeepStateOptions,\n LiteralUnion,\n Message,\n Mode,\n MultipleFieldErrors,\n Names,\n NativeFieldValue,\n NestedValue,\n NonUndefined,\n Noop,\n Primitive,\n ReadFormState,\n Ref,\n RefCallBack,\n RegisterOptions,\n Resolver,\n ResolverError,\n ResolverOptions,\n ResolverResult,\n ResolverSuccess,\n SetFieldValue,\n SetValueConfig,\n Subjects,\n SubmitErrorHandler,\n SubmitHandler,\n TriggerConfig,\n UnpackNestedValue,\n UseControllerProps,\n UseControllerReturn,\n UseFieldArrayProps,\n UseFieldArrayReturn,\n UseFormClearErrors,\n UseFormGetValues,\n UseFormHandleSubmit,\n UseFormProps,\n UseFormRegister,\n UseFormRegisterReturn,\n UseFormReset,\n UseFormResetField,\n UseFormReturn,\n UseFormSetError,\n UseFormSetFocus,\n UseFormSetValue,\n UseFormStateProps,\n UseFormStateReturn,\n UseFormTrigger,\n UseFormUnregister,\n UseFormWatch,\n UseWatchProps,\n Validate,\n ValidateResult,\n ValidationMode,\n ValidationRule,\n ValidationValue,\n ValidationValueMessage,\n WatchInternal,\n WatchObserver,\n} from 'react-hook-form'\n\nexport {\n appendErrors,\n useController,\n useFieldArray,\n useForm,\n useFormState,\n useWatch,\n Controller,\n} from 'react-hook-form'\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@saas-ui/forms",
3
- "version": "2.0.3",
3
+ "version": "2.0.5",
4
4
  "description": "Fully functional forms for Chakra UI.",
5
5
  "source": "src/index.ts",
6
6
  "exports": {
@@ -104,7 +104,7 @@
104
104
  "@chakra-ui/react-utils": "^2.0.12",
105
105
  "@chakra-ui/utils": "^2.0.15",
106
106
  "@hookform/resolvers": "^3.1.0",
107
- "@saas-ui/core": "2.0.2",
107
+ "@saas-ui/core": "2.0.3",
108
108
  "react-hook-form": "^7.44.3"
109
109
  },
110
110
  "peerDependencies": {
@@ -6,10 +6,10 @@ import {
6
6
  FieldProps,
7
7
  FieldValues,
8
8
  FieldsProvider,
9
- Form,
10
9
  GetFieldResolver,
11
10
  ObjectField,
12
11
  } from './'
12
+ import { Form } from './form'
13
13
  import { Field } from './field'
14
14
  import { FormStep, StepsOptions } from './step-form'
15
15
  import {