Token
Token is a compact representation of an object, and is typically used to show a collection of related metadata.
Page navigation navigation
Tokens are typically used in groups, either as read-only labels or for data entry.
Anatomy
data:image/s3,"s3://crabby-images/cf38a/cf38a7394a3611a69e28e2e8a88121e78e136a60" alt="token anatomy diagram"
- Leading visual (optional): Provides additional context (e.g.: user avatar)
- Label (required): Concise text label
- Remove button (optional): Removes the token from an editable group of tokens
Interactivity
Tokens are usually interactive, with hover and focus states. They can function like links/buttons but should not replace them.
For removable tokens, users can press "Backspace" or "Delete" to remove. Screen readers should announce these options.
Examples of interactions:
- An issue label token that links to a list of issues with that label
- A user token that shows a profile summary dialog on hover
Truncating tokens
data:image/s3,"s3://crabby-images/27623/27623e8da2a0313f57476efacd378b6cefabc233" alt="a group of tokens restricted to one line with a counter for hidden tokens"
When space is limited, like in a table, some tokens in a group may be hidden. The amount hidden tokens is added in a text label, e.g. +3
. Make sure to add an accessible label like 3 more tokens
to make this screen reader accessible.
It is important to make sure that users can access all tokens in a group, even if they have to navigate to a detail view to see them all.
Tokens as a way to enter information
The TextInputWithTokens component is designed to handle this usage.
data:image/s3,"s3://crabby-images/09258/092587541d0ace7d032c1ccfeabc3e9a8b988c5e" alt="TextInputWithTokens inside with an autocomplete menu below it"
If tokens are being used for data input, it should be obvious that the user is in an edit or creation context.
Consider pairing with Autocomplete for selection.
The remove button is standard but can be hidden if another method suits the case.
data:image/s3,"s3://crabby-images/9bd10/9bd10bf24d067e3ee73395a4c59af1537fef1189" alt="tokens rendered at all sizes"
Tokens in inputs can wrap to multiple lines, expanding the input's height. Set a max height if needed; exceeding rows will scroll.