PurePanel.js 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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 React = _interopRequireWildcard(require("react"));
  10. var _classnames = _interopRequireDefault(require("classnames"));
  11. var _useClosable = _interopRequireDefault(require("../_util/hooks/useClosable"));
  12. var _PurePanel = require("../_util/PurePanel");
  13. var _reactNode = require("../_util/reactNode");
  14. var _configProvider = require("../config-provider");
  15. var _PurePanel2 = require("../popover/PurePanel");
  16. var _panelRender = _interopRequireDefault(require("./panelRender"));
  17. var _style = _interopRequireDefault(require("./style"));
  18. var __rest = void 0 && (void 0).__rest || function (s, e) {
  19. var t = {};
  20. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  21. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  22. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  23. }
  24. return t;
  25. };
  26. const PurePanel = props => {
  27. const {
  28. prefixCls: customizePrefixCls,
  29. current = 0,
  30. total = 6,
  31. className,
  32. style,
  33. type,
  34. closable,
  35. closeIcon
  36. } = props,
  37. restProps = __rest(props, ["prefixCls", "current", "total", "className", "style", "type", "closable", "closeIcon"]);
  38. const {
  39. getPrefixCls
  40. } = React.useContext(_configProvider.ConfigContext);
  41. const prefixCls = getPrefixCls('tour', customizePrefixCls);
  42. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls);
  43. const [mergedClosable, mergedCloseIcon] = (0, _useClosable.default)({
  44. closable,
  45. closeIcon
  46. }, null, {
  47. closable: true,
  48. closeIconRender: icon => {
  49. var _a;
  50. return /*#__PURE__*/React.isValidElement(icon) ? (0, _reactNode.cloneElement)(icon, {
  51. className: (0, _classnames.default)((_a = icon.props) === null || _a === void 0 ? void 0 : _a.className, `${prefixCls}-close-icon`)
  52. }) : icon;
  53. }
  54. });
  55. return wrapCSSVar(/*#__PURE__*/React.createElement(_PurePanel2.RawPurePanel, {
  56. prefixCls: prefixCls,
  57. hashId: hashId,
  58. className: (0, _classnames.default)(className, `${prefixCls}-pure`, type && `${prefixCls}-${type}`, cssVarCls),
  59. style: style
  60. }, /*#__PURE__*/React.createElement(_panelRender.default, {
  61. stepProps: Object.assign(Object.assign({}, restProps), {
  62. prefixCls,
  63. total,
  64. closable: mergedClosable ? {
  65. closeIcon: mergedCloseIcon
  66. } : undefined
  67. }),
  68. current: current,
  69. type: type
  70. })));
  71. };
  72. var _default = exports.default = (0, _PurePanel.withPureRenderTheme)(PurePanel);