storybook/docs/snippets/react/button-story.with-hooks.js.mdx
2021-11-09 01:41:54 +00:00

35 lines
898 B
Plaintext

```js
// Button.stories.js|ts|jsx|tsx
import React, { useState } from 'react';
import { Button } from './Button';
export default {
/* 👇 The title prop is optional.
* See https://storybook.js.org/docs/react/configure/overview#configure-story-loading
* to learn how to generate automatic titles
*/
title: 'Button',
component: Button,
};
/*
* Example Button story with React Hooks.
* See note below related to this example.
*/
export const Primary = () => {
// Sets the hooks for both the label and primary props
const [value, setValue] = useState('Secondary');
const [isPrimary, setIsPrimary] = useState(false);
// Sets a click handler to change the label's value
const handleOnChange = () => {
if (!isPrimary) {
setIsPrimary(true);
setValue('Primary');
}
};
return <Button primary={isPrimary} onClick={handleOnChange} label={value} />;
};
```