mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
6e5ab2a945
Migrate AvatarIcon to TS --------- Co-authored-by: georgewrmarshall <george.marshall@consensys.net>
60 lines
1.5 KiB
TypeScript
60 lines
1.5 KiB
TypeScript
import React from 'react';
|
|
import classnames from 'classnames';
|
|
import {
|
|
BorderColor,
|
|
Display,
|
|
AlignItems,
|
|
JustifyContent,
|
|
BackgroundColor,
|
|
IconColor,
|
|
TextColor,
|
|
} from '../../../helpers/constants/design-system';
|
|
|
|
import { Icon } from '../icon';
|
|
import type { PolymorphicRef } from '../box';
|
|
import { AvatarBase, AvatarBaseProps } from '../avatar-base';
|
|
import type { AvatarIconComponent } from './avatar-icon.types';
|
|
import {
|
|
AvatarIconProps,
|
|
AvatarIconSize,
|
|
avatarIconSizeToIconSize,
|
|
} from './avatar-icon.types';
|
|
|
|
export const AvatarIcon: AvatarIconComponent = React.forwardRef(
|
|
<C extends React.ElementType = 'div'>(
|
|
{
|
|
size = AvatarIconSize.Md,
|
|
color = TextColor.primaryDefault,
|
|
backgroundColor = BackgroundColor.primaryMuted,
|
|
className = '',
|
|
iconProps,
|
|
iconName,
|
|
...props
|
|
}: AvatarIconProps<C>,
|
|
ref?: PolymorphicRef<C>,
|
|
) => {
|
|
const iconSize = avatarIconSizeToIconSize[size];
|
|
return (
|
|
<AvatarBase
|
|
ref={ref}
|
|
size={size}
|
|
display={Display.Flex}
|
|
alignItems={AlignItems.center}
|
|
justifyContent={JustifyContent.center}
|
|
color={color as TextColor}
|
|
backgroundColor={backgroundColor}
|
|
borderColor={BorderColor.transparent}
|
|
className={classnames('mm-avatar-icon', className)}
|
|
{...(props as AvatarBaseProps<C>)}
|
|
>
|
|
<Icon
|
|
color={IconColor.inherit}
|
|
name={iconName}
|
|
size={iconSize}
|
|
{...iconProps}
|
|
/>
|
|
</AvatarBase>
|
|
);
|
|
},
|
|
);
|