Button

A Button is a clickable element used to initialize an action.

Import#

import { Button } from '@volue/wave-react';

Examples#

Basic#

Variants#

We provide buttons of three "visual" variants: strong (high emphasis), outline (medium emphasis) and ghost (low emphasis).

Sizes#

Wave provides two button sizes ‐ medium and small, with exception of lone icon buttons which can also be xSmall or xxSmall.

  • medium size buttons are used by default.
  • small size buttons and xSmall lone icon buttons can be used in cases when there is limited space available for rendering, like in data tables or complex dashboards.

Responsive#

Button supports responsive syntax for its size property, which means you can change its size based on the viewport.

Multi-sizing#

Wave provides applySizes utility, which lets you specify size "scopes" within your app.

import { applySizes } from '@volue/wave-react';

All buttons within a scope will share the same size unless overwritten on a per-control basis.

Color scheme#

You can theme the buttons using color prop.

Different button color schemes have special purposes that are indicating specific actions to the users. Check the guidelines below for details.

Accent (default)#

Success/Danger#

Inverse (white)#

Button with icon#

You can add left and right icons to the Button component using the leftIcon and rightIcon props respectively.

Icon only button#

Buttons may include an icon without a label. Icon only buttons work well in compact spaces.

Please provide aria-label prop to support assistive technology (i.e. screen readers) or wrap the button with a tooltip.

Button states#

Disabled#

Each button may be displayed as disabled.

Loading#

Pass the isLoading prop to show button in a loading state. By default, the button will show a spinner and leave the button's width unchanged.

You can also pass the loadingText prop to show a spinner and the loading text.

As link#

Elements that are visually equivalent to buttons but change the URL and link to a new experience should be rendered as HTML anchor tags. Provide an as prop, and the button will render as an anchor tag.

as prop allows you to change the component to a different HTML tag or custom component (so called polymorphism).

This will merge the original component props with the props of the supplied element/component and change the underlying DOM node. You can now pass extra props to the underlying <a> element such as href etc. and it's perfectly type-safe 🎉


API Reference#

Prop
Type
Default
as
enum
button
css
StitchesCss
No default value
variant
enum
"strong"
size
enum
No default value
color
enum
"accent"
leftIcon
React.ReactElement
No default value
rightIcon
React.ReactElement
No default value
withLoneIcon
boolean
false
shape
enum
"default"
isLoading
boolean
false
loadingText
string
No default value
isDisabled
boolean
false
isActive
boolean
false
isNarrow
boolean
false

Guidelines#

Variants#

Different button variants have special purposes that are indicating specific actions to the users. Each button type should represent correct actions consistently, considering their hierarchy and emphasis.

Button banner
Button type
Purpose
Primary
The primary button serves as a main call-to-action on the layout. It's important to keep its appearance to one time per screen to lead users attention correctly. If the user have to choose between primary and secondary action, consider using outline button or ghost button for the secondary action.
Secondary
This type of button can be used as an alternative to the primary button if the actions requires less focus or attention. Secondary buttons should be used in tandem with a primary button.
Ghost
This type of button, similarly to the outline button, can be used for less-pronounced actions. Since ghost buttons don’t have a container, they don’t distract from nearby content.
Danger
Such buttons are used for an indication of negative actions or post-effects of actions (action such as "Remove" or "Delete"). They're coming in three styles: primary, secondary, and ghost.
Success
Success buttons are indicating positive actions or post-effects of actions. They're also coming in three styles: primary, secondary, and ghost.

Button sizes#

Button sizes
Button size
Use case
Large 48px/3rem
This size is used for visually emphasising important actions.
Medium 40px/2.5rem
This size is used by default for primary page actions and other standalone actions.
Small 28px/1.75rem
Smaller buttons are used in case when there's not enough space for a default button, like in data tables or complex dashboards.

Alignment#

Alignment rules will help you understand how to align your buttons based on the context of the interface.

Button alignment
Alignment
Use case
Left side
One-page forms, and nested buttons in components like tiles or table lists.
Right side
Notification toasters, modal windows, popups, inline field buttons, header above the data tables, form in a stepper, and single-button dialogs.
Center
Mobile resolutions, features on maps.

Hierarchy#

Visual hierarchy in the UI is crucial. It helps to find the needed elements and information efficiently.

Having a single high-emphasis button clarifies that other buttons are less important in the hierarchy.

At the same time, the layout can also contain more than one button at a time. A high-emphasis button can be followed by medium- and low-emphasis buttons that perform less critical actions.

Button - Corrent Hierarchy
Do use high-emphasis and medium or low-emphasis buttons in a button group.
Button - Wrong Hierarchy
Don't use only high-emphasis buttons in a button group.

Text labels#

Text labels are communicating the action that will be performed when the user interacts with the button. Text labels in buttons must be clear, not long as poems, and predictable.

Button - Corrent text label
Do combine nouns under the verb if the action of the verb is relating to both nouns.
Button - Wrong text label
Don't use verbs separately if their action is relating to respective nouns.
Button - Correct value styling
Do use "Uppercased first letter" or "Capitalized" text formatting options.
Button - Wrong value styling
Don't use other text formatting options.

Buttons with icons#

A button can include an icon to clarify and call attention to a specific action.

  • Icons within the buttons should be 16px/1rem by 16px/1rem
  • Use icons that are directly related to the action that the user is taking
Button - Correct icon in the btn aligned to left
Do use a button icon-left if the button is aligned to the left side.
Button - Wrong icon in the btn aligned to left
Don't use a button with icon-right if the button is aligned to the left side.

The alignment of icons within buttons depends on the layout and the context of where these elements are used.

Button - Correct icon in the btn aligned to left
Do align icons in buttons to the correct sides of the movement, in the case of a stepper.
Button - Wrong icon in the btn aligned to left
Don't align icons in buttons to the opposite sides of the movement, in the case of a stepper.

Icon-only buttons#

In some cases, an icon-only button can be used in the layout. Usually, such practice is used for simple meaning actions.

Button danger
Button - Overview of the icon-only buttons

An example of a correct replacement of the text labels with icons.

Don't replace a complicated text label with a single icon

Not all actions can be replaced with an icon.

Button groups#

You can group together buttons related by function. A button group is a series of buttons laid out next to each other, joined together to create one continuous UI.

Button groups are useful to create "toggles" that allow to switch between two or more options. This can be used to filter content for example.

Danger and success buttons#

Danger and success buttons are available in three types: primary, success, ghost. The use of each depends on the level of emphasis of the action.

Button danger
Types of a danger button.
Button - Wrong icon in the btn aligned to left
Types of a success button.

Map controllers#

A lot of Volume products are operating using maps. Follow the guide below to make sure that your map controlling buttons are consistent and convenient.

One-page form
1
"Zoom in" controller
2
"Zoom out" controller
3
"My location" controller
Correct location of the map controller in the bottom right corner
Do locate controllers in the bottom right corner.
Button - Wrong icon in the btn aligned to left
Don't locate controllers in the centre or the middle of the map's viewport.
Correct location of the map controller in the bottom right corner
In specific use cases, controllers can be located in the top left corner.
Button - Wrong icon in the btn aligned to left
Don't break the controller's layout.

A recommendation for the icon of the My location controller.

Correct location of the map controller in the bottom right corner

Locate icon

Use the `locate` icon for web applications, where the GPS navigation is unavailable.
Correct location of the map controller in the bottom right corner

Location icon

Use the `location` icon for mobile solutions, where the GPS navigation is available.