Import
import { Textarea } from '@contentful/f36-components';// orimport { Textarea } from '@contentful/f36-forms';
Examples
Using as a controlled input
Controlled components in React are those in which form data is handled by the component’s state.
For using the Textarea
as a controlled input, you need to:
- Pass
value
property, with this property it will already be a controlled component; - Pass
onChange
handler, so you can use it to update the value of the input;
Provide a short, but descriptive information
Using as an uncontrolled input
Uncontrolled components are those for which the form data is handled by the DOM itself. “Uncontrolled” refers to the fact that these components are not controlled by React state.
You can use the Textarea
as an uncontrolled input, for that you can:
- Set the
defaultValue
property, it will ensure that the initial value of the input is set. - Don't set the
value
as it will make the input controlled.
Provide detailed information
Using outside of forms
When Textarea
is used outside of form (without FormControl
) and has no <label>
associated with it, you need to specify aria-label
.
Different states
Accessibility
- To ensure
Textarea
meets accessibility keyboard standards, set thename
andid
properties. - If you are using this component in a form, provide validation to the input and use
isInvalid
to control the error state of Textarea. - The
invalid
anddisabled
states do not need to be set on FormControl but can be set in Textarea. - In case the input is required, use
isRequired
prop. - To display meaningful error messages make use of
<FormControl.ValidationMessage>
. For further details refer to FormControl.
Props (API reference)
Open in StorybookThis component also accepts relevant HTML attributes as props. These include rows
, autoFocus
and autoComplete
.
Name | Type | Default |
---|---|---|
className | string CSS class to be appended to the root element | |
css | string number false true ComponentSelector Keyframes SerializedStyles ArrayInterpolation<undefined> ObjectInterpolation<undefined> (theme: any) => Interpolation<undefined> | |
defaultValue | string Set's default value for textarea | |
icon | ReactElement<any, string | JSXElementConstructor<any>> Expects any of the icon components | |
id | string Sets the id of the input | |
isDisabled | false true Applies disabled styles | false |
isInvalid | false true Applies invalid styles | false |
isReadOnly | false true Applies read-only styles | false |
isRequired | false true Validate the input | false |
name | string Set the name of the input | |
onBlur | FocusEventHandler<HTMLTextAreaElement | HTMLInputElement> Allows to listen to an event when an element loses focus | |
onChange | ChangeEventHandler<HTMLTextAreaElement | HTMLInputElement> Allows to listen to an input’s change in value | |
onFocus | FocusEventHandler<HTMLTextAreaElement | HTMLInputElement> Allows to listen to an event when an element get focused | |
onKeyDown | KeyboardEventHandler<HTMLTextAreaElement | HTMLInputElement> Allows to listen to an event when a key is pressed | |
resize | "none" "both" "horizontal" "vertical" Sets whether an element is resizable, and if so, in which directions | vertical |
testId | string A [data-test-id] attribute used for testing purposes | cf-ui-textarea |
value | string Set the value of the input | |
willBlurOnEsc | false true Boolean property that allows to blur on escape | true |