Text area

To add the TextArea component to your app:

1 import { TextArea } from '@forge/react';

Description

A text area lets users enter long form text which spans over multiple lines.

Props

NameTypeRequiredAvailable in macro configDescription
appearance"standard" | "subtle" | "none"NoNoControls the appearance of the field. subtle shows styling on hover. none prevents all field styling. Take care when using the none appearance as this doesn't include accessible interactions.
aria-invalidboolean | "false" | "true" | "grammar" | "spelling"NoNoIndicates the entered value does not conform to the format expected by the application.
aria-labelledbystringNoNoIdentifies the element (or elements) that labels the current element.
defaultValuestringNoYesThe default value of the text area.
idstringNoNoUsed to specify a unique ID for the current element.
isCompactbooleanNoNoSets whether the field should expand to fill available horizontal space.
isDisabledbooleanNoNoSets the field as uneditable, with a changed hover state.
isInvalidbooleanNoNoSets styling to indicate that the input is invalid.
isMonospacedbooleanNoNoSets the content text value to monospace.
isReadOnlybooleanNoNoIf true, prevents the value of the input from being edited.
isRequiredbooleanNoYesSets whether the field is required for form that the field is part of.
maxHeightstringNoNoThe maximum height of the text area.
maxLengthnumberNoNoSpecifies the maximum number of characters allowed in the input area.
minimumRowsnumberNoNoThe minimum number of rows of text to display.
minLengthnumberNoNoSpecifies the minimum number of characters required in the input area.
namestringRequired for macro configuration, not required for other extension pointsYesName of the input form control.
onBlur(e: FocusEvent) => voidNoNoHandler to be called when the input is blurred.
onChange(e: ChangeEvent) => voidNoNoHandler to be called when the input changes.
onFocus(e: FocusEvent) => voidNoNoHandler to be called when the input is focused.
placeholderstringNoYesThe placeholder within the text area.
resize"none" | "auto" | "vertical" | "horizontal" | "smart"NoNoEnables resizing of the text area. The default setting is smart. auto enables resizing in both directions. horizontal enables resizing only along the X axis. vertical enables resizing only along the Y axis. smart vertically grows and shrinks the text area automatically to wrap your input text. none explicitly disallows resizing of the text area.
spellCheckbooleanNoNoEnables native spell check on the textarea element.
valuestringNoNoThe value of the text area.

Examples

Default

The default text area.

Example image of a rendered default text area

1
2
import { TextArea, Label } from '@forge/react';

export const TextAreaExample = () => (
  <>
    <Label labelFor="area">Field label</Label>
    <TextArea
      id="area"
      placeholder="Enter long form text here"
      name="area"
    />
  </>
);

Field label and message

Always use a label component for each field and associate the label to the field properly. Use the HelperMessage component for any optional field-related message.

Required field label

For required fields, always add RequiredAsterisk component next to the label.

Validation

Use ErrorMessage or ValidationMessage components to display validation-related messages.

Example image of a validation message


Appearance

Standard

The default text area appearance.

Example image of a rendered standard appearance text area

1
2
export const TextAreaStandard = () => {
  return (
    <TextArea
      appearance="standard"
      placeholder="Placeholder"
      name="area"
    />
  );
}

Subtle

A text area that's transparent until interaction or error.

Example image of a rendered subtle appearance text area

1
2
export const TextAreaSubtle = () => {
  return (
    <TextArea
      appearance="subtle"
      placeholder="Placeholder"
      name="area"
    />
  );
}

Resize

Use the resize prop to set whether the text area expands when the user enters text that exceeds the size of the text area.

Smart

Use smart for a text area that shows all user input at once. Overflow text wraps onto a new line and expands the text area. This is the default sizing option.

Example image of a rendered smart resize text area

1
2
export const TextAreaSmartResizeExample = () => (
  <TextArea
    resize="smart"
    name="resize-smart"
  />
);

Auto

Use auto for a text area that will resize horizontally and vertically.

Example image of a rendered auto resize text area

1
2
export const TextAreaAutoResizeExample = () => (
  <TextArea
    resize="auto"
    name="resize-auto"
  />
);

Vertical / horizontal resize

Use vertical or horizontal for a text area that will resize either vertically only or horizontally only.

Example image of a vertical and horizontal resizeable text area

1
2
export const TextAreaHorizontalResizeExample = () => (
  <TextArea
    resize="horizontal"
    name="resize-horizontal"
  />
);
1
2
export const TextAreaVerticalResizeExample = () => (
  <TextArea
    resize="vertical"
    name="resize-vertical"
  />
);

Accessibility considerations

When using the TextArea component, we recommend keeping the following accessibility considerations in mind:

  • Always use a label and associate the label to the field properly so that the text area is accessible to assistive technology.
  • Avoid using placeholder text whenever possible. Make sure any critical information is communicated either in the field label or using helper text below the field. Search fields or brief examples are exceptions where placeholder text may be okay.

Rate this page: