2023-04-04 18:48:04 +02:00
|
|
|
import React from 'react';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
|
2023-05-25 22:53:31 +02:00
|
|
|
import { IconColor, Display } from '../../../helpers/constants/design-system';
|
2023-04-04 18:48:04 +02:00
|
|
|
|
2023-07-25 18:05:37 +02:00
|
|
|
import { Box, BoxProps } from '../box';
|
|
|
|
import type { PolymorphicRef } from '../box';
|
|
|
|
|
|
|
|
import { IconSize, IconProps, IconComponent } from './icon.types';
|
2023-04-04 18:48:04 +02:00
|
|
|
|
2023-07-25 18:05:37 +02:00
|
|
|
export const Icon: IconComponent = React.forwardRef(
|
|
|
|
<C extends React.ElementType = 'span'>(
|
|
|
|
{
|
|
|
|
name,
|
|
|
|
size = IconSize.Md,
|
|
|
|
color = IconColor.inherit,
|
|
|
|
className = '',
|
|
|
|
style,
|
|
|
|
...props
|
|
|
|
}: IconProps<C>,
|
|
|
|
ref?: PolymorphicRef<C>,
|
|
|
|
) => (
|
|
|
|
<Box
|
|
|
|
className={classnames(className, 'mm-icon', `mm-icon--size-${size}`)}
|
|
|
|
ref={ref}
|
|
|
|
as="span"
|
|
|
|
display={Display.InlineBlock}
|
|
|
|
color={color}
|
|
|
|
style={{
|
|
|
|
/**
|
|
|
|
* To reduce the possibility of injection attacks
|
|
|
|
* the icon component uses mask-image instead of rendering
|
|
|
|
* the svg directly.
|
|
|
|
*/
|
|
|
|
maskImage: `url('./images/icons/${String(name)}.svg')`,
|
|
|
|
WebkitMaskImage: `url('./images/icons/${String(name)}.svg')`,
|
|
|
|
...style,
|
|
|
|
}}
|
|
|
|
{...(props as BoxProps<C>)}
|
|
|
|
/>
|
|
|
|
),
|
2023-04-04 18:48:04 +02:00
|
|
|
);
|