123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- var _typeof = require("@babel/runtime/helpers/typeof");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
- var _classnames2 = _interopRequireDefault(require("classnames"));
- var _rcDialog = _interopRequireDefault(require("rc-dialog"));
- var _addEventListener = _interopRequireDefault(require("rc-util/lib/Dom/addEventListener"));
- var _KeyCode = _interopRequireDefault(require("rc-util/lib/KeyCode"));
- var _react = _interopRequireWildcard(require("react"));
- var _Operations = _interopRequireDefault(require("./Operations"));
- var _context = require("./context");
- var _useImageTransform2 = _interopRequireDefault(require("./hooks/useImageTransform"));
- var _useMouseEvent2 = _interopRequireDefault(require("./hooks/useMouseEvent"));
- var _useStatus3 = _interopRequireDefault(require("./hooks/useStatus"));
- var _useTouchEvent2 = _interopRequireDefault(require("./hooks/useTouchEvent"));
- var _previewConfig = require("./previewConfig");
- var _excluded = ["fallback", "src", "imgRef"],
- _excluded2 = ["prefixCls", "src", "alt", "imageInfo", "fallback", "movable", "onClose", "visible", "icons", "rootClassName", "closeIcon", "getContainer", "current", "count", "countRender", "scaleStep", "minScale", "maxScale", "transitionName", "maskTransitionName", "imageRender", "imgCommonProps", "toolbarRender", "onTransform", "onChange"];
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(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 PreviewImage = function PreviewImage(_ref) {
- var fallback = _ref.fallback,
- src = _ref.src,
- imgRef = _ref.imgRef,
- props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
- var _useStatus = (0, _useStatus3.default)({
- src: src,
- fallback: fallback
- }),
- _useStatus2 = (0, _slicedToArray2.default)(_useStatus, 2),
- getImgRef = _useStatus2[0],
- srcAndOnload = _useStatus2[1];
- return /*#__PURE__*/_react.default.createElement("img", (0, _extends2.default)({
- ref: function ref(_ref2) {
- imgRef.current = _ref2;
- getImgRef(_ref2);
- }
- }, props, srcAndOnload));
- };
- var Preview = function Preview(props) {
- var prefixCls = props.prefixCls,
- src = props.src,
- alt = props.alt,
- imageInfo = props.imageInfo,
- fallback = props.fallback,
- _props$movable = props.movable,
- movable = _props$movable === void 0 ? true : _props$movable,
- onClose = props.onClose,
- visible = props.visible,
- _props$icons = props.icons,
- icons = _props$icons === void 0 ? {} : _props$icons,
- rootClassName = props.rootClassName,
- closeIcon = props.closeIcon,
- getContainer = props.getContainer,
- _props$current = props.current,
- current = _props$current === void 0 ? 0 : _props$current,
- _props$count = props.count,
- count = _props$count === void 0 ? 1 : _props$count,
- countRender = props.countRender,
- _props$scaleStep = props.scaleStep,
- scaleStep = _props$scaleStep === void 0 ? 0.5 : _props$scaleStep,
- _props$minScale = props.minScale,
- minScale = _props$minScale === void 0 ? 1 : _props$minScale,
- _props$maxScale = props.maxScale,
- maxScale = _props$maxScale === void 0 ? 50 : _props$maxScale,
- _props$transitionName = props.transitionName,
- transitionName = _props$transitionName === void 0 ? 'zoom' : _props$transitionName,
- _props$maskTransition = props.maskTransitionName,
- maskTransitionName = _props$maskTransition === void 0 ? 'fade' : _props$maskTransition,
- imageRender = props.imageRender,
- imgCommonProps = props.imgCommonProps,
- toolbarRender = props.toolbarRender,
- onTransform = props.onTransform,
- onChange = props.onChange,
- restProps = (0, _objectWithoutProperties2.default)(props, _excluded2);
- var imgRef = (0, _react.useRef)();
- var groupContext = (0, _react.useContext)(_context.PreviewGroupContext);
- var showLeftOrRightSwitches = groupContext && count > 1;
- var showOperationsProgress = groupContext && count >= 1;
- var _useState = (0, _react.useState)(true),
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
- enableTransition = _useState2[0],
- setEnableTransition = _useState2[1];
- var _useImageTransform = (0, _useImageTransform2.default)(imgRef, minScale, maxScale, onTransform),
- transform = _useImageTransform.transform,
- resetTransform = _useImageTransform.resetTransform,
- updateTransform = _useImageTransform.updateTransform,
- dispatchZoomChange = _useImageTransform.dispatchZoomChange;
- var _useMouseEvent = (0, _useMouseEvent2.default)(imgRef, movable, visible, scaleStep, transform, updateTransform, dispatchZoomChange),
- isMoving = _useMouseEvent.isMoving,
- onMouseDown = _useMouseEvent.onMouseDown,
- onWheel = _useMouseEvent.onWheel;
- var _useTouchEvent = (0, _useTouchEvent2.default)(imgRef, movable, visible, minScale, transform, updateTransform, dispatchZoomChange),
- isTouching = _useTouchEvent.isTouching,
- onTouchStart = _useTouchEvent.onTouchStart,
- onTouchMove = _useTouchEvent.onTouchMove,
- onTouchEnd = _useTouchEvent.onTouchEnd;
- var rotate = transform.rotate,
- scale = transform.scale;
- var wrapClassName = (0, _classnames2.default)((0, _defineProperty2.default)({}, "".concat(prefixCls, "-moving"), isMoving));
- (0, _react.useEffect)(function () {
- if (!enableTransition) {
- setEnableTransition(true);
- }
- }, [enableTransition]);
- var onAfterClose = function onAfterClose() {
- resetTransform('close');
- };
- var onZoomIn = function onZoomIn() {
- dispatchZoomChange(_previewConfig.BASE_SCALE_RATIO + scaleStep, 'zoomIn');
- };
- var onZoomOut = function onZoomOut() {
- dispatchZoomChange(_previewConfig.BASE_SCALE_RATIO / (_previewConfig.BASE_SCALE_RATIO + scaleStep), 'zoomOut');
- };
- var onRotateRight = function onRotateRight() {
- updateTransform({
- rotate: rotate + 90
- }, 'rotateRight');
- };
- var onRotateLeft = function onRotateLeft() {
- updateTransform({
- rotate: rotate - 90
- }, 'rotateLeft');
- };
- var onFlipX = function onFlipX() {
- updateTransform({
- flipX: !transform.flipX
- }, 'flipX');
- };
- var onFlipY = function onFlipY() {
- updateTransform({
- flipY: !transform.flipY
- }, 'flipY');
- };
- var onReset = function onReset() {
- resetTransform('reset');
- };
- var onActive = function onActive(offset) {
- var position = current + offset;
- if (!Number.isInteger(position) || position < 0 || position > count - 1) {
- return;
- }
- setEnableTransition(false);
- resetTransform(offset < 0 ? 'prev' : 'next');
- onChange === null || onChange === void 0 || onChange(position, current);
- };
- var onKeyDown = function onKeyDown(event) {
- if (!visible || !showLeftOrRightSwitches) return;
- if (event.keyCode === _KeyCode.default.LEFT) {
- onActive(-1);
- } else if (event.keyCode === _KeyCode.default.RIGHT) {
- onActive(1);
- }
- };
- var onDoubleClick = function onDoubleClick(event) {
- if (visible) {
- if (scale !== 1) {
- updateTransform({
- x: 0,
- y: 0,
- scale: 1
- }, 'doubleClick');
- } else {
- dispatchZoomChange(_previewConfig.BASE_SCALE_RATIO + scaleStep, 'doubleClick', event.clientX, event.clientY);
- }
- }
- };
- (0, _react.useEffect)(function () {
- var onKeyDownListener = (0, _addEventListener.default)(window, 'keydown', onKeyDown, false);
- return function () {
- onKeyDownListener.remove();
- };
- }, [visible, showLeftOrRightSwitches, current]);
- var imgNode = /*#__PURE__*/_react.default.createElement(PreviewImage, (0, _extends2.default)({}, imgCommonProps, {
- width: props.width,
- height: props.height,
- imgRef: imgRef,
- className: "".concat(prefixCls, "-img"),
- alt: alt,
- style: {
- transform: "translate3d(".concat(transform.x, "px, ").concat(transform.y, "px, 0) scale3d(").concat(transform.flipX ? '-' : '').concat(scale, ", ").concat(transform.flipY ? '-' : '').concat(scale, ", 1) rotate(").concat(rotate, "deg)"),
- transitionDuration: (!enableTransition || isTouching) && '0s'
- },
- fallback: fallback,
- src: src,
- onWheel: onWheel,
- onMouseDown: onMouseDown,
- onDoubleClick: onDoubleClick,
- onTouchStart: onTouchStart,
- onTouchMove: onTouchMove,
- onTouchEnd: onTouchEnd,
- onTouchCancel: onTouchEnd
- }));
- var image = (0, _objectSpread2.default)({
- url: src,
- alt: alt
- }, imageInfo);
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_rcDialog.default, (0, _extends2.default)({
- transitionName: transitionName,
- maskTransitionName: maskTransitionName,
- closable: false,
- keyboard: true,
- prefixCls: prefixCls,
- onClose: onClose,
- visible: visible,
- classNames: {
- wrapper: wrapClassName
- },
- rootClassName: rootClassName,
- getContainer: getContainer
- }, restProps, {
- afterClose: onAfterClose
- }), /*#__PURE__*/_react.default.createElement("div", {
- className: "".concat(prefixCls, "-img-wrapper")
- }, imageRender ? imageRender(imgNode, (0, _objectSpread2.default)({
- transform: transform,
- image: image
- }, groupContext ? {
- current: current
- } : {})) : imgNode)), /*#__PURE__*/_react.default.createElement(_Operations.default, {
- visible: visible,
- transform: transform,
- maskTransitionName: maskTransitionName,
- closeIcon: closeIcon,
- getContainer: getContainer,
- prefixCls: prefixCls,
- rootClassName: rootClassName,
- icons: icons,
- countRender: countRender,
- showSwitch: showLeftOrRightSwitches,
- showProgress: showOperationsProgress,
- current: current,
- count: count,
- scale: scale,
- minScale: minScale,
- maxScale: maxScale,
- toolbarRender: toolbarRender,
- onActive: onActive,
- onZoomIn: onZoomIn,
- onZoomOut: onZoomOut,
- onRotateRight: onRotateRight,
- onRotateLeft: onRotateLeft,
- onFlipX: onFlipX,
- onFlipY: onFlipY,
- onClose: onClose,
- onReset: onReset,
- zIndex: restProps.zIndex !== undefined ? restProps.zIndex + 1 : undefined,
- image: image
- }));
- };
- var _default = exports.default = Preview;
|