From 454c1f927a0e8c10757521590483bf49cf9b7b21 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期六, 12 四月 2025 15:34:47 +0800
Subject: [PATCH] 检验任务-新增不合格复测修改

---
 src/plugins/download.js |   35 ++++++++++++++++++++++++++++++-----
 1 files changed, 30 insertions(+), 5 deletions(-)

diff --git a/src/plugins/download.js b/src/plugins/download.js
index 62b21b8..17bcf96 100644
--- a/src/plugins/download.js
+++ b/src/plugins/download.js
@@ -4,6 +4,7 @@
 import { getToken } from "@/utils/auth";
 import errorCode from "@/utils/errorCode";
 import { blobValidate } from "@/utils/ruoyi";
+import Vue from "vue";
 
 const baseURL = process.env.VUE_APP_BASE_API;
 let downloadLoadingInstance;
@@ -80,11 +81,35 @@
         downloadLoadingInstance.close();
       });
   },
-  saveAs(text, name, opts) {
+  async saveAs(text, name, opts) {
     if (typeof text === "string") {
-      // 璺緞涓嬭浇
-      saveAs(text, name, opts);
-      Message.success("鏁版嵁瀵煎嚭鎴愬姛");
+      try {
+        let state = /\.(jpg|jpeg|png|gif)$/i.test(text) // 鍒ゆ柇鏄惁涓哄浘鐗�
+        let url1 = ''
+        if (state) {
+          url1 = Vue.prototype.javaApi + '/img/' + text;
+        } else {
+          if (text.startsWith("/word/")) {
+            url1 = Vue.prototype.javaApi + text
+          } else if (text.startsWith("word/")) {
+            url1 = Vue.prototype.javaApi + '/' + text
+          } else {
+            url1 = Vue.prototype.javaApi + '/word/' + text
+          }
+        }
+        // 浣跨敤 fetch 鑾峰彇鏂囦欢
+        const response = await fetch(url1);
+        if (!response.ok) {
+          throw new Error('鏂囦欢涓嬭浇澶辫触: ' + response.statusText);
+        }
+        // 灏嗘枃浠惰浆鎹负 Blob
+        const blob = await response.blob();
+        // 浣跨敤 saveAs 淇濆瓨鏂囦欢
+        saveAs(blob, name);
+        Message.success("鏁版嵁瀵煎嚭鎴愬姛");
+      } catch (error) {
+        Message.error(error);
+      }
     } else {
       // 娴佷笅杞�
       blobToText(text)
@@ -113,7 +138,7 @@
     fileReader.onload = function () {
       try {
         const result = JSON.parse(this.result);
-        if (result && result["code"] === 500) {
+        if (result && result["code"] !== 200) {
           resolve(result);
         } else {
           reject();

--
Gitblit v1.9.3