Text area
A text area lets a user input a longer amount of text than a standard text field. It can include all of the standard validation options supported by the
data:image/s3,"s3://crabby-images/279f8/279f8912995bdffbf1e3509d8c55f2f859617417" alt="Key example of a text area in not quiet style, no drag icon and a number height. Label, Description. 5 lines of sample input text."
Anatomy#
data:image/s3,"s3://crabby-images/6ae80/6ae80a7f294cac51bb49a245ab2bdf8366f44d63" alt="Image illustrating through labels the component parts of a text area including its field, label, required asterisk, value, character count, validation marker, and help text, description or error message."
Options#
Table of options#
From the design point of view, each component has a number of options. These options and their names are platform agnostic, and each implementation should adapt these to fit into their framework.
Behaviors#
data:image/s3,"s3://crabby-images/ee26c/ee26c5f0c873122d6304fd9a03706fa3cd571992" alt="Key example of a text area at minimum width and minimum height. Label Interests. Value text, Snowboarding, canoeing, calligraphy."
Minimum size#
Text areas are ideal for long sentences or paragraphs, and should comfortably accommodate larger amounts of text. They should have a minimum height of 56 px on desktop and 70 px on mobile (when the height of the text area is a defined number). The minimum width is 112 px on desktop and 140 px on mobile.
data:image/s3,"s3://crabby-images/a1780/a178078304054c8ba538ba13d34eb47d998445fb" alt="Key example of two text areas. Both labeled Interests with a long list of various interests and hobbies as the sample input text. One is an active state text area with input text overflowing out of the top of the text area. The second is an inactive state text area with input text overflowing out of the bottom of the text area."
Overflow#
When typing into a text area and reaching the end of the field on a number-height text area, the cursor should remain as static in the bottom right corner (for left-to-right languages) while text above it overflows through the top of the field. When the field loses focus, text should overflow through the bottom of the text area, showing the beginning of the text.
data:image/s3,"s3://crabby-images/375a7/375a7a475927fa1a14ccb9487743a6832a989137" alt="Key example of a text area with help text that has overflowed to a second line. Text area label, Interests. Help text in grey color, Describe the interests you’d like to explore through our tutorials."
Help text overflow#
When the help text is too long for the available horizontal space, it wraps to form another line.
data:image/s3,"s3://crabby-images/97610/97610f8296db2f81e6281e52bfaa799f15fd243b" alt="Key example of text areas in Windows “high contrast black” theme with label “Text area” and disabled text area with label “Disabled text area”."
Windows high contrast mode#
In Windows high contrast mode, text area should be displayed using the high contrast theme-specified colors for buttons. By default, border colors should be the same as the button text color and labels should use default text color. In hover and keyboard focus states, the border color should display as the button border color. In the disabled state, border and text color should display as the disabled color.
Usage guidelines#
Include a label#
Every text area should have a label. A text area without a label is ambiguous and not accessible.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/14600/14600fca68f443873609d86ccdddd24d5ddf86b6" alt="Key example of a text area correctly using a label above the text area. Label Members. Input text Lisa."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/80e1b/80e1b1e2649dcc40499403aab239145b1013c928" alt="Key example of incorrect usage of a text area. Text area missing a label. Input text Lisa."
Follow capitalization rules#
Text area labels and placeholder text should be written in sentence case.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/ce4e2/ce4e205eb72560d90c9d9ccab6fabe1825b48097" alt="Key example of a text area correctly using sentence case styling for the label text. Label Hobbies and interests. Value text Photography, gardening."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/db4a8/db4a849ea2db6c165a30410dd2de2ec14a480255" alt="Key example of an incorrect text styling on a text area. Title case for the label text. Label Hobbies and Interests, value Photography, gardening."
Mark the minority of text areas in a form as required or optional#
In a single form, mark only the required fields or only the optional fields, depending on whichever is less frequent in the entire form. If most of the text fields are optional, only the required fields should be give an asterisk or have labels appended with “(required)”. If most of the text fields are required, only the optional fields should be appended with “(optional)”. An asterisk should never be used to note that a text area is optional.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/f6e89/f6e896e3456a6aac50571611d132d3ad7aad1840" alt="Key example of a group of text areas correctly marking the minority of text areas as optional. 3 text areas, labels First name, Last name, Interests (optional)."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/0cd82/0cd823aab393e579273a0f21274027c7cef7aab6" alt="Key example of a group of text areas incorrectly marking the majority of text areas as required. 3 text areas, labels First name (required), Last name (required), Interests."
Don't use quiet style for fixed-height text areas#
Because text areas are typically taller and wider than other components, it’s important to include the background of the field in order to help a user know where to click or tap to start entering text. If a text area is using the quiet style, the field underline may be too far away from the text to be recognized as part of the component. Only use the quiet style when the height option is not a fixed number.
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/be9c6/be9c691ea6faf3ff02f7918c0842aa4c01e42483" alt="Key example of a text area incorrectly using the quiet style with a fixed number-height."
Use help text to show hints, formatting, and requirements#
The description in the help text is flexible and encompasses a range of guidance. Sometimes this guidance is about what to input, and sometime it’s about how to input. This includes information such as:
- An overall description of the input field
- Hints for what kind of information needs to be input
- Specific formatting examples or requirements
The help text’s message should not simply restate the same information in the label in order to prompt someone to interact with it. Don’t add help text if it isn’t actually relevant or meaningful to a user in order to try to maintain layout continuity with other inputs that require help text.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/1b7d2/1b7d21efee84cfc117b1be8d83e5b3a5ca7d42df" alt="Key example of correct usage of help text in a text area. Text area label, Interests. Help text in grey color, Describe the interests you’d like to explore through our tutorials."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/0e4a2/0e4a299cecb15229f8d28abd5e60579ef065e714" alt="Key example of incorrect usage of help text in a text area. Text area label, Interests. Help text in grey color, Enter your interests."
Don’t use placeholder text#
Putting instructions for how to complete an input, requirements, or any other essential information into placeholder text is not accessible. Once a value is entered, placeholder text is no longer viewable; if someone is using an automatic form filler, they will never get the information in the placeholder text.
Instead of placeholder text, use the help text description to convey requirements or to show any formatting examples that would help user comprehension. If there's placeholder text and help text at the same time, it becomes redundant and distracting, especially if they're communicating the same thing.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/4d9e0/4d9e0b3b42a4c6021eba14f16097a6e66abdb7a0" alt="Key example of correct usage of help text instead of placeholder text in a text area. Text area label, Interests. Help text in grey color, Describe the interests you’d like to explore through our tutorials."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/f7009/f70096b4bbf005b14f8e3249356044ea03af9164" alt="Key example of incorrect usage of placeholder text instead of help text in a text area. Text area label, Interests. Placeholder text inside of text area, Describe the interests you’d like to explore through our tutorials."
Switch help text with error text#
The help text area also displays an error message. When a text area already includes help text and an error is triggered, the help text is replaced with error text. Once the error is resolved, the help text description reappears below the field.
Since one gets replaced by the other, the language of the help text and error text need to work together to convey the same messaging. Help text explains the requirement or adds supplementary context for how to successfully complete the input. Error text tells a user how to fix the error by re-stating the input requirements or describing the necessary interaction. Make sure that the help text and the error text include the same essential information so that it isn’t lost if one replaces the other (e.g., minimum requirements).
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/cd09c/cd09cdf49403b921f6f8c2d1aa1d04654a9a18ea" alt="Key example of correct usage of switching help text with error text. Required text area, label Interests. Help text description in grey color, Describe the interests you’d like to explore through our tutorials. Error text message in red color, Enter at least one interest."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/57cf9/57cf91a2f521818d70c45607bc96d51e13328139" alt="Key example of incorrect usage of switching help text with error text. Required text area, label Interests. Help text description in grey color, Enter your interests. Error text message in red color, Enter your interests."
Write error text that shows a solution#
Write error messaging in a human-centered way by guiding a user and showing them a solution — don’t simply state what’s wrong and then leave them guessing as to how to resolve it. Ambiguous error messages can be frustrating and even shame-inducing for users. Also, keep in mind that something that a system may deem an error may not actually be perceived as an error to a user.
Error text should be written in 1-2 short, complete sentences and in a clear and straightforward way. End sentences with a period, and never with an exclamation point. For text areas, the nature of the error is often related to something that needs to be fixed for in-line validation, so a
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/9c903/9c903974a9eb0b1951673ac958980e2e3ad2e4b4" alt="Key example of correct way to write an error message. Required text area, label Interests. Error message shown in red color, text Enter at least one interest."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/4eba2/4eba255e71d393e9a1da7ad3238bf09a3f5b4b3a" alt="Key example of incorrect way to write an error message. Required text area, label Interests. Error message shown in red color, text Invalid field."
Internationalization#
Keyboard interactions#
Changelog#
- Updated read-only option design
- Updated all colors to 6.0.0
- Removed placeholder text option
- Updated read-only option design
- Added size option
- Updated border color to be more accessible
- This component has been added to the website
Design checklist#
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All interactive states
Includes all interactive states that are applicable (hover, down, focus, keyboard focus, disabled).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All color themes
Works properly across all four color themes (lightest, light, dark, darkest).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All platform scales
Includes a desktop scale (UWP, macOS, web desktop) and a mobile scale (iOS, Android, web mobile).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Accessible use of color
Color is not used as the only visual means of conveying information (WCAG 2.0 1.4.1).
data:image/s3,"s3://crabby-images/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
Accessible contrast for text
Text has a contrast ratio of at least 4.5:1 for small text and at least 3:1 for large text (WCAG 2.0 1.4.3).
Accessible contrast for UI components
Visual information required to identify components and states (except inactive components) has a contrast ratio of at least 3:1 (WCAG 2.1 1.4.11).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Content design
UI language and information design considerations have been incorporated into component design.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined options
Includes relevant options (variant, style, size, orientation, optional iconography, decorations, selection, error state, etc.)
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined behaviors
Includes guidelines for keyboard focus, layout (wrapping, truncation, overflow), animation, interactions, etc.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Usage guidelines
Includes a list of dos and don'ts that highlight best practices and common mistakes.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Writing guidelines
Includes content standards or usage guidelines for how to write or format in-product content for the component.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Internationalization guidelines
Works properly across various locales and includes guidelines for bi-directionality (RTL).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Keyboard interactions
Follows WCAG 2.0 standards for keyboard accessibility guidelines and includes a description of the keyboard interactions.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Design tokens
All design attributes (color, typography, layout, animation, etc.) are available as design tokens.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
UI kit
Includes a downloadable XD file that shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Generated UI kit
Includes a downloadable XD file, generated by code using design tokens defined in Spectrum DNA, and shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.