index.js 4.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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 _tour = _interopRequireDefault(require("@rc-component/tour"));
  11. var _classnames = _interopRequireDefault(require("classnames"));
  12. var _useZIndex = require("../_util/hooks/useZIndex");
  13. var _placements = _interopRequireDefault(require("../_util/placements"));
  14. var _zindexContext = _interopRequireDefault(require("../_util/zindexContext"));
  15. var _configProvider = require("../config-provider");
  16. var _internal = require("../theme/internal");
  17. var _panelRender = _interopRequireDefault(require("./panelRender"));
  18. var _PurePanel = _interopRequireDefault(require("./PurePanel"));
  19. var _style = _interopRequireDefault(require("./style"));
  20. var __rest = void 0 && (void 0).__rest || function (s, e) {
  21. var t = {};
  22. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  23. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  24. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  25. }
  26. return t;
  27. };
  28. const Tour = props => {
  29. const {
  30. prefixCls: customizePrefixCls,
  31. type,
  32. rootClassName,
  33. indicatorsRender,
  34. actionsRender,
  35. steps,
  36. closeIcon
  37. } = props,
  38. restProps = __rest(props, ["prefixCls", "type", "rootClassName", "indicatorsRender", "actionsRender", "steps", "closeIcon"]);
  39. const {
  40. getPrefixCls,
  41. direction,
  42. tour
  43. } = (0, _react.useContext)(_configProvider.ConfigContext);
  44. const prefixCls = getPrefixCls('tour', customizePrefixCls);
  45. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls);
  46. const [, token] = (0, _internal.useToken)();
  47. const mergedSteps = _react.default.useMemo(() => steps === null || steps === void 0 ? void 0 : steps.map(step => {
  48. var _a;
  49. return Object.assign(Object.assign({}, step), {
  50. className: (0, _classnames.default)(step.className, {
  51. [`${prefixCls}-primary`]: ((_a = step.type) !== null && _a !== void 0 ? _a : type) === 'primary'
  52. })
  53. });
  54. }), [steps, type]);
  55. const builtinPlacements = config => {
  56. var _a;
  57. return (0, _placements.default)({
  58. arrowPointAtCenter: (_a = config === null || config === void 0 ? void 0 : config.arrowPointAtCenter) !== null && _a !== void 0 ? _a : true,
  59. autoAdjustOverflow: true,
  60. offset: token.marginXXS,
  61. arrowWidth: token.sizePopupArrow,
  62. borderRadius: token.borderRadius
  63. });
  64. };
  65. const customClassName = (0, _classnames.default)({
  66. [`${prefixCls}-rtl`]: direction === 'rtl'
  67. }, hashId, cssVarCls, rootClassName);
  68. const mergedRenderPanel = (stepProps, stepCurrent) => (/*#__PURE__*/_react.default.createElement(_panelRender.default, {
  69. type: type,
  70. stepProps: stepProps,
  71. current: stepCurrent,
  72. indicatorsRender: indicatorsRender,
  73. actionsRender: actionsRender
  74. }));
  75. // ============================ zIndex ============================
  76. const [zIndex, contextZIndex] = (0, _useZIndex.useZIndex)('Tour', restProps.zIndex);
  77. return wrapCSSVar(/*#__PURE__*/_react.default.createElement(_zindexContext.default.Provider, {
  78. value: contextZIndex
  79. }, /*#__PURE__*/_react.default.createElement(_tour.default, Object.assign({}, restProps, {
  80. closeIcon: closeIcon !== null && closeIcon !== void 0 ? closeIcon : tour === null || tour === void 0 ? void 0 : tour.closeIcon,
  81. zIndex: zIndex,
  82. rootClassName: customClassName,
  83. prefixCls: prefixCls,
  84. animated: true,
  85. renderPanel: mergedRenderPanel,
  86. builtinPlacements: builtinPlacements,
  87. steps: mergedSteps
  88. }))));
  89. };
  90. if (process.env.NODE_ENV !== 'production') {
  91. Tour.displayName = 'Tour';
  92. }
  93. Tour._InternalPanelDoNotUseOrYouWillBeFired = _PurePanel.default;
  94. var _default = exports.default = Tour;