UNPKG

@carbon/ibm-security

Version:

Carbon for Cloud & Cognitive IBM Security UI components

94 lines (91 loc) 5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.sizePropType = exports.sizeDefaultProp = exports.renderIconPropType = exports.renderIconDefaultProp = exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _classnames = _interopRequireDefault(require("classnames")); var _propTypes = require("prop-types"); var _react = _interopRequireWildcard(require("react")); var _propTypes2 = _interopRequireDefault(require("../../globals/prop-types")); var _namespace = require("../../globals/namespace"); var _excluded = ["className", "height", "path", "renderIcon", "size", "title", "viewBox", "width"]; /** * @file Icon. * @copyright IBM Security 2019 */ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } 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) { (0, _defineProperty2.default)(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; } var sizeDefaultProp = exports.sizeDefaultProp = 20; var sizePropType = exports.sizePropType = (0, _propTypes.oneOfType)([_propTypes.number, _propTypes.string]); var renderIconDefaultProp = exports.renderIconDefaultProp = null; var renderIconPropType = exports.renderIconPropType = (0, _propTypes.oneOfType)([_propTypes.func, _propTypes.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 = (0, _objectWithoutProperties2.default)(_ref, _excluded); var iconProps = _objectSpread({ 'aria-hidden': 'true', className: (0, _classnames.default)((0, _namespace.getComponentNamespace)('icon'), className), focusable: false, preserveAspectRatio: 'xMidYMid meet', style: { willChange: 'transform' } }, other); var iconSize = size || height || width; if (path) { return /*#__PURE__*/_react.default.createElement("svg", (0, _extends2.default)({}, iconProps, { height: iconSize, width: iconSize, viewBox: viewBox }), title && /*#__PURE__*/_react.default.createElement("title", null, title), /*#__PURE__*/_react.default.createElement("path", { d: path })); } return RenderIcon ? /*#__PURE__*/(0, _react.cloneElement)(/*#__PURE__*/_react.default.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 = (0, _propTypes2.default)('size', sizePropType); Icon.propTypes = { /** @type {string} Extra classes to add. */ className: _propTypes.string, height: deprecatedSizeProp, /** @type {string} Path. */ path: _propTypes.string, /** @type {Function|object} Icon to render. */ renderIcon: renderIconPropType, /** @type {number|string} Size. */ size: sizePropType, /** @type {string} Title. */ title: _propTypes.string, /** @type {string} The SVG viewBox property. */ viewBox: _propTypes.string, width: deprecatedSizeProp }; var _default = exports.default = Icon;