From 9ddb942462a18fe7056eb635183df316df73717e Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期三, 26 二月 2025 17:49:16 +0800
Subject: [PATCH] 标准物质验收

---
 src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue |  335 ++++++++++++++++++++++--------
 /dev/null                                                                    |  198 ------------------
 src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue               |   71 ++----
 src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js |   27 ++
 4 files changed, 298 insertions(+), 333 deletions(-)

diff --git a/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js b/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js
index 010c461..e9a0a7a 100644
--- a/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js
+++ b/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js
@@ -15,10 +15,18 @@
     data: query
   })
 }
-
+// 鏂板楠屾敹
 export function addAcceptance(query) {
   return request({
     url: '/feStandardSubstanceAcceptance/addAcceptance',
+    method: 'post',
+    data: query
+  })
+}
+// 淇敼楠屾敹
+export function updateAcceptance(query) {
+  return request({
+    url: '/feStandardSubstanceAcceptance/updateAcceptance',
     method: 'post',
     data: query
   })
@@ -34,6 +42,23 @@
     params: query
   })
 }
+// 鏍囧噯鐗╄川楠屾敹鏌ョ湅璇︽儏
+export function getAcceptanceDetails(query) {
+  return request({
+    url: '/feStandardSubstanceAcceptance/getAcceptanceDetails',
+    method: 'get',
+    params: query
+  })
+}
+// 鏍囧噯鐗╄川楠屾敹瀵煎嚭
+export function exportFeStandardSubstanceAcceptance(query) {
+  return request({
+    url: '/feStandardSubstanceAcceptance/exportFeStandardSubstanceAcceptance',
+    method: 'get',
+    params: query,
+    responseType: "blob"
+  })
+}
 
 
 
diff --git a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
index bd776c7..4863654 100644
--- a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
+++ b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
@@ -1,103 +1,260 @@
 <template>
-    <el-dialog :visible.sync="dialogVisible" title="鏍囧噯鐗╄川楠屾敹璁板綍" width="70%">
-       <el-steps :active="currentStep" finish-status="success">
-            <el-step class="cursor-pointer" v-for="(item, index) in steps" :key="index" :title="item">
-            </el-step>
-        </el-steps>
-        <el-form :model="model" label-width="140px" size="small">
-            <Step1 :model.sync="model"></Step1>
-        </el-form>
-        <span slot="footer" class="dialog-footer">
-            <el-button @click="dialogVisible = false">鍙� 娑�</el-button>
-            <el-button type="primary" @click="submit">淇� 瀛�</el-button>
-        </span>
-    </el-dialog>
+  <el-dialog :visible.sync="dialogVisible" title="鏍囧噯鐗╄川楠屾敹璁板綍" width="72%" v-loading="loading">
+    <el-form :model="acceptance" ref="acceptance" label-width="140px" size="small">
+      <el-col :span="12">
+        <el-form-item label="鍘傚浠h〃">
+          <el-input v-model="acceptance.producer"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鐩稿叧闄勪欢">
+          <div class="table-between">
+            <el-input v-model="acceptance.file" style="width: 80%;" disabled></el-input>
+            <el-upload
+              ref="upload"
+              style="float: right;"
+              :headers="uploadHeader"
+              :action="action"
+              :show-file-list="false"
+              :on-success="onSuccess"
+            >
+              <el-button type="primary">
+                闄勪欢涓婁紶
+              </el-button>
+            </el-upload>
+          </div>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鎺ユ敹浜�">
+          <el-input v-model="acceptance.recipient"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鎺ュ彈绛惧瓧">
+          <el-input v-model="acceptance.signature"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="楠屾敹鎯呭喌">
+          <el-input v-model="acceptance.situation"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="瀹夎璋冭瘯鎯呭喌">
+          <el-input v-model="acceptance.installation"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="娓呭崟" prop="substanceId" :rule="[{ required: true, message: '璇烽�夋嫨娓呭崟', trigger: 'change' }]">
+          <el-select v-model="acceptance.substanceId" placeholder="璇烽�夋嫨" style="width: 100%">
+            <el-option
+              v-for="item in options"
+              :key="item.value"
+              :label="item.name"
+              :value="item.id">
+            </el-option>
+          </el-select>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鍒拌揣鏃ユ湡">
+          <el-date-picker
+            v-model="acceptance.arriveDate"
+            align="right"
+            type="date"
+            placeholder="閫夋嫨鏃ユ湡"
+            style="width: 100%"
+            value-format="yyyy-MM-dd"
+          >
+          </el-date-picker>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="缁翠慨鍗曚綅">
+          <el-input v-model="acceptance.maintenanceUnit"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="24">
+        <el-form-item label="澶囦欢纭">
+          <el-button type="primary" style="float: right;" @click="addSpareTable">澧炲姞琛�</el-button>
+        </el-form-item>
+      </el-col>
+      <el-col :span="24">
+        <lims-table :tableData="list" :column="spareColumns" height="300">
+          <template slot="name" slot-scope="{ row, index }">
+            <el-input v-if="row.isEdit" size="small" v-model="row.name"></el-input>
+            <span v-else>{{ row.name }}</span>
+          </template>
+          <template slot="number" slot-scope="{ row, index }">
+            <el-input v-if="row.isEdit" size="small" v-model="row.number"></el-input>
+            <span v-else>{{ row.number }}</span>
+          </template>
+          <template slot="action" slot-scope="{ row, index }">
+            <div v-if="row.isEdit">
+              <el-button type="text" @click="save(index)">淇濆瓨</el-button>
+              <el-button type="text">鍙栨秷</el-button>
+            </div>
+            <div v-else>
+              <el-button type="text" @click="edit(index)">淇敼</el-button>
+            </div>
+          </template>
+        </lims-table>
+      </el-col>
+    </el-form>
+    <span slot="footer" class="dialog-footer">
+      <el-button @click="closeDialog">鍙� 娑�</el-button>
+      <el-button type="primary" :loading="submitLoading" @click="submit">淇� 瀛�</el-button>
+    </span>
+  </el-dialog>
 </template>
 
 <script>
