storybook/docs/snippets/react/component-story-custom-args-complex.ts.mdx
Norbert de Langen 84a4bde3f0
FIX
2020-12-09 14:42:24 +01:00

46 lines
1.1 KiB
Plaintext

```ts
// YourComponent.stories.js
import React from 'react';
import { Story, Meta } from '@storybook/react';
import { YourComponent, YourComponentProps } from './your-component'
// a function to apply some computation
const someFunction = (valuePropertyA, valuePropertyB) => {
// makes some computations and returns something
};
export default {
component: YourComponent,
title: 'A complex case with a function',
// creates specific argTypes with options
argTypes: {
propertyA: {
control: {
type: 'select',
options: [
'Item One',
'Item Two',
'Item Three'
],
},
},
propertyB: {
control: {
type: 'select',
options: [
'Another Item One',
'Another Item Two',
'Another Item Three'
],
},
},
},
} as Meta;
const Template: Story<YourComponentProps> = ({propertyA, propertyB, ...rest}) => {
const someFunctionResult = someFunction(propertyA, propertyB);
return <YourComponent somePoperty={someFunctionResult} {...rest} />;
};
```