From 37b718547bc441c7502f0bfcf86209efe253851b Mon Sep 17 00:00:00 2001
From: Your Name <123456>
Date: Wed, 06 Apr 2022 17:32:03 +0800
Subject: [PATCH] 'lct'
---
src/views/contingencyplan/uploadFile.vue | 130 +++++++++++++++++++++++++++++++++++++++++++
1 files changed, 130 insertions(+), 0 deletions(-)
diff --git a/src/views/contingencyplan/uploadFile.vue b/src/views/contingencyplan/uploadFile.vue
new file mode 100644
index 0000000..9181943
--- /dev/null
+++ b/src/views/contingencyplan/uploadFile.vue
@@ -0,0 +1,130 @@
+<template>
+ <div style="display: flex">
+ <el-input :disabled="true" type="text" size="medium" v-model="viewName" style="width: 60%" ></el-input>
+ <el-upload
+ v-if="!disabled"
+ action=""
+ multiple
+ :limit="1"
+ :file-list="fileList"
+ :http-request="uploadSectionFile"
+ :show-file-list="false"
+ :before-upload="beforeUpload"
+ :on-success="handleSuccess"
+ :on-error="handleError"
+ >
+ <div style="">
+ <el-button v-if="!fileName" type="primary" size="small" style="margin-left:25px;;width:65px;height:36px;display: flex;align-items: center;justify-content: center">上传<i class="el-icon-upload el-icon--right"></i></el-button>
+ </div>
+ </el-upload>
+
+ <div style="display: flex">
+ <a v-if="!disabled&&fileName">
+ <el-button @click="downLoadFile(downloadUrl)" slot="tip" type="primary" size="small" style="margin-left:25px;width:65px;height:36px;display: flex;align-items: center;justify-content: center">
+ 下载<i class="el-icon-download el-icon--right"></i>
+ </el-button>
+ </a>
+ <el-button v-if="!disabled&&fileName" slot="tip" type="primary" size="small " @click="handleClear" style="margin-left:5px;width:65px;height:36px;display: flex;align-items: center;justify-content: center"
+ >清除<i class="el-icon-delete el-icon--right"></i></el-button>
+ </div>
+ </div>
+</template>
+
+<script>
+
+ import {emergencyPlanUpload} from "@/api/emergencyplan.js";
+
+export default {
+ props: {
+ name: {
+ type: String
+ },
+ url: {
+ type: String
+ },
+ disabled: {
+ type: Boolean
+ }
+ },
+ data() {
+ return {
+ action: '',
+ viewName:'',
+ fileName: '',
+ filePath: '',
+ downloadUrl: '',
+ fileList: [],
+ }
+ },
+ mounted() {
+ setTimeout(() => {
+ this.fileName = this.$props.name;
+ this.downloadUrl = this.$props.url;
+ this.viewName=this.$props.name
+ }, 100);
+ },
+ watch: {
+ name() {
+ this.fileName = this.$props.name;
+ this.downloadUrl = this.$props.url;
+ this.viewName=this.$props.name;
+ }
+ },
+ methods: {
+
+ downLoadFile(fileUrl){
+ let a = document.createElement('a')
+ // a.href = this.defaultUrl+`/upload/downloadNew?path=`+encodeURI(fileUrl)
+ a.href = process.env.BASE_API + '/upload/'+fileUrl
+ a.click();
+ },
+
+ downloadFile(){
+
+ },
+ uploadSectionFile(param) {
+ let form = new FormData();
+ form.append('file', param.file);
+ emergencyPlanUpload(form).then(res=>{
+ if (res.data.code==200){
+ this.fileName = res.data.result.fileName;
+ this.viewName=res.data.result.fileName;
+ this.downloadUrl=res.data.result.fileUrl
+ this.$nextTick(() => {
+ this.$emit('uploadFileSuccess', {
+ fileName: this.fileName,
+ fileUrl: this.downloadUrl
+ });
+ });
+ this.$message({
+ type:'success',
+ message:'上传成功',
+ duration:2000,
+ })
+ }else {
+ this.$message.error('上传失败,系统未知错误!错误码为【500】');
+ }
+ })
+ },
+
+ handleClear(){
+ this.fileName = '';
+ this.fileList = [];
+ this.viewName=""
+ this.$emit('uploadFileSuccess', {
+ fileUrl: '',
+ fileName: ''
+ });
+ },
+
+ beforeUpload(file) {
+ },
+ handleError(err, file, fileList) {
+ this.$message.error('上传失败,系统未知错误!错误码为【500】');
+ },
+ handleSuccess(err, file, fileList) {
+ },
+ }
+}
+</script>
+
--
Gitblit v1.9.2