import Vue from 'vue'
|
// 导入组件
|
import DeleteFileDialog from './Dialog.vue'
|
// 使用基础 Vue 构造器,创建一个“子类”
|
const DeleteFileConstructor = Vue.extend(DeleteFileDialog)
|
|
let deleteFileInstance = null
|
/**
|
* 初始化删除文件实例
|
* @param {boolean} isBatchOperation 是否为批量删除:true - 批量删除,false - 单文件删除
|
* @param {object | array} fileInfo 文件信息,批量时为数组、单文件时为对象
|
* @param {number} deleteMode 删除模式:1-删除到回收站 2-彻底删除
|
*/
|
const initInstanceDeleteFile = (isBatchOperation, fileInfo, deleteMode) => {
|
deleteFileInstance = new DeleteFileConstructor({
|
el: document.createElement('div'),
|
data() {
|
return {
|
isBatchOperation,
|
fileInfo,
|
deleteMode
|
}
|
}
|
})
|
}
|
/**
|
* 删除文件 Promise 函数
|
* @returns {Promise} 抛出确认和取消回调函数
|
*/
|
const showDeleteFileDialog = (obj) => {
|
// 非首次调用服务时,在 DOM 中移除上个实例
|
if (deleteFileInstance !== null) {
|
document.body.removeChild(deleteFileInstance.$el)
|
}
|
let { isBatchOperation, fileInfo, deleteMode } = obj
|
return new Promise((reslove) => {
|
initInstanceDeleteFile(isBatchOperation, fileInfo, deleteMode)
|
deleteFileInstance.callback = (res) => {
|
reslove(res)
|
// 服务取消时卸载 DOM
|
if (res === 'cancel' && deleteFileInstance !== null) {
|
document.body.removeChild(deleteFileInstance.$el)
|
deleteFileInstance = null
|
}
|
}
|
document.body.appendChild(deleteFileInstance.$el) // 挂载 DOM
|
Vue.nextTick(() => {
|
deleteFileInstance.visible = true // 打开对话框
|
})
|
})
|
}
|
|
export default showDeleteFileDialog
|