Files
xen-orchestra/src/common/icon.js
2017-11-14 15:25:02 +01:00

25 lines
677 B
JavaScript

import classNames from 'classnames'
import isInteger from 'lodash/isInteger'
import React from 'react'
import propTypes from './prop-types-decorator'
const Icon = ({ icon, size = 1, color, fixedWidth, ...props }) => {
props.className = classNames(
props.className,
icon !== undefined ? `xo-icon-${icon}` : 'fa', // Without icon prop, is a placeholder.
isInteger(size) ? `fa-${size}x` : `fa-${size}`,
color,
fixedWidth && 'fa-fw'
)
return <i {...props} />
}
propTypes(Icon)({
color: propTypes.string,
fixedWidth: propTypes.bool,
icon: propTypes.string,
size: propTypes.oneOfType([propTypes.string, propTypes.number]),
})
export default Icon