75 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| // Copyright 2021 Signal Messenger, LLC
 | |
| // SPDX-License-Identifier: AGPL-3.0-only
 | |
| 
 | |
| import React from 'react';
 | |
| import { action } from '@storybook/addon-actions';
 | |
| 
 | |
| import { Button, ButtonSize, ButtonVariant } from './Button';
 | |
| 
 | |
| export default {
 | |
|   title: 'Components/Button',
 | |
| };
 | |
| 
 | |
| export function KitchenSink(): JSX.Element {
 | |
|   return (
 | |
|     <>
 | |
|       {Object.values(ButtonVariant).map(variant => (
 | |
|         <React.Fragment key={variant}>
 | |
|           {[ButtonSize.Large, ButtonSize.Medium, ButtonSize.Small].map(size => (
 | |
|             <React.Fragment key={size}>
 | |
|               <p>
 | |
|                 <Button
 | |
|                   onClick={action('onClick')}
 | |
|                   size={size}
 | |
|                   variant={variant}
 | |
|                 >
 | |
|                   {variant}
 | |
|                 </Button>
 | |
|               </p>
 | |
|               <p>
 | |
|                 <Button
 | |
|                   disabled
 | |
|                   onClick={action('onClick')}
 | |
|                   size={size}
 | |
|                   variant={variant}
 | |
|                 >
 | |
|                   {variant}
 | |
|                 </Button>
 | |
|               </p>
 | |
|             </React.Fragment>
 | |
|           ))}
 | |
|         </React.Fragment>
 | |
|       ))}
 | |
|     </>
 | |
|   );
 | |
| }
 | |
| 
 | |
| KitchenSink.story = {
 | |
|   name: 'Kitchen sink',
 | |
| };
 | |
| 
 | |
| export function AriaLabel(): JSX.Element {
 | |
|   return (
 | |
|     <Button
 | |
|       aria-label="hello"
 | |
|       className="module-ForwardMessageModal__header--back"
 | |
|       onClick={action('onClick')}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| AriaLabel.story = {
 | |
|   name: 'aria-label',
 | |
| };
 | |
| 
 | |
| export function CustomStyles(): JSX.Element {
 | |
|   return (
 | |
|     <Button onClick={action('onClick')} style={{ transform: 'rotate(5deg)' }}>
 | |
|       Hello world
 | |
|     </Button>
 | |
|   );
 | |
| }
 | |
| 
 | |
| CustomStyles.story = {
 | |
|   name: 'Custom styles',
 | |
| };
 | 
