From e7ba634031cc9a7e48869b5fed8eadb7f4c317a6 Mon Sep 17 00:00:00 2001
From: Josh Winn <965114+jawinn@users.noreply.github.com>
Date: Tue, 2 Apr 2024 11:08:04 -0400
Subject: [PATCH] docs(button): custom mdx docs page
Create an MDX "Docs" page that works as a replacement for the YML docs
pages, and covers the important Button options from there and the
guidelines.
Adds the tag "is-hidden-story" for excluding Storybook sidebar items.
---
.storybook/main.js | 1 +
.storybook/manager.js | 2 +-
components/button/stories/button.mdx | 101 +++++
components/button/stories/button.stories.js | 469 +++++++++++++-------
4 files changed, 417 insertions(+), 156 deletions(-)
create mode 100644 components/button/stories/button.mdx
diff --git a/.storybook/main.js b/.storybook/main.js
index 8a024ddafa8..d6e748a3330 100644
--- a/.storybook/main.js
+++ b/.storybook/main.js
@@ -10,6 +10,7 @@ const componentPkgs = readdirSync(componentsPath, {
module.exports = {
stories: [
+ "../components/*/stories/*.mdx",
"../components/*/stories/*.stories.js",
"./guides/*.mdx",
"./foundations/*/*.mdx",
diff --git a/.storybook/manager.js b/.storybook/manager.js
index fb843f695a3..791ceaca79f 100644
--- a/.storybook/manager.js
+++ b/.storybook/manager.js
@@ -50,7 +50,7 @@ addons.setConfig({
sidebar: {
showRoots: false,
filters: {
- patterns: (item) => !(item.id.includes('forced-colors') || item.tags.includes('foundation')),
+ patterns: (item) => !item.id.includes('forced-colors') && ['foundation','is-hidden-story'].every((tag) => !item.tags.includes(tag)),
}
},
});
diff --git a/components/button/stories/button.mdx b/components/button/stories/button.mdx
new file mode 100644
index 00000000000..b7eed0188ff
--- /dev/null
+++ b/components/button/stories/button.mdx
@@ -0,0 +1,101 @@
+import { Canvas, Meta, Description } from '@storybook/blocks';
+
+import * as ButtonStories from './button.stories';
+
+
+
+# Button
+
+
+
+## Variants
+
+There are four available variants that are used for different levels of emphasis and different
+types of actions. By default, a button uses the fill style with a solid background. The primary
+and secondary variants also have an outline option.
+
+### Accent
+
+The call to action button communicates strong emphasis and is reserved for encouraging critical
+actions. In general, only use the emphasized option for the most important action on the page.
+
+
+
+### Primary
+
+The primary button is for medium emphasis. Use it in place of a call to action button when the
+action requires less prominence, or if there are multiple primary actions of the same importance
+in the same view. Both the fill (default) and outline styles are demonstrated below:
+
+
+
+### Secondary
+
+The secondary button is for low emphasis. It’s paired with other button types to surface less
+prominent actions, and should never be the only button in a group. Both the fill (default) and
+outline styles are demonstrated below:
+
+
+
+### Negative
+
+The negative button is for emphasizing actions that can be destructive or have negative
+consequences if taken. Use it sparingly.
+
+
+
+## Static color
+
+When a button needs to be placed on top of a color background or a visual, use the static color
+option. Static color buttons do not change shades or values depending upon the color theme.
+
+### Static white - primary
+
+
+
+### Static white - secondary
+
+
+
+### Static black - primary
+
+
+
+### Static black - secondary
+
+
+
+## Sizing
+
+Buttons come in four different sizes: small, medium, large, and extra large. The medium size is
+the default and most frequently used option. Use the other sizes sparingly; they should be used
+to create a hierarchy of importance within the page.
+
+
+
+## Pending state
+
+The pending button is for indicating that a quick progress action is taking place. In this case, the
+label and optional icon disappear and a progress circle appears. The progress circle always shows an
+indeterminate progress. We recommend the use of the `.is-pending` class on the component’s parent
+container, but there is also an option to use an attribute of `pending` instead. Buttons should have
+the disabled attribute when the pending state is applied.
+
+
+
+## Disabled state
+
+A button in a disabled state shows that an action exists, but is not available in that circumstance.
+This state can be used to maintain layout continuity and to communicate that an action may become
+available later.
+
+
+
+## Text overflow behavior
+
+When the button text is too long for the horizontal space available, it wraps to form another line.
+When there is no icon present, the text is aligned center. When there is an icon present, the text is
+aligned `start` (left with a writing direction of left-to-right) and the icon remains vertically aligned
+at the top.
+
+
\ No newline at end of file
diff --git a/components/button/stories/button.stories.js b/components/button/stories/button.stories.js
index 3047ae884be..1bf61b2396b 100644
--- a/components/button/stories/button.stories.js
+++ b/components/button/stories/button.stories.js
@@ -1,5 +1,6 @@
import { html } from "lit";
import { styleMap } from "lit/directives/style-map.js";
+import { when } from "lit/directives/when.js";
import { withDownStateDimensionCapture } from "../../../.storybook/decorators";
import { default as IconStories } from "@spectrum-css/icon/stories/icon.stories.js";
@@ -13,7 +14,6 @@ import { Template } from "./template";
export default {
title: "Components/Button",
component: "Button",
- decorators: [withDownStateDimensionCapture(".spectrum-Button:not(:disabled)")],
argTypes: {
size: {
name: "Size",
@@ -114,7 +114,7 @@ export default {
type: { name: "string" },
table: {
type: { summary: "string" },
- category: "Advanced",
+ category: "Component",
},
options: ["white", "black"],
@@ -145,6 +145,7 @@ export default {
}
},
decorators: [
+ withDownStateDimensionCapture(".spectrum-Button:not(:disabled)"),
(Story, context) => html`