import React from 'react'; import PropTypes from 'prop-types'; import classnames from 'classnames'; import Box from '../../../ui/box/box'; import { Size, IconColor, DISPLAY, } from '../../../../helpers/constants/design-system'; import { ICON_SIZES, ICON_NAMES } from './icon.constants'; /** * @deprecated This is the javascript version of `Icon` which has been deprecated in favour of the TypeScript version of the same name. * * To use the TS version update the imports and enums as follows: * * `import { Icon, IconSize, IconName } from '../../component-library'`; */ export const Icon = ({ name, size = Size.MD, color = IconColor.inherit, className, style, ...props }) => { return ( ); }; Icon.propTypes = { /** * The name of the icon to display. Should be one of ICON_NAMES */ name: PropTypes.oneOf(Object.values(ICON_NAMES)).isRequired, /** * The size of the Icon. * Possible values could be SIZES.XS (12px), SIZES.SM (16px), SIZES.MD (20px), SIZES.LG (24px), SIZES.XL (32px), * Default value is SIZES.MD (20px). */ size: PropTypes.oneOf(Object.values(ICON_SIZES)), /** * The color of the icon. * Defaults to IconColor.inherit. */ color: PropTypes.oneOf(Object.values(IconColor)), /** * An additional className to apply to the icon. */ className: PropTypes.string, /** * Addition style properties to apply to the icon. * The Icon component uses inline styles to apply the icon's mask-image so be wary of overriding */ style: PropTypes.object, /** * Icon accepts all the props from Box */ ...Box.propTypes, };