1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-10-23 03:36:18 +02:00
metamask-extension/ui/components/component-library/button-primary/button-primary.js
2022-11-18 12:36:33 -08:00

44 lines
1.0 KiB
JavaScript

import React from 'react';
import PropTypes from 'prop-types';
import classnames from 'classnames';
import { ButtonBase } from '../button-base';
import { BUTTON_PRIMARY_SIZES } from './button-primary.constants';
export const ButtonPrimary = ({
className,
danger,
size = BUTTON_PRIMARY_SIZES.MD,
...props
}) => {
return (
<ButtonBase
className={classnames(className, 'mm-button-primary', {
'mm-button-primary--type-danger': danger,
})}
size={size}
{...props}
/>
);
};
ButtonPrimary.propTypes = {
/**
* An additional className to apply to the ButtonPrimary.
*/
className: PropTypes.string,
/**
* When true, `ButtonPrimary` color becomes Danger.
*/
danger: PropTypes.bool,
/**
* Possible size values: 'SIZES.SM'(32px), 'SIZES.MD'(40px), 'SIZES.LG'(48px).
* Default value is 'SIZES.MD'.
*/
size: PropTypes.oneOf(Object.values(BUTTON_PRIMARY_SIZES)),
/**
* ButtonPrimary accepts all the props from ButtonBase
*/
...ButtonBase.propTypes,
};