mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
5b5ca4599e
* Replaces SEVERITIES const with Severity enum in BannerAlert * Replaced SEVERITIES with Severity in banner-alert.constants.js * Used BANNER_ALERT_SEVERITIES instead of SEVERITIES in banner-alert.stories.js * Updated README for usage of Severity instead of SEVERITIES * Updates to stories and docs link --------- Co-authored-by: Brad Decker <bhdecker84@gmail.com> Co-authored-by: georgewrmarshall <george.marshall@consensys.net>
148 lines
3.7 KiB
JavaScript
148 lines
3.7 KiB
JavaScript
import React from 'react';
|
|
import { useState } from '@storybook/addons';
|
|
import {
|
|
Display,
|
|
FlexDirection,
|
|
Size,
|
|
Severity,
|
|
} from '../../../helpers/constants/design-system';
|
|
|
|
import { ButtonLink, ButtonPrimary, IconName, Box } from '..';
|
|
|
|
import README from './README.mdx';
|
|
|
|
import { BannerAlert } from './banner-alert';
|
|
|
|
export default {
|
|
title: 'Components/ComponentLibrary/BannerAlert',
|
|
component: BannerAlert,
|
|
parameters: {
|
|
docs: {
|
|
page: README,
|
|
},
|
|
},
|
|
argTypes: {
|
|
severity: {
|
|
control: 'select',
|
|
options: Object.values(Severity),
|
|
},
|
|
className: {
|
|
control: 'text',
|
|
},
|
|
title: {
|
|
control: 'text',
|
|
},
|
|
description: {
|
|
control: 'text',
|
|
},
|
|
children: {
|
|
control: 'text',
|
|
},
|
|
actionButtonLabel: {
|
|
control: 'text',
|
|
},
|
|
actionButtonOnClick: {
|
|
action: 'actionButtonOnClick',
|
|
},
|
|
actionButtonProps: {
|
|
control: 'object',
|
|
},
|
|
onClose: {
|
|
action: 'onClose',
|
|
},
|
|
},
|
|
};
|
|
|
|
const Template = (args) => <BannerAlert {...args} />;
|
|
|
|
export const DefaultStory = Template.bind({});
|
|
DefaultStory.storyName = 'Default';
|
|
DefaultStory.args = {
|
|
title: 'Title is sentence case no period',
|
|
children: "Description shouldn't repeat title. 1-3 lines.",
|
|
actionButtonLabel: 'Action',
|
|
};
|
|
|
|
export const SeverityStory = (args) => {
|
|
return (
|
|
<Box display={Display.Flex} flexDirection={FlexDirection.Column} gap={3}>
|
|
<BannerAlert {...args} severity={Severity.Info} title="Info">
|
|
This is a demo of severity Info.
|
|
</BannerAlert>
|
|
<BannerAlert {...args} severity={Severity.Warning} title="Warning">
|
|
This is a demo of severity Warning.
|
|
</BannerAlert>
|
|
<BannerAlert {...args} severity={Severity.Danger} title="Danger">
|
|
This is a demo of severity Danger.
|
|
</BannerAlert>
|
|
<BannerAlert {...args} severity={Severity.Success} title="Success">
|
|
This is a demo of severity Success.
|
|
</BannerAlert>
|
|
</Box>
|
|
);
|
|
};
|
|
SeverityStory.storyName = 'Severity';
|
|
|
|
export const Title = Template.bind({});
|
|
Title.args = {
|
|
title: 'Title is sentence case no period',
|
|
children: 'Pass only a string through the title prop',
|
|
};
|
|
|
|
export const Description = Template.bind({});
|
|
Description.args = {
|
|
title: 'Description vs children',
|
|
description:
|
|
'Pass only a string through the description prop or you can use children if the contents require more',
|
|
};
|
|
|
|
export const Children = Template.bind({});
|
|
Children.args = {
|
|
children: (
|
|
<>
|
|
{`Description shouldn't repeat title. 1-3 lines. Can contain a `}
|
|
<ButtonLink size={Size.auto} href="https://metamask.io/" externalLink>
|
|
hyperlink.
|
|
</ButtonLink>
|
|
</>
|
|
),
|
|
};
|
|
|
|
export const ActionButton = Template.bind({});
|
|
ActionButton.args = {
|
|
title: 'Action prop demo',
|
|
actionButtonLabel: 'Action',
|
|
actionButtonOnClick: () => console.log('ButtonLink actionButtonOnClick demo'),
|
|
actionButtonProps: {
|
|
endIconName: IconName.Arrow2Right,
|
|
},
|
|
children:
|
|
'Use actionButtonLabel for action text, actionButtonOnClick for the onClick handler, and actionButtonProps to pass any ButtonLink prop types such as iconName',
|
|
};
|
|
|
|
export const OnClose = (args) => {
|
|
const [isShown, setShown] = useState(true);
|
|
const bannerAlertToggle = () => {
|
|
if (isShown) {
|
|
console.log('close button clicked');
|
|
}
|
|
setShown(!isShown);
|
|
};
|
|
return (
|
|
<>
|
|
{isShown ? (
|
|
<BannerAlert {...args} onClose={bannerAlertToggle} />
|
|
) : (
|
|
<ButtonPrimary onClick={bannerAlertToggle}>
|
|
View BannerAlert
|
|
</ButtonPrimary>
|
|
)}
|
|
</>
|
|
);
|
|
};
|
|
|
|
OnClose.args = {
|
|
title: 'onClose demo',
|
|
children: 'Click the close button icon to hide this notifcation',
|
|
};
|