mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-09 00:19:13 +08:00
In 6.5 the `framework` config option was one of `react`, `angular`, etc. and included Webpack settings. In the 7.0, we’ve updated it so that these are now called `renderers`, and are builder-independent. Now, frameworks contain specific builder information, such as `cra` or `nextjs` (for specific app environments) or `react-webpack5` / `react-vite` (for custom apps). This fixes the `sb init` CLI command to use renderer-specific templates. I also call out some follow-up work to fix automigrations & telemetry
51 lines
1.1 KiB
JavaScript
51 lines
1.1 KiB
JavaScript
import React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import './button.css';
|
|
|
|
/**
|
|
* Primary UI component for user interaction
|
|
*/
|
|
export const Button = ({ primary, backgroundColor, size, 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,
|
|
};
|
|
|
|
Button.defaultProps = {
|
|
backgroundColor: null,
|
|
primary: false,
|
|
size: 'medium',
|
|
onClick: undefined,
|
|
};
|