Stepper
Stepper
Introduction
An example of the stepper component.
Interactive example
Component variants
Default
Use the default stepper when you have the available space.
Compact
Use the compact variant for compact layouts or processes with many steps.
When to use
Use steppers when a multi-step linear process is required. Steps are displayed from left to right and show the direction of movement through the process.
data:image/s3,"s3://crabby-images/706de/706de150df1371d043a13f4d3e20d9990d620359" alt="An image showing a form titled 'Make a coffee' featuring a stepper with four steps, titled 'Take order', 'Make drink', 'Take payment', and 'Finish'. The first step is selected, and the page below shows three input fields and a button labelled 'Confirm order'."
Always indicate which step the user is currently on. This gives a sense of control and describes their position in the process in relation to where they have been, as well as how much they have left to do.
When not to use
Don't use the stepper to indicate a non-linear process where steps can be completed in any order. Linear processes require each step to be completed in order.
Interaction behaviour
Steps
Steps are single elements that together form the stepper. Steps have four different states:
-
Active: Indicates that the step is available but not yet completed by the user. This step type is rendered as current if displayed in the compact stepper.
-
Current: Shows the step the user is currently on.
-
Completed: Shows a previous step that has been completed by the user.
-
Disabled: Shows a step that is unavailable. This could be because it's conditional on another step. If a step is always unavailable, then it should not be included in the stepper when it's loaded.
Interactive example
Layout and placement
Always align steppers to the left and place them above the main body content of the page.
data:image/s3,"s3://crabby-images/29fc4/29fc4f7cd9750bb81ad63e167eef7909f71992de" alt="An image showing a stepper with four steps, titled 'Warm kettle', 'Add milk', 'Pour water', and 'Drink coffee'. The first step is selected, and the stepper is accurately placed at the top-left of a page."
data:image/s3,"s3://crabby-images/8af33/8af333eda5227616e62a2581cbb3618cc1ac9404" alt="An image showing a stepper with four steps, titled 'Warm kettle', 'Add milk’, 'Pour water’, and 'Drink coffee'. The first step is selected, and the stepper is incorrectly placed in the centre of a page."
When a stepper is too large to fit comfortably within its container, it will switch to use the compact stepper. This shows the current step along with its status, as well as the next step in the process.
data:image/s3,"s3://crabby-images/0cef2/0cef2cb12f3c9604be1e3b7aecd977379ce197dd" alt="A compact stepper showing the current step labelled 'warm kettle' and the next step label 'add milk'."
Content
Labels
Use the heading to describe each step concisely in one or two words. Avoid using lengthy headings.
data:image/s3,"s3://crabby-images/3de29/3de29dfd63b8ec92ad6cc5a4a2ce929bdaff6b48" alt="An image showing a stepper with four steps, labelled 'Take order', 'make drink', 'Take payment', and 'Finish’. The first step is selected."
data:image/s3,"s3://crabby-images/d2583/d25839897cbc166a9c74a1d334ca4d3c39ce0d45" alt="An image showing a stepper with four steps, each with very long labels. The first step is selected."
When a stepper is used, always use page titles and section headings on the page content itself.
data:image/s3,"s3://crabby-images/fb972/fb97272830163a2170252125eaac335e3f837253" alt="An image showing a form titled 'Make a coffee' featuring a stepper with four steps, labelled 'Take order', 'Make drink', 'Take payment', and 'Finish’. The first step, 'Take order', is selected, and the page below shows three input fields and a button labelled 'Confirm order'."
Hide step information only if the step content is clearly labelled itself. Do not omit step labels if no headings are provided in the step content.
data:image/s3,"s3://crabby-images/b591d/b591d17f8d5618a6a020e5e158d84410813b6361" alt="An image showing a form without a heading featuring a stepper with 4 steps, each without a label. The first unlabelled step is selected, and the page below shows three input fields and a button labelled ‘Confirm order’."
Set a status to show whether the step is required or optional in the subheading. Override the subheading text to provide a custom message.
Validation
Validate each step as the user moves through the process. Use the standard error handling approach to display inline