1、左侧菜单树和按钮样式调整
2、上传文件夹逻辑调整 3、文档工具详情新增预览 4、所有的预览功能新增遮罩处理
This commit is contained in:
parent
7fe80361f7
commit
d60b5adb62
@ -4,7 +4,7 @@
|
|||||||
:before-upload="beforeUpload"
|
:before-upload="beforeUpload"
|
||||||
:on-change="onChange"
|
:on-change="onChange"
|
||||||
:on-remove="handleRemove"
|
:on-remove="handleRemove"
|
||||||
:multiple="isMultiple"
|
:multiple="false"
|
||||||
:on-exceed="handleExceed"
|
:on-exceed="handleExceed"
|
||||||
:accept="acceptType"
|
:accept="acceptType"
|
||||||
:file-list="fileList"
|
:file-list="fileList"
|
||||||
@ -18,11 +18,7 @@
|
|||||||
<!-- 上传-->
|
<!-- 上传-->
|
||||||
<input v-show="false" ref="fileRef" id="fileFolder" type="file" @change="handleFolderUpload" webkitdirectory
|
<input v-show="false" ref="fileRef" id="fileFolder" type="file" @change="handleFolderUpload" webkitdirectory
|
||||||
multiple="multiple" />
|
multiple="multiple" />
|
||||||
|
|
||||||
<!-- <input v-show="false" type="file" ref="fileRef" webkitdirectory @change="handleFolderUpload">
|
|
||||||
<el-button slot="trigger" size="small" type="primary">选取文件夹</el-button>-->
|
|
||||||
</el-upload>
|
</el-upload>
|
||||||
<!-- <div slot="tip" class="el-upload__tip" >只能上传{{acceptType}}文件</div>-->
|
|
||||||
<div v-show="progressFlag" class="head-img">
|
<div v-show="progressFlag" class="head-img">
|
||||||
<el-progress :text-inside="true" :stroke-width="14" :percentage="progressPercent" status="success"></el-progress>
|
<el-progress :text-inside="true" :stroke-width="14" :percentage="progressPercent" status="success"></el-progress>
|
||||||
</div>
|
</div>
|
||||||
@ -34,7 +30,6 @@ import axios from 'axios'
|
|||||||
import {
|
import {
|
||||||
getToken
|
getToken
|
||||||
} from "@/utils/auth";
|
} from "@/utils/auth";
|
||||||
import JSZip from 'jszip'
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
props: {
|
props: {
|
||||||
@ -96,6 +91,8 @@ export default {
|
|||||||
uploadedNum: 0,
|
uploadedNum: 0,
|
||||||
_shardCount: null, //是否最后一片
|
_shardCount: null, //是否最后一片
|
||||||
isFolder: false,
|
isFolder: false,
|
||||||
|
totalFiles: 0, // 总文件数量
|
||||||
|
uploadedCount: 0, // 已上传文件数量
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
@ -196,38 +193,42 @@ export default {
|
|||||||
});
|
});
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
self.uploadedNum = 0
|
self.uploadIdSharding(file);
|
||||||
file._shardCount = Math.ceil(file.size / this.partSize) //总片数
|
|
||||||
file.uploaded = 0
|
|
||||||
let formData = new FormData()
|
|
||||||
formData.append('fileName', file.name)
|
|
||||||
//大文件上传初始化,返回uploadId initUpload(formData)
|
|
||||||
axios({
|
|
||||||
url: process.env.VUE_APP_BASE_API + "/common/initUpload",
|
|
||||||
method: 'post',
|
|
||||||
data: formData,
|
|
||||||
headers: {
|
|
||||||
'Authorization': 'Bearer ' + getToken(),
|
|
||||||
'Content-Type': 'multipart/form-data'
|
|
||||||
},
|
|
||||||
}).then(function (res) {
|
|
||||||
if (res.status == 200) {
|
|
||||||
//从第0块开始上传
|
|
||||||
file.uploadId = res.data.uploadId
|
|
||||||
file.objectKey = res.data
|
|
||||||
file.chunkId = 0
|
|
||||||
self.uploadByChunk(file)
|
|
||||||
} else {
|
|
||||||
this.progress--
|
|
||||||
self.$message.error(res.msg)
|
|
||||||
}
|
|
||||||
}).catch(error => {
|
|
||||||
self.progressPercent = 0
|
|
||||||
self.progressFlag = false;
|
|
||||||
console.error(error)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
uploadIdSharding(file){
|
||||||
|
let self = this
|
||||||
|
self.uploadedNum = 0
|
||||||
|
file._shardCount = Math.ceil(file.size / this.partSize) //总片数
|
||||||
|
file.uploaded = 0
|
||||||
|
let formData = new FormData()
|
||||||
|
formData.append('fileName', file.name)
|
||||||
|
//大文件上传初始化,返回uploadId initUpload(formData)
|
||||||
|
axios({
|
||||||
|
url: process.env.VUE_APP_BASE_API + "/common/initUpload",
|
||||||
|
method: 'post',
|
||||||
|
data: formData,
|
||||||
|
headers: {
|
||||||
|
'Authorization': 'Bearer ' + getToken(),
|
||||||
|
'Content-Type': 'multipart/form-data'
|
||||||
|
},
|
||||||
|
}).then(function (res) {
|
||||||
|
if (res.status == 200) {
|
||||||
|
//从第0块开始上传
|
||||||
|
file.uploadId = res.data.uploadId
|
||||||
|
file.objectKey = res.data
|
||||||
|
file.chunkId = 0
|
||||||
|
self.uploadByChunk(file)
|
||||||
|
} else {
|
||||||
|
this.progress--
|
||||||
|
self.$message.error(res.msg)
|
||||||
|
}
|
||||||
|
}).catch(error => {
|
||||||
|
self.progressPercent = 0
|
||||||
|
self.progressFlag = false;
|
||||||
|
console.error(error)
|
||||||
|
})
|
||||||
},
|
},
|
||||||
//分片上传大文件
|
//分片上传大文件
|
||||||
uploadByChunk(file) {
|
uploadByChunk(file) {
|
||||||
@ -254,7 +255,6 @@ export default {
|
|||||||
'Authorization': 'Bearer ' + getToken(),
|
'Authorization': 'Bearer ' + getToken(),
|
||||||
'Content-Type': 'multipart/form-data'
|
'Content-Type': 'multipart/form-data'
|
||||||
},
|
},
|
||||||
|
|
||||||
}).then(response => {
|
}).then(response => {
|
||||||
if (response.status == 200) {
|
if (response.status == 200) {
|
||||||
//判断返回的MD5值是否一致,一致继续传下一块,否则重传本块(这里目前前后端MD5一直不一致,暂时先注释掉,有时间了我再研究一下)
|
//判断返回的MD5值是否一致,一致继续传下一块,否则重传本块(这里目前前后端MD5一直不一致,暂时先注释掉,有时间了我再研究一下)
|
||||||
@ -327,6 +327,7 @@ export default {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
resetData() {
|
resetData() {
|
||||||
this.progress = 0;
|
this.progress = 0;
|
||||||
},
|
},
|
||||||
@ -346,7 +347,6 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 清空文件 **/
|
/** 清空文件 **/
|
||||||
clearFile(){
|
clearFile(){
|
||||||
this.progressFlag = false;
|
|
||||||
if(this.$refs.upload){
|
if(this.$refs.upload){
|
||||||
this.$refs.upload.clearFiles();
|
this.$refs.upload.clearFiles();
|
||||||
}
|
}
|
||||||
@ -357,7 +357,7 @@ export default {
|
|||||||
document.getElementById("fileFolder").value = null;
|
document.getElementById("fileFolder").value = null;
|
||||||
this.$refs.fileRef.dispatchEvent(new MouseEvent("click"));
|
this.$refs.fileRef.dispatchEvent(new MouseEvent("click"));
|
||||||
},
|
},
|
||||||
async handleFolderUpload(event) {
|
/* async handleFolderUpload(event) {
|
||||||
let self = this;
|
let self = this;
|
||||||
self.isFolder = true
|
self.isFolder = true
|
||||||
const files = event.target.files;
|
const files = event.target.files;
|
||||||
@ -376,17 +376,236 @@ export default {
|
|||||||
}
|
}
|
||||||
await self.uploadFile(temp);
|
await self.uploadFile(temp);
|
||||||
}
|
}
|
||||||
/* console.info("files=========", files)
|
}, */
|
||||||
let fileListTemp = []
|
|
||||||
for(let item of files){
|
/* // 处理文件夹上传
|
||||||
fileListTemp.push(item);
|
async handleFolderUpload(event) {
|
||||||
|
const files = event.target.files;
|
||||||
|
this.isFolder = true;
|
||||||
|
this.progressFlag = true;
|
||||||
|
|
||||||
|
if (files.length === 0) {
|
||||||
|
this.$message.warning('没有选择文件');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let successCount = 0;
|
||||||
|
let failCount = 0;
|
||||||
|
for (const file of files) {
|
||||||
|
try {
|
||||||
|
await this.uploadFolderFile({ file });
|
||||||
|
successCount++;
|
||||||
|
} catch (error) {
|
||||||
|
failCount++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.$message.success(`上传完成!成功:${successCount},失败:${failCount}`);
|
||||||
|
this.progressFlag = false;
|
||||||
|
this.progressPercent = 0;
|
||||||
|
}, */
|
||||||
|
// 单个文件上传
|
||||||
|
uploadFolderFile({ data, file }) {
|
||||||
|
let self = this
|
||||||
|
//初始化参数
|
||||||
|
if (file.size < this.partSize) {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
const formData = new FormData();
|
||||||
|
formData.append("file", file);
|
||||||
|
this.progressFlag = true;
|
||||||
|
|
||||||
|
axios({
|
||||||
|
url: self.uploadUrl,
|
||||||
|
method: 'post',
|
||||||
|
data: formData,
|
||||||
|
headers: {
|
||||||
|
'Authorization': 'Bearer ' + getToken(),
|
||||||
|
'Content-Type': 'multipart/form-data'
|
||||||
|
},
|
||||||
|
/* onUploadProgress: progressEvent => {
|
||||||
|
this.progressPercent = ((progressEvent.loaded / progressEvent.total) * 100) | 0;
|
||||||
|
} */
|
||||||
|
}).then(res => {
|
||||||
|
setTimeout(() => {
|
||||||
|
if (res.data.code === 200) {
|
||||||
|
// self.progressFlag = false;
|
||||||
|
// self.progressPercent = 0;
|
||||||
|
self.handleResult(res,file);
|
||||||
|
resolve(); // 上传成功后,调用 resolve
|
||||||
|
} else {
|
||||||
|
// self.progressFlag = false;
|
||||||
|
self.$message.error(file.name + '上传失败!');
|
||||||
|
reject(); // 上传失败时调用 reject
|
||||||
|
}
|
||||||
|
}, 500);
|
||||||
|
}).catch(error => {
|
||||||
|
// self.progressFlag = false;
|
||||||
|
// self.progressPercent = 0;
|
||||||
|
self.$message.error(file.name + '上传失败!');
|
||||||
|
reject(error); // 上传失败时调用 reject
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}else{
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
self.uploadIdShardingFolder(file)
|
||||||
|
.then(() => {
|
||||||
|
resolve(); // 上传成功,继续下一个文件
|
||||||
|
})
|
||||||
|
.catch(error => {
|
||||||
|
reject(error); // 上传失败,触发 reject
|
||||||
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
self.fileList = fileListTemp; */
|
|
||||||
/* files.for()
|
|
||||||
self.onChange(null, files); */
|
|
||||||
// self.fileList = files;
|
|
||||||
// this.$refs.fileRef.value = null;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
|
async handleFolderUpload(event) {
|
||||||
|
const files = Array.from(event.target.files);
|
||||||
|
this.totalFiles = files.length;
|
||||||
|
this.uploadedCount = 0;
|
||||||
|
this.progressFlag = true;
|
||||||
|
let failCount = 0;
|
||||||
|
for (let i = 0; i < files.length; i++) {
|
||||||
|
try {
|
||||||
|
await this.uploadFolderFile(
|
||||||
|
{
|
||||||
|
data: null,
|
||||||
|
file: files[i]
|
||||||
|
}
|
||||||
|
);
|
||||||
|
this.uploadedCount++;
|
||||||
|
this.updateProgress();
|
||||||
|
} catch (error) {
|
||||||
|
failCount++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.$message.success('上传完成!成功:' + this.uploadedCount+',失败:' + failCount);
|
||||||
|
this.progressFlag = false;
|
||||||
|
this.progressPercent = 0;
|
||||||
|
},
|
||||||
|
updateProgress() {
|
||||||
|
if (this.uploadedCount === this.totalFiles) {
|
||||||
|
this.progressPercent = 100;
|
||||||
|
} else {
|
||||||
|
this.progressPercent = Math.min(100, Math.floor((this.uploadedCount / this.totalFiles) * 100));
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
if (this.uploadedCount % 10 === 0 || this.uploadedCount === this.totalFiles) {
|
||||||
|
this.$message.success(`已上传 ${this.uploadedCount} 个文件`);
|
||||||
|
} */
|
||||||
|
},
|
||||||
|
|
||||||
|
// 初始化分片上传
|
||||||
|
uploadIdShardingFolder(file) {
|
||||||
|
let self = this
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
file._shardCount = Math.ceil(file.size / this.partSize); // 总片数
|
||||||
|
file.uploaded = 0;
|
||||||
|
|
||||||
|
const formData = new FormData();
|
||||||
|
formData.append('fileName', file.name);
|
||||||
|
|
||||||
|
// 大文件上传初始化, 返回 uploadId
|
||||||
|
axios({
|
||||||
|
url: process.env.VUE_APP_BASE_API + "/common/initUpload",
|
||||||
|
method: 'post',
|
||||||
|
data: formData,
|
||||||
|
headers: {
|
||||||
|
'Authorization': 'Bearer ' + getToken(),
|
||||||
|
'Content-Type': 'multipart/form-data'
|
||||||
|
},
|
||||||
|
}).then(res => {
|
||||||
|
if (res.status === 200) {
|
||||||
|
file.uploadId = res.data.uploadId;
|
||||||
|
file.chunkId = 0;
|
||||||
|
this.uploadByChunkFolder(file)
|
||||||
|
.then(() => resolve()) // 全部分片上传完成,返回 resolve
|
||||||
|
.catch(error => reject(error)); // 分片上传出错,返回 reject
|
||||||
|
} else {
|
||||||
|
reject(new Error('初始化上传失败'));
|
||||||
|
}
|
||||||
|
}).catch(error => {
|
||||||
|
reject(error);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
// 分片上传逻辑
|
||||||
|
uploadByChunkFolder(file) {
|
||||||
|
let self = this
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
const uploadChunk = (chunkId) => {
|
||||||
|
const _start = chunkId * this.partSize;
|
||||||
|
const _end = Math.min(file.size, _start + this.partSize);
|
||||||
|
const fileData = file.slice(_start, _end);
|
||||||
|
|
||||||
|
const form1 = new FormData();
|
||||||
|
form1.append('chunkFile', fileData);
|
||||||
|
form1.append('uploadId', file.uploadId);
|
||||||
|
form1.append('chunkId', (chunkId + 1).toString());
|
||||||
|
form1.append('shardCount', file._shardCount.toString());
|
||||||
|
|
||||||
|
axios({
|
||||||
|
url: process.env.VUE_APP_BASE_API + "/common/uploadChunk",
|
||||||
|
method: 'post',
|
||||||
|
data: form1,
|
||||||
|
headers: {
|
||||||
|
'Authorization': 'Bearer ' + getToken(),
|
||||||
|
'Content-Type': 'multipart/form-data'
|
||||||
|
},
|
||||||
|
}).then(response => {
|
||||||
|
if (response.status === 200) {
|
||||||
|
file.uploadedNum++;
|
||||||
|
// const percent = Math.floor((file.uploadedNum / file._shardCount) * 100);
|
||||||
|
// this.percentageSend(file, percent);
|
||||||
|
if (chunkId + 1 < file._shardCount) {
|
||||||
|
// 继续上传下一片
|
||||||
|
uploadChunk(chunkId + 1);
|
||||||
|
} else {
|
||||||
|
// 所有分片上传完成,合并文件
|
||||||
|
this.mergeFileFolder(file).then(() => resolve()).catch(error => reject(error));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
reject(new Error('分片上传失败'));
|
||||||
|
}
|
||||||
|
}).catch(error => {
|
||||||
|
reject(error);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// 从第0块开始上传
|
||||||
|
uploadChunk(0);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
// 合并文件
|
||||||
|
mergeFileFolder(file) {
|
||||||
|
let self = this
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
const form2 = new FormData();
|
||||||
|
form2.append('uploadId', file.uploadId);
|
||||||
|
form2.append('fileName', file.name);
|
||||||
|
|
||||||
|
axios({
|
||||||
|
url: process.env.VUE_APP_BASE_API + "/common/mergeFile",
|
||||||
|
method: 'post',
|
||||||
|
data: form2,
|
||||||
|
headers: {
|
||||||
|
'Authorization': 'Bearer ' + getToken(),
|
||||||
|
'Content-Type': 'multipart/form-data'
|
||||||
|
},
|
||||||
|
}).then(res => {
|
||||||
|
if (res.status === 200) {
|
||||||
|
self.handleResult(res,file);
|
||||||
|
resolve(); // 合并成功
|
||||||
|
} else {
|
||||||
|
reject(new Error('文件合并失败'));
|
||||||
|
}
|
||||||
|
}).catch(error => {
|
||||||
|
reject(error);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
@ -97,9 +97,9 @@ export default {
|
|||||||
})
|
})
|
||||||
}).catch(() => {});
|
}).catch(() => {});
|
||||||
},
|
},
|
||||||
// 跳转到购物车
|
// 跳转到消息中心
|
||||||
toMyCartPage() {
|
toMyCartPage() {
|
||||||
this.$router.push({ path: '/message' })
|
this.$router.push({ path: '/message', query: {'states':'1'} })
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
</el-form><!--el-form-->
|
</el-form><!--el-form-->
|
||||||
</div><!--el-form-border 表单-->
|
</div><!--el-form-border 表单-->
|
||||||
</el-tab-pane><!--el-tab-pane-->
|
</el-tab-pane><!--el-tab-pane-->
|
||||||
<el-tab-pane label="关联附件" name="second" v-loading="previewLoading" element-loading-text="加载中">
|
<el-tab-pane label="关联附件" name="second" v-loading="previewLoading" >
|
||||||
<el-table :data="attachmentList" style="width: 100%">
|
<el-table :data="attachmentList" style="width: 100%">
|
||||||
<el-table-column label="序号" width="60" type="index" align="center"></el-table-column>
|
<el-table-column label="序号" width="60" type="index" align="center"></el-table-column>
|
||||||
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
||||||
@ -480,7 +480,6 @@
|
|||||||
this.isPreviewDisable = true
|
this.isPreviewDisable = true
|
||||||
this.previewLoading = true
|
this.previewLoading = true
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
console.info("this.$refs.previewForm====999999=======", this.$refs.previewForm)
|
|
||||||
this.$refs.previewForm.frontModulePreview(row)
|
this.$refs.previewForm.frontModulePreview(row)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
<div class="fbox1">
|
<div class="fbox1">
|
||||||
<div class="fl">
|
<div class="fl">
|
||||||
<el-tabs v-model="detailActiveName">
|
<el-tabs v-model="detailActiveName">
|
||||||
<el-tab-pane label="附件信息" name="first" v-loading="previewLoading" element-loading-text="加载中">
|
<el-tab-pane label="附件信息" name="first" v-loading="previewLoading" >
|
||||||
<el-table :data="attachmentList" style="width: 100%">
|
<el-table :data="attachmentList" style="width: 100%">
|
||||||
<el-table-column label="序号" width="60" align="center" type="index"></el-table-column>
|
<el-table-column label="序号" width="60" align="center" type="index"></el-table-column>
|
||||||
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
||||||
|
@ -128,7 +128,7 @@
|
|||||||
<div class="tboper">
|
<div class="tboper">
|
||||||
<div class="tit">关联附件</div>
|
<div class="tit">关联附件</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="el-form-border">
|
<div class="el-form-border" v-loading="previewLoading" >
|
||||||
<div class="operate">
|
<div class="operate">
|
||||||
<template v-if="editStatus && !detailBoolean">
|
<template v-if="editStatus && !detailBoolean">
|
||||||
<uploadVue
|
<uploadVue
|
||||||
@ -236,7 +236,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<preview-util v-if="isPreviewDisable" ref="previewForm" @previewClose="previewClose"></preview-util>
|
<preview-util v-if="isPreviewDisable" ref="previewForm" @previewClose="previewClose" @previewLoadingClose="previewLoadingClose"></preview-util>
|
||||||
|
|
||||||
<tool-selector ref="toolSelect" @selectHandle="selectHandle"></tool-selector>
|
<tool-selector ref="toolSelect" @selectHandle="selectHandle"></tool-selector>
|
||||||
<bl-user-selector ref="peopleSelect" :type="'single'" :isCheck="true" :open="toolPrincipalsChoose" :deptFilter="true" @cancel="toolPrincipalsChoose=false" @submit="submitPeople"></bl-user-selector>
|
<bl-user-selector ref="peopleSelect" :type="'single'" :isCheck="true" :open="toolPrincipalsChoose" :deptFilter="true" @cancel="toolPrincipalsChoose=false" @submit="submitPeople"></bl-user-selector>
|
||||||
@ -387,7 +387,7 @@
|
|||||||
},
|
},
|
||||||
currentPage: 1, // 当前页
|
currentPage: 1, // 当前页
|
||||||
pageSize: 10, // 每页显示数量
|
pageSize: 10, // 每页显示数量
|
||||||
|
previewLoading: false,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@ -789,6 +789,7 @@
|
|||||||
},
|
},
|
||||||
handlePreview(row){
|
handlePreview(row){
|
||||||
this.isPreviewDisable = true
|
this.isPreviewDisable = true
|
||||||
|
this.previewLoading = true
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
this.$refs.previewForm.frontModulePreview(row)
|
this.$refs.previewForm.frontModulePreview(row)
|
||||||
})
|
})
|
||||||
@ -797,6 +798,10 @@
|
|||||||
previewClose(){
|
previewClose(){
|
||||||
this.isPreviewDisable = false
|
this.isPreviewDisable = false
|
||||||
},
|
},
|
||||||
|
/** 关闭预览遮罩 **/
|
||||||
|
previewLoadingClose(){
|
||||||
|
this.previewLoading = false
|
||||||
|
},
|
||||||
/**
|
/**
|
||||||
* 处理下载
|
* 处理下载
|
||||||
* **/
|
* **/
|
||||||
|
@ -285,7 +285,6 @@ export default {
|
|||||||
let self = this
|
let self = this
|
||||||
this.downLoading = true
|
this.downLoading = true
|
||||||
listDocCount(this.addDateRange(this.queryParams, this.dateRange)).then(res => {
|
listDocCount(this.addDateRange(this.queryParams, this.dateRange)).then(res => {
|
||||||
console.info("res.total=============", res.total)
|
|
||||||
self.downTotal = res.total
|
self.downTotal = res.total
|
||||||
self.toolDownStatList = res?.rows || []
|
self.toolDownStatList = res?.rows || []
|
||||||
self.downLoading = false
|
self.downLoading = false
|
||||||
|
@ -196,8 +196,12 @@ export default {
|
|||||||
};
|
};
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
|
if(this.$route.query.states){
|
||||||
|
this.queryParams.states = this.$route.query.states
|
||||||
|
}
|
||||||
this.getList();
|
this.getList();
|
||||||
this.getDeptTree();
|
this.getDeptTree();
|
||||||
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
/** 查询部门下拉树结构 */
|
/** 查询部门下拉树结构 */
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
<div class="fbox1">
|
<div class="fbox1">
|
||||||
<div class="fl">
|
<div class="fl">
|
||||||
<el-tabs v-model="detailActiveName">
|
<el-tabs v-model="detailActiveName">
|
||||||
<el-tab-pane label="附件信息" name="first" v-loading="previewLoading" element-loading-text="加载中">
|
<el-tab-pane label="附件信息" name="first" v-loading="previewLoading" >
|
||||||
<el-table :data="attachmentList" style="width: 100%">
|
<el-table :data="attachmentList" style="width: 100%">
|
||||||
<el-table-column label="序号" width="60" align="center" type="index"></el-table-column>
|
<el-table-column label="序号" width="60" align="center" type="index"></el-table-column>
|
||||||
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
||||||
@ -101,6 +101,7 @@
|
|||||||
},
|
},
|
||||||
handlePreview(row){
|
handlePreview(row){
|
||||||
this.isPreviewDisable = true
|
this.isPreviewDisable = true
|
||||||
|
this.previewLoading = true
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
this.$refs.previewForm.frontModulePreview(row)
|
this.$refs.previewForm.frontModulePreview(row)
|
||||||
})
|
})
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
</el-form><!--el-form-->
|
</el-form><!--el-form-->
|
||||||
</div><!--el-form-border 表单-->
|
</div><!--el-form-border 表单-->
|
||||||
</el-tab-pane><!--el-tab-pane-->
|
</el-tab-pane><!--el-tab-pane-->
|
||||||
<el-tab-pane label="关联附件" name="second" v-loading="previewLoading" element-loading-text="加载中">
|
<el-tab-pane label="关联附件" name="second" v-loading="previewLoading" >
|
||||||
<el-table :data="attachmentList" style="width: 100%">
|
<el-table :data="attachmentList" style="width: 100%">
|
||||||
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
||||||
<!-- <el-table-column label="类别" prop="docType" :show-overflow-tooltip="true" width="80" >
|
<!-- <el-table-column label="类别" prop="docType" :show-overflow-tooltip="true" width="80" >
|
||||||
|
@ -225,7 +225,6 @@
|
|||||||
<div class="el-form-border">
|
<div class="el-form-border">
|
||||||
<div class="operate">
|
<div class="operate">
|
||||||
<!-- <el-form-item label="文件" required>
|
<!-- <el-form-item label="文件" required>
|
||||||
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-button type="primary" icon="el-icon-upload2" v-if="editStatus" @click="handleDocAdd">上传</el-button>-->
|
<el-button type="primary" icon="el-icon-upload2" v-if="editStatus" @click="handleDocAdd">上传</el-button>-->
|
||||||
<template v-if="editStatus">
|
<template v-if="editStatus">
|
||||||
@ -244,7 +243,7 @@
|
|||||||
</template>
|
</template>
|
||||||
<!-- <el-button icon="el-icon-delete">删除</el-button>-->
|
<!-- <el-button icon="el-icon-delete">删除</el-button>-->
|
||||||
</div><!--operate 操作按钮-->
|
</div><!--operate 操作按钮-->
|
||||||
<el-table :data="paginatedData" style="width: 100%">
|
<el-table :data="paginatedData" style="width: 100%" v-loading="previewLoading" >
|
||||||
<!-- <el-table-column type="selection" width="50" align="center"> </el-table-column>-->
|
<!-- <el-table-column type="selection" width="50" align="center"> </el-table-column>-->
|
||||||
<el-table-column label="序号" width="60" align="center" type="index"></el-table-column>
|
<el-table-column label="序号" width="60" align="center" type="index"></el-table-column>
|
||||||
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
<el-table-column label="附件名称" prop="fileName" :show-overflow-tooltip="true" />
|
||||||
@ -311,7 +310,7 @@
|
|||||||
<tool-selector ref="toolSelect" @selectHandle="selectHandle"></tool-selector>
|
<tool-selector ref="toolSelect" @selectHandle="selectHandle"></tool-selector>
|
||||||
<bl-user-selector ref="peopleSelect" :type="'single'" :isCheck="true" :open="toolPrincipalsChoose" :deptFilter="true" @cancel="toolPrincipalsChoose=false" @submit="submitPeople"></bl-user-selector>
|
<bl-user-selector ref="peopleSelect" :type="'single'" :isCheck="true" :open="toolPrincipalsChoose" :deptFilter="true" @cancel="toolPrincipalsChoose=false" @submit="submitPeople"></bl-user-selector>
|
||||||
|
|
||||||
<preview-util v-if="isPreviewDisable" ref="previewForm" @previewClose="previewClose"></preview-util>
|
<preview-util v-if="isPreviewDisable" ref="previewForm" @previewClose="previewClose" @previewLoadingClose="previewLoadingClose"></preview-util>
|
||||||
|
|
||||||
<el-dialog :title="viewDialogTitle" :visible.sync="viewDialogOpen" fullscreen width="500px" append-to-body :before-close="handleBeforeClose">
|
<el-dialog :title="viewDialogTitle" :visible.sync="viewDialogOpen" fullscreen width="500px" append-to-body :before-close="handleBeforeClose">
|
||||||
<i-frame :src="previewUrl" v-if="viewDialogOpen"/>
|
<i-frame :src="previewUrl" v-if="viewDialogOpen"/>
|
||||||
@ -339,7 +338,6 @@ import ToolSelector from '@/components/tool-selector/index.vue'
|
|||||||
import uploadVue from '@/components/FileUpload/optimizeToolUpload.vue'
|
import uploadVue from '@/components/FileUpload/optimizeToolUpload.vue'
|
||||||
import { addCount } from "@/api/tool/downloadCount";
|
import { addCount } from "@/api/tool/downloadCount";
|
||||||
import previewUtil from '@/components/PreviewUtil/previewUtil.vue'
|
import previewUtil from '@/components/PreviewUtil/previewUtil.vue'
|
||||||
import store from "@/store";
|
|
||||||
|
|
||||||
// PDF本地文件预览
|
// PDF本地文件预览
|
||||||
export default {
|
export default {
|
||||||
@ -400,7 +398,8 @@ export default {
|
|||||||
viewShow: false,
|
viewShow: false,
|
||||||
monitorDrawerVisible:false,
|
monitorDrawerVisible:false,
|
||||||
form: {
|
form: {
|
||||||
toolRespDept: this.$store.getters.userInfo.deptId
|
toolRespDept: this.$store.getters.userInfo.deptId,
|
||||||
|
status: "zy"
|
||||||
},
|
},
|
||||||
rules: {
|
rules: {
|
||||||
toolCode: [
|
toolCode: [
|
||||||
@ -474,6 +473,7 @@ export default {
|
|||||||
title: '工具发布',
|
title: '工具发布',
|
||||||
currentPage: 1, // 当前页
|
currentPage: 1, // 当前页
|
||||||
pageSize: 10, // 每页显示数量
|
pageSize: 10, // 每页显示数量
|
||||||
|
previewLoading: false,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@ -970,6 +970,7 @@ export default {
|
|||||||
},
|
},
|
||||||
handlePreview(row){
|
handlePreview(row){
|
||||||
this.isPreviewDisable = true
|
this.isPreviewDisable = true
|
||||||
|
this.previewLoading = true
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
this.$refs.previewForm.frontModulePreview(row)
|
this.$refs.previewForm.frontModulePreview(row)
|
||||||
})
|
})
|
||||||
@ -978,6 +979,10 @@ export default {
|
|||||||
previewClose(){
|
previewClose(){
|
||||||
this.isPreviewDisable = false
|
this.isPreviewDisable = false
|
||||||
},
|
},
|
||||||
|
/** 关闭预览遮罩 **/
|
||||||
|
previewLoadingClose(){
|
||||||
|
this.previewLoading = false
|
||||||
|
},
|
||||||
/**
|
/**
|
||||||
* 处理下载
|
* 处理下载
|
||||||
* **/
|
* **/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user