1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
import type { ComponentMeta, ComponentStory } from '@storybook/react';
import { Heading } from '../../atoms';
import { Collapsible } from './collapsible';
/**
* HeadingButton - Storybook Meta
*/
export default {
title: 'Molecules/Collapsible',
component: Collapsible,
argTypes: {
heading: {
control: {
type: 'text',
},
description: 'Define the collapsible heading.',
type: {
name: 'function',
required: true,
},
},
isCollapsed: {
control: {
type: 'boolean',
},
description: 'Define if the component should be collapsed or expanded.',
table: {
category: 'Options',
defaultValue: { summary: false },
},
type: {
name: 'boolean',
required: true,
},
},
},
} as ComponentMeta<typeof Collapsible>;
const Template: ComponentStory<typeof Collapsible> = ({ heading, ...args }) => (
<Collapsible
{...args}
heading={
<Heading isFake level={3}>
{heading}
</Heading>
}
/>
);
const heading = 'Your title';
const body =
'Eius et eum ex voluptas laboriosam aliquid quas necessitatibus. Molestiae eius voluptatem qui voluptas eaque et totam. Ut ipsum ea sit. Quos molestiae id est consequatur. Suscipit illo at. Omnis non suscipit. Qui itaque laboriosam quos ut est laudantium. Iusto recusandae excepturi quia labore voluptatem quod recusandae. Quod ducimus ut rem dolore et.';
/**
* Collapsible Stories - Collapsed
*/
export const Collapsed = Template.bind({});
Collapsed.args = {
children: body,
heading,
isCollapsed: true,
};
/**
* Collapsible Stories - Expanded
*/
export const Expanded = Template.bind({});
Expanded.args = {
children: body,
heading,
isCollapsed: false,
};
|