release-v1.0 #1

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

View File

@ -876,7 +876,6 @@ body .el-form-border .el-form-item .el-cascader ,
body .el-form-border .el-form-item .el-select, body .el-form-border .el-form-item .el-select,
body .el-form-border .el-form-item .el-date-editor{ body .el-form-border .el-form-item .el-date-editor{
width: 100%; width: 100%;
max-width: 340px;
} }
body .el-form-border .el-form-item .el-checkbox-group .el-checkbox{ body .el-form-border .el-form-item .el-checkbox-group .el-checkbox{
min-width: 200px; min-width: 200px;

View File

@ -42,3 +42,13 @@ export function delDocument(id) {
method: 'delete' method: 'delete'
}) })
} }
// 发布文档
export function pushDoc(id) {
return request({
url: '/document/pushDoc/' + id,
method: 'put'
})
}

View File

@ -33,22 +33,6 @@ export default {
type: String, type: String,
required: true required: true
}, },
headers: {
type: Object,
default: () => ({})
},
extraData: {
type: Object,
default: () => ({})
},
onSuccess: {
type: Function,
default: () => {}
},
onError: {
type: Function,
default: () => {}
},
// //
isMultiple: { isMultiple: {
type: Boolean, type: Boolean,
@ -75,6 +59,13 @@ export default {
return 1 return 1
} }
}, },
//
dataFile: {
type: [Object, Array, String],
default() {
return ''
}
},
}, },
data() { data() {
return { return {
@ -86,6 +77,18 @@ export default {
partSize: 5 * 1024 * 1024, partSize: 5 * 1024 * 1024,
}; };
}, },
watch: {
dataFile: {
handler(newValue, oldValue) {
if (newValue) {
this.fileList = Array.isArray(newValue) ? newValue : [newValue]
} else {
this.fileList = []
}
},
immediate: true
}
},
methods: { methods: {
// //
beforeUpload(file) { beforeUpload(file) {
@ -99,67 +102,6 @@ export default {
return false return false
}*/ }*/
}, },
/* //上传函数
submitUpload(file) {
// 便setTimeout --setTimeoutvue
var that = this;
// that.$refs.upload.submit();
//
if (this.fileList.length == 0) {
that.$message({
message: '请选择导入的文件',
type: 'warning',
duration: '2000'
});
return;
}
//FormData();
let paramFormData = new FormData();
// fileList
that.fileList.forEach(file => {
paramFormData.append("file", file.raw);
});
//progressFlag
that.progressFlag = true;
//axios
axios({
url: that.uploadUrl,
method: 'post',
data: paramFormData,
headers: {
'Authorization': 'Bearer ' + getToken(),
'Content-Type': 'multipart/form-data'
},
onUploadProgress: progressEvent => {
// progressEvent.loaded:
// progressEvent.total:
//
that.progressPercent = ((progressEvent.loaded / progressEvent.total) * 100) | 0;
}
}).then(res => {
console.info("res===========", res)
if (res.data.code == 200 && that.progressPercent === 100) {
setTimeout(function () {
that.$message({
message: '上传成功!',
type: 'success',
duration: '2000'
});
that.progressFlag = false;
that.progressPercent = 0
}, 500);
}
}).catch(error => {
that.progressFlag = false;
that.progressPercent = 0
that.$refs.upload.clearFiles();
that.$message({
message: '上传失败!',
type: 'error',
duration: '2000'
});
})
},*/
// //
onChange(file, fileList) { onChange(file, fileList) {
this.fileList = fileList; this.fileList = fileList;
@ -205,6 +147,7 @@ export default {
}); });
self.progressFlag = false; self.progressFlag = false;
self.progressPercent = 0 self.progressPercent = 0
self.handleResult(res,file);
}, 500); }, 500);
} else { } else {
self.$message({ self.$message({
@ -227,7 +170,6 @@ export default {
}); });
}) })
} else { } else {
console.info("111111111111")
file._shardCount = Math.ceil(file.size / this.partSize) // file._shardCount = Math.ceil(file.size / this.partSize) //
file.uploaded = 0 file.uploaded = 0
let formData = new FormData() let formData = new FormData()
@ -244,7 +186,6 @@ export default {
'Content-Type': 'multipart/form-data' 'Content-Type': 'multipart/form-data'
}, },
}).then(function (res) { }).then(function (res) {
console.info("res=====initUpload=======", res)
if (res.status == 200) { if (res.status == 200) {
//0 //0
file.uploadId = res.data.uploadId file.uploadId = res.data.uploadId
@ -272,12 +213,6 @@ export default {
//MD5 //MD5
let reader = new FileReader() let reader = new FileReader()
reader.readAsBinaryString(fileData) reader.readAsBinaryString(fileData)
//
// reader.onloadend = function(e) {
// hex_md5md5OSSmd5-js
// self.md5Str[index] = (CryptoJS(this.result)).toLocaleUpperCase()
// self.md5Str[index] = CryptoJS.MD5(e.target.result)
// }
let form1 = new FormData()//newform let form1 = new FormData()//newform
form1.append('chunkFile', fileData) //slice form1.append('chunkFile', fileData) //slice
form1.append('uploadId', file.uploadId) form1.append('uploadId', file.uploadId)
@ -300,7 +235,6 @@ export default {
self.progressPercent = ((progressEvent.loaded / progressEvent.total) * 100) | 0; self.progressPercent = ((progressEvent.loaded / progressEvent.total) * 100) | 0;
} }
}).then(response => { }).then(response => {
console.info("response=======uploadChunk=====", response)
if (response.status == 200) { if (response.status == 200) {
//MD5MD5 //MD5MD5
// self.md5Str[index] === response.msg || // self.md5Str[index] === response.msg ||
@ -345,9 +279,8 @@ export default {
'Authorization': 'Bearer ' + getToken(), 'Authorization': 'Bearer ' + getToken(),
'Content-Type': 'multipart/form-data' 'Content-Type': 'multipart/form-data'
}, },
}).then(response => { }).then(res => {
console.info("response====mergeFile========", response) if (res.status == 200) {
if (response.status == 200) {
setTimeout(function () { setTimeout(function () {
self.$message({ self.$message({
message: '上传成功!', message: '上传成功!',
@ -356,6 +289,7 @@ export default {
}); });
self.progressFlag = false; self.progressFlag = false;
self.progressPercent = 0 self.progressPercent = 0
self.handleResult(res,file);
}, 500); }, 500);
} else { } else {
self.$message({ self.$message({
@ -364,13 +298,30 @@ export default {
duration: '2000' duration: '2000'
}); });
} }
console.info("file===============", file)
}) })
} }
}, },
resetData() { resetData() {
this.progress = 0; this.progress = 0;
}, },
handleResult(res, file) {
let self = this
const data = {
fileName: file.name,
fileSize: file.size,
fileUrl: res.data.url,
filePath: res.data.filePath,
fileOldName: res.data.originalFilename,
fileNewName: res.data.newFileName,
suffixType: res.data.suffixType
}
self.$emit("handleSuccess", data)
},
/** 清空文件 **/
clearFile(){
this.$refs.upload.clearFiles();
this.fileList = []
}
} }
}; };
</script> </script>

