AntdIcon.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. "use strict";
  2. 'use client';
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = void 0;
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  11. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  12. var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
  13. var React = _interopRequireWildcard(require("react"));
  14. var _classnames = _interopRequireDefault(require("classnames"));
  15. var _colors = require("@ant-design/colors");
  16. var _Context = _interopRequireDefault(require("./Context"));
  17. var _IconBase = _interopRequireDefault(require("./IconBase"));
  18. var _twoTonePrimaryColor = require("./twoTonePrimaryColor");
  19. var _utils = require("../utils");
  20. var _excluded = ["className", "icon", "spin", "rotate", "tabIndex", "onClick", "twoToneColor"];
  21. // Initial setting
  22. // should move it to antd main repo?
  23. (0, _twoTonePrimaryColor.setTwoToneColor)(_colors.blue.primary);
  24. // https://github.com/DefinitelyTyped/DefinitelyTyped/issues/34757#issuecomment-488848720
  25. var Icon = /*#__PURE__*/React.forwardRef(function (props, ref) {
  26. var className = props.className,
  27. icon = props.icon,
  28. spin = props.spin,
  29. rotate = props.rotate,
  30. tabIndex = props.tabIndex,
  31. onClick = props.onClick,
  32. twoToneColor = props.twoToneColor,
  33. restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
  34. var _React$useContext = React.useContext(_Context.default),
  35. _React$useContext$pre = _React$useContext.prefixCls,
  36. prefixCls = _React$useContext$pre === void 0 ? 'anticon' : _React$useContext$pre,
  37. rootClassName = _React$useContext.rootClassName;
  38. var classString = (0, _classnames.default)(rootClassName, prefixCls, (0, _defineProperty2.default)((0, _defineProperty2.default)({}, "".concat(prefixCls, "-").concat(icon.name), !!icon.name), "".concat(prefixCls, "-spin"), !!spin || icon.name === 'loading'), className);
  39. var iconTabIndex = tabIndex;
  40. if (iconTabIndex === undefined && onClick) {
  41. iconTabIndex = -1;
  42. }
  43. var svgStyle = rotate ? {
  44. msTransform: "rotate(".concat(rotate, "deg)"),
  45. transform: "rotate(".concat(rotate, "deg)")
  46. } : undefined;
  47. var _normalizeTwoToneColo = (0, _utils.normalizeTwoToneColors)(twoToneColor),
  48. _normalizeTwoToneColo2 = (0, _slicedToArray2.default)(_normalizeTwoToneColo, 2),
  49. primaryColor = _normalizeTwoToneColo2[0],
  50. secondaryColor = _normalizeTwoToneColo2[1];
  51. return /*#__PURE__*/React.createElement("span", (0, _extends2.default)({
  52. role: "img",
  53. "aria-label": icon.name
  54. }, restProps, {
  55. ref: ref,
  56. tabIndex: iconTabIndex,
  57. onClick: onClick,
  58. className: classString
  59. }), /*#__PURE__*/React.createElement(_IconBase.default, {
  60. icon: icon,
  61. primaryColor: primaryColor,
  62. secondaryColor: secondaryColor,
  63. style: svgStyle
  64. }));
  65. });
  66. Icon.displayName = 'AntdIcon';
  67. Icon.getTwoToneColor = _twoTonePrimaryColor.getTwoToneColor;
  68. Icon.setTwoToneColor = _twoTonePrimaryColor.setTwoToneColor;
  69. var _default = exports.default = Icon;