@aliretail/react-materials-components
Version:
69 lines (59 loc) • 3.37 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
exports.__esModule = true;
exports["default"] = Preview;
var _overlay = _interopRequireDefault(require("@alifd/next/lib/overlay"));
var _icon = _interopRequireDefault(require("@alifd/next/lib/icon"));
var _react = _interopRequireWildcard(require("react"));
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function Preview(props) {
var _props$value = props.value,
value = _props$value === void 0 ? {} : _props$value;
var wrapperRef = (0, _react.useRef)(null);
var _useState = (0, _react.useState)(false),
visible = _useState[0],
setVisible = _useState[1];
var showFull = (0, _react.useCallback)(function () {
setVisible(true);
}, []);
var onClose = (0, _react.useCallback)(function () {
setVisible(false);
}, []);
return /*#__PURE__*/_react["default"].createElement("div", {
className: "aliretail-upload-preview-wrapper",
ref: wrapperRef
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "aliretail-upload-preview-thumbnail"
}, /*#__PURE__*/_react["default"].createElement("img", {
src: value.url
})), /*#__PURE__*/_react["default"].createElement("span", {
className: "aliretail-upload-preview-tool"
}, /*#__PURE__*/_react["default"].createElement("a", {
className: "enlarge-link",
onClick: showFull
}, /*#__PURE__*/_react["default"].createElement(_icon["default"], {
type: "enlarge"
}))), /*#__PURE__*/_react["default"].createElement(_overlay["default"], {
visible: visible,
safeNode: wrapperRef.current,
align: "cc cc",
hasMask: true,
disableScroll: true,
onRequestClose: onClose,
animation: false,
shouldUpdatePosition: true,
canCloseByEsc: true,
canCloseByMask: true
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "aliretail-upload-preview-full-wrapper"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "aliretail-upload-preview-full-close"
}, /*#__PURE__*/_react["default"].createElement(_icon["default"], {
type: "close",
onClick: onClose
})), /*#__PURE__*/_react["default"].createElement("img", {
alt: "img-full",
src: value.url
}))));
}