64 lines
1.5 KiB
TypeScript
64 lines
1.5 KiB
TypeScript
import { ComponentStory, ComponentMeta } from '@storybook/react';
|
|
import React from 'react';
|
|
|
|
import Button from 'soapbox/components/ui/button/button';
|
|
|
|
// More on default export: https://storybook.js.org/docs/react/writing-stories/introduction#default-export
|
|
export default {
|
|
title: 'UI/Button',
|
|
component: Button,
|
|
// More on argTypes: https://storybook.js.org/docs/react/api/argtypes
|
|
argTypes: {
|
|
text: { type: 'string', defaultValue: 'Button' },
|
|
theme: {
|
|
control: 'select',
|
|
options: [
|
|
'primary',
|
|
'secondary',
|
|
'tertiary',
|
|
'accent',
|
|
'danger',
|
|
'transparent',
|
|
'outline',
|
|
'muted',
|
|
],
|
|
defaultValue: 'primary',
|
|
},
|
|
size: {
|
|
control: 'select',
|
|
options: [
|
|
'xs',
|
|
'sm',
|
|
'md',
|
|
'lg',
|
|
],
|
|
defaultValue: 'md',
|
|
},
|
|
disabled: { type: 'boolean', defaultValue: false },
|
|
onClick: { action: 'onClick' },
|
|
},
|
|
} as ComponentMeta<typeof Button>;
|
|
|
|
// More on component templates: https://storybook.js.org/docs/react/writing-stories/introduction#using-args
|
|
const Template: ComponentStory<typeof Button> = (args) => <Button {...args} />;
|
|
|
|
export const Primary = Template.bind({});
|
|
// More on args: https://storybook.js.org/docs/react/writing-stories/args
|
|
Primary.args = {
|
|
theme: 'primary',
|
|
};
|
|
|
|
export const Secondary = Template.bind({});
|
|
Secondary.args = {
|
|
theme: 'secondary',
|
|
};
|
|
|
|
export const Large = Template.bind({});
|
|
Large.args = {
|
|
size: 'lg',
|
|
};
|
|
|
|
export const Small = Template.bind({});
|
|
Small.args = {
|
|
size: 'sm',
|
|
};
|