Icon.js 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  3. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = void 0;
  8. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  9. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  10. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  11. var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
  12. var React = _interopRequireWildcard(require("react"));
  13. var _classnames = _interopRequireDefault(require("classnames"));
  14. var _ref = require("rc-util/lib/ref");
  15. var _Context = _interopRequireDefault(require("./Context"));
  16. var _utils = require("../utils");
  17. var _excluded = ["className", "component", "viewBox", "spin", "rotate", "tabIndex", "onClick", "children"]; // Seems this is used for iconFont
  18. var Icon = /*#__PURE__*/React.forwardRef(function (props, ref) {
  19. var className = props.className,
  20. Component = props.component,
  21. viewBox = props.viewBox,
  22. spin = props.spin,
  23. rotate = props.rotate,
  24. tabIndex = props.tabIndex,
  25. onClick = props.onClick,
  26. children = props.children,
  27. restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
  28. var iconRef = React.useRef();
  29. var mergedRef = (0, _ref.useComposeRef)(iconRef, ref);
  30. (0, _utils.warning)(Boolean(Component || children), 'Should have `component` prop or `children`.');
  31. (0, _utils.useInsertStyles)(iconRef);
  32. var _React$useContext = React.useContext(_Context.default),
  33. _React$useContext$pre = _React$useContext.prefixCls,
  34. prefixCls = _React$useContext$pre === void 0 ? 'anticon' : _React$useContext$pre,
  35. rootClassName = _React$useContext.rootClassName;
  36. var classString = (0, _classnames.default)(rootClassName, prefixCls, (0, _defineProperty2.default)({}, "".concat(prefixCls, "-spin"), !!spin && !!Component), className);
  37. var svgClassString = (0, _classnames.default)((0, _defineProperty2.default)({}, "".concat(prefixCls, "-spin"), !!spin));
  38. var svgStyle = rotate ? {
  39. msTransform: "rotate(".concat(rotate, "deg)"),
  40. transform: "rotate(".concat(rotate, "deg)")
  41. } : undefined;
  42. var innerSvgProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, _utils.svgBaseProps), {}, {
  43. className: svgClassString,
  44. style: svgStyle,
  45. viewBox: viewBox
  46. });
  47. if (!viewBox) {
  48. delete innerSvgProps.viewBox;
  49. }
  50. // component > children
  51. var renderInnerNode = function renderInnerNode() {
  52. if (Component) {
  53. return /*#__PURE__*/React.createElement(Component, innerSvgProps, children);
  54. }
  55. if (children) {
  56. (0, _utils.warning)(Boolean(viewBox) || React.Children.count(children) === 1 && /*#__PURE__*/React.isValidElement(children) && React.Children.only(children).type === 'use', 'Make sure that you provide correct `viewBox`' + ' prop (default `0 0 1024 1024`) to the icon.');
  57. return /*#__PURE__*/React.createElement("svg", (0, _extends2.default)({}, innerSvgProps, {
  58. viewBox: viewBox
  59. }), children);
  60. }
  61. return null;
  62. };
  63. var iconTabIndex = tabIndex;
  64. if (iconTabIndex === undefined && onClick) {
  65. iconTabIndex = -1;
  66. }
  67. return /*#__PURE__*/React.createElement("span", (0, _extends2.default)({
  68. role: "img"
  69. }, restProps, {
  70. ref: mergedRef,
  71. tabIndex: iconTabIndex,
  72. onClick: onClick,
  73. className: classString
  74. }), renderInnerNode());
  75. });
  76. Icon.displayName = 'AntdIcon';
  77. var _default = exports.default = Icon;