View File

@ -9,7 +9,7 @@ const baseURL = process.env.VUE_APP_BASE_API
let downloadLoadingInstance; let downloadLoadingInstance;
export default { export default {
name(name, isDelete = true) { downloadByName(name, isDelete) {
var url = baseURL + "/common/download?fileName=" + encodeURIComponent(name) + "&delete=" + isDelete var url = baseURL + "/common/download?fileName=" + encodeURIComponent(name) + "&delete=" + isDelete
axios({ axios({
method: 'get', method: 'get',

View File

@ -3,8 +3,8 @@
<el-form ref="form" :model="form" :rules="rules" label-width="150px"> <el-form ref="form" :model="form" :rules="rules" label-width="150px">
<el-row> <el-row>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="文件分类" prop="docCode"> <el-form-item label="文件分类" prop="docCategoryId">
<treeselect v-model="form.categoryId" :options="docCategory" :show-count="true" placeholder="请选择文件分类"/> <treeselect v-model="form.docCategoryId" :options="docCategory" :show-count="true" placeholder="请选择文件分类"/>
</el-form-item> </el-form-item>
</el-col> </el-col>
@ -21,20 +21,51 @@
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="文档类别" prop="docType"> <el-form-item label="文档类别" prop="docType" style="width: 100%">
<el-input v-model="form.docType" placeholder="请输入文档类别" maxlength="50" show-word-limit/> <el-select v-model="form.docType" placeholder="请选择文档来源" style="width: 100% !important;">
<el-option style="width: 100%"
v-for="dict in dict.type.doc_class"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="文档来源" prop="docSource"> <el-form-item label="文档来源" prop="docSource">
<el-input v-model="form.docSource" placeholder="请输入文档来源" maxlength="50" show-word-limit/> <el-select v-model="form.docSource" placeholder="请选择文档来源" style="width: 100%">
<el-option
v-for="dict in dict.type.doc_source"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select>
<!-- <el-input v-model="form.docSource" placeholder="请输入文档来源" maxlength="50" show-word-limit/>-->
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24" v-if="relatedTool">
<el-form-item label="关联工具" prop="toolId"> <el-form-item label="关联工具" prop="toolId">
<el-input v-model="form.toolId" placeholder="请选择关联工具" @focus="drawer1 = true"/> <el-select
v-model="toolDataInfo"
ref="selectHeadTool"
multiple
value-key="toolId"
filterable
remote
placeholder="请选择关联工具"
@focus="toolSelect">
<el-option
v-for="item in toolDataInfo"
:key="item.toolId"
:label="item.toolName"
:value="item">
</el-option>
</el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="负责人" prop="docPrincipals"> <el-form-item label="负责人" prop="docPrincipals">
@ -43,75 +74,39 @@
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="归属单位" prop="docRespDept"> <el-form-item label="归属单位" prop="docRespDept">
<treeselect v-model="form.docRespDept" :options="deptOptions" :show-count="true" placeholder="请输入归属单位" /> <treeselect v-model="form.docRespDept" :options="deptOptions" :show-count="true" placeholder="请输入归属单位"/>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="文件" required> <el-form-item label="文件" required>
<uploadVue <uploadVue
:display="editStatus"
:uploadUrl="uploadFileUrl" :uploadUrl="uploadFileUrl"
:type="['.txt','.doc','.docx','.pdf','.mp4','.zip','.rar','.7z','.png','.jpg','.jpeg']" :type="['.txt','.doc','.docx','.pdf','.mp4','.zip','.rar','.7z','.png','.jpg','.jpeg']"
:acceptType="acceptType" :acceptType="acceptType"
:limit="1" :limit="1"
:onSuccess="handleUploadSuccess" :dataFile="dataFile"
:onError="handleUploadError" ref="uploadFile"
@handleSuccess="handleUploadSuccess"
@handleError="handleUploadError"
/> />
<!-- <uploadVue-->
<!-- <upload-progress/>
<el-upload
class="upload-component"
ref="upload"
:auto-upload="false"
:file-list="fileList"
:on-change="onChange"
:on-remove="onRemove"
:multiple="true"
action=""
>
<el-button size="small" type="primary">点击上传</el-button>
<div slot="tip" class="el-upload__tip">只能上传jpg/png文件且不超过500kb</div>
<div slot="tip" class="el-upload__tip"><el-progress :percentage="progress"></el-progress></div>
</el-upload>-->
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="24"> <el-col :span="24">
<el-form-item label="备注"> <el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" :rows="3" maxlength="500" show-word-limit></el-input> <el-input v-model="form.remark" type="textarea" :rows="3" maxlength="500" show-word-limit></el-input>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
</el-form><!--el-form--> </el-form><!--el-form-->
<el-dialog title="选择关联工具" :visible.sync="drawer1" width="75%" append-to-body> <tool-selector ref="toolSelect" @selectHandle="selectHandle"></tool-selector>
<div>
<el-table :data="tableData2" @row-click="singleElection" highlight-current-row style="width: 100%">
<!--<el-table-column label="选择" align="center" width="65">
<template slot-scope="scope">
<el-radio :label="scope.row.prop1" v-model="radio" @change.native="getCurrentRow(scope.row)" />
</template>
</el-table-column>-->
<el-table-column align="center" width="55">
<template slot-scope="scope">
<el-radio v-model="templateSelection" :label="scope.row.prop1"></el-radio>
</template>
</el-table-column>
<el-table-column prop="prop1" label="工具编号"></el-table-column>
<el-table-column prop="prop2" label="工具名称"></el-table-column>
<el-table-column prop="prop5" label="工具类别" ></el-table-column>
<el-table-column prop="prop3" label="归属单位" width="180"> </el-table-column>
<el-table-column prop="prop4" label="负责人" width="100" ></el-table-column>
</el-table><!--el-table-->
</div>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="chooseToolConfirm()"> </el-button>
<el-button @click="cancel()"> </el-button>
</div>
</el-dialog><!--el-drawer 流程监控-抽屉-->
</div><!--el-form-border 表单--> </div><!--el-form-border 表单-->
</template> </template>
<script> <script>
import { addDocument, updateDocument } from "@/api/document/document"; import { addDocument, updateDocument, getDocument } from "@/api/document/document";
import axios from 'axios'; import axios from 'axios';
import { getToken } from '@/utils/auth' import { getToken } from '@/utils/auth'
import { deptTreeSelect } from "@/api/system/user"; import { deptTreeSelect } from "@/api/system/user";
@ -119,15 +114,22 @@
import Treeselect from "@riophae/vue-treeselect"; import Treeselect from "@riophae/vue-treeselect";
import uploadProgress from "./uploadProgress"; import uploadProgress from "./uploadProgress";
import uploadVue from '@/components/FileUpload/optimizeUpload.vue' import uploadVue from '@/components/FileUpload/optimizeUpload.vue'
import ToolSelector from '@/components/tool-selector/index.vue'
export default { export default {
name: 'editDocument', name: 'editDocument',
components: { Treeselect, uploadProgress, uploadVue}, components: { Treeselect, uploadProgress, uploadVue, ToolSelector},
dicts:['doc_class','doc_source'],
props: { props: {
tooId: { tooId: {
type: String, type: String,
default: "", default: "",
} required: false
},
relatedTool: {
type: Boolean,
default: true,
},
}, },
data(){ data(){
return{ return{
@ -152,19 +154,24 @@
], ],
// //
form: { form: {
categoryId: undefined, docId: undefined,
docCategoryId: undefined,
docCode: '', docCode: '',
docName: '', docName: '',
docType: '', docType: '',
docPrincipals: '', docPrincipals: '',
docRespDept: undefined, docRespDept: undefined,
docSource: '', docSource: '',
toolId: '' toolId: '',
remark: undefined
}, },
fileList: [], fileList: [],
progress: 0, progress: 0,
// //
rules: { rules: {
docCategoryId: [
{ required: true, message: "文档分类不能为空", trigger: "blur" }
],
docCode: [ docCode: [
{ required: true, message: "文档编号不能为空", trigger: "blur" } { required: true, message: "文档编号不能为空", trigger: "blur" }
], ],
@ -182,7 +189,10 @@
deptOptions:[], deptOptions:[],
uploadFileUrl: process.env.VUE_APP_BASE_API + "/common/upload", // uploadFileUrl: process.env.VUE_APP_BASE_API + "/common/upload", //
fileData: null, fileData: null,
acceptType: ".txt,.doc,.docx,.pdf,.mp4,.zip,.rar,.7z,.png,.jpg,.jpeg" acceptType: ".txt,.doc,.docx,.pdf,.mp4,.zip,.rar,.7z,.png,.jpg,.jpeg",
editStatus: true,
toolDataInfo: [],
dataFile: [],
} }
}, },
created(){ created(){
@ -229,21 +239,6 @@
this.drawer1 = false; this.drawer1 = false;
this.reset(); this.reset();
}, },
onChange(file, fileList) {
// valid the suffix of file
/*let validSuffix = ['pdf', 'docx', 'doc', 'txt', 'eml', 'mp4']
let splits = file.name.split('.')
let suffix = splits[splits.length - 1]
if (!validSuffix.includes(suffix)) {
this.$message.error(`只能上传 ${validSuffix.join(',')} 类型的文件!`)
this.fileList = fileList.filter(item => item.uid !== file.uid)
return
}*/
this.fileList = fileList
},
onRemove(file, fileList) {
this.fileList = fileList.filter(item => item.uid !== file.uid)
},
generateUniqueID() { generateUniqueID() {
// 使ID // 使ID
const timestamp = new Date().getTime(); const timestamp = new Date().getTime();
@ -253,80 +248,81 @@
}, },
/** 提交按钮 */ /** 提交按钮 */
submitForm: function() { submitForm: function() {
let fileName = []
//
if(this.form.docId && (this.fileList == null || this.fileList.length <= 0 )){
fileName = this.$refs.uploadFile.fileList[0]
this.fileList = this.$refs.uploadFile.fileList
}else{
fileName = this.fileList[0]
this.fileList = this.fileList
}
// //
if (this.fileList.length === 0) { if (this.fileList.length == 0) {
return this.$message.warning('请选取文件后再上传') return this.$message.warning('请选取文件后再上传')
} }
this.fileList.map(file =>{ /*this.fileList.map(file =>{
this.form.docName = file.name this.form.docName = file.name
}) })*/
this.form.toolId = this.toolId if(fileName){
this.$set(this.form,"docUrl", fileName.filePath)
this.$set(this.form,"docStatus", "ysc")
this.$set(this.form,"attachment", fileName)
}
if(this.toolDataInfo && this.toolDataInfo.length > 0){
this.$set(this.form,"toolId", this.toolDataInfo[0].toolId)
}
this.$refs["form"].validate(valid => { this.$refs["form"].validate(valid => {
if (valid) { if (valid) {
if (this.form.id != undefined) { if (this.form.docId) {
updateDocument(this.form).then(response => { updateDocument(this.form).then(res => {
this.$modal.msgSuccess("修改成功"); this.$modal.msgSuccess("修改成功");
this.open = false; this.open = false;
this.$emit("submit"); this.$emit("submit");
}); });
} else { } else {
addDocument(this.form).then(response => { addDocument(this.form).then(res => {
this.$modal.msgSuccess("新增成功"); this.$modal.msgSuccess("新增成功");
this.open = false; this.open = false;
this.confirmSubmit(response.data); // this.confirmSubmit(response.data);
this.$emit("submit"); this.$emit("submit");
}); });
} }
} }
}); });
}, },
testUpdate(docId){ /** 提交按钮 */
// formData assembleSubmit: function() {
const formData = new FormData() let self = this
// upload FormData let fileName = []
this.fileList.forEach((file) => { //
formData.append('folder', file.raw) if(this.form.docId && (this.fileList == null || this.fileList.length <= 0 )){
}) fileName = this.$refs.uploadFile.fileList[0]
formData.append('docId', '') this.fileList = this.$refs.uploadFile.fileList
formData.append('requestId', this.generateUniqueID())
axios.post(process.env.VUE_APP_BASE_API + '/document/upload/folder', formData, {
headers: {
'Content-Type': 'multipart/form-data',
'Authorization': 'Bearer ' + getToken(),
}
}).then((response) => {
if(response.data.code===200){
this.$emit("submit");
}else{ }else{
// response.data.message fileName = this.fileList[0]
} }
}).catch((error) => { //
console.error('Failed to upload file:', error); if (this.fileList.length == 0) {
}); return this.$message.warning('请选取文件后再上传')
},
confirmSubmit(docId) {
// formData
const formData = new FormData()
// upload FormData
this.fileList.forEach((file) => {
formData.append('files', file.raw)
})
formData.append('docId', docId)
formData.append('requestId', this.generateUniqueID())
//ajax
axios.post(process.env.VUE_APP_BASE_API + '/document/upload', formData, {
headers: {
'Content-Type': 'multipart/form-data',
'Authorization': 'Bearer ' + getToken(),
} }
}).then((response) => { /*this.fileList.map(file =>{
if(response.data.code===200){ this.form.docName = file.name
this.$emit("submit"); })*/
}else{ if(fileName){
// response.data.message this.$set(this.form,"docUrl", fileName.filePath)
this.$set(this.form,"docStatus", "ysc")
this.$set(this.form,"attachment", fileName)
}
if(this.toolDataInfo && this.toolDataInfo.length > 0){
this.$set(this.form,"toolId", this.toolDataInfo[0].toolId)
}
this.$refs["form"].validate(valid => {
if (valid) {
self.$emit("docSubmitData",self.form)
} }
}).catch((error) => {
console.error('Failed to upload file:', error);
}); });
}, },
/** 查询部门下拉树结构 */ /** 查询部门下拉树结构 */
@ -354,20 +350,57 @@
}, },
// flag true // flag true
getData(data, flag, index) { getData(data, flag, index) {
console.info("data============", data)
console.info("flag============", flag)
console.info("index============", index)
}, },
getError(message) { getError(message) {
this.$message.error(message); this.$message.error(message);
}, },
handleUploadSuccess(response) { handleUploadSuccess(res) {
alert('File uploaded successfully'); this.fileList = []
this.fileList.push(res)
// //
}, },
handleUploadError(error) { handleUploadError(error) {
alert('Failed to upload file');
// //
},
toolSelect(){
this.$refs.selectHeadTool.blur();
this.$nextTick(()=>{
this.$refs.toolSelect.init(null,null,false)
})
},
selectHandle(source,index,data){
this.toolDataInfo = []
let toolInfo = {toolId:data.toolId,toolCode:data.toolCode,toolName:data.toolName}
this.toolDataInfo.push(toolInfo)
},
/**初始化 **/
resetForm() {
this.$refs.form.resetFields();
this.toolDataInfo = []
this.fileList = []
this.$nextTick(()=>{
this.$refs.uploadFile.clearFile();
})
},
editInit(docId, type){
this.$refs.form.resetFields();
this.toolDataInfo = []
this.$nextTick(()=>{
this.$refs.uploadFile.clearFile();
getDocument(docId).then(res => {
this.form = res.data
this.toolDataInfo = []
let toolInfo = {toolId:this.form.toolId,toolName:this.form.toolName}
this.toolDataInfo.push(toolInfo)
this.dataFile = []
let fileData = res.data.attachment
this.$set(fileData, "name", fileData.fileOldName)
this.$set(fileData, "size", fileData.fileSize)
this.dataFile.push(fileData)
});
})
} }
} }
} }

View File

@ -48,45 +48,63 @@
size="mini" size="mini"
@click="handleAdd" @click="handleAdd"
>上传文档</el-button> >上传文档</el-button>
<el-button type="primary" icon="el-icon-position">发布</el-button> <el-button type="primary" icon="el-icon-position" @click="handlePush">发布</el-button>
<el-button icon="el-icon-delete" @click="handleDelete">批量删除</el-button> <el-button icon="el-icon-delete" @click="handleDelete">批量删除</el-button>
</div><!--operate 操作按钮--> </div><!--operate 操作按钮-->
<el-table v-loading="loading" :data="docList" @selection-change="handleSelectionChange"> <el-table v-loading="loading" :data="docList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" /> <el-table-column type="selection" width="55" align="center" :selectable="isSelectable"/>
<el-table-column label="文档编号" prop="docCode" width="120" /> <el-table-column label="文档编号" align="center" prop="docCode" width="120" />
<el-table-column label="文档名称" prop="docName" :show-overflow-tooltip="true" /> <el-table-column label="文档名称" align="center" prop="docName" :show-overflow-tooltip="true" />
<el-table-column label="类别" prop="docType" :show-overflow-tooltip="true" width="80" /> <el-table-column label="类别" align="center" prop="docType" :show-overflow-tooltip="true" width="80">
<el-table-column label="负责人" prop="docPrincipals" :show-overflow-tooltip="true" width="80" />
<el-table-column label="归属部门" prop="docRespDept" :show-overflow-tooltip="true" width="150" />
<el-table-column label="来源" prop="docSource" width="100" />
<el-table-column label="关联工具" prop="roleSort" width="100" />
<el-table-column label="上传状态" prop="docUploadProgress" width="100" >
<template slot-scope="scope"> <template slot-scope="scope">
<el-tag type="success" v-if="scope.row.docStatus == 'ysc'">已上传</el-tag> <dict-tag :options="dict.type.doc_class" :value="scope.row.docType"/>
<el-tag type="danger" v-else>上传失败</el-tag> </template>
</el-table-column>·
<el-table-column label="负责人" align="center" prop="docPrincipals" :show-overflow-tooltip="true" width="80" />
<el-table-column label="归属单位" align="center" prop="docRespDeptName" :show-overflow-tooltip="true" width="80" />
<el-table-column label="来源" align="center" prop="docSource" width="100">
<template slot-scope="scope">
<dict-tag :options="dict.type.doc_source" :value="scope.row.docSource"/>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="创建时间" align="center" prop="createTime" width="180"> <el-table-column label="关联工具" align="center" prop="toolName" width="100" />
<el-table-column label="上传状态" align="center" prop="docUploadProgress" width="100" >
<template slot-scope="scope">
<el-tag type="info" v-if="scope.row.docStatus == 'ysc'">已上传</el-tag>
<el-tag type="success" v-else-if="scope.row.docStatus == 'yfb'">已发布</el-tag>
<el-tag type="warning" v-else-if="scope.row.docStatus == 'shz'">审核中</el-tag>
</template>
</el-table-column>
<el-table-column label="创建时间" align="center" prop="createTime" width="180" :show-overflow-tooltip="true">
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime) }}</span> <span>{{ parseTime(scope.row.createTime) }}</span>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="操作" align="center" width="180"> <el-table-column label="操作" align="center" width="180">
<template slot-scope="scope" v-if="scope.row.roleId !== 1"> <template slot-scope="scope" v-if="scope.row.roleId !== 1">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
v-if="scope.row.docStatus != 'yfb' && scope.row.docStatus != 'shz'"
@click="handleEdit(scope.row)"
>编辑</el-button>
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
icon="el-icon-view" icon="el-icon-view"
@click="handlePriew(scope.row)" v-if="previewAuth(scope.row)"
@click="handlePreview(scope.row)"
>预览</el-button> >预览</el-button>
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
icon="el-icon-delete" icon="el-icon-delete"
v-if="scope.row.docStatus != 'yfb' && scope.row.docStatus != 'shz'"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
>删除</el-button> >删除</el-button>
<el-button type="text" icon="el-icon-download">下载</el-button> <el-button type="text" icon="el-icon-download" @click="handleDownload(scope.row)" v-loading="loadingDownload">下载</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -132,7 +150,7 @@
<span class="title">新增文档资源</span> <span class="title">新增文档资源</span>
<div class="drawer-head-btn"> <div class="drawer-head-btn">
<el-button type="primary" @click="$refs.editDocumentRef.submitForm()"> </el-button> <el-button type="primary" @click="$refs.editDocumentRef.submitForm()"> </el-button>
<el-button @click="$refs.editDocumentRef.cancel()"> </el-button> <el-button @click="docCancel()"> </el-button>
</div><!--drawer-head-btn 抽屉顶部按钮区域--> </div><!--drawer-head-btn 抽屉顶部按钮区域-->
</template> </template>
<edit-document ref="editDocumentRef" @submit="editDocumentSubmit"/> <edit-document ref="editDocumentRef" @submit="editDocumentSubmit"/>
@ -143,7 +161,7 @@
</template> </template>
<script> <script>
import { listDocument, getDocument, delDocument, addDocument, updateDocument } from "@/api/document/document"; import { listDocument, getDocument, delDocument, addDocument, updateDocument,pushDoc } from "@/api/document/document";
import { deptTreeSelect } from "@/api/system/user"; import { deptTreeSelect } from "@/api/system/user";
import { documentTree,addCategory,updateCategory,delCategory,getCategory } from "@/api/documentCategory/documentCategory.js"; import { documentTree,addCategory,updateCategory,delCategory,getCategory } from "@/api/documentCategory/documentCategory.js";
@ -153,10 +171,10 @@ import editDocument from "./editDocument";
import uploadProgress from "./uploadProgress"; import uploadProgress from "./uploadProgress";
import { w3cwebsocket as WebSocket } from 'websocket'; import { w3cwebsocket as WebSocket } from 'websocket';
import Treeselect from "@riophae/vue-treeselect"; import Treeselect from "@riophae/vue-treeselect";
export default { export default {
name: "Document", name: "Document",
components: { iFrame, editDocument, uploadProgress, Treeselect}, components: { iFrame, editDocument, uploadProgress, Treeselect},
dicts:['doc_class','doc_source'],
data() { data() {
return { return {
// //
@ -243,6 +261,8 @@ export default {
categoryDescription: null, categoryDescription: null,
parentId: null parentId: null
}, },
loadingDownload: false,
acceptType: "zip,rar,7z",
}; };
}, },
created() { created() {
@ -297,9 +317,17 @@ export default {
/** 新增按钮操作 */ /** 新增按钮操作 */
handleAdd() { handleAdd() {
this.open = true this.open = true
this.$nextTick(()=>{
this.$refs.editDocumentRef.resetForm();
})
}, },
handlePriew(row){ handleEdit(row){
console.log('mmmmmmmmmmm',process.env.VUE_APP_BASE_API + row.docUrl) this.open = true
this.$nextTick(()=>{
this.$refs.editDocumentRef.editInit(row.docId, "edit");
})
},
handlePreview(row){
this.previewUrl = process.env.VUE_APP_TOOL_TECH_FILE_VIEW_API + '/onlinePreview?url=' + encodeURIComponent(Base64.encode(process.env.VUE_APP_BASE_API + row.docUrl)); this.previewUrl = process.env.VUE_APP_TOOL_TECH_FILE_VIEW_API + '/onlinePreview?url=' + encodeURIComponent(Base64.encode(process.env.VUE_APP_BASE_API + row.docUrl));
this.viewDialogTitle = '文档在线预览' this.viewDialogTitle = '文档在线预览'
this.viewDialogOpen = true; this.viewDialogOpen = true;
@ -322,11 +350,10 @@ export default {
}).then(() => { }).then(() => {
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}).catch(() => {}); }).catch((err) => {console.info(err)});
}, },
/** 新增按钮操作 */ /** 新增按钮操作 */
handleDocCategoryAdd(data) { handleDocCategoryAdd(data) {
console.info("data================", data)
this.docCategoryOpen = true; this.docCategoryOpen = true;
// this.docCategoryForm.parentId = data.id; // this.docCategoryForm.parentId = data.id;
this.$nextTick(() => { this.$nextTick(() => {
@ -385,6 +412,54 @@ export default {
/** 重置 **/ /** 重置 **/
resetDocCategoryForm(){ resetDocCategoryForm(){
this.$refs.docCategoryForm.resetFields(); this.$refs.docCategoryForm.resetFields();
},
/**
* 处理下载
* **/
handleDownload(row){
let self = this
self.loadingDownload = true
this.$download.resource(row.docUrl);
setTimeout(()=>{
self.loadingDownload = false
},1000)
},
/** 删除按钮操作 */
handlePush(row) {
const docIds = row.docId || this.ids;
this.$modal.confirm('是否确认发布?').then(function() {
return pushDoc(docIds);
}).then(() => {
this.getList();
this.$modal.msgSuccess("发布成功");
}).catch((err) => {
console.error(err)
});
},
docCancel(){
this.$refs.editDocumentRef.resetForm();
this.open = false
},
previewAuth(row){
if(row.docUrl == null || row.docUrl == '' || row.docUrl == undefined){
return false
}
let extension = this.getExtension(row.docUrl);
const acceptedExtensions = this.acceptType.toLowerCase().split(',');
if(acceptedExtensions.includes(extension)){
return false
}
return true
},
getExtension(filePath) {
// '.'
const parts = filePath.split('.');
//
const extension = parts.pop();
return extension;
},
isSelectable(row) {
return row.docStatus !== 'yfb' && row.docStatus !== 'shz';
} }
} }

View File

@ -1,8 +1,8 @@
<template> <template>
<el-dialog title="新增文档" :visible.sync="visible" width="85%" append-to-body> <el-dialog title="新增附件信息" :visible.sync="visible" width="85%" append-to-body>
<edit-document ref="editDocumentRef" :toolId="toolId" @submit="editDocumentSubmit"/> <edit-document ref="editDocumentRef" :toolId="toolId" @docSubmitData="editDocumentSubmit" :relatedTool="false"/>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
<el-button type="primary" @click="$refs.editDocumentRef.submitForm()"> </el-button> <el-button type="primary" @click="submitForm()"> </el-button>
<el-button @click="cancel()"> </el-button> <el-button @click="cancel()"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
@ -26,7 +26,7 @@ export default {
*/ */
toolId: { toolId: {
type: String, type: String,
default: true default: ''
} }
}, },
computed: { computed: {
@ -45,13 +45,19 @@ export default {
} }
}, },
methods: { methods: {
editDocumentSubmit(){ editDocumentSubmit(data){
this.$emit('callback') this.$emit("addFileData", data)
this.visible = false this.visible = false
}, },
cancel() { cancel() {
this.$refs.editDocumentRef.cancel() this.$refs.editDocumentRef.cancel()
this.visible = false this.visible = false
},
submitForm(){
this.$refs.editDocumentRef.assembleSubmit()
},
resetForm(){
this.$refs.editDocumentRef.resetForm()
} }
} }
} }

View File

@ -28,17 +28,20 @@
</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"> <el-tab-pane label="关联文件" name="second">
<div class="operate">
<el-button type="primary" icon="el-icon-upload2" @click="handleAdd">上传</el-button>
<el-button icon="el-icon-delete">删除</el-button>
</div><!--operate 操作按钮-->
<el-table :data="docList" style="width: 100%"> <el-table :data="docList" style="width: 100%">
<el-table-column type="selection" width="50" align="center"> </el-table-column>
<el-table-column label="文档名称" prop="docName" :show-overflow-tooltip="true" /> <el-table-column label="文档名称" prop="docName" :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" >
<template slot-scope="scope">
<dict-tag :options="dict.type.doc_class" :value="scope.row.docType"/>
</template>
</el-table-column>
<el-table-column label="负责人" prop="docPrincipals" :show-overflow-tooltip="true" width="80" /> <el-table-column label="负责人" prop="docPrincipals" :show-overflow-tooltip="true" width="80" />
<el-table-column label="归属部门" prop="docRespDept" :show-overflow-tooltip="true" width="150" /> <el-table-column label="归属单位" align="center" prop="docRespDeptName" :show-overflow-tooltip="true" width="80" />
<el-table-column label="来源" prop="docSource" width="100" /> <el-table-column label="来源" prop="docSource" width="100" >
<template slot-scope="scope">
<dict-tag :options="dict.type.doc_source" :value="scope.row.docSource"/>
</template>
</el-table-column>
<el-table-column label="创建时间" align="center" prop="createTime" width="180"> <el-table-column label="创建时间" align="center" prop="createTime" width="180">
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime) }}</span> <span>{{ parseTime(scope.row.createTime) }}</span>
@ -52,19 +55,81 @@
icon="el-icon-view" icon="el-icon-view"
@click="handlePriew(scope.row)" @click="handlePriew(scope.row)"
>预览</el-button> >预览</el-button>
<el-button <el-button type="text" icon="el-icon-download" @click="handleDownload(scope.row)" v-loading="loadingDownload">下载</el-button>
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
>删除</el-button>
<el-button type="text" icon="el-icon-download">下载</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table><!--el-table--> </el-table><!--el-table-->
</el-tab-pane><!--el-tab-pane--> </el-tab-pane><!--el-tab-pane-->
</el-tabs><!--el-tabs--> </el-tabs><!--el-tabs-->
</div><!--fl 左侧页签--> </div><!--fl 左侧页签-->
<div class="fr">
<div class="tboper">
<div class="tit">评论</div>
</div><!--tboper 标题与操作按钮-->
<div class="pltextarea">
<el-input type="textarea" placeholder="请输入您的意见" :rows="4" maxlength="1000" show-word-limit></el-input>
<div class="plbtn"><el-button>发布</el-button></div>
</div><!--pltextarea-->
<div class="pllist">
<div class="list">
<div class="luser"><span class="xuser"></span></div>
<div class="ltext">
<div class="nt"><span class="name">张鑫辉</span><span class="time">05/01 12:00</span></div>
<div class="te">这个工具可以</div>
<div class="hb"><a class="btn"><i class="el-icon-chat-line-round"></i>回复</a></div>
<div class="pltextarea">
<el-input type="textarea" placeholder="请输入您的意见" :rows="2" maxlength="1000" show-word-limit></el-input>
<div class="plbtn"><el-button>取消</el-button><el-divider direction="vertical"></el-divider><el-button>发布</el-button></div>
</div><!--pltextarea-->
</div>
</div><!--list-->
<div class="list">
<div class="luser"><span class="xuser"></span></div>
<div class="ltext">
<div class="nt"><span class="name">钱多多</span><span class="time">05/01 12:00</span></div>
<div class="te">好用</div>
<div class="hb"><a class="btn"><i class="el-icon-chat-line-round"></i>回复</a></div>
<div class="list">
<div class="luser"><span class="xuser"></span></div>
<div class="ltext">
<div class="nt"><span class="name">赵宇</span><span class="time">05/01 12:00</span></div>
<div class="te">希望再选代一下还有待完善的地方</div>
<div class="hb"><a class="btn"><i class="el-icon-chat-line-round"></i>回复</a></div>
</div>
</div><!--list-->
<div class="list">
<div class="luser"><span class="xuser"></span></div>
<div class="ltext">
<div class="nt"><span class="name">李志</span><span class="time">05/01 12:00</span></div>
<div class="te">很好的解决了我的问题感谢</div>
<div class="hb"><a class="btn"><i class="el-icon-chat-line-round"></i>回复</a></div>
</div>
</div><!--list-->
</div>
</div><!--list-->
<div class="list">
<div class="luser"><span class="xuser"></span></div>
<div class="ltext">
<div class="nt"><span class="name">赵宇</span><span class="time">05/01 12:00</span></div>
<div class="te">希望再选代一下还有待完善的地方</div>
<div class="hb"><a class="btn"><i class="el-icon-chat-line-round"></i>回复</a></div>
</div>
</div><!--list-->
<div class="list">
<div class="luser"><span class="xuser"></span></div>
<div class="ltext">
<div class="nt"><span class="name">李志</span><span class="time">05/01 12:00</span></div>
<div class="te">很好的解决了我的问题感谢</div>
<div class="hb"><a class="btn"><i class="el-icon-chat-line-round"></i>回复</a></div>
</div>
</div><!--list-->
</div><!--pllist-->
</div><!--fl 右侧评论-->
<el-dialog :title="viewDialogTitle" :visible.sync="viewDialogOpen" fullscreen width="500px" append-to-body>
<i-frame :src="previewUrl" />
</el-dialog>
<!-- 上传 --> <!-- 上传 -->
<AddDoc :show.sync="open" :toolId="toolDetail.toolId" @callback="getDocList"/> <AddDoc :show.sync="open" :toolId="toolDetail.toolId" @callback="getDocList"/>
</div><!--fbox1 左右分栏--> </div><!--fbox1 左右分栏-->
@ -75,10 +140,12 @@
import AddDoc from './AddDoc' import AddDoc from './AddDoc'
import editDocument from "../document/editDocument"; import editDocument from "../document/editDocument";
import { Base64 } from 'js-base64'; import { Base64 } from 'js-base64';
import iFrame from "@/components/iFrame/index"
export default { export default {
name: 'toolDetail', name: 'toolDetail',
components: { editDocument, AddDoc }, components: { editDocument, AddDoc, iFrame },
dicts:['sys_normal_disable','tool_type'], dicts:['sys_normal_disable','tool_type','doc_class','doc_source'],
props: { props: {
toolDetail: { toolDetail: {
type: Object, type: Object,
@ -99,6 +166,7 @@
viewDialogOpen: false, viewDialogOpen: false,
title: '新增文档', title: '新增文档',
open: false, open: false,
loadingDownload: false,
} }
}, },
created(){ created(){
@ -136,7 +204,18 @@
this.getList(); this.getList();
this.$modal.msgSuccess("删除成功"); this.$modal.msgSuccess("删除成功");
}).catch(() => {}); }).catch(() => {});
} },
/**
* 处理下载
* **/
handleDownload(row){
let self = this
self.loadingDownload = true
this.$download.resource(row.docUrl);
setTimeout(()=>{
self.loadingDownload = false
},1000)
},
} }
} }
</script> </script>

