Manuel Bustillo
c01135257d
All checks were successful
Add copyright notice / copyright_notice (pull_request) Successful in 59s
Playwright Tests / test (pull_request) Successful in 3m57s
Build Nginx-based docker image / build-static-assets (pull_request) Successful in 5m19s
Check usage of free licenses / build-static-assets (pull_request) Successful in 15s
42 lines
966 B
TypeScript
42 lines
966 B
TypeScript
import React from 'react';
|
|
|
|
import './button.css';
|
|
|
|
export interface ButtonProps {
|
|
/** Is this the principal call to action on the page? */
|
|
primary?: boolean;
|
|
/** What background color to use */
|
|
backgroundColor?: string;
|
|
/** How large should the button be? */
|
|
size?: 'small' | 'medium' | 'large';
|
|
/** Button contents */
|
|
label: string;
|
|
/** Optional click handler */
|
|
onClick?: () => void;
|
|
}
|
|
|
|
/** Primary UI component for user interaction */
|
|
export const Button = ({
|
|
primary = false,
|
|
size = 'medium',
|
|
backgroundColor,
|
|
label,
|
|
...props
|
|
}: ButtonProps) => {
|
|
const mode = primary ? 'storybook-button--primary' : 'storybook-button--secondary';
|
|
return (
|
|
<button
|
|
type="button"
|
|
className={['storybook-button', `storybook-button--${size}`, mode].join(' ')}
|
|
{...props}
|
|
>
|
|
{label}
|
|
<style jsx>{`
|
|
button {
|
|
background-color: ${backgroundColor};
|
|
}
|
|
`}</style>
|
|
</button>
|
|
);
|
|
};
|