vxe-pc-ui
Version:
A vue based PC component library
44 lines (43 loc) • 1.57 kB
JavaScript
import { h } from 'vue';
import { VxeUI } from '@vxe-ui/core';
import VxeImagePreviewComponent from './preview';
import XEUtils from 'xe-utils';
export const openPreviewImage = (options) => {
if (VxeUI.modal) {
const opts = Object.assign({
escClosable: true
}, options);
const { urlList, activeIndex } = opts;
const modalId = XEUtils.uniqueId('image-preview');
VxeUI.modal.open({
id: modalId,
title: '预览',
width: '100%',
height: '100%',
showHeader: false,
showFooter: false,
padding: false,
escClosable: opts.escClosable,
className: 'vxe-image-preview-popup-wrapper',
slots: {
default() {
return h(VxeImagePreviewComponent, {
modelValue: activeIndex,
urlList,
urlField: opts.urlField,
marginSize: opts.marginSize,
maskClosable: opts.maskClosable,
showPrintButton: opts.showPrintButton,
showDownloadButton: opts.showDownloadButton,
beforeDownloadMethod: opts.beforeDownloadMethod,
downloadMethod: opts.downloadMethod,
onClose() {
VxeUI.modal.close(modalId);
}
});
}
}
});
}
return Promise.resolve();
};