View File

@ -157,16 +157,28 @@
关联附件 关联附件
</div> </div>
<div class="operate"> <div class="operate">
<el-button type="primary" icon="el-icon-upload2" @click="handleDocAdd">上传</el-button> <el-button type="primary" icon="el-icon-upload2" v-if="editStatus" @click="handleDocAdd">上传</el-button>
<el-button icon="el-icon-delete">删除</el-button> <!-- <el-button icon="el-icon-delete">删除</el-button>-->
</div><!--operate 操作按钮--> </div><!--operate 操作按钮-->
<el-table :data="docList" style="width: 100%"> <el-table :data="docList" style="width: 100%">
<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="文档名称" prop="docName" :show-overflow-tooltip="true" /> <el-table-column label="文档名称" prop="docName" :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" >
<template slot-scope="scope">
<dict-tag :options="dict.type.doc_class" :value="scope.row.docType"/>
</template>
</el-table-column>
<el-table-column label="负责人" prop="docPrincipals" :show-overflow-tooltip="true" width="80" /> <el-table-column label="负责人" prop="docPrincipals" :show-overflow-tooltip="true" width="80" />
<el-table-column label="归属部门" prop="docRespDept" :show-overflow-tooltip="true" width="150" /> <el-table-column label="归属部门" prop="docRespDept" :show-overflow-tooltip="true" width="150" >
<el-table-column label="来源" prop="docSource" width="100" /> <template slot-scope="scope">
{{convertDeptName(scope.row)}}
</template>
</el-table-column>
<el-table-column label="来源" prop="docSource" width="100" >
<template slot-scope="scope">
<dict-tag :options="dict.type.doc_source" :value="scope.row.docSource"/>
</template>
</el-table-column>
<el-table-column label="创建时间" align="center" prop="createTime" width="180"> <el-table-column label="创建时间" align="center" prop="createTime" width="180">
<template slot-scope="scope"> <template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime) }}</span> <span>{{ parseTime(scope.row.createTime) }}</span>
@ -178,15 +190,17 @@
size="mini" size="mini"
type="text" type="text"
icon="el-icon-view" icon="el-icon-view"
@click="handlePriew(scope.row)" v-if="isShowOperation(scope.row)"
@click="handlePreview(scope.row)"
>预览</el-button> >预览</el-button>
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
icon="el-icon-delete" icon="el-icon-delete"
v-if="editStatus"
@click="handleDelete(scope.row)" @click="handleDelete(scope.row)"
>删除</el-button> >删除</el-button>
<el-button type="text" icon="el-icon-download">下载</el-button> <el-button type="text" icon="el-icon-download" v-if="isShowOperation(scope.row)" @click="handleDownload(scope.row)" v-loading="loadingDownload">下载</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table><!--el-table--> </el-table><!--el-table-->
@ -225,7 +239,7 @@
</div> </div>
</el-form> </el-form>
<!-- 上传 --> <!-- 上传 -->
<add-doc :show.sync="addDocShow" toolId="1111"/> <add-doc :show.sync="addDocShow" ref="addDocRef" @addFileData="addFileData"/>
</div><!--el-form-border 表单--> </div><!--el-form-border 表单-->
<div v-show="activeName==='log'"> <div v-show="activeName==='log'">
<workflow-logs :procInstId = "pListData.procInstId"></workflow-logs> <workflow-logs :procInstId = "pListData.procInstId"></workflow-logs>
@ -260,10 +274,16 @@
></monitor-drawer> ></monitor-drawer>
<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" @cancel="toolPrincipalsChoose=false" @submit="submitPeople"></bl-user-selector> <bl-user-selector ref="peopleSelect" :type="'single'" :isCheck="true" :open="toolPrincipalsChoose" @cancel="toolPrincipalsChoose=false" @submit="submitPeople"></bl-user-selector>
<el-dialog :title="viewDialogTitle" :visible.sync="viewDialogOpen" fullscreen width="500px" append-to-body>
<i-frame :src="previewUrl" />
</el-dialog>
</div> </div>
</template> </template>
<script> <script>
import { listDocument } from "@/api/document/document"; import iFrame from "@/components/iFrame/index"
import { listDocument,delDocument } from "@/api/document/document";
import processcode from "@/views/workflowList/processcode/index.vue"; import processcode from "@/views/workflowList/processcode/index.vue";
import { import {
workflowprocesskey, workflowprocesskey,
@ -278,15 +298,17 @@ import { deptTreeSelect } from "@/api/system/user";
import { addTool, checkToolExist, getInfoByBpmcId, updateTool } from '@/api/tool/tool' import { addTool, checkToolExist, getInfoByBpmcId, updateTool } from '@/api/tool/tool'
import blUserSelector from '@/components/user-selector/src/user-selector.vue' import blUserSelector from '@/components/user-selector/src/user-selector.vue'
import ToolSelector from '@/components/tool-selector/index.vue' import ToolSelector from '@/components/tool-selector/index.vue'
import { Base64 } from 'js-base64'
// PDF // PDF
export default { export default {
dicts: ['sys_normal_disable','tool_type'], dicts: ['sys_normal_disable','tool_type','doc_source','doc_class'],
components: { components: {
ToolSelector, ToolSelector,
blUserSelector, blUserSelector,
Treeselect, AddDoc, Treeselect, AddDoc,
WorkflowLogs, WorkflowLogs,
processcode, processcode,
iFrame
}, },
name: "Borrow_doc", name: "Borrow_doc",
props: ['data'], props: ['data'],
@ -392,6 +414,10 @@ export default {
flowStepLoading : false, flowStepLoading : false,
// //
initPassword: undefined, initPassword: undefined,
viewDialogTitle: "",
viewDialogOpen: false,
previewUrl: '',
loadingDownload: false,
}; };
}, },
computed: {}, computed: {},
@ -445,6 +471,7 @@ export default {
getInfoByBpmcId(procInstId).then(async (res) => { getInfoByBpmcId(procInstId).then(async (res) => {
let formData = res.data; let formData = res.data;
formData.type = _this.form.type formData.type = _this.form.type
// _this.docList = formData.documentList
formData.association = JSON.parse(res.data.association) formData.association = JSON.parse(res.data.association)
_this.form = formData _this.form = formData
_this.getDocumentList(res.data.toolId) _this.getDocumentList(res.data.toolId)
@ -547,6 +574,7 @@ export default {
formData.editStatus = _this.editStatus formData.editStatus = _this.editStatus
formData.association = JSON.stringify(_this.form.association) formData.association = JSON.stringify(_this.form.association)
if (formData.toolId) { if (formData.toolId) {
this.$set(formData,'documentList',_this.docList)
updateTool(formData).then((res) => { updateTool(formData).then((res) => {
if (res.code===200) { if (res.code===200) {
_this.$message({ _this.$message({
@ -582,6 +610,7 @@ export default {
review: _this.attributeModelBool('approve'), review: _this.attributeModelBool('approve'),
}; };
formData.editStatus = _this.editStatus formData.editStatus = _this.editStatus
this.$set(formData,'documentList',_this.docList)
addTool(formData).then((res) => { addTool(formData).then((res) => {
if (res.code===200) { if (res.code===200) {
_this.form.toolId = res.data.businessKey; _this.form.toolId = res.data.businessKey;
@ -725,6 +754,7 @@ export default {
formData.recordStatus = 'doing' formData.recordStatus = 'doing'
} }
formData.editStatus = _this.editStatus formData.editStatus = _this.editStatus
this.$set(formData,'documentList',_this.docList)
addTool(formData).then((res) => { addTool(formData).then((res) => {
if (res.code===200) { if (res.code===200) {
_this.$message({ _this.$message({
@ -747,21 +777,25 @@ export default {
this.$refs.monitorDrawer.init(this.pListData.procInstId); this.$refs.monitorDrawer.init(this.pListData.procInstId);
}); });
}, },
handleDelete(dataList,index){ handleDelete(row){
dataList.splice(index,1) this.docList.splice(row,1)
}, },
/** /**
* 新增上传附件 * 新增上传附件
*/ */
handleDocAdd() { handleDocAdd() {
this.addDocShow = true this.addDocShow = true
this.$nextTick(() => {
this.$refs.addDocRef.resetForm()
})
}, },
getDocumentList(toolId) { getDocumentList(toolId) {
this.loading = true this.loading = true
this.docQueryParams.toolId = toolId this.docQueryParams.toolId = toolId
listDocument(this.docQueryParams).then(response => { this.$set(this.docQueryParams,'isDeleted',"0")
this.docList = response.rows; listDocument(this.docQueryParams).then(res => {
this.total = response.total; this.docList = res.rows;
this.total = res.total;
this.loading = false; this.loading = false;
} }
); );
@ -790,7 +824,58 @@ export default {
list.push({toolId:itme.toolId,toolName:itme.toolName}) list.push({toolId:itme.toolId,toolName:itme.toolName})
}) })
this.form.association = list this.form.association = list
}
}, },
/** 添加关联附件数据**/
addFileData(dataInfo){
let document = JSON.parse(JSON.stringify(dataInfo))
this.docList.push(document)
},
findDeptInTree(tree, id) {
for (const node of tree) {
if (node.id == id) {
return node;
}
if (node.children && node.children.length > 0) {
const found = this.findDeptInTree(node.children, id);
if (found) {
return found;
}
}
}
return null;
},
/** 获取部门名称 **/
convertDeptName(row){
let foundDept = this.findDeptInTree(this.deptOptions, row.docRespDept);
if(foundDept){
return foundDept.label
}
return null
},
isShowOperation(row){
let self = this
if(row.docId == null || row.docId == undefined || row.docId == ''){
return false
}
return true
},
handlePreview(row){
this.previewUrl = process.env.VUE_APP_TOOL_TECH_FILE_VIEW_API + '/onlinePreview?url=' + encodeURIComponent(Base64.encode(process.env.VUE_APP_BASE_API + row.docUrl));
this.viewDialogTitle = '文档在线预览'
this.viewDialogOpen = true;
},
/**
* 处理下载
* **/
handleDownload(row){
let self = this
self.loadingDownload = true
this.$download.resource(row.docUrl);
setTimeout(()=>{
self.loadingDownload = false
},1000)
},
},
}; };
</script> </script>