mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-08 11:11:53 +08:00
52 lines
1.0 KiB
TypeScript
52 lines
1.0 KiB
TypeScript
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 createButton = ({
|
|
primary = false,
|
|
size = 'medium',
|
|
backgroundColor,
|
|
label,
|
|
onClick,
|
|
}: ButtonProps) => {
|
|
const btn = document.createElement('button');
|
|
btn.type = 'button';
|
|
btn.innerText = label;
|
|
if (onClick) {
|
|
btn.addEventListener('click', onClick);
|
|
}
|
|
|
|
const mode = primary ? 'storybook-button--primary' : 'storybook-button--secondary';
|
|
btn.className = ['storybook-button', `storybook-button--${size}`, mode].join(' ');
|
|
|
|
if (backgroundColor) {
|
|
btn.style.backgroundColor = backgroundColor;
|
|
}
|
|
|
|
return btn;
|
|
};
|