UNPKG

tdesign-vue-next

Version:
456 lines (448 loc) 18.3 kB
/** * tdesign v1.11.5 * (c) 2025 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _defineProperty = require('@babel/runtime/helpers/defineProperty'); var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); var Vue = require('vue'); var tdesignIconsVueNext = require('tdesign-icons-vue-next'); var hooks_tnode = require('../_chunks/dep-a69ce597.js'); var hooks_useConfig = require('../hooks/useConfig.js'); var hooks_useDefaultValue = require('../hooks/useDefaultValue.js'); var hooks_usePopupManager = require('../hooks/usePopupManager.js'); var hooks_useTeleport = require('../hooks/useTeleport.js'); var hooks_useVModel = require('../hooks/useVModel.js'); var image_index = require('../image/index.js'); var imageViewer_base_ImageItem = require('./base/ImageItem.js'); var imageViewer_base_ImageModalIcon = require('./base/ImageModalIcon.js'); var imageViewer_base_ImageViewerModal = require('./base/ImageViewerModal.js'); var imageViewer_base_ImageViewerUtils = require('./base/ImageViewerUtils.js'); var imageViewer_consts_index = require('./consts/index.js'); var imageViewer_hooks_index = require('./hooks/index.js'); var imageViewer_props = require('./props.js'); var imageViewer_utils_index = require('./utils/index.js'); require('../utils/render-tnode.js'); require('../_chunks/dep-0a510359.js'); require('@babel/runtime/helpers/typeof'); require('../_chunks/dep-b8b9c2a3.js'); require('../_chunks/dep-bbe343d7.js'); require('../_chunks/dep-5ad8a2ab.js'); require('../_chunks/dep-0c2ad01b.js'); require('../_chunks/dep-db023c41.js'); require('../_chunks/dep-e495f218.js'); require('../_chunks/dep-bafc1f63.js'); require('../_chunks/dep-c07d6878.js'); require('../_chunks/dep-a957c564.js'); require('../_chunks/dep-acb090bf.js'); require('../_chunks/dep-76218bd8.js'); require('../_chunks/dep-047617bf.js'); require('../_chunks/dep-9a321a91.js'); require('../_chunks/dep-ecbaedee.js'); require('../_chunks/dep-8b98fa07.js'); require('../_chunks/dep-b0b4fff1.js'); require('../_chunks/dep-7a21da5b.js'); require('../_chunks/dep-ed572eb3.js'); require('../_chunks/dep-9de7d250.js'); require('../_chunks/dep-be3c3d53.js'); require('../config-provider/hooks/useConfig.js'); require('../_chunks/dep-b4c4a54b.js'); require('../_chunks/dep-f8ff548f.js'); require('../_chunks/dep-30fb1b25.js'); require('dayjs'); require('../_chunks/dep-b6c192db.js'); require('../_chunks/dep-ba2090c8.js'); require('../_chunks/dep-b27d3215.js'); require('../_chunks/dep-50a41d31.js'); require('../_chunks/dep-49fa220e.js'); require('../_chunks/dep-02ebb419.js'); require('../_chunks/dep-feae46a3.js'); require('../_chunks/dep-abf21389.js'); require('../_chunks/dep-7f32423d.js'); require('../_chunks/dep-7c9e3d93.js'); require('../_chunks/dep-61a7e281.js'); require('../_chunks/dep-6f8a66a3.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); require('../utils/dom.js'); require('../image/image.js'); require('../_chunks/dep-9da21bcd.js'); require('../image/props.js'); require('../space/index.js'); require('../space/space.js'); require('../space/props.js'); require('../hooks/slot.js'); require('../_chunks/dep-25acc189.js'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/objectWithoutProperties'); require('../_chunks/dep-93cf0a54.js'); require('../_chunks/dep-8afe2bf0.js'); require('../_chunks/dep-cea0dc9b.js'); require('../utils/withInstall.js'); require('../hooks/useImagePreviewUrl.js'); require('../_chunks/dep-f025d925.js'); require('../_chunks/dep-cef23b69.js'); require('../_chunks/dep-d67d6b6f.js'); require('../_chunks/dep-55d8c3ed.js'); require('../_chunks/dep-beb9de0a.js'); require('../_chunks/dep-43bc982b.js'); require('@babel/runtime/helpers/asyncToGenerator'); require('@babel/runtime/regenerator'); require('../dialog/index.js'); require('../dialog/dialog.js'); require('../dialog/props.js'); require('../button/index.js'); require('../button/button.js'); require('../loading/index.js'); require('../_chunks/dep-0d31a2f0.js'); require('../loading/plugin.js'); require('../loading/loading.js'); require('../loading/icon/gradient.js'); require('../_chunks/dep-b1b8272b.js'); require('../loading/props.js'); require('../_chunks/dep-d4796921.js'); require('../_chunks/dep-62aae11c.js'); require('../_chunks/dep-7c08b9a8.js'); require('../_chunks/dep-56c837c8.js'); require('../_chunks/dep-fd1ddb6b.js'); require('../_chunks/dep-d83ac33f.js'); require('../button/props.js'); require('../hooks/useRipple.js'); require('../hooks/useKeepAnimation.js'); require('../hooks/useDisabled.js'); require('../_chunks/dep-82a90f9f.js'); require('../dialog/hooks/useSameTarget.js'); require('../hooks/useDestroyOnClose.js'); require('../_chunks/dep-31c4c452.js'); require('../dialog/utils/index.js'); require('../dialog/dialog-card.js'); require('../dialog/dialog-card-props.js'); require('../hooks/useGlobalIcon.js'); require('../dialog/hooks/useAction.js'); require('../dialog/plugin.js'); require('../tooltip/index.js'); require('../tooltip/tooltip.js'); require('../tooltip/props.js'); require('../popup/props.js'); require('../popup/index.js'); require('../popup/popup.js'); require('@popperjs/core'); require('../popup/container.js'); require('../hooks/useResizeObserver.js'); require('../_chunks/dep-31140ae7.js'); require('../_chunks/dep-533159e9.js'); require('../tooltip/utils/index.js'); require('../_chunks/dep-de8595be.js'); require('../_chunks/dep-628f2a1a.js'); require('../_chunks/dep-be62446e.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty); var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray); var _ImageViewer = Vue.defineComponent({ name: "TImageViewer", props: imageViewer_props["default"], setup: function setup(props2) { var _props2$defaultIndex; var classPrefix = hooks_useConfig.usePrefixClass(); var COMPONENT_NAME = hooks_useConfig.usePrefixClass("image-viewer"); var renderTNodeJSX = hooks_tnode.useTNodeJSX(); var isExpand = Vue.ref(true); var showOverlayValue = Vue.computed(function () { return imageViewer_utils_index.getOverlay(props2); }); var _toRefs = Vue.toRefs(props2), index = _toRefs.index, visible = _toRefs.visible, modelValue = _toRefs.modelValue, imageReferrerpolicy = _toRefs.imageReferrerpolicy; var _useDefaultValue = hooks_useDefaultValue["default"](index, (_props2$defaultIndex = props2.defaultIndex) !== null && _props2$defaultIndex !== void 0 ? _props2$defaultIndex : 0, props2.onIndexChange, "index"), _useDefaultValue2 = _slicedToArray__default["default"](_useDefaultValue, 2), indexValue = _useDefaultValue2[0], setIndexValue = _useDefaultValue2[1]; var _useVModel = hooks_useVModel["default"](visible, modelValue, props2.defaultVisible, function () {}, "visible"), _useVModel2 = _slicedToArray__default["default"](_useVModel, 2), visibleValue = _useVModel2[0], setVisibleValue = _useVModel2[1]; var animationEnd = Vue.ref(true); var animationTimer = Vue.ref(); var teleportElement = hooks_useTeleport["default"](function () { return props2.attach; }); var wrapClass = Vue.computed(function () { return [COMPONENT_NAME.value, "".concat(COMPONENT_NAME.value, "-preview-image"), _defineProperty__default["default"]({}, "".concat(classPrefix.value, "-is-hide"), !visibleValue.value)]; }); var headerClass = Vue.computed(function () { return ["".concat(classPrefix.value, "-image-viewer__modal-header"), _defineProperty__default["default"]({}, "".concat(classPrefix.value, "-is-show"), isExpand.value)]; }); var zIndexValue = Vue.computed(function () { var _props2$zIndex; return (_props2$zIndex = props2.zIndex) !== null && _props2$zIndex !== void 0 ? _props2$zIndex : 2600; }); var toggleExpand = function toggleExpand() { isExpand.value = !isExpand.value; }; var _useMirror = imageViewer_hooks_index.useMirror(), mirror = _useMirror.mirror, onMirror = _useMirror.onMirror, resetMirror = _useMirror.resetMirror; var _useScale = imageViewer_hooks_index.useScale(props2.imageScale), scale = _useScale.scale, onZoomIn = _useScale.onZoomIn, onZoomOut = _useScale.onZoomOut, resetScale = _useScale.resetScale; var _useRotate = imageViewer_hooks_index.useRotate(), rotate = _useRotate.rotate, onRotate = _useRotate.onRotate, resetRotate = _useRotate.resetRotate; var onRest = function onRest() { resetMirror(); resetScale(); resetRotate(); }; var images = Vue.computed(function () { return imageViewer_utils_index.formatImages(props2.images); }); var currentImage = Vue.computed(function () { var _images$value$indexVa; return (_images$value$indexVa = images.value[indexValue.value]) !== null && _images$value$indexVa !== void 0 ? _images$value$indexVa : { mainImage: "" }; }); var _usePopupManager = hooks_usePopupManager["default"]("dialog", { visible: visibleValue }), isLastDialog = _usePopupManager.isLastDialog; var prevImage = function prevImage() { var newIndex = indexValue.value - 1; onRest(); setIndexValue(newIndex < 0 ? 0 : newIndex, { trigger: "prev" }); }; var nextImage = function nextImage() { var newIndex = indexValue.value + 1; onRest(); setIndexValue(newIndex >= images.value.length ? indexValue.value : newIndex, { trigger: "next" }); }; var onImgClick = function onImgClick(i) { setIndexValue(i, { trigger: "current" }); }; var onDownloadClick = function onDownloadClick(url) { props2.onDownload ? props2.onDownload(url) : imageViewer_utils_index.downloadFile(url); }; var openHandler = function openHandler() { setVisibleValue(true); }; var onClose = function onClose(ctx) { var _props2$onClose; setVisibleValue(false); (_props2$onClose = props2.onClose) === null || _props2$onClose === void 0 || _props2$onClose.call(props2, ctx); }; var closeBtnAction = function closeBtnAction(e) { onClose({ e: e, trigger: "close-btn" }); }; var clickOverlayHandler = function clickOverlayHandler(e) { if (props2.closeOnOverlay) { onClose({ e: e, trigger: "overlay" }); } }; var keydownHandler = function keydownHandler(e) { e.stopPropagation(); switch (e.code) { case imageViewer_consts_index.EVENT_CODE.left: prevImage(); break; case imageViewer_consts_index.EVENT_CODE.right: nextImage(); break; case imageViewer_consts_index.EVENT_CODE.up: onZoomIn(); break; case imageViewer_consts_index.EVENT_CODE.down: onZoomOut(); break; case imageViewer_consts_index.EVENT_CODE.esc: if (props2.closeOnEscKeydown && isLastDialog()) { onClose({ e: e, trigger: "esc" }); } break; } }; var divRef = Vue.ref(); Vue.watch(function () { return visibleValue.value; }, function (val) { clearTimeout(animationTimer.value); if (val) { animationEnd.value = false; Vue.nextTick().then(function () { var _divRef$value, _divRef$value$focus; (_divRef$value = divRef.value) === null || _divRef$value === void 0 || (_divRef$value$focus = _divRef$value.focus) === null || _divRef$value$focus === void 0 || _divRef$value$focus.call(_divRef$value); }); onRest(); } else { animationTimer.value = setTimeout(function () { animationEnd.value = true; }, 200); } }); var onWheel = function onWheel(e) { e.preventDefault(); var deltaY = e.deltaY; deltaY > 0 ? onZoomOut() : onZoomIn(); }; var transStyle = Vue.computed(function () { return { transform: "translateX(calc(-".concat(indexValue.value, " * (40px / 9 * 16 + 4px)))") }; }); var renderHeader = function renderHeader() { return Vue.createVNode("div", { "class": headerClass.value }, [Vue.createVNode(imageViewer_base_ImageModalIcon["default"], { "icon": function icon() { return Vue.createVNode(tdesignIconsVueNext.ChevronDownIcon, null, null); }, "class": "".concat(COMPONENT_NAME.value, "__header-pre-bt"), "onClick": toggleExpand }, null), Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__header-prev") }, [Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__header-trans"), "style": transStyle.value }, [images.value.map(function (image, index2) { return Vue.createVNode("div", { "key": index2, "class": ["".concat(COMPONENT_NAME.value, "__header-box"), _defineProperty__default["default"]({}, "".concat(classPrefix.value, "-is-active"), index2 === indexValue.value)] }, [Vue.createVNode(image_index.Image, { "src": image.thumbnail || image.mainImage, "error": "", "class": "".concat(COMPONENT_NAME.value, "__header-img"), "onClick": function onClick() { return onImgClick(index2); } }, null)]); })])])]); }; var renderNavigationArrow = function renderNavigationArrow(type) { var rotateDeg = type === "prev" ? 0 : 180; var _icon = renderTNodeJSX("navigationArrow", Vue.createVNode(tdesignIconsVueNext.ChevronLeftIcon, { "style": { transform: "rotate(".concat(rotateDeg, "deg)") }, "size": "24px" }, null)); return Vue.createVNode(imageViewer_base_ImageModalIcon["default"], { "class": "".concat(COMPONENT_NAME.value, "__modal-").concat(type, "-bt"), "onClick": type === "prev" ? prevImage : nextImage, "icon": function icon() { return _icon; } }, null); }; var renderCloseBtn = function renderCloseBtn() { if (props2.closeBtn === false) { return; } return Vue.createVNode("div", { "class": ["".concat(COMPONENT_NAME.value, "__modal-icon"), "".concat(COMPONENT_NAME.value, "__modal-close-bt")], "onClick": closeBtnAction }, [renderTNodeJSX("closeBtn", Vue.createVNode(tdesignIconsVueNext.CloseIcon, { "size": "24px" }, null))]); }; return function () { if (props2.mode === "modeless") { return Vue.createVNode(Vue.Fragment, null, [renderTNodeJSX("trigger", { params: { open: openHandler } }), Vue.createVNode(imageViewer_base_ImageViewerModal["default"], { "zIndex": zIndexValue.value, "visible": visibleValue.value, "index": indexValue.value, "images": images.value, "scale": scale.value, "rotate": rotate.value, "mirror": mirror.value, "currentImage": currentImage.value, "onRotate": onRotate, "onZoomIn": onZoomIn, "onZoomOut": onZoomOut, "onMirror": onMirror, "onReset": onRest, "onClose": onClose, "onDownload": onDownloadClick, "draggable": props2.draggable, "showOverlay": showOverlayValue.value, "title": props2.title, "imageReferrerpolicy": imageReferrerpolicy.value }, null)]); } return Vue.createVNode(Vue.Fragment, null, [renderTNodeJSX("trigger", { params: { open: openHandler } }), Vue.createVNode(Vue.Teleport, { "disabled": !props2.attach || !teleportElement.value, "to": teleportElement.value }, { "default": function _default() { return [Vue.createVNode(Vue.Transition, null, { "default": function _default() { return [(visibleValue.value || !animationEnd.value) && Vue.withDirectives(Vue.createVNode("div", { "ref": divRef, "class": wrapClass.value, "style": { zIndex: zIndexValue.value }, "onWheel": onWheel, "tabindex": -1, "onKeydown": keydownHandler }, [!!showOverlayValue.value && Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__modal-mask"), "onClick": clickOverlayHandler }, null), images.value.length > 1 && Vue.createVNode(Vue.Fragment, null, [renderHeader(), Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__modal-index") }, [props2.title && renderTNodeJSX("title"), "".concat(indexValue.value + 1, "/").concat(images.value.length)]), renderNavigationArrow("prev"), renderNavigationArrow("next")]), renderCloseBtn(), Vue.createVNode(imageViewer_base_ImageViewerUtils["default"], { "onZoomIn": onZoomIn, "onZoomOut": onZoomOut, "onMirror": onMirror, "onReset": onRest, "onRotate": onRotate, "onDownload": onDownloadClick, "scale": scale.value, "currentImage": currentImage.value }, null), Vue.createVNode(imageViewer_base_ImageItem["default"], { "scale": scale.value, "rotate": rotate.value, "mirror": mirror.value, "src": currentImage.value.mainImage, "placementSrc": currentImage.value.thumbnail, "isSvg": currentImage.value.isSvg, "imageReferrerpolicy": imageReferrerpolicy.value }, null)]), [[Vue.vShow, visibleValue.value]])]; } })]; } })]); }; } }); exports["default"] = _ImageViewer; //# sourceMappingURL=image-viewer.js.map