From 37b718547bc441c7502f0bfcf86209efe253851b Mon Sep 17 00:00:00 2001
From: Your Name <123456>
Date: 星期三, 06 四月 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