On September 25th, 2024, we released v2 of the Apps SDK. To learn what’s new and how to upgrade, see Migration FAQ and Migration guide.

Loading

Guidelines for using progress and loading indicators.

Loading indicators are an important way to provide feedback to users when a process is taking place. Common examples include:

  • Loading the app when data is being fetched.
  • A process is occurring, such as export, saving, or payment.

For an example of how to implement this pattern, see the Storybook(opens in a new tab or window).

Types of loading indicators

We have three types of loading indicators:

When to use

Placeholders

Use placeholders in place of content while it's being loaded. They help reduce cognitive load and give an indication of what users should expect once the content has loaded. Where possible, use placeholders instead of alternative loading methods, such as spinners.

Placeholders consist of basic shapes, such as circles and rectangles, and are used in a way that represents the structure of the loading content.

To create a new placeholder, import existing placeholders, either the basic shapes or those created by others, and arrange them as needed. Modify the size and color of the placeholders to allow you to recreate any existing component.

The basic placeholder shapes:

By default, all placeholders have a flashing animation. Multiple placeholders can be orchestrated to flash in sequence using the index prop.

You can access all of the basic shape placeholders through the App UI Kit's Placeholder component. Or, if you're loading text content, use TextPlaceholder or TitlePlaceholder.

Progress bars

Bar progress indicators are helpful when the waiting time could be 5 seconds or more. Having a determinate state provides more incentive for users to stick around longer.

You can find a pre-built ProgressBar in the App UI Kit.

Animated circle loaders

Circle loading indicators are helpful for shorter wait times and are perfect for more confined spaces, such as buttons.

You can find a circular LoadingIndicator in the App UI Kit.