mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-04 10:11:05 +08:00
50 lines
1.1 KiB
TypeScript
50 lines
1.1 KiB
TypeScript
import type { Meta, StoryObj } from '@storybook/web-components';
|
|
import type { ButtonProps } from './Button';
|
|
import { Button } from './Button';
|
|
|
|
// More on how to set up stories at: https://storybook.js.org/docs/web-components/writing-stories/introduction#default-export
|
|
const meta: Meta<ButtonProps> = {
|
|
title: 'Example/Button',
|
|
render: (args) => Button(args),
|
|
// More on argTypes: https://storybook.js.org/docs/web-components/api/argtypes
|
|
argTypes: {
|
|
backgroundColor: { control: 'color' },
|
|
onClick: { action: 'onClick' },
|
|
size: {
|
|
control: { type: 'select' },
|
|
options: ['small', 'medium', 'large'],
|
|
},
|
|
},
|
|
};
|
|
|
|
export default meta;
|
|
type Story = StoryObj<ButtonProps>;
|
|
|
|
// More on component templates: https://storybook.js.org/docs/web-components/writing-stories/introduction#using-args
|
|
export const Primary: Story = {
|
|
args: {
|
|
primary: true,
|
|
label: 'Button',
|
|
},
|
|
};
|
|
|
|
export const Secondary: Story = {
|
|
args: {
|
|
label: 'Button',
|
|
},
|
|
};
|
|
|
|
export const Large: Story = {
|
|
args: {
|
|
size: 'large',
|
|
label: 'Button',
|
|
},
|
|
};
|
|
|
|
export const Small: Story = {
|
|
args: {
|
|
size: 'small',
|
|
label: 'Button',
|
|
},
|
|
};
|