UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

69 lines 3.09 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import _typeof from "@babel/runtime/helpers/esm/typeof"; import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray"; var __rest = this && this.__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; }; import EyeOutlined from "@ant-design/icons/es/icons/EyeOutlined"; import classNames from 'classnames'; import RcImage from 'rc-image'; import * as React from 'react'; import { useContext } from 'react'; import { ConfigContext } from '../config-provider'; import defaultLocale from '../locale/en_US'; import { getTransitionName } from '../_util/motion'; // CSSINJS import PreviewGroup, { icons } from './PreviewGroup'; import useStyle from './style'; var Image = function Image(_a) { var customizePrefixCls = _a.prefixCls, preview = _a.preview, rootClassName = _a.rootClassName, otherProps = __rest(_a, ["prefixCls", "preview", "rootClassName"]); var _useContext = useContext(ConfigContext), getPrefixCls = _useContext.getPrefixCls, _useContext$locale = _useContext.locale, contextLocale = _useContext$locale === void 0 ? defaultLocale : _useContext$locale, getContextPopupContainer = _useContext.getPopupContainer; var prefixCls = getPrefixCls('image', customizePrefixCls); var rootPrefixCls = getPrefixCls(); var imageLocale = contextLocale.Image || defaultLocale.Image; // Style var _useStyle = useStyle(prefixCls), _useStyle2 = _slicedToArray(_useStyle, 2), wrapSSR = _useStyle2[0], hashId = _useStyle2[1]; var mergedRootClassName = classNames(rootClassName, hashId); var mergedPreview = React.useMemo(function () { if (preview === false) { return preview; } var _preview = _typeof(preview) === 'object' ? preview : {}; var getContainer = _preview.getContainer, restPreviewProps = __rest(_preview, ["getContainer"]); return _extends(_extends({ mask: /*#__PURE__*/React.createElement("div", { className: prefixCls + "-mask-info" }, /*#__PURE__*/React.createElement(EyeOutlined, null), imageLocale === null || imageLocale === void 0 ? void 0 : imageLocale.preview), icons: icons }, restPreviewProps), { getContainer: getContainer || getContextPopupContainer, transitionName: getTransitionName(rootPrefixCls, 'zoom', _preview.transitionName), maskTransitionName: getTransitionName(rootPrefixCls, 'fade', _preview.maskTransitionName) }); }, [preview, imageLocale]); return wrapSSR( /*#__PURE__*/React.createElement(RcImage, _extends({ prefixCls: "" + prefixCls, preview: mergedPreview, rootClassName: mergedRootClassName }, otherProps))); }; Image.PreviewGroup = PreviewGroup; export default Image;