Design Guidelines
Selection Control
Selection controls allow the user to select options.
Usage
Selection controls allow users to complete tasks that involve making choices such as selecting options, or switching settings on or off. Selection controls are found on screens that ask users to make decisions or declare preferences such as settings or dialogs.
data:image/s3,"s3://crabby-images/422c6/422c6fac3cadd98290f17d6fc11cd7ea4f7b205d" alt="Selection controls Selection controls"
Selection controls
Principles
Familiar
Selection controls have been in user interfaces for a long time and should be used as expected.
Scannable
It should be visible at a glance if a selection control has been selected, and selected items should be more visually prominent than unselected items.
Efficient
Selection controls make it easy to compare available options.
Checkboxes
When to Use Checkboxes
Use checkboxes to:
- Select one or multiple items from a list
- Present a list containing sub-selections
- Turn an option/setting on or off
data:image/s3,"s3://crabby-images/d051b/d051b59e01e681b0b229b69c7f482e7f20f0f5aa" alt="Checkbox example Checkbox example"
Checkboxes
Parent and Child Checkboxes
Checkboxes can have a parent-child relationship with other checkboxes.
- When the parent checkbox is checked, all child checkboxes are checked
- If a parent checkbox is unchecked, all child checkboxes are unchecked
- If some, but not all, child checkboxes are checked, the parent checkbox becomes an indeterminate checkbox
data:image/s3,"s3://crabby-images/0989c/0989c13564d8309af0052bffbfa04d512bb24c7e" alt="Checkbox parent child example Checkbox parent child example"
Parent-child relationship for checkboxes
States
Checkboxes can be selected, unselected, or indeterminate. Checkboxes have enabled, disabled, focused and pressed states.
data:image/s3,"s3://crabby-images/5d802/5d802f44268eb3b93f8c1864dd37bcb7997ca45e" alt="Checkbox states Checkbox states"
Checkbox states
Colors
The default color used for checked checkboxes is the "primary" color in the Magma palette, but sometimes a special scenario or specific UI can benefit from using one of the other colors from the palette. Colors like Success Green, Danger Red, or just one of the "Pop" colors, when used responsibly and consistently, can help add context to your checkbox or just add some visual interest.
data:image/s3,"s3://crabby-images/43e1d/43e1d9d8cb0513b240d67d725e5ab423f1281d2a" alt="Checkbox alternate colors Checkbox alternate colors"
Alternate colors
Inverse Checkboxes
Sometimes you have to put those checkboxes on a dark background, and that's when you'll want to use the inverse version. You can also still use alternate colors like Success Green and Danger Red if you wish.
data:image/s3,"s3://crabby-images/20077/20077c95c4e17fdf5be76dc0c4a12e2451deb160" alt="Checkbox inverse Checkbox inverse"
Inverse colors
data:image/s3,"s3://crabby-images/7f31f/7f31ff9e8b38a10c84a5b7aa25cd1f5ec771d8e7" alt="Checkbox incorrect multi color Checkbox incorrect multi color"
Incorrect
Don't use multiple colors in the same UI. Pick one and stick with it.
data:image/s3,"s3://crabby-images/98885/98885688ecebb22d7b1537a85cbe754591bf8385" alt="Checkbox incorrect neutral Checkbox incorrect neutral"
Incorrect
If you're going to change the color, don't use a neutral color. This could be confused with a checkbox that is checked and disabled.
Radio Buttons
When to Use Radio Buttons
Use radio buttons to select a single option from a list. Radio buttons should be used instead of checkboxes if only one item can be selected from a list.
data:image/s3,"s3://crabby-images/cacd0/cacd04b9cb9fd328c3ba46e97ac7904a16861343" alt="Radio buttons example Radio buttons example"
Radio buttons
data:image/s3,"s3://crabby-images/2fd0e/2fd0e9a719ae9e113ad421a96566c9bbdf6cbf8e" alt="Radio select only one Radio select only one"
Correct
Use radio buttons when only one item can be selected from a list.
data:image/s3,"s3://crabby-images/41f8d/41f8d86f2680d4d51034c76c55afc3e448be9a9f" alt="Radio select only one incorrect Radio select only one incorrect"
Incorrect
Don’t use checkboxes when only one item can be selected from a list. Use radio buttons instead.
data:image/s3,"s3://crabby-images/06644/0664499203e6ddfea3b8bab5c5db53b679d56705" alt="Radio example 2 Radio example 2"
Radio buttons - only one option can be selected at a time.
States
Radio buttons can be off or on. Radio buttons have enabled, focused and pressed states.
data:image/s3,"s3://crabby-images/8ae2e/8ae2ea6ce03d234d1fba35aab908e9c1387366eb" alt="Radio states Radio states"
Radio states
Colors
The default color used for radio buttons is the "primary" color in the Magma palette, but sometimes a special scenario or specific UI can benefit from using one of the other colors from the palette. Colors like Success Green, Danger Red, or just one of the "Pop" colors, when used responsibly and consistently, can help add context to your radio button or just add some visual interest.
data:image/s3,"s3://crabby-images/2848c/2848c98452afe56b0da1611ffae87732f13344fc" alt="Radio alternate colors Radio alternate colors"
Alternate colors
Inverse Radio Buttons
Sometimes you have to put those radio buttons on a dark background, and that's when you'll want to use the inverse version. You can also still use alternate colors like Success Green and Danger Red if you wish.
data:image/s3,"s3://crabby-images/4aa0d/4aa0ddce61b9bb2634d785b0c69c6bd1cbca95fb" alt="Radio inverse Radio inverse"
Inverse colors
Toggle Switches
When to Use Toggle Switches
Use toggle switches to toggle the state of a single setting on or off. You may use toggle switches within a web application, but keep in mind that they are most common within mobile applications.
data:image/s3,"s3://crabby-images/5cd0e/5cd0e57a0ce46117db8fefc18105acd25280dade" alt="Toggle switch example Toggle switch example"
Toggle switches
States
The state of a toggle switch is changed by tapping or clicking on it, and the handle slides over to the other side of the track.
Text Label
The setting that the switch controls is made clear by the inline text label.
data:image/s3,"s3://crabby-images/7af25/7af256654b993bcdff86b9c38615ee6a1a7ab04e" alt="Toggle switch states Toggle switch states"
Toggle switch states