Empty state
Empty state
Component demo
Interactive example
When to use
Use an empty state component to communicate to people that no content is available to display. Use them to engage people and guide them on what is best to do next by including a button or a link to the next best action.
Empty states are used for many different reasons such as:
-
No content yet exists due to the first-time use of the functionality.
-
Data was not successfully loaded.
-
A query or search term yielded no results.
-
Data was removed resulting in nothing remaining to display.
Use empty states when no data can be displayed in a component’s contents. For example, show an empty state when no data is available to display in a data table, or if a search term didn’t find any results.
data:image/s3,"s3://crabby-images/18d4f/18d4f478393c7a708d8cb5eb74e2900314ff6601" alt="An example app called ‘We love coffee’ with a page displaying favourite teas. An empty data table is displayed with an empty state that reads ‘There’s nothing here’."
Use empty states to highlight access issues. If a user does not have access to some content, use an empty state to provide this messaging as well as a means of continuing.
data:image/s3,"s3://crabby-images/6ace9/6ace9bcaf0f9e64ba971115febf00561b406b521" alt="An example app showing favourite coffees. The ‘americano’ product is selected, but show’s a ‘locked’ status on it. A drawer is displayed containing an empty state component that reads ‘Sorry, you don’t have access to this at the moment’."
Empty states are not always due to errors, so use positive messaging as well. For example, in a to-do list app, all items might have been cleared and so the empty state message may be celebratory.
data:image/s3,"s3://crabby-images/d5acd/d5acda7788acefd59d76f78acfa2b0b399498136" alt="An example app that shows new orders for coffee that need to be fulfilled. After the orders have been completed, an empty state component is displayed showing a positive message that reads ‘All done! Have a cuppa’."
Use empty states as starting points for processes that require people to add input into an app. For example, a calendar entry may have no events yet, so use an empty state to prompt for an event to be added.
data:image/s3,"s3://crabby-images/e44a5/e44a5be777b5d9f75beff6f007ff9177d821a7c3" alt="An example app showing a product customisation page for an Americano coffee. A section appears titled ‘Extras’ and an empty state message is displayed prompting the user to ‘add extras’."
When not to use
Avoid using custom components instead of empty states. The empty state component creates an easily understandable, consistent method of indicating that no data is available and therefore what to do next.
Don’t use empty states to communicate other messages to people that are not related to something being empty, use
data:image/s3,"s3://crabby-images/c98b6/c98b61324b6e95b0262040592d9ca4188dee6040" alt="A blog post titled ‘The perfect blend’. An empty state component is used inline with the content that reads ‘This is a brand new post’."
Don’t use empty states to show error messages that could otherwise be displayed using other
Don’t use empty states to indicate something is loading, instead use a
data:image/s3,"s3://crabby-images/0ca6e/0ca6e4f20c97fdb1c36e11d564d2a920119eceb4" alt="An empty state component being used to indicate that an order history is loading."
Sizing
Embed empty states in components that would otherwise show data. For example, use them in containers, cards, dialogs or data tables.
Use an empty state on a full screen in case something couldn’t be loaded, or there is no content available yet. For example, use an empty state to show a 404 message.
data:image/s3,"s3://crabby-images/ec920/ec92092eb8ac8d8f7a5d0c9fd83109547323aaf5" alt="An empty state component displayed on a full screen that reads ‘There’s nothing here.’"
data:image/s3,"s3://crabby-images/c6a5c/c6a5ce33cc7e994d109ebd51e3e103dd3d67e95f" alt="An example app with a side panel displayed over the page content containing an empty state component that reads ‘No comments yet’."
data:image/s3,"s3://crabby-images/41869/41869c713c1d87681c74c0fbaf19d931b5b23226" alt="A grid of cards for coffee products with one card showing an empty state component that reads ‘Woops, this coffee cup is empty’."
Layout and placement
Set the alignment of the empty state to match the component or container it sits in.
Place empty states at the top and don’t resize the container, keep it sized the same as if the primary content was displayed instead.
Content
Use the empty state to clearly communicate to someone what has happened, why they are seeing the empty state and what to do next.
data:image/s3,"s3://crabby-images/1570c/1570cfdce0bc7cd817b0fc29bb5bcfc753328e8a" alt="A diagram showing the different elements that make up the empty state component. These are an image or icon, a title, a subtitle, some body text, and an interaction area."
Add an illustration, image or icon to an empty state to provide additional recognition or reinforce the written message.
Use the empty state heading to clearly indicate the state of the empty content.
Use the subheading to add more detail and explain why this may have happened.
Use the body to explain how to rectify the issue, or to explain what is best to do next.
Use the interaction area to include actions and links that will help people to continue through the app. Always include either a primary button or a navigation link, and occasionally include a secondary button or link if other routes are possible.
However, avoid placing too many actions in the interaction area as this will cause confusion about what to do next.
data:image/s3,"s3://crabby-images/992c1/992c13efdf825695aabf78f668b1ffcaed07f319" alt="An empty state component that has three buttons and three links within its interaction area."
Don’t place other interactive components, such as inputs, in an empty state’s interaction area. If input needs to be collected, then do this on a full page or on a dialog.
data:image/s3,"s3://crabby-images/65077/65077abde5b3dae3499a66aec1dd7d5f36b32c4b" alt=""
Accessibility considerations
If an empty state is displayed as a result of a change on a page, make sure it is announced by a screen reader using a live region.