Button
Button is used to initiate actions on a page or form.
Page navigation navigation
Buttons allow users to initiate an action or command when clicked or tapped. The Button's label or text description indicates the purpose of the action to the user. At GitHub, buttons are a fundamental building block of our products. Most of the time, we use the secondary
variant, but other variants of buttons may be used to indicate something special about the Button's hierarchy or functionality.
Anatomy
data:image/s3,"s3://crabby-images/c7a40/c7a40f7c6b1d626efb4d17dc47d19b4576e4ba52" alt="Anatomy of a Button, including the label, leading visual, trailing visual, and trailing action"
Inactive buttons
data:image/s3,"s3://crabby-images/8afa8/8afa8669d5ed0158fe328c9dfa29044a9efe734a" alt="A Button that looks like a disabled primary Button, but it has a focus state"
An inactive Button has styles that make the Button appear "muted". The style is the same for all Button variants.
An inactive Button is an accessible alternative to a disabled Button. They're intended to be used for buttons that are non-functional, but cannot be removed from the page.
Unlike a disabled Button, an inactive Button can respond to user input. For example, if a Button shows a tooltip when hovered or focused, or a Dialog when clicked.
If you need to use an inactive Button, it's best to have something else on the page that informs users about the issue that broke the Button's normal functionality. For example, showing a global Banner for service outages.
Ways an inactive Button should respond to user input
- Show a Dialog on click: When a user tries to activate an inactive the Button, open a Dialog that explains why the action cannot be completed and give them a path forward if possible. It is required to provide some kind of feedback when a user clicks a Button.
- Show a tooltip on hover or focus: Before a user tries to activate a non-functional control, a Tooltip with additional context may be displayed on hover or focus. It is not required to respond to hover and focus.
Best practices
Primary variant
Only use one primary Button on a page, whenever possible, to indicate its emphasis relative to other actions.
General
data:image/s3,"s3://crabby-images/8ecf8/8ecf852b1e9f5b9ef3a321a3918418f78c26de2d" alt="An image showing a Button with no line breaks"
data:image/s3,"s3://crabby-images/1deaa/1deaaf44944ef24d654c33c8b3f1b17ab34a9320" alt="An image showing a Button with a line break"
data:image/s3,"s3://crabby-images/75955/759557ec7e5cb4f18a0334d9523bf55b8368e283" alt="A Button using sentance case"
data:image/s3,"s3://crabby-images/e5467/e54672744457c6e2eceb621ea3d594fd2267ddae" alt="A Button with text in all caps"
data:image/s3,"s3://crabby-images/1c38c/1c38cc5c4ae4a03eb6ce057f8ca37901925f741c" alt="A Button showing :focus state"
data:image/s3,"s3://crabby-images/e9514/e95145662662d41a96140a52a9d6e3ad243ccd62" alt="A Button with the default :focus styles removed"
data:image/s3,"s3://crabby-images/7441a/7441a108f44ac58f37d6faccbd2b79a4c53b5dc8" alt="Primary Button placed at the end of the ButtonGroup"
data:image/s3,"s3://crabby-images/b57a7/b57a7e017403e86cdd41ef75126bd62d613c88c5" alt="Primary Button placed at the start of the ButtonGroup"
data:image/s3,"s3://crabby-images/a6242/a62429ef036105472352eb8a15dec29bdcedc263" alt="A primary Button next to a secondary Button"
data:image/s3,"s3://crabby-images/23ea4/23ea43a3a46e1a52480a1f7399b8d873ae4fee10" alt="Multiple primary buttons placed together"
Selections
Buttons are commonly used to show a choice within a SelectPanel or ActionMenu. In such instances, they are frequently paired with an internal or external label.
data:image/s3,"s3://crabby-images/0b0ab/0b0ab440407a503d12d565d65f071c3b9368b7ef" alt="Two examples of dropdown buttons are shown. The left one has a label 'Visibility: Everybody' and is marked as 'Internal label'. The right one has an external label 'Visibility' above the Button and a internal label 'Everybody', and is marked as 'External Label'."
When dealing with multiple selections, it's essential to maintain clarity regarding the total selection at all times. We suggest showing the value directly within the Button. However, in scenarios where multiple items are selected, transitioning to a format such as 2 selected
is advisable.
data:image/s3,"s3://crabby-images/52c3b/52c3b111538d09061f9e85d2a8b6d197e96c00eb" alt="Button with label 'Labels: 2 selected'"
data:image/s3,"s3://crabby-images/cc25a/cc25a7db8f9361e59c88a88be3ec29c2c9001a63" alt="Button with label 'Labels: feature-request,bu...'"