import * as React from 'react';
import type { Form } from "../../form/index.js";
import { BaseUIComponentProps } from "../../utils/types.js";
/**
* Groups all parts of the field.
* Renders a `
` element.
*
* Documentation: [Base UI Field](https://base-ui.com/react/components/field)
*/
export declare const FieldRoot: React.ForwardRefExoticComponent>;
export interface FieldValidityData {
state: {
badInput: boolean;
customError: boolean;
patternMismatch: boolean;
rangeOverflow: boolean;
rangeUnderflow: boolean;
stepMismatch: boolean;
tooLong: boolean;
tooShort: boolean;
typeMismatch: boolean;
valueMissing: boolean;
valid: boolean | null;
};
error: string;
errors: string[];
value: unknown;
initialValue: unknown;
}
export interface FieldRootState {
/** Whether the component should ignore user interaction. */
disabled: boolean;
touched: boolean;
dirty: boolean;
valid: boolean | null;
filled: boolean;
focused: boolean;
}
export interface FieldRootProps extends BaseUIComponentProps<'div', FieldRoot.State> {
/**
* Whether the component should ignore user interaction.
* Takes precedence over the `disabled` prop on the `` component.
* @default false
*/
disabled?: boolean;
/**
* Identifies the field when a form is submitted.
* Takes precedence over the `name` prop on the `` component.
*/
name?: string;
/**
* A function for custom validation. Return a string or an array of strings with
* the error message(s) if the value is invalid, or `null` if the value is valid.
* Asynchronous functions are supported, but they do not prevent form submission
* when using `validationMode="onSubmit"`.
*/
validate?: (value: unknown, formValues: Form.Values) => string | string[] | null | Promise;
/**
* Determines when the field should be validated.
* This takes precedence over the `validationMode` prop on `