-
Notifications
You must be signed in to change notification settings - Fork 4.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Button: Revise documentation #66617
Button: Revise documentation #66617
Changes from 11 commits
d50f8a6
0711230
f3db348
ec69ef6
41c4ad5
4f9a5ac
bb2b227
fd025c7
172c49c
8db516e
42d7cb9
0850874
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Large diffs are not rendered by default.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
{ | ||
"$schema": "../../schemas/docs-manifest.json", | ||
"displayName": "Button", | ||
"filePath": "./index.tsx" | ||
} |
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. How about we write the supplementary docs in a file like this? I'm having second thoughts about putting all the documentation into the main Docs page, because it can already be quite long with the props table and the stories. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Chat notes:
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
import { Meta } from '@storybook/blocks'; | ||
import FigmaEmbed from '/storybook/components/figma-embed'; | ||
|
||
<Meta title="Components/Actions/Button/Best Practices" /> | ||
|
||
# Button | ||
Buttons allow users to take actions and make selections with a single click or tap. | ||
|
||
<FigmaEmbed url="https://www.figma.com/design/V7NfxdP0ybEMXf01WyWGKB/Storybook-documentation-Figma-assets?node-id=5-280&node-type=frame&t=JLKM1grrtWleRkFR-11" title="Overview of button variants" height="400" /> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @auareyou I went in and fixed them all in this one, but FYI the |
||
|
||
|
||
## Usage | ||
Buttons indicate available actions and allow user interaction within the interface. As key elements in the WordPress UI, they appear in toolbars, modals, and forms. Default buttons support most actions, while primary buttons emphasize the main action in a view. Secondary buttons pair as secondary actions next to a primary action. | ||
|
||
Each layout contains one prominently placed, high-emphasis button. If you need multiple buttons, use one primary button for the main action, secondary for the rest of the actions and tertiary sparingly when an action needs to not stand out at all. | ||
|
||
## Variants | ||
|
||
### Primary | ||
Primary buttons stand out with bold color fills, making them distinct from the background. Since they naturally draw attention, each layout should contain only one primary button to guide users toward the most important action. | ||
|
||
<FigmaEmbed url="https://www.figma.com/design/V7NfxdP0ybEMXf01WyWGKB/Storybook-documentation-Figma-assets?node-id=5-640&node-type=frame&t=HfUDxJShbqa3dM4N-11" title="Primary variant" height="400" /> | ||
|
||
### Secondary | ||
Secondary buttons complement primary buttons. Use them for standard actions that may appear alongside a primary action. | ||
|
||
<FigmaEmbed url="https://www.figma.com/design/V7NfxdP0ybEMXf01WyWGKB/Storybook-documentation-Figma-assets?node-id=5-808&node-type=frame&t=HfUDxJShbqa3dM4N-11" title="Secondary variant" height="400" /> | ||
|
||
### Tertiary | ||
Tertiary buttons have minimal emphasis. Use them sparingly to subtly highlight an action. | ||
|
||
<FigmaEmbed url="https://www.figma.com/design/V7NfxdP0ybEMXf01WyWGKB/Storybook-documentation-Figma-assets?node-id=5-874&node-type=frame&t=HfUDxJShbqa3dM4N-11" title="Tertiary variant" height="400" /> | ||
|
||
### Default | ||
Use default buttons for actions of equal priority. | ||
|
||
<FigmaEmbed url="https://www.figma.com/design/V7NfxdP0ybEMXf01WyWGKB/Storybook-documentation-Figma-assets?node-id=5-940&node-type=frame&t=HfUDxJShbqa3dM4N-11" title="Default variant" height="400" /> | ||
|
||
### Link | ||
Link buttons have low emphasis and blend into the page, making them suitable for supplementary actions, especially those involving navigation away from the current view. | ||
|
||
<FigmaEmbed url="https://www.figma.com/design/V7NfxdP0ybEMXf01WyWGKB/Storybook-documentation-Figma-assets?node-id=5-1006&node-type=frame&t=HfUDxJShbqa3dM4N-11" title="Link variant" height="400" /> | ||
|
||
### Destructive | ||
Use this variant for irreversible actions. Apply sparingly and only for actions with significant impact. | ||
|
||
<FigmaEmbed url="https://www.figma.com/design/V7NfxdP0ybEMXf01WyWGKB/Storybook-documentation-Figma-assets?node-id=5-1069&node-type=frame&t=HfUDxJShbqa3dM4N-11" title="isDestructive prop enabled" height="400" /> | ||
|
||
### Sizes | ||
|
||
- `'default'`: For normal text-label buttons, unless it is a toggle button. | ||
- `'compact'`: For toggle buttons, icon buttons, and buttons when used in context of either. | ||
- `'small'`: For icon buttons associated with more advanced or auxiliary features. | ||
|
||
## Best practices | ||
|
||
- Label buttons to show that a click or tap initiates an action. | ||
- Use established color conventions; for example, reserve red buttons for irreversible or dangerous actions. | ||
- Avoid crowding the screen with multiple calls to action, which confuses users. | ||
- Keep button locations consistent across the interface. | ||
|
||
## Content guidelines | ||
|
||
Buttons should be clear and predictable, showing users what will happen when clicked. Make labels reflect actions accurately to avoid confusion. | ||
|
||
Start button text with a strong action verb and include a noun to specify the change, except for common actions like Save, Close, Cancel, or OK. | ||
|
||
For other actions, use a `{verb}+{noun}` format for context. Keep button text brief and remove unnecessary words like "the," "an," or "a" for easy scanning. |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -65,6 +65,11 @@ Default.args = { | |
children: 'Code is poetry', | ||
}; | ||
|
||
/** | ||
* Primary buttons stand out with bold color fills, making them distinct | ||
* from the background. Since they naturally draw attention, each layout should contain | ||
* only one primary button to guide users toward the most important action. | ||
*/ | ||
Comment on lines
+68
to
+72
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I am reevaluating this PR from a user perspective, and I realized that we're probably not adding much value by showing a separate page with variants, including a full specimen of hover/active/disabled states. Also, some of the states are already wrong (i.e. not the same as in shipping code). For example, look at all the Link variants — they're all wrong. @auareyou Can you troubleshoot this? Are we using the Figma library components incorrectly in some way? What I see in the Figma embedActual Link variant (default)We already show an interactive list of all the variants in the normal story docs, so I suggest we just move the copy there. That's where all this kind of basic, important information should live. What do you think? The Best Practices page is probably a good home for more supplementary information, like patterns/examples that don't quite fit in the normal story docs. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There's an issue in Figma where replacing underlined text layer values removes the underline 🙃 I fixed it.
I tend to agree with this though. The value doesn't quite reflect the effort, imo. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I moved all the variant descriptions to the main stories 👍 Figma embeds should be a last resort, given the slow load times and maintenance cost. |
||
export const Primary = Template.bind( {} ); | ||
Primary.args = { | ||
...Default.args, | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -111,11 +111,13 @@ type BaseButtonProps = { | |
tooltipPosition?: PopoverProps[ 'position' ]; | ||
/** | ||
* Specifies the button's style. | ||
* | ||
* The accepted values are: | ||
* 'primary' (the primary button styles) | ||
* 'secondary' (the default button styles) | ||
* 'tertiary' (the text-based button styles) | ||
* 'link' (the link button styles) | ||
* | ||
* 1. `'primary'` (the primary button styles) | ||
* 2. `'secondary'` (the default button styles) | ||
* 3. `'tertiary'` (the text-based button styles) | ||
* 4. `'link'` (the link button styles) | ||
Comment on lines
+117
to
+120
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. These descriptions need to be improved (see |
||
*/ | ||
variant?: 'primary' | 'secondary' | 'tertiary' | 'link'; | ||
}; | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
/** | ||
* Internal dependencies | ||
*/ | ||
import './style.scss'; | ||
|
||
// See https://www.figma.com/developers/embed#embed-a-figma-file | ||
const CONFIG = { | ||
'embed-host': 'wordpress-storybook', | ||
footer: false, | ||
'page-selector': false, | ||
'viewport-controls': true, | ||
}; | ||
|
||
/** | ||
* Embed Figma links in the Storybook. | ||
* | ||
* @param {Object} props | ||
* @param {string} props.url - Figma URL to embed. | ||
* @param {string} props.title - Accessible title for the iframe. | ||
*/ | ||
function FigmaEmbed( { url, title, ...props } ) { | ||
const urlObj = new URL( url ); | ||
|
||
const queryParams = new URLSearchParams( urlObj.search ); | ||
Object.entries( CONFIG ).forEach( ( [ key, value ] ) => { | ||
queryParams.set( key, value ); | ||
} ); | ||
urlObj.search = queryParams.toString(); | ||
|
||
urlObj.hostname = urlObj.hostname.replace( | ||
'www.figma.com', | ||
'embed.figma.com' | ||
); | ||
|
||
const normalizedUrl = urlObj.toString(); | ||
|
||
return ( | ||
<iframe | ||
title={ title } | ||
src={ normalizedUrl } | ||
className="wp-storybook-figma-embed" | ||
{ ...props } | ||
/> | ||
); | ||
} | ||
|
||
export default FigmaEmbed; |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
.wp-storybook-figma-embed { | ||
width: 100%; | ||
border: none; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is now auto-generated using the
npm run docs:components
command.