2025-03-05 17:03:50 +01:00

38 lines
956 B
JavaScript

import PropTypes from 'prop-types';
import './button.css';
/** Primary UI component for user interaction */
export const Button = ({
primary = false,
backgroundColor = null,
size = 'medium',
label,
...props
}) => {
const mode = primary ? 'storybook-button--primary' : 'storybook-button--secondary';
return (
<button
type="button"
className={['storybook-button', `storybook-button--${size}`, mode].join(' ')}
style={backgroundColor && { backgroundColor }}
{...props}
>
{label}
</button>
);
};
Button.propTypes = {
/** Is this the principal call to action on the page? */
primary: PropTypes.bool,
/** What background color to use */
backgroundColor: PropTypes.string,
/** How large should the button be? */
size: PropTypes.oneOf(['small', 'medium', 'large']),
/** Button contents */
label: PropTypes.string.isRequired,
/** Optional click handler */
onClick: PropTypes.func,
};