2022-12-08 19:25:19 +01:00
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
import {
|
2023-02-02 21:15:26 +01:00
|
|
|
BorderColor,
|
|
|
|
Size,
|
2022-12-08 19:25:19 +01:00
|
|
|
DISPLAY,
|
2023-02-02 21:15:26 +01:00
|
|
|
AlignItems,
|
|
|
|
JustifyContent,
|
|
|
|
BackgroundColor,
|
|
|
|
IconColor,
|
|
|
|
TextColor,
|
2022-12-08 19:25:19 +01:00
|
|
|
} from '../../../helpers/constants/design-system';
|
|
|
|
|
|
|
|
import Box from '../../ui/box/box';
|
|
|
|
|
2023-04-05 18:11:10 +02:00
|
|
|
import { IconName, Icon } from '../icon';
|
2022-12-08 19:25:19 +01:00
|
|
|
import { AvatarBase } from '../avatar-base';
|
|
|
|
|
|
|
|
import { AVATAR_ICON_SIZES } from './avatar-icon.constants';
|
|
|
|
|
|
|
|
export const AvatarIcon = ({
|
2023-02-02 21:15:26 +01:00
|
|
|
size = Size.MD,
|
|
|
|
color = TextColor.primaryDefault,
|
|
|
|
backgroundColor = BackgroundColor.primaryMuted,
|
2022-12-08 19:25:19 +01:00
|
|
|
className,
|
|
|
|
iconProps,
|
|
|
|
iconName,
|
|
|
|
...props
|
2023-04-05 18:11:10 +02:00
|
|
|
}) => (
|
|
|
|
<AvatarBase
|
|
|
|
size={size}
|
|
|
|
display={DISPLAY.FLEX}
|
|
|
|
alignItems={AlignItems.center}
|
|
|
|
justifyContent={JustifyContent.center}
|
|
|
|
color={color}
|
|
|
|
backgroundColor={backgroundColor}
|
|
|
|
borderColor={BorderColor.transparent}
|
|
|
|
className={classnames('mm-avatar-icon', className)}
|
|
|
|
{...props}
|
|
|
|
>
|
|
|
|
<Icon
|
|
|
|
color={IconColor.inherit}
|
|
|
|
name={iconName}
|
2022-12-08 19:25:19 +01:00
|
|
|
size={size}
|
2023-04-05 18:11:10 +02:00
|
|
|
{...iconProps}
|
|
|
|
/>
|
|
|
|
</AvatarBase>
|
|
|
|
);
|
2022-12-08 19:25:19 +01:00
|
|
|
|
|
|
|
AvatarIcon.propTypes = {
|
|
|
|
/**
|
|
|
|
*
|
2023-04-05 18:11:10 +02:00
|
|
|
* The name of the icon to display. Should be one of IconName
|
2022-12-08 19:25:19 +01:00
|
|
|
*/
|
2023-04-05 18:11:10 +02:00
|
|
|
iconName: PropTypes.oneOf(Object.values(IconName)).isRequired,
|
2022-12-08 19:25:19 +01:00
|
|
|
/**
|
|
|
|
* Props for the icon inside AvatarIcon. All Icon props can be used
|
|
|
|
*/
|
2023-04-05 18:11:10 +02:00
|
|
|
iconProps: PropTypes.object,
|
2022-12-08 19:25:19 +01:00
|
|
|
/**
|
|
|
|
* The size of the AvatarIcon
|
|
|
|
* Possible values could be 'SIZES.XS' 16px, 'SIZES.SM' 24px, 'SIZES.MD' 32px, 'SIZES.LG' 40px, 'SIZES.XL' 48px
|
|
|
|
* Defaults to SIZES.MD
|
|
|
|
*/
|
|
|
|
size: PropTypes.oneOf(Object.values(AVATAR_ICON_SIZES)),
|
|
|
|
/**
|
|
|
|
* The background color of the AvatarIcon
|
2023-02-02 21:15:26 +01:00
|
|
|
* Defaults to BackgroundColor.primaryMuted
|
2022-12-08 19:25:19 +01:00
|
|
|
*/
|
2023-03-16 21:18:00 +01:00
|
|
|
backgroundColor: PropTypes.oneOf(Object.values(BackgroundColor)),
|
2022-12-08 19:25:19 +01:00
|
|
|
/**
|
|
|
|
* The color of the text inside the AvatarIcon
|
2023-02-02 21:15:26 +01:00
|
|
|
* Defaults to TextColor.primaryDefault
|
2022-12-08 19:25:19 +01:00
|
|
|
*/
|
2023-04-19 23:16:49 +02:00
|
|
|
color: PropTypes.oneOf([
|
|
|
|
...Object.values(TextColor),
|
|
|
|
...Object.values(IconColor),
|
|
|
|
]),
|
2022-12-08 19:25:19 +01:00
|
|
|
/**
|
|
|
|
* Additional classNames to be added to the AvatarIcon
|
|
|
|
*/
|
|
|
|
className: PropTypes.string,
|
|
|
|
/**
|
|
|
|
* AvatarIcon also accepts all Box props including but not limited to
|
|
|
|
* className, as(change root element of HTML element) and margin props
|
|
|
|
*/
|
|
|
|
...Box.propTypes,
|
|
|
|
};
|