UNPKG

@carbon/ibm-security

Version:

Carbon for Cloud & Cognitive IBM Security UI components

86 lines (83 loc) 3.43 kB
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 };