useClosable.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. "use strict";
  2. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.useClosable = useClosable;
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
  10. var React = _interopRequireWildcard(require("react"));
  11. function isConfigObj(closable) {
  12. return closable !== null && (0, _typeof2.default)(closable) === 'object';
  13. }
  14. /**
  15. * Convert `closable` to ClosableConfig.
  16. * When `preset` is true, will auto fill ClosableConfig with default value.
  17. */
  18. function getClosableConfig(closable, closeIcon, preset) {
  19. if (closable === false || closeIcon === false && (!isConfigObj(closable) || !closable.closeIcon)) {
  20. return null;
  21. }
  22. var mergedCloseIcon = typeof closeIcon !== 'boolean' ? closeIcon : undefined;
  23. if (isConfigObj(closable)) {
  24. var _closable$closeIcon;
  25. return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, closable), {}, {
  26. closeIcon: (_closable$closeIcon = closable.closeIcon) !== null && _closable$closeIcon !== void 0 ? _closable$closeIcon : mergedCloseIcon
  27. });
  28. }
  29. // When StepClosable no need auto fill, but RootClosable need this.
  30. return preset || closable || closeIcon ? {
  31. closeIcon: mergedCloseIcon
  32. } : 'empty';
  33. }
  34. function useClosable(stepClosable, stepCloseIcon, closable, closeIcon) {
  35. return React.useMemo(function () {
  36. var stepClosableConfig = getClosableConfig(stepClosable, stepCloseIcon, false);
  37. var rootClosableConfig = getClosableConfig(closable, closeIcon, true);
  38. if (stepClosableConfig !== 'empty') {
  39. return stepClosableConfig;
  40. }
  41. return rootClosableConfig;
  42. }, [closable, closeIcon, stepClosable, stepCloseIcon]);
  43. }