summaryrefslogtreecommitdiffstats
path: root/browser/components/storybook/stories/button.stories.mjs
diff options
context:
space:
mode:
Diffstat (limited to 'browser/components/storybook/stories/button.stories.mjs')
-rw-r--r--browser/components/storybook/stories/button.stories.mjs56
1 files changed, 56 insertions, 0 deletions
diff --git a/browser/components/storybook/stories/button.stories.mjs b/browser/components/storybook/stories/button.stories.mjs
new file mode 100644
index 0000000000..b0d6b04401
--- /dev/null
+++ b/browser/components/storybook/stories/button.stories.mjs
@@ -0,0 +1,56 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+import { html } from "lit";
+import { classMap } from "lit/directives/class-map.js";
+
+export default {
+ title: "Design System/Atoms/Button",
+};
+
+const Template = ({ disabled, primary, text, ghostButton, icon }) =>
+ html`
+ <style>
+ .icon-button {
+ background-image: url("${icon}");
+ }
+ </style>
+ <button
+ ?disabled=${disabled}
+ class=${classMap({
+ primary,
+ "ghost-button": ghostButton,
+ "icon-button": icon,
+ })}
+ >
+ ${text}
+ </button>
+ `;
+
+export const RegularButton = Template.bind({});
+RegularButton.args = {
+ text: "Regular",
+ primary: false,
+ disabled: false,
+};
+export const PrimaryButton = Template.bind({});
+PrimaryButton.args = {
+ text: "Primary",
+ primary: true,
+ disabled: false,
+};
+export const DisabledButton = Template.bind({});
+DisabledButton.args = {
+ text: "Disabled",
+ primary: false,
+ disabled: true,
+};
+
+export const GhostIconButton = Template.bind({});
+GhostIconButton.args = {
+ text: "",
+ icon: "chrome://browser/skin/login.svg",
+ disabled: false,
+ ghostButton: true,
+};