@carbon/ibm-security
Version:
Carbon for Cloud & Cognitive IBM Security UI components
86 lines (83 loc) • 3.43 kB
JavaScript
import _extends from "@babel/runtime/helpers/extends";
import _defineProperty from "@babel/runtime/helpers/defineProperty";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
var _excluded = ["className", "height", "path", "renderIcon", "size", "title", "viewBox", "width"];
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
/**
* @file Icon.
* @copyright IBM Security 2019
*/
import classnames from 'classnames';
import { func, number, object, oneOfType, string } from 'prop-types';
import React, { cloneElement } from 'react';
import deprecatedProp from '../../globals/prop-types';
import { getComponentNamespace } from '../../globals/namespace';
var sizeDefaultProp = 20;
var sizePropType = oneOfType([number, string]);
var renderIconDefaultProp = null;
var renderIconPropType = oneOfType([func, object]);
// TODO: `2.x` - Remove deprecated props `height` and `width`.
/**
* Icon component.
*/
var Icon = function Icon(_ref) {
var className = _ref.className,
height = _ref.height,
path = _ref.path,
RenderIcon = _ref.renderIcon,
size = _ref.size,
title = _ref.title,
viewBox = _ref.viewBox,
width = _ref.width,
other = _objectWithoutProperties(_ref, _excluded);
var iconProps = _objectSpread({
'aria-hidden': 'true',
className: classnames(getComponentNamespace('icon'), className),
focusable: false,
preserveAspectRatio: 'xMidYMid meet',
style: {
willChange: 'transform'
}
}, other);
var iconSize = size || height || width;
if (path) {
return /*#__PURE__*/React.createElement("svg", _extends({}, iconProps, {
height: iconSize,
width: iconSize,
viewBox: viewBox
}), title && /*#__PURE__*/React.createElement("title", null, title), /*#__PURE__*/React.createElement("path", {
d: path
}));
}
return RenderIcon ? /*#__PURE__*/cloneElement(/*#__PURE__*/React.createElement(RenderIcon, null), iconProps) : RenderIcon;
};
Icon.defaultProps = {
className: '',
height: null,
path: null,
renderIcon: renderIconDefaultProp,
size: sizeDefaultProp,
title: undefined,
viewBox: '0 0 32 32',
width: null
};
var deprecatedSizeProp = deprecatedProp('size', sizePropType);
Icon.propTypes = {
/** @type {string} Extra classes to add. */
className: string,
height: deprecatedSizeProp,
/** @type {string} Path. */
path: string,
/** @type {Function|object} Icon to render. */
renderIcon: renderIconPropType,
/** @type {number|string} Size. */
size: sizePropType,
/** @type {string} Title. */
title: string,
/** @type {string} The SVG viewBox property. */
viewBox: string,
width: deprecatedSizeProp
};
export default Icon;
export { renderIconDefaultProp, renderIconPropType, sizeDefaultProp, sizePropType };