Progress stepper
Progress steppers are visual indicators of progression through a process or experience.
- Skin
- CoreUI
- React
Glanceable
Progress steppers are immediately understandable at a glance.
Minimal
Progress steppers use minimal visual UI to allow for quick identification.
Informative
Progress steppers focus on key milestones.
- Trailing line
- Icon
- Leading line
- Primary label
- Secondary label
Label
All steps require a primary label. The label describes an important milestone within a process.
An optional secondary label is available for additional information, like the date a step was completed.
Title
The title sits above the progress stepper and summarizes the latest update in a conversational tone.
Horizontal orientation
Use horizontal steppers when saving vertical space is important. They allow for scrolling if the content extends off screen, but we recommend avoiding this behavior where possible.
Vertical orientation
The vertical orientation is available when vertical space isn’t an issue. This is the preferred orientation on smaller screens with more steps.
Incomplete state
Steps that have not been completed use the incomplete state. Incomplete steps indicate what is expected to occur, and only changes state when completed or when an issue occurs.
Latest state
A checkmark and bold title means this was the most recent completed step and the following step is in process. This state doesn’t apply to the last step in the stepper.
Completed state
A checkmark and non-bold label means this step is complete and the process has moved on. The final step of the stepper enters this state by default when completed.
Blocked state
The outlined error icon indicates that a blocking issue has occurred and requires user attention before the process can continue. Errors should be paired with an alert banner or notice providing more information about what happened and how to resolve the issue, if possible.
Errors
When an error occurs, a section notice or alert banner should appear providing more information and context to the occurrence.
If the issue can be resolved by the user, provide an action within the notice. If the issue is something out of the user’s control, provide as much detail as possible.
Number of steps
Steppers have a minimum of 3 steps. There are no maximums, but aim for as few as possible to avoid overwhelming the user. Focus on the key milestones within a process.
Minimum height
For vertical steppers, the minimum gap height between step icons is 24px.
Minimum step width
For horizontal steps, the minimum gap width between step icons is 104px.
Maximum stepper width
If there are enough steps, steppers will stretch to fill their parent container. Aim to keep steppers to a reasonable width according to the number of steps. Overly wide steppers can reduce the stepper’s readability.
Scroll behavior
The stepper component behaves similar to a carousel when the content extends beyond the screen. The latest step is scrolled into view by default.
Label overflow
Longer labels wrap to a new line when wider than the step’s width. Keep titles and secondary labels to fewer than 25 characters to avoid overly tall stepper heights.
Content
Use a minimum of 3 steps and keep each step concise.
Don’t use redundant steps like “in-transit,” “processing,” or “completed”. The lines and checkmarks imply those states.
Labels
Keep all steps past tense.
Don’t use present tense for a step that has been or has yet to be completed.
Number of steps
Progress steppers should have a minimum of 3 steps.
Don’t use progress steppers if there are only 1 or 2 steps. Explore using titles and body content or another pattern altogether.