UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

91 lines (90 loc) 4.48 kB
"use strict"; "use client"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var React = _interopRequireWildcard(require("react")); var _EyeOutlined = _interopRequireDefault(require("@ant-design/icons/EyeOutlined")); var _classnames = _interopRequireDefault(require("classnames")); var _rcImage = _interopRequireDefault(require("rc-image")); var _useZIndex = require("../_util/hooks/useZIndex"); var _motion = require("../_util/motion"); var _configProvider = require("../config-provider"); var _useCSSVarCls = _interopRequireDefault(require("../config-provider/hooks/useCSSVarCls")); var _en_US = _interopRequireDefault(require("../locale/en_US")); var _PreviewGroup = _interopRequireWildcard(require("./PreviewGroup")); var _style = _interopRequireDefault(require("./style")); var __rest = void 0 && (void 0).__rest || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; const Image = props => { var _a; const { prefixCls: customizePrefixCls, preview, className, rootClassName, style } = props, otherProps = __rest(props, ["prefixCls", "preview", "className", "rootClassName", "style"]); const { getPrefixCls, locale: contextLocale = _en_US.default, getPopupContainer: getContextPopupContainer, image } = React.useContext(_configProvider.ConfigContext); const prefixCls = getPrefixCls('image', customizePrefixCls); const rootPrefixCls = getPrefixCls(); const imageLocale = contextLocale.Image || _en_US.default.Image; // Style const rootCls = (0, _useCSSVarCls.default)(prefixCls); const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls, rootCls); const mergedRootClassName = (0, _classnames.default)(rootClassName, hashId, cssVarCls, rootCls); const mergedClassName = (0, _classnames.default)(className, hashId, image === null || image === void 0 ? void 0 : image.className); const [zIndex] = (0, _useZIndex.useZIndex)('ImagePreview', typeof preview === 'object' ? preview.zIndex : undefined); const mergedPreview = React.useMemo(() => { var _a; if (preview === false) { return preview; } const _preview = typeof preview === 'object' ? preview : {}; const { getContainer, closeIcon } = _preview, restPreviewProps = __rest(_preview, ["getContainer", "closeIcon"]); return Object.assign(Object.assign({ mask: ( /*#__PURE__*/React.createElement("div", { className: `${prefixCls}-mask-info` }, /*#__PURE__*/React.createElement(_EyeOutlined.default, null), imageLocale === null || imageLocale === void 0 ? void 0 : imageLocale.preview)), icons: _PreviewGroup.icons }, restPreviewProps), { getContainer: getContainer !== null && getContainer !== void 0 ? getContainer : getContextPopupContainer, transitionName: (0, _motion.getTransitionName)(rootPrefixCls, 'zoom', _preview.transitionName), maskTransitionName: (0, _motion.getTransitionName)(rootPrefixCls, 'fade', _preview.maskTransitionName), zIndex, closeIcon: closeIcon !== null && closeIcon !== void 0 ? closeIcon : (_a = image === null || image === void 0 ? void 0 : image.preview) === null || _a === void 0 ? void 0 : _a.closeIcon }); }, [preview, imageLocale, (_a = image === null || image === void 0 ? void 0 : image.preview) === null || _a === void 0 ? void 0 : _a.closeIcon]); const mergedStyle = Object.assign(Object.assign({}, image === null || image === void 0 ? void 0 : image.style), style); return wrapCSSVar( /*#__PURE__*/React.createElement(_rcImage.default, Object.assign({ prefixCls: prefixCls, preview: mergedPreview, rootClassName: mergedRootClassName, className: mergedClassName, style: mergedStyle }, otherProps))); }; Image.PreviewGroup = _PreviewGroup.default; if (process.env.NODE_ENV !== 'production') { Image.displayName = 'Image'; } var _default = exports.default = Image;