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> ) });