2022-11-09 22:57:21 +01:00
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
|
|
|
|
import {
|
2023-02-02 21:15:26 +01:00
|
|
|
AlignItems,
|
|
|
|
BackgroundColor,
|
|
|
|
BorderRadius,
|
2022-11-09 22:57:21 +01:00
|
|
|
DISPLAY,
|
2023-02-02 21:15:26 +01:00
|
|
|
IconColor,
|
|
|
|
JustifyContent,
|
|
|
|
Size,
|
2023-04-12 17:55:24 +02:00
|
|
|
} from '../../../../helpers/constants/design-system';
|
2022-11-09 22:57:21 +01:00
|
|
|
|
2023-04-12 17:55:24 +02:00
|
|
|
import Box from '../../../ui/box';
|
|
|
|
import { Icon, ICON_NAMES } from '../../icon/deprecated';
|
2022-11-09 22:57:21 +01:00
|
|
|
|
|
|
|
import { BUTTON_ICON_SIZES } from './button-icon.constants';
|
|
|
|
|
|
|
|
export const ButtonIcon = ({
|
|
|
|
ariaLabel,
|
|
|
|
as = 'button',
|
|
|
|
className,
|
2023-02-02 21:15:26 +01:00
|
|
|
color = IconColor.iconDefault,
|
2022-11-09 22:57:21 +01:00
|
|
|
href,
|
2023-02-02 21:15:26 +01:00
|
|
|
size = Size.LG,
|
2022-12-01 18:26:31 +01:00
|
|
|
iconName,
|
2022-11-09 22:57:21 +01:00
|
|
|
disabled,
|
|
|
|
iconProps,
|
|
|
|
...props
|
|
|
|
}) => {
|
|
|
|
const Tag = href ? 'a' : as;
|
|
|
|
return (
|
|
|
|
<Box
|
|
|
|
aria-label={ariaLabel}
|
|
|
|
as={Tag}
|
|
|
|
className={classnames(
|
|
|
|
'mm-button-icon',
|
|
|
|
`mm-button-icon--size-${size}`,
|
|
|
|
{
|
|
|
|
'mm-button-icon--disabled': disabled,
|
|
|
|
},
|
|
|
|
className,
|
|
|
|
)}
|
|
|
|
color={color}
|
|
|
|
disabled={disabled}
|
|
|
|
display={DISPLAY.INLINE_FLEX}
|
2023-02-02 21:15:26 +01:00
|
|
|
justifyContent={JustifyContent.center}
|
|
|
|
alignItems={AlignItems.center}
|
|
|
|
borderRadius={BorderRadius.LG}
|
|
|
|
backgroundColor={BackgroundColor.transparent}
|
2022-11-09 22:57:21 +01:00
|
|
|
href={href}
|
|
|
|
{...props}
|
|
|
|
>
|
2022-12-01 18:26:31 +01:00
|
|
|
<Icon name={iconName} size={size} {...iconProps} />
|
2022-11-09 22:57:21 +01:00
|
|
|
</Box>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
ButtonIcon.propTypes = {
|
|
|
|
/**
|
|
|
|
* String that adds an accessible name for ButtonIcon
|
|
|
|
*/
|
|
|
|
ariaLabel: PropTypes.string.isRequired,
|
|
|
|
/**
|
|
|
|
* The polymorphic `as` prop allows you to change the root HTML element of the Button component between `button` and `a` tag
|
|
|
|
*/
|
|
|
|
as: PropTypes.string,
|
|
|
|
/**
|
|
|
|
* An additional className to apply to the ButtonIcon.
|
|
|
|
*/
|
|
|
|
className: PropTypes.string,
|
|
|
|
/**
|
2023-02-02 21:15:26 +01:00
|
|
|
* The color of the ButtonIcon component should use the IconColor object from
|
2022-11-09 22:57:21 +01:00
|
|
|
* ./ui/helpers/constants/design-system.js
|
|
|
|
*/
|
2023-02-02 21:15:26 +01:00
|
|
|
color: PropTypes.oneOf(Object.values(IconColor)),
|
2022-11-09 22:57:21 +01:00
|
|
|
/**
|
|
|
|
* Boolean to disable button
|
|
|
|
*/
|
|
|
|
disabled: PropTypes.bool,
|
|
|
|
/**
|
|
|
|
* When an `href` prop is passed, ButtonIcon will automatically change the root element to be an `a` (anchor) tag
|
|
|
|
*/
|
|
|
|
href: PropTypes.string,
|
|
|
|
/**
|
2023-04-05 18:11:10 +02:00
|
|
|
* The name of the icon to display. Should be one of IconName
|
2022-11-09 22:57:21 +01:00
|
|
|
*/
|
2023-04-12 17:55:24 +02:00
|
|
|
iconName: PropTypes.oneOf(Object.values(ICON_NAMES)).isRequired,
|
2022-11-09 22:57:21 +01:00
|
|
|
/**
|
|
|
|
* iconProps accepts all the props from Icon
|
|
|
|
*/
|
|
|
|
iconProps: PropTypes.object,
|
|
|
|
/**
|
|
|
|
* The size of the ButtonIcon.
|
2023-02-02 21:15:26 +01:00
|
|
|
* Possible values could be 'Size.SM' 24px, 'Size.LG' 32px,
|
2022-11-09 22:57:21 +01:00
|
|
|
*/
|
|
|
|
size: PropTypes.oneOf(Object.values(BUTTON_ICON_SIZES)),
|
|
|
|
/**
|
|
|
|
* ButtonIcon accepts all the props from Box
|
|
|
|
*/
|
|
|
|
...Box.propTypes,
|
|
|
|
};
|