release-v1.0 #1

Merged
panchichun merged 57 commits from release-v1.0 into main 2024-09-13 17:04:18 +08:00
10 changed files with 296 additions and 64 deletions
Showing only changes of commit d60b5adb62 - Show all commits

View File

@ -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,6 +193,12 @@ export default {
}); });
}) })
} else { } else {
self.uploadIdSharding(file);
}
},
uploadIdSharding(file){
let self = this
self.uploadedNum = 0 self.uploadedNum = 0
file._shardCount = Math.ceil(file.size / this.partSize) // file._shardCount = Math.ceil(file.size / this.partSize) //
file.uploaded = 0 file.uploaded = 0
@ -226,8 +229,6 @@ export default {
self.progressFlag = false; self.progressFlag = false;
console.error(error) 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) {
//MD5MD5 //MD5MD5
@ -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;
} }
self.fileList = fileListTemp; */
/* files.for() let successCount = 0;
self.onChange(null, files); */ let failCount = 0;
// self.fileList = files; for (const file of files) {
// this.$refs.fileRef.value = null; 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
});
});
}
},
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>

View File

@ -97,9 +97,9 @@ export default {
}) })
}).catch(() => {}); }).catch(() => {});
}, },
// //
toMyCartPage() { toMyCartPage() {
this.$router.push({ path: '/message' }) this.$router.push({ path: '/message', query: {'states':'1'} })
}, },
} }
} }

View File

@ -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)
}) })
}, },

View File

@ -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" />

View File

@ -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
},
/** /**
* 处理下载 * 处理下载
* **/ * **/

View File

@ -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

View File

@ -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: {
/** 查询部门下拉树结构 */ /** 查询部门下拉树结构 */

View File

@ -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)
}) })

View File

@ -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" >

View File

@ -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
},
/** /**
* 处理下载 * 处理下载
* **/ * **/