@carbon/ibm-security
Version:
Carbon for Cloud & Cognitive IBM Security UI components
94 lines (91 loc) • 5 kB
JavaScript
;
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;