storybook/docs/snippets/html/button-story-with-args.ts.mdx
2022-07-15 11:09:15 -07:00

40 lines
990 B
Plaintext

```ts
// Button.stories.ts
import type { Meta, Story } from '@storybook/html';
type ButtonArgs = {
primary: boolean;
label: string;
};
export default {
/* 👇 The title prop is optional.
* See https://storybook.js.org/docs/html/configure/overview#configure-story-loading
* to learn how to generate automatic titles
*/
title: 'Button',
} as Meta<ButtonArgs>;
/*
*👇 Render functions are a framework specific feature to allow you control on how the component renders.
* See https://storybook.js.org/docs/7.0/html/api/csf
* to learn how to use render functions.
*/
export const Primary: Story = {
render: (args) => {
const btn = document.createElement('button');
btn.innerText = args.label;
const mode = args.primary ? 'storybook-button--primary' : 'storybook-button--secondary';
btn.className = ['storybook-button', 'storybook-button--medium', mode].join(' ');
return btn;
},
args: {
primary: true,
label: 'Button',
},
};
```