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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
import { ComponentMeta, ComponentStory } from '@storybook/react';
import { IntlProvider } from 'react-intl';
import SharingWidget from './sharing';
/**
* Sharing - Storybook Meta
*/
export default {
title: 'Organisms/Widgets',
component: SharingWidget,
argTypes: {
data: {
description: 'The page data.',
type: {
name: 'object',
required: true,
value: {},
},
},
expanded: {
control: {
type: null,
},
description: 'Default widget state (expanded or collapsed).',
table: {
category: 'Options',
defaultValue: { summary: true },
},
type: {
name: 'boolean',
required: false,
},
},
level: {
control: {
type: 'number',
min: 1,
max: 6,
},
description: 'The heading level.',
table: {
category: 'Options',
defaultValue: { summary: 2 },
},
type: {
name: 'number',
required: false,
},
},
media: {
control: {
type: null,
},
description: 'An array of active and ordered sharing medium.',
type: {
name: 'string',
required: true,
},
},
},
decorators: [
(Story) => (
<IntlProvider locale="en">
<Story />
</IntlProvider>
),
],
} as ComponentMeta<typeof SharingWidget>;
const Template: ComponentStory<typeof SharingWidget> = (args) => (
<SharingWidget {...args} />
);
/**
* Widgets Stories - Sharing
*/
export const Sharing = Template.bind({});
Sharing.args = {
data: {
excerpt:
'Alias similique eius ducimus laudantium aspernatur. Est rem ut eum temporibus sit reprehenderit aut non molestias. Vel dolorem expedita labore quo inventore aliquid nihil nam. Possimus nobis enim quas corporis eos.',
title: 'Accusantium totam nostrum',
url: 'https://www.example.test',
},
media: ['diaspora', 'facebook', 'linkedin', 'twitter', 'email'],
};
|