UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

88 lines (87 loc) 4.81 kB
"use strict"; "use client"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); 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 _en_US = _interopRequireDefault(require("../locale/en_US")); var _PreviewGroup = _interopRequireWildcard(require("./PreviewGroup")); var _style = _interopRequireDefault(require("./style")); var _useCSSVarCls = _interopRequireDefault(require("../config-provider/hooks/useCSSVarCls")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } 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 => { 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(() => { if (preview === false) { return preview; } const _preview = typeof preview === 'object' ? preview : {}; const { getContainer } = _preview, restPreviewProps = __rest(_preview, ["getContainer"]); 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 }); }, [preview, imageLocale]); 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;