index.js 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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 _EyeOutlined = _interopRequireDefault(require("@ant-design/icons/EyeOutlined"));
  11. var _classnames = _interopRequireDefault(require("classnames"));
  12. var _rcImage = _interopRequireDefault(require("rc-image"));
  13. var _useZIndex = require("../_util/hooks/useZIndex");
  14. var _motion = require("../_util/motion");
  15. var _warning = require("../_util/warning");
  16. var _context = require("../config-provider/context");
  17. var _useCSSVarCls = _interopRequireDefault(require("../config-provider/hooks/useCSSVarCls"));
  18. var _locale = require("../locale");
  19. var _PreviewGroup = _interopRequireWildcard(require("./PreviewGroup"));
  20. var _style = _interopRequireDefault(require("./style"));
  21. var __rest = void 0 && (void 0).__rest || function (s, e) {
  22. var t = {};
  23. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  24. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  25. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  26. }
  27. return t;
  28. };
  29. const Image = props => {
  30. const {
  31. prefixCls: customizePrefixCls,
  32. preview,
  33. className,
  34. rootClassName,
  35. style
  36. } = props,
  37. otherProps = __rest(props, ["prefixCls", "preview", "className", "rootClassName", "style"]);
  38. if (process.env.NODE_ENV !== 'production') {
  39. const warning = (0, _warning.devUseWarning)('Image');
  40. warning.deprecated(!(preview && typeof preview === 'object' && 'destroyOnClose' in preview), 'destroyOnClose', 'destroyOnHidden');
  41. }
  42. const {
  43. getPrefixCls,
  44. getPopupContainer: getContextPopupContainer,
  45. className: contextClassName,
  46. style: contextStyle,
  47. preview: contextPreview
  48. } = (0, _context.useComponentConfig)('image');
  49. const [imageLocale] = (0, _locale.useLocale)('Image');
  50. const prefixCls = getPrefixCls('image', customizePrefixCls);
  51. const rootPrefixCls = getPrefixCls();
  52. // Style
  53. const rootCls = (0, _useCSSVarCls.default)(prefixCls);
  54. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls, rootCls);
  55. const mergedRootClassName = (0, _classnames.default)(rootClassName, hashId, cssVarCls, rootCls);
  56. const mergedClassName = (0, _classnames.default)(className, hashId, contextClassName);
  57. const [zIndex] = (0, _useZIndex.useZIndex)('ImagePreview', typeof preview === 'object' ? preview.zIndex : undefined);
  58. const mergedPreview = React.useMemo(() => {
  59. if (preview === false) {
  60. return preview;
  61. }
  62. const _preview = typeof preview === 'object' ? preview : {};
  63. const {
  64. getContainer,
  65. closeIcon,
  66. rootClassName,
  67. destroyOnClose,
  68. destroyOnHidden
  69. } = _preview,
  70. restPreviewProps = __rest(_preview, ["getContainer", "closeIcon", "rootClassName", "destroyOnClose", "destroyOnHidden"]);
  71. return Object.assign(Object.assign({
  72. mask: (/*#__PURE__*/React.createElement("div", {
  73. className: `${prefixCls}-mask-info`
  74. }, /*#__PURE__*/React.createElement(_EyeOutlined.default, null), imageLocale === null || imageLocale === void 0 ? void 0 : imageLocale.preview)),
  75. icons: _PreviewGroup.icons
  76. }, restPreviewProps), {
  77. // TODO: In the future, destroyOnClose in rc-image needs to be upgrade to destroyOnHidden
  78. destroyOnClose: destroyOnHidden !== null && destroyOnHidden !== void 0 ? destroyOnHidden : destroyOnClose,
  79. rootClassName: (0, _classnames.default)(mergedRootClassName, rootClassName),
  80. getContainer: getContainer !== null && getContainer !== void 0 ? getContainer : getContextPopupContainer,
  81. transitionName: (0, _motion.getTransitionName)(rootPrefixCls, 'zoom', _preview.transitionName),
  82. maskTransitionName: (0, _motion.getTransitionName)(rootPrefixCls, 'fade', _preview.maskTransitionName),
  83. zIndex,
  84. closeIcon: closeIcon !== null && closeIcon !== void 0 ? closeIcon : contextPreview === null || contextPreview === void 0 ? void 0 : contextPreview.closeIcon
  85. });
  86. }, [preview, imageLocale, contextPreview === null || contextPreview === void 0 ? void 0 : contextPreview.closeIcon]);
  87. const mergedStyle = Object.assign(Object.assign({}, contextStyle), style);
  88. return wrapCSSVar(/*#__PURE__*/React.createElement(_rcImage.default, Object.assign({
  89. prefixCls: prefixCls,
  90. preview: mergedPreview,
  91. rootClassName: mergedRootClassName,
  92. className: mergedClassName,
  93. style: mergedStyle
  94. }, otherProps)));
  95. };
  96. Image.PreviewGroup = _PreviewGroup.default;
  97. if (process.env.NODE_ENV !== 'production') {
  98. Image.displayName = 'Image';
  99. }
  100. var _default = exports.default = Image;