-import Step1 from './Step1.vue'
+import limsTable from "@/components/Table/lims-table.vue";
+import {
+  addAcceptance, getAcceptanceDetails,
+  getStandardSubstanceAll,
+  updateAcceptance
+} from "@/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept";
 export default {
-    components: {
-        Step1
-    },
-    data() {
-        return {
-            dialogVisible: false,
-            currentStep: 0, // 姝ラ鏉℃樉绀虹鍑犳
-            steps: ['鎻愪氦', '寮�绠遍獙鏀跺鏍�', '瀹夎楠屾敹妫�鏌�', '瀹夎楠屾敹澶嶆牳', '楠屾敹鏍告煡', '楠屾敹鏍告煡瀹℃牳'],
-            model: {
-                acceptance: {
-                    id: undefined,
-                    producer: undefined, // 鍘傚浠h〃
-                    file: undefined,   // 鐩稿叧闄勪欢
-                    recipient: undefined,   // 鎺ユ敹浜�
-                    signature: undefined,   // 鎺ュ彈绛惧瓧
-                    situation: undefined,   // 楠屾敹鎯呭喌
-                    installation: undefined,    // 瀹夎璋冭瘯鎯呭喌
-                    substanceId: undefined, // 娓呭崟
-                    arriveDate: undefined,   // 鍒拌揣鏃ユ湡
-                    maintenanceUnit: undefined,   // 缁翠慨鍗曚綅
-                },
-                list: []
-            }
+  components: {
+    limsTable,
+  },
+  data() {
+    return {
+      dialogVisible: false,
+      loading: false,
+      submitLoading: false,
+      acceptance: {
+        id: undefined,
+        producer: undefined, // 鍘傚浠h〃
+        file: undefined,   // 鐩稿叧闄勪欢
+        recipient: undefined,   // 鎺ユ敹浜�
+        signature: undefined,   // 鎺ュ彈绛惧瓧
+        situation: undefined,   // 楠屾敹鎯呭喌
+        installation: undefined,    // 瀹夎璋冭瘯鎯呭喌
+        substanceId: undefined, // 娓呭崟
+        arriveDate: undefined,   // 鍒拌揣鏃ユ湡
+        maintenanceUnit: undefined,   // 缁翠慨鍗曚綅
+        list: [],
+      },
+      list: [],
+      spareColumns: [
+        {
+          label: "鍚嶇О",
+          prop: "name",
+          align: "center",
+          dataType: "slot",
+          slot: "name",
+        }, {
+          label: "鏁伴噺",
+          prop: "number",
+          align: "center",
+          dataType: "slot",
+          slot: "number",
+        }, {
+          label: "鎿嶄綔",
+          align: "center",
+          dataType: "slot",
+          slot: "action",
+          width: 150
         }
-    },
-    watch: {
-        model(newVal) {
-            this.model = newVal
-        }
-    },
-    methods: {
-        clearForm() {
-            this.model.acceptance.id = undefined
-            this.model.acceptance.producer = undefined
-            this.model.acceptance.file = undefined
-            this.model.acceptance.recipient = undefined
-            this.model.acceptance.signature = undefined
-            this.model.acceptance.situation = undefined
-            this.model.acceptance.installation = undefined
-            this.model.acceptance.substanceId = undefined
-            this.model.acceptance.arriveDate = undefined
-            this.model.acceptance.maintenanceUnit = undefined
-            this.model.list = []
-        },
-        openDialog(form) {
-            console.log(form)
-            if(form) {
-                this.model.acceptance.id = form.acceptance.id
-                this.model.acceptance.producer = form.acceptance.producer
-                this.model.acceptance.file = form.acceptance.file
-                this.model.acceptance.recipient = form.acceptance.recipient
-                this.model.acceptance.signature = form.acceptance.signature
-                this.model.acceptance.situation = form.acceptance.situation
-                this.model.acceptance.installation = form.acceptance.installation
-                this.model.acceptance.substanceId = form.acceptance.substanceId
-                this.model.acceptance.arriveDate = form.acceptance.arriveDate
-                this.model.acceptance.maintenanceUnit = form.acceptance.maintenanceUnit
-                this.model.list = form.list
-            } else {
-                this.clearForm()
-            }
-            this.dialogVisible = true
-        },
-        closeDialog() {
-            this.dialogVisible = false
-        },
-        submit() {
-          if (!this.model.acceptance.substanceId) {
-            this.$message.warning('璇烽�夋嫨娓呭崟')
-            return
-          }
-            this.$emit('submit', this.model)
-            this.closeDialog()
-        }
+      ],
+      options: []
     }
+  },
+  mounted() {
+    this.getStand()
+  },
+  methods: {
+    openDialog(id) {
+      if(id) {
+        this.getDetail(id)
+      } else {
+        this.clearForm()
+      }
+      this.dialogVisible = true
+    },
+    getDetail(id) {
+      this.loading = true
+      getAcceptanceDetails({id: id}).then(res => {
+        this.acceptance = res.data.acceptance
+        this.list = res.data.list
+        this.loading = false
+      }).catch(err => {
+        this.loading = false
+      })
+    },
+    getStand() {
+      getStandardSubstanceAll().then(res => {
+        this.options = res.data
+      })
+    },
+    addSpareTable() {
+      this.list.push({
+        acceptanceId: this.acceptance.id,
+        name: '',
+        number: '',
+        isEdit: true
+      })
+    },
+    onSuccess(response) {
+      this.acceptance.file = response.data
+    },
+    save(index) {
+      this.$set(this.list[index], 'isEdit', false)
+    },
+    edit(index) {
+      this.$set(this.list[index], 'isEdit', true)
+    },
+    clearForm() {
+      this.list = []
+      this.resetForm('acceptance')
+    },
+    closeDialog() {
+      this.clearForm()
+      this.resetForm('acceptance')
+      this.dialogVisible = false
+    },
+    submit() {
+      if (!this.acceptance.substanceId) {
+        this.$message.warning('璇烽�夋嫨娓呭崟')
+        return
+      }
+      this.acceptance.list = this.HaveJson(this.list)
+      this.submitLoading = true
+      if(this.acceptance.id) {
+        updateAcceptance({acceptance: this.acceptance, list: this.list}).then(res => {
+          this.$message.success('缂栬緫鎴愬姛')
+          this.submitLoading = false
+          this.closeDialog()
+          this.$emit('submit')
+        }).catch((e) => {
+          this.submitLoading = false
+        })
+      } else {
+        addAcceptance({acceptance: this.acceptance, list: this.list}).then(res => {
+          this.$message.success('鏂板鎴愬姛')
+          this.closeDialog()
+          this.$emit('submit')
+        }).catch((e) => {
+          this.submitLoading = false
+        })
+      }
+    },
+  },
+  computed: {
+    action() {
+      return this.javaApi + '/personBasicInfo/saveCNASFile'
+    }
+  },
 }
 
 </script>
 
 <style scoped>
-.cursor-pointer {
-    cursor: pointer;
+>>>.el-dialog__body {
+  height: 580px;
+  overflow-y: auto;
 }
 </style>
diff --git a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/Step1.vue b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/Step1.vue
deleted file mode 100644
index 967c41b..0000000
--- a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/Step1.vue
+++ /dev/null
@@ -1,198 +0,0 @@
-<template>
-  <el-card class="card">
-    <el-col :span="12">
-      <el-form-item label="鍘傚浠h〃">
-        <el-input v-model="model.acceptance.producer"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鐩稿叧闄勪欢">
-        <div class="table-between">
-          <el-input v-model="model.acceptance.file" style="width: 82%;"></el-input>
-          <el-upload
-            ref="upload"
-            style="float: left; margin: 0 12px 0 20px;"
-            :action="action"
-            :show-file-list="false"
-            :on-success="onSuccess"
-          >
-            <el-button type="primary">
-              闄勪欢涓婁紶
-            </el-button>
-          </el-upload>
-        </div>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鎺ユ敹浜�">
-        <el-input v-model="model.acceptance.recipient"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鎺ュ彈绛惧瓧">
-        <el-input v-model="model.acceptance.signature"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="楠屾敹鎯呭喌">
-        <el-input v-model="model.acceptance.situation"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="瀹夎璋冭瘯鎯呭喌">
-        <el-input v-model="model.acceptance.installation"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="娓呭崟" prop="substanceId" required>
-        <el-select v-model="model.acceptance.substanceId" placeholder="璇烽�夋嫨" style="width: 100%">
-          <el-option
-            v-for="item in options"
-            :key="item.value"
-            :label="item.name"
-            :value="item.id">
-          </el-option>
-        </el-select>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鍒拌揣鏃ユ湡">
-        <el-date-picker
-          v-model="model.acceptance.arriveDate"
-          align="right"
-          type="date"
-          placeholder="閫夋嫨鏃ユ湡"
-          style="width: 100%"
-          value-format="yyyy-MM-dd"
-        >
-        </el-date-picker>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="缁翠慨鍗曚綅">
-        <el-input v-model="model.acceptance.maintenanceUnit"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="24">
-      <el-form-item label="澶囦欢纭">
-        <el-button type="primary" style="float: right;" @click="addSpareTable">澧炲姞琛�</el-button>
-      </el-form-item>
-    </el-col>
-    <el-col :span="24">
-      <el-form-item>
-        <lims-table :tableData="model.list" :column="spareColumns" :height="'calc(100vh - 250px)'">
-          <template slot="name" slot-scope="{ row, index }">
-            <el-input v-if="row.isEdit" size="small" v-model="row.name"></el-input>
-            <span v-else>{{ row.name }}</span>
-          </template>
-          <template slot="number" slot-scope="{ row, index }">
-            <el-input v-if="row.isEdit" size="small" v-model="row.number"></el-input>
-            <span v-else>{{ row.number }}</span>
-          </template>
-          <template slot="action" slot-scope="{ row, index }">
-            <div v-if="row.isEdit">
-              <el-button type="text" @click="save(index)">淇濆瓨</el-button>
-              <el-button type="text">鍙栨秷</el-button>
-            </div>
-            <div v-else>
-              <el-button type="text" @click="edit(index)">淇敼</el-button>
-            </div>
-          </template>
-        </lims-table>
-      </el-form-item>
-    </el-col>
-  </el-card>
-</template>
-
-<script>
-// import { getStandardSubstanceAll } from "@/assets/api/api";
-import axios from 'axios';
-import limsTable from '@/components/Table/lims-table.vue'
-import {
-  getStandardSubstanceAll
-} from '@/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept'
-
-export default {
-  components: {
-    limsTable
-  },
-  props: {
-    model: {
-      type: Object,
-      default: () => {}
-    }
-  },
-  data() {
-    return {
-      spareColumns: [
-        {
-          label: "鍚嶇О",
-          prop: "name",
-          align: "center",
-          dataType: "slot",
-          slot: "name",
-        }, {
-          label: "鏁伴噺",
-          prop: "number",
-          align: "center",
-          dataType: "slot",
-          slot: "number",
-        }, {
-          label: "鎿嶄綔",
-          align: "center",
-          dataType: "slot",
-          slot: "action",
-          width: 150
-        }
-      ],
-      options: []
-    }
-  },
-  computed: {
-    action() {
-     return `${this.javaApi}/personBasicInfo/saveCNASFile`
-    }
-  },
-  mounted() {
-    this.getStand()
-  },
-  methods: {
-    async getStand() {
-      getStandardSubstanceAll().then(res => {
-        this.options = res.data
-      })
-    },
-    addSpareTable() {
-      this.model.list.push({
-        acceptanceId: this.model.acceptance.id,
-        name: '',
-        number: '',
-        isEdit: true
-      })
-    },
-    onSuccess(response) {
-      this.model.acceptance.file = response.data
-      this.$emit('update:model', this.model)
-    },
-    save(index) {
-      this.model.list[index].isEdit = false
-      this.$emit('update:model', this.model)
-    },
-    edit(index) {
-      this.model.list[index].isEdit = true
-    }
-  }
-}
-</script>
-
-<style scoped>
-.card {
-  margin-top: 1em;
-  height: 56vh;
-  overflow-y: scroll;
-}
-.table-between {
-  display: flex;
-  justify-content: space-between;
-}
-</style>
diff --git a/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue b/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue
index 241a3c0..fe9ee04 100644
--- a/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue
+++ b/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue
@@ -19,24 +19,21 @@
     </div>
     <div class="table">
       <lims-table :tableData="tableData" :column="columns" :height="'calc(100vh - 250px)'" @pagination="pagination"
-        :page="page" :tableLoading="tableLoading"></lims-table>
+        :page="page" :tableLoading="tableLoading">
+        <template slot="action" slot-scope="{ row }">
+          <el-button type="text" @click="edit(row)">缂栬緫</el-button>
+        </template>
+      </lims-table>
     </div>
-    <AddRecord ref="addRecordRef" @submit="submit"></AddRecord>
+    <AddRecord ref="addRecordRef" v-if="addRecordRef" @submit="submit"></AddRecord>
   </div>
 </template>
 
 <script>
-// import axios from "axios";
-// import { getPageAcceptance, addAcceptance, updateAcceptance, getAcceptanceDetails, exportAcceptance } from "@/assets/api/api";
-// import ZTTable from '@/components/caorui/ZTTable/index.vue';
-// import AddRecord from './components/AddRecord.vue';
-
 import limsTable from '@/components/Table/lims-table.vue'
 import AddRecord from './component/AddRecord.vue';
 import {
-  getPageAcceptance,
-  updateAcceptanc,
-  addAcceptance
+  getPageAcceptance, getAcceptanceDetails, exportFeStandardSubstanceAcceptance, updateAcceptance, addAcceptance
 } from '@/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept'
 export default {
   components: {
@@ -48,6 +45,7 @@
       form: {
         search: undefined
       },
+      addRecordRef: false,
       columns: [
         {
           label: "鍑哄満缂栧彿",
@@ -114,56 +112,39 @@
     this.getTableData()
   },
   methods: {
-    async getTableData() {
-      const res = await getPageAcceptance(this.form);
-      if (res.code === 200) {
+    getTableData() {
+      getPageAcceptance(this.form).then(res => {
         this.tableData = res.data.records;
         this.page.total = res.data.total;
-      }
-
+      })
     },
     openDialog() {
-      this.$refs.addRecordRef.openDialog()
-    },
-    async submit(form) {
-
-      const { code } = await form.acceptance.id ? updateAcceptanc(this.form) : addAcceptance((this.form));
-      if (code == 200) {
-        this.$message.success(`${form.acceptance.id ? '缂栬緫' : '娣诲姞'}鎴愬姛`)
-        this.getTableData()
-      }
-    },
-    async edit(row) {
-      const res = await this.getDetail(row.id)
-      this.$refs.addRecordRef.openDialog({
-        acceptance: res.acceptance,
-        list: res.list
+      this.addRecordRef = true;
+      this.$nextTick(() => {
+        this.$refs.addRecordRef.openDialog()
       })
     },
-    async getDetail(id) {
-      const { code, data } = await axios({
-        method: 'get',
-        url: getAcceptanceDetails,
-        params: { id }
+    submit() {
+      this.addRecordRef = false;
+      this.getTableData()
+    },
+    edit(row) {
+      this.addRecordRef = true;
+      this.$nextTick(() => {
+        this.$refs.addRecordRef.openDialog(row.id)
       })
-      if (code == 200) {
-        return data;
-      }
     },
     reset() {
       this.form.search = undefined
       this.getTableData()
     },
     async exportExcel() {
-      const res = await axios({
-        method: "get",
-        url: `${exportAcceptance}`,
-        responseType: "blob"
+      exportFeStandardSubstanceAcceptance().then(res => {
+        const blob = new Blob([res], { type: 'application/octet-stream' });
+        this.$download.saveAs(blob, '鏍囧噯鐗╄川楠屾敹.xlsx');
+        this.$message.success('瀵煎嚭鎴愬姛')
       })
-      const blob = new Blob([res], { type: 'application/octet-stream' });
-      this.$download.saveAs(blob, '鏍囧噯鐗╄川楠屾敹.xlsx');
     },
-
     // 鍒嗛〉鍒囨崲
     pagination(page) {
       this.page.size = page.limit

--
Gitblit v1.9.3