components/RuiAlert/RuiAlert.stories.tsx (101 lines of code) (raw):
import React, {Fragment} from 'react';
import {storiesOf} from '@storybook/react';
import {text, boolean, radios} from '@storybook/addon-knobs';
import {register} from './src';
import Readme from './readme.md';
register();
storiesOf('RuiAlert', module)
.addParameters({
readme: {
sidebar: Readme,
},
})
.add('Default', () => (
<rui-alert>
<rui-rich-text>
<h5>Alert title</h5>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Integer in malesuada lectus. Quisque tristique tellus ante, vitae pharetra nulla sollicitudin tempus </p>
<a href="#">This is a CTA link or action to do something</a>
</rui-rich-text>
</rui-alert>
))
.add('Icons', () => (
<rui-alert>
<rui-icon slot="icon" src="">
</rui-icon>
<rui-rich-text>
<h5>Alert title</h5>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Integer in malesuada lectus. Quisque tristique tellus ante, vitae pharetra nulla sollicitudin tempus </p>
<a href="#">This is a CTA link or action to do something</a>
</rui-rich-text>
</rui-alert>
))
.add('Types', () => (
<Fragment>
<rui-alert type="success">
<rui-icon slot="icon" src="">
</rui-icon>
<rui-rich-text>
<p> This is a success alert </p>
</rui-rich-text>
</rui-alert>
<rui-alert type="warning">
<rui-icon slot="icon" src="">
</rui-icon>
<rui-rich-text>
<p> This is a warning alert </p>
</rui-rich-text>
</rui-alert>
<rui-alert type="error">
<rui-icon slot="icon" src="">
</rui-icon>
<rui-rich-text>
<p> This is an error alert </p>
</rui-rich-text>
</rui-alert>
<rui-alert type="info">
<rui-icon slot="icon" src="">
</rui-icon>
<rui-rich-text>
<p> This is an info alert </p>
</rui-rich-text>
</rui-alert>
</Fragment>
))
.add('Dismissible', () => (
<rui-alert dismissible>
<rui-rich-text>
<p> This is a dismissable alert </p>
</rui-rich-text>
<rui-icon slot="dismissible" label="Dismiss alert" src="">
</rui-icon>
</rui-alert>
))
.add('Playground', () => {
const dismissible = boolean('Dismissible', false);
const type = radios('Type', {default: 'default', success: 'success', warning: 'warning', error: 'error', info: 'info'}, 'default');
const withIcon = boolean('With Icon', true);
const icon = text('Icon', '');
const content = text('Content', 'This is an alert');
const closeLabel = text('Close Label', 'Dismiss alert');
const closeIcon = text('Close Icon', '');
// TODO: find a way to make `dismissible` an optional prop. Lit-element does not see `dismissible={false}` as a false value but as a true value as it ignores the `={false}` part
return (
<Fragment>
<rui-alert dismissible={dismissible} type={type}>
{withIcon && (
<rui-icon slot="icon" src={icon}></rui-icon>
)}
<rui-rich-text>
<p>{content}</p>
</rui-rich-text>
{dismissible && (
<rui-icon slot="dismissible" label={closeLabel} src={closeIcon}></rui-icon>
)}
</rui-alert>
<p>* please note dismissible does not work fully as intended due to a storybook constraint of injecting boolean values as properties and Lit-element constraint of taking boolean properties on a component.
At the moment `dismissible = false` only hides the icon but keeps the invisible button in place, where the actual behaviour is that this does not exist.
</p>
</Fragment>
)
});