Skip to main contentCarbon Design System

Progress bar

A progress bar provides feedback about the duration and progression of a process.

Overview

A progress bar indicates that the user’s request has been received and the application is making progress toward completing the requested action. Progress bars inform users about the status of ongoing processes, the estimated time of how long a process will take, or a request is being excuted.

Progress bar hero image

When to use

  • If a process can take a considerable or unknown amount of time
  • When the process can be described with quantitative information, for example as a percentage
  • To visually show the progression of a system operation such as downloading, uploading, loading data, submitting a form, or saving updates
  • To convey that data is being requested, transferred or processed

When not to use

  • When the progress bar will be replaced by a minor user interface element once loaded, use skeleton states instead
  • When manual user actions are required to progress, use a progress indicator instead
  • When the progress is determined by user actions such as tutorials completed, or storage space, rather than system actions
  • If the process takes less than 10 seconds to load, use loading spinners instead

Loading, inline loading, or progress bar?

  • If an activity displays a loading spinners on one screen, it should not show the progress bar elsewhere in the design.
  • Both progress bars and circles can show either determinate or indeterminate progress. The given area should help determine if a progress bar or circle is best for that space. Progress bars are preferred in vertically narrow areas (tables, cards, etc.) while progress circles are ideal for full page loading or in very small areas.

Live demo

Variants

A progress bar can either be determinate or indeterminate. The determinate variant is visualized as a track on which a bar fills up from left to right representing the progress. The indeterminate variant is visualized as a track on which a bar is moving along in constant speed, repeating over time.

VariantPurpose
DeterminateUse determinate progress bars for a specified amount of time or clear information about the progression — they convey exact and qualitative information about the progression.
IndeterminateUse indeterminate progress bars for an unspecified completion of time or unclear information about the progression — they convey that users’ request, action, or data is being processed at the moment without indicating how long the activity will take.
Determinate progress bars fill from 0 to 100%.

Determinate progress bars fill from 0 to 100%.

Indeterminate progress bars move along a fixed track, growing and shrinking in size.

Indeterminate progress bars move along a fixed track, growing and shrinking in size.

Determinate progress bar

Determinate progress bars are used when the loading progress can be tracked and translated into a percentage indicator which fills from 0% to 100% and never decrease in value. The entire animation moves from the left to the right – with no back and forth motion.

Use a determinate progress bar when progress can be calculated against a specific goal. For example, when downloading a file of a known size.

Progress bar uploading

Indeterminate progress bar

Once triggered, the loading bar will begin by moving along in constant speed, repeating over time while data is being gathered during the first stages of the load. This bar then changes to a determinate indicator (finishing from left to right) when enough information is gathered to end the load animation. The final determinate stage of the load is used to visually indicate the completion of the task to the user. In this scenario, a percentage indicator would not be present.

Progress bar uploading

Progress status

It’s best to give the user transparency about the process which usually leads to increased trust in the software or platform. However, it may not be possible to provide progress estimation in certain cases. If progress data is not available, an indeterminate progress bar can be used.

As a more concrete set of examples, there are generally three different major progressions of a system operation: downloading, uploading, and local processing.

Downloading

For downloading actions it’s usually possible to get a value of progress and update it in real time for a determinate progress bar. Depending on the information reported from a data source, time remaining could be estimated based on how much has been downloaded so far over a time period.

Uploading

Upload actions may be unable to report real time progress status depending on the data source and API configuration. In these cases, indeterminate progress bars can be used.

Local Processing

Local processing refers to manipulations or operations done on the local device that does not require communication with an external entity such as a server. This can include currency exchange, file generation, data reformatting, or similar operations. Depending on the operation, time estimated or cycles to complete processing could be used to populate a determinate progress bar. Otherwise, an indeterminate progress bar would be best.

Formatting

Determinate and indeterminate progress bars both have the labels and optional helper text. However, the inderterminate can’t provide the exact, quantiative information about the progression in the optional helper text.

Anatomy

Progress bar anatomy
  1. Label: The text describes the process that the progress bar refers to. Label can be visually hidden, but requires to be defined to be accessible.
  2. Track: The static area that the bar indicator moves on top of and acts as a fixed visual reference of what the total length and duration of the process could be.
  3. Bar indicator: Indicates how much the process has progressed.
  4. Helper text (optional): Assistive text to show additional information about the process taking place. For determinate, the information is usually values of number or percentage. Sometimes, a fraction or ratio may be shown. These values are not applicable when a progress bar is indeterminate.

Sizing

Height

The progress bar is offered in two different sizes—default (8px) and small (4px). The default progress bar height is typically used when there is large amounts of space on a page. The small progress bar height is commonly used when space is restricted and can be placed within cards, data table, or side panels.

Progress bar sizes

Width

The width of a progress bar can be customized appropriately for its context. The minimum width of a progress bar is 48px and keep its width to a maximum of six columns when possible. If the progress bar width is too long it can reduce readability. Don’t increase the progress bar length to fill the entire width of a window or application.

