UNPKG

@porsche-design-system/components-react

Version:

Porsche Design System is a component library designed to help developers create the best experience for software or services distributed by Dr. Ing. h.c. F. Porsche AG.

209 lines (208 loc) 7.55 kB
import type { BaseProps } from '../../BaseProps'; import type { BreakpointCustomizable, TextareaBlurEventDetail, TextareaChangeEventDetail, TextareaInputEventDetail, TextareaResize, TextareaState, Theme, TextareaWrap } from '../types'; export type PTextareaProps = BaseProps & { /** * Provides a hint to the browser about what type of data the field expects, which can assist with autofill features (e.g., autocomplete='on'). */ autoComplete?: string; /** * A boolean value that, if present, renders the textarea as a compact version. */ compact?: boolean; /** * Show or hide the character counter. */ counter?: boolean; /** * Supplementary text providing more context or explanation for the textarea. */ description?: string; /** * A boolean value that, if present, makes the textarea unusable and unclickable. The value will not be submitted with the form. */ disabled?: boolean; /** * Specifies the id of the <form> element that the textarea belongs to (useful if the textarea is not a direct descendant of the form). */ form?: string; /** * Controls the visibility of the label. */ hideLabel?: BreakpointCustomizable<boolean>; /** * Text content for a user-facing label. */ label?: string; /** * A non-negative integer specifying the maximum number of characters the user can enter into the textarea. */ maxLength?: number; /** * Dynamic feedback text for validation or status. */ message?: string; /** * A non-negative integer specifying the minimum number of characters required for the textarea's value to be considered valid. */ minLength?: number; /** * The name of the textarea, used when submitting the form data. */ name: string; /** * Emitted when the textarea has lost focus. */ onBlur?: (event: CustomEvent<TextareaBlurEventDetail>) => void; /** * Emitted when the textarea loses focus after its value was changed. */ onChange?: (event: CustomEvent<TextareaChangeEventDetail>) => void; /** * Emitted when the value has been changed as a direct result of a user action. */ onInput?: (event: CustomEvent<TextareaInputEventDetail>) => void; /** * A string that provides a brief hint to the user about what kind of information is expected in the field (e.g., placeholder='Write your message here...'). This text is displayed when the textarea is empty. */ placeholder?: string; /** * A boolean value that, if present, makes the textarea uneditable by the user, but its value will still be submitted with the form. */ readOnly?: boolean; /** * A boolean value that, if present, indicates that the textarea must be filled out before the form can be submitted. */ required?: boolean; /** * Controls whether the textarea is resizable and in which direction. */ resize?: TextareaResize; /** * The number of rows. Has no effect when field-sizing CSS Variable '--p-textarea-field-sizing' is set to 'content'. */ rows?: number; /** * Specifies whether the textarea should have its spelling and grammar checked */ spellCheck?: boolean; /** * Indicates the validation or overall status of the textarea component. */ state?: TextareaState; /** * Controls the visual appearance of the component. */ theme?: Theme; /** * The textarea value. */ value?: string; /** * Handles wrapping behavior of elements. */ wrap?: TextareaWrap; }; export declare const PTextarea: import("react").ForwardRefExoticComponent<Omit<import("react").DOMAttributes<{}>, "onChange" | "onInput" | "onToggle"> & Pick<import("react").HTMLAttributes<{}>, "suppressHydrationWarning" | "autoFocus" | "className" | "dir" | "hidden" | "id" | "inert" | "lang" | "slot" | "style" | "tabIndex" | "title" | "translate" | "role"> & { /** * Provides a hint to the browser about what type of data the field expects, which can assist with autofill features (e.g., autocomplete='on'). */ autoComplete?: string; /** * A boolean value that, if present, renders the textarea as a compact version. */ compact?: boolean; /** * Show or hide the character counter. */ counter?: boolean; /** * Supplementary text providing more context or explanation for the textarea. */ description?: string; /** * A boolean value that, if present, makes the textarea unusable and unclickable. The value will not be submitted with the form. */ disabled?: boolean; /** * Specifies the id of the <form> element that the textarea belongs to (useful if the textarea is not a direct descendant of the form). */ form?: string; /** * Controls the visibility of the label. */ hideLabel?: BreakpointCustomizable<boolean>; /** * Text content for a user-facing label. */ label?: string; /** * A non-negative integer specifying the maximum number of characters the user can enter into the textarea. */ maxLength?: number; /** * Dynamic feedback text for validation or status. */ message?: string; /** * A non-negative integer specifying the minimum number of characters required for the textarea's value to be considered valid. */ minLength?: number; /** * The name of the textarea, used when submitting the form data. */ name: string; /** * Emitted when the textarea has lost focus. */ onBlur?: (event: CustomEvent<TextareaBlurEventDetail>) => void; /** * Emitted when the textarea loses focus after its value was changed. */ onChange?: (event: CustomEvent<TextareaChangeEventDetail>) => void; /** * Emitted when the value has been changed as a direct result of a user action. */ onInput?: (event: CustomEvent<TextareaInputEventDetail>) => void; /** * A string that provides a brief hint to the user about what kind of information is expected in the field (e.g., placeholder='Write your message here...'). This text is displayed when the textarea is empty. */ placeholder?: string; /** * A boolean value that, if present, makes the textarea uneditable by the user, but its value will still be submitted with the form. */ readOnly?: boolean; /** * A boolean value that, if present, indicates that the textarea must be filled out before the form can be submitted. */ required?: boolean; /** * Controls whether the textarea is resizable and in which direction. */ resize?: TextareaResize; /** * The number of rows. Has no effect when field-sizing CSS Variable '--p-textarea-field-sizing' is set to 'content'. */ rows?: number; /** * Specifies whether the textarea should have its spelling and grammar checked */ spellCheck?: boolean; /** * Indicates the validation or overall status of the textarea component. */ state?: TextareaState; /** * Controls the visual appearance of the component. */ theme?: Theme; /** * The textarea value. */ value?: string; /** * Handles wrapping behavior of elements. */ wrap?: TextareaWrap; } & { children?: import("react").ReactNode | undefined; } & import("react").RefAttributes<HTMLElement>>;