Do keep a width within six columns.

Do keep a width within six columns.

Don't exceed a width of six columns.

Don't exceed a width of six columns.

Alignment

Text alignment depends on the context and area given. As long as the text is placed close to the progres bar, it’s up to designers to provide the best judgement that fits the context.

Progress bar alignments

A few common examples of text alignmnet for progress bars

Internationalization (RTL)

For RTL (right-to-left) languages, the layout of the progress bar is mirrored for both determinate and indeterminate options. The label is right-aligned, the value is left-aligned, and the fill progresses from right to left. Keep in mind that the placement of the percent sign differs depending on the locale.

Progress bar RTL

Text placement

Labels or helper text should always be placed above, below, or beside the progress bar for readibility. Avoid placing text inside or centering text with the progress bar. This visual could cause clutter and inconsistency in text alignment. Meanwhile, placing the text far away from the progress bar could cause confusion in the context.

Do place text inline with the progress bar

Do place text inline with the progress bar.

Don’t embed text into the progres bar

Don’t embed text into the progres bar.

Do place text close to the progress bar

Do place text close to the progress bar.

Don't place text far away from the progress bar

Don't place text far away from the progress bar.

Content

Main elements

Labels

  • Labels inform users what information the progress bar is processing.
  • Keep the label short and concise by limiting it to a single line of text.
  • Labels should never change as the progres bar is loading.

Helper text

  • Helper text is used to show additional information about the process taking place.
  • Common usecases of helper text for a progress bar can either be a generic phrase, for example “Fetching assets…”, or it can indicate an exact amount of something to be completed, for example “42/256 items”.
  • When indicating a loading percentage, the percentage number should count up as the bar progresses.

Further guidance

For further content guidance, see Carbon’s content guidelines.

Universal behaviors

States

There are three states for the progress bar: active, success, and error. These states also apply on both indeterminate and determinate progress bars. After the process completes successfully or unsuccesfully, a progress bar can either remain persistent as confirmation or validation, or it can be automatically dismissed depending on what is most suitable for the use case.

Progress bar states.

Active

The active loading state indicates that the action is still in progress.

Successful

The success loading state indicates that the action completed successfully.

Error

The error loading state indicates that the action did not successfully complete. If an error occurs, an inline notification or error handling within the form should appear. The error loading state indicates that the action did not successfully complete. If an error occurs, an inline notification or error handling within the form should appear. As soon as a process fails, the current visual progress remains but just stops. For example, if a process fails at 75%, then the red line would fill 75% of the total track width.

The example shows the progress bar with error remains persistent as confirmation inside the image tile

The example shows the progress bar with error remains persistent as confirmation inside the image tile.

The example shows thep progress bar is automatically dismissed once it’s done uploading

The example shows thep progress bar is automatically dismissed once it’s done uploading.

Interactions

Part of a page

While the progress bar is processing information on part of a page, you can still interact with other elements on the page. When the progress bar is finished processing it can either remain persistant on the page for confirmation or automatically dismiss itself depending on the usecase.

Progress bar as a part of a page

Inside a container

While the progress bar is processing information that could affect multiple pieces of content within a container, such as a card, depending on the use case, the whole container should become inactive until processing has been completed or the specific section within the container being processed should become inactive until processing has been completed. The user should be able to interact with the rest of the container or page that is unaffected by the progress bar.

Progress bar inside a container

Modifiers

Transitions

An indeterminate bar can change to a determinate indicator (finishing from left to right) when enough information is gathered to end the load animation.

An indeterminate bar can change to a determinate indicator

Accessibility

The loading component is implemented using the ARIA 1.1 progressbar pattern. It outputs an ARIA role=“progressbar” and uses aria-valuemin, aria-value-max, and aria-valuenow to convey the loaded percentage to screen reader users.

If is neccesary to show the percentage and the descriptive text, the developers will have to calculate the percentage on their side with the value ${(value/max*100).toFixed(2)}% (${value} of ${max} items).

Components

Components

Loading, inline loading, or progress bar?

  • If an activity displays a loading spinners on one screen, it should not show the progress bar elsewhere in the design.
  • Both progress bars and circles can show either determinate or indeterminate progress. The given area should help determine if a progress bar or circle is best for that space. Progress bars are preferred in vertically narrow areas (tables, cards, etc.) while progress circles are ideal for full page loading or in very small areas.

References

Accessible Rich, Internet Applications Working Group, [“progressbar” role], (W3C, 2017) Katie Sherwin, Progress Indicators Make a Slow System Less Insufferable (Nielsen Norman Group, 2001) Jakob Nielsen, Response Times: The 3 Important Limits (Nielsen Norman Group, (Nielsen Norman Group,1993)

Feedback

Help us improve this component by providing feedback, asking questions, and leaving any other comments on GitHub.