From 5aa165156994b1b8a601063fa0a1107d1893ea57 Mon Sep 17 00:00:00 2001
From: WXL <wl_5969728@163.com>
Date: 星期四, 19 三月 2026 16:48:13 +0800
Subject: [PATCH] 更新

---
 src/views/business/course/components/DeathJudgmentStage.vue |  564 +++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 396 insertions(+), 168 deletions(-)

diff --git a/src/views/business/course/components/DeathJudgmentStage.vue b/src/views/business/course/components/DeathJudgmentStage.vue
index a1d2bc4..ce25f7f 100644
--- a/src/views/business/course/components/DeathJudgmentStage.vue
+++ b/src/views/business/course/components/DeathJudgmentStage.vue
@@ -4,14 +4,70 @@
       <!-- 鍩虹淇℃伅 -->
       <div slot="header" class="clearfix">
         <span class="detail-title">姝讳骸鍒ゅ畾鍩烘湰淇℃伅</span>
+        <el-button
+          v-if="isEdit"
+          type="success"
+          style="float: right"
+          @click="handleSave"
+          :loading="saveLoading"
+        >
+          淇濆瓨淇℃伅
+        </el-button>
+        <el-button
+          v-else
+          type="primary"
+          style="float: right"
+          @click="handleEdit"
+        >
+          缂栬緫淇℃伅
+        </el-button>
       </div>
 
       <el-form :model="form" ref="form" :rules="rules" label-width="120px">
         <el-row :gutter="20">
           <el-col :span="8">
-            <el-form-item label="姝讳骸鍘熷洜" prop="deathReason">
+            <el-form-item label="鎹愮尞鑰呯紪鍙�" prop="donorno">
+              <el-input
+                v-model="form.donorno"
+                :readonly="!isEdit"
+                placeholder="鑷姩鐢熸垚鎹愮尞鑰呯紪鍙�"
+              />
+            </el-form-item>
+          </el-col>
+          <el-col :span="8">
+            <el-form-item label="鎹愮尞鑰呭鍚�" prop="name">
+              <el-input v-model="form.name" :readonly="!isEdit" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="8">
+            <el-form-item label="鎬у埆" prop="sex">
               <el-select
-                v-model="form.deathReason"
+                v-model="form.sex"
+                :disabled="!isEdit"
+                style="width: 100%"
+              >
+                <el-option label="鐢�" value="1" />
+                <el-option label="濂�" value="2" />
+              </el-select>
+            </el-form-item>
+          </el-col>
+        </el-row>
+
+        <el-row :gutter="20">
+          <el-col :span="8">
+            <el-form-item label="骞撮緞" prop="age">
+              <el-input v-model="form.age" :readonly="!isEdit" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="8">
+            <el-form-item label="鐤剧梾璇婃柇" prop="diagnosisname">
+              <el-input v-model="form.diagnosisname" :readonly="!isEdit" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="8">
+            <el-form-item label="姝讳骸鍘熷洜" prop="deathreason">
+              <el-select
+                v-model="form.deathreason"
                 :disabled="!isEdit"
                 style="width: 100%"
               >
@@ -25,9 +81,9 @@
 
         <el-row :gutter="20">
           <el-col :span="8">
-            <el-form-item label="姝讳骸鏃堕棿" prop="deathTime">
+            <el-form-item label="姝讳骸鏃堕棿" prop="deathtime">
               <el-date-picker
-                v-model="form.deathTime"
+                v-model="form.deathtime"
                 type="datetime"
                 value-format="yyyy-MM-dd HH:mm:ss"
                 style="width: 100%"
@@ -36,13 +92,63 @@
             </el-form-item>
           </el-col>
           <el-col :span="8">
-            <el-form-item label="鍒ゅ畾鍖荤敓" prop="judgmentDoctor">
-              <el-input v-model="form.judgmentDoctor" :readonly="!isEdit" />
+            <el-form-item label="鍒ゅ畾鍖荤敓涓�" prop="deathjudgedocto">
+              <el-input v-model="form.deathjudgedocto" :readonly="!isEdit" />
             </el-form-item>
           </el-col>
           <el-col :span="8">
-            <el-form-item label="鐧昏浜�" prop="registrant">
-              <el-input v-model="form.registrant" :readonly="!isEdit" />
+            <el-form-item label="鍒ゅ畾鍖荤敓浜�" prop="deathjudgedoctt">
+              <el-input v-model="form.deathjudgedoctt" :readonly="!isEdit" />
+            </el-form-item>
+          </el-col>
+        </el-row>
+
+        <el-row :gutter="20">
+          <el-col :span="8">
+            <el-form-item label="鍣ㄥ畼鑾峰彇鏈烘瀯" prop="gainhospitalname">
+              <el-input v-model="form.gainhospitalname" :readonly="!isEdit" />
+            </el-form-item>
+          </el-col>
+          <el-col :span="8">
+            <el-form-item label="鏄惁榛樺搥缂呮��" prop="isspendremember">
+              <el-select
+                v-model="form.isspendremember"
+                :disabled="!isEdit"
+                style="width: 100%"
+              >
+                <el-option label="鏄�" :value="1" />
+                <el-option label="鍚�" :value="0" />
+              </el-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="8">
+            <el-form-item label="鏄惁鎭㈠閬椾綋浠" prop="isrestoreremains">
+              <el-select
+                v-model="form.isrestoreremains"
+                :disabled="!isEdit"
+                style="width: 100%"
+              >
+                <el-option label="鏄�" :value="1" />
+                <el-option label="鍚�" :value="0" />
+              </el-select>
+            </el-form-item>
+          </el-col>
+        </el-row>
+
+        <el-row :gutter="20">
+          <el-col :span="8">
+            <el-form-item label="璐熻矗浜�" prop="responsibleusername">
+              <el-input
+                v-model="form.responsibleusername"
+                :readonly="!isEdit"
+              />
+            </el-form-item>
+          </el-col>
+          <el-col :span="8">
+            <el-form-item label="璁板綍鐘舵��" prop="recordstate">
+              <el-tag :type="getStatusTag(form.recordstate)">
+                {{ getStatusText(form.recordstate) }}
+              </el-tag>
             </el-form-item>
           </el-col>
         </el-row>
@@ -63,7 +169,7 @@
     <el-card class="attachment-card">
       <div slot="header" class="clearfix">
         <span class="detail-title">姝讳骸鍒ゅ畾璇勪及琛ㄩ檮浠�</span>
-        <el-button
+        <!-- <el-button
           v-if="isEdit"
           type="primary"
           size="mini"
@@ -71,7 +177,7 @@
           :loading="uploadLoading"
         >
           涓婁紶闄勪欢
-        </el-button>
+        </el-button> -->
       </div>
 
       <!-- 闄勪欢绫诲瀷閫夐」鍗� -->
@@ -118,7 +224,9 @@
 
               <el-table-column label="鏂囦欢绫诲瀷" width="100" align="center">
                 <template slot-scope="scope">
-                  <el-tag size="small">{{ getFileType(scope.row.fileName) }}</el-tag>
+                  <el-tag size="small">{{
+                    getFileType(scope.row.fileName)
+                  }}</el-tag>
                 </template>
               </el-table-column>
 
@@ -140,11 +248,7 @@
                 </template>
               </el-table-column>
 
-              <el-table-column
-                label="鎿嶄綔"
-                width="180"
-                align="center"
-              >
+              <el-table-column label="鎿嶄綔" width="180" align="center">
                 <template slot-scope="scope">
                   <el-button
                     size="mini"
@@ -177,7 +281,10 @@
               v-if="getAttachmentsByType(type.value).length === 0"
               class="empty-attachment"
             >
-              <el-empty description="鏆傛棤璇勪及琛ㄩ檮浠�" :image-size="80"></el-empty>
+              <el-empty
+                description="鏆傛棤璇勪及琛ㄩ檮浠�"
+                :image-size="80"
+              ></el-empty>
             </div>
           </div>
         </el-tab-pane>
@@ -195,16 +302,20 @@
         ref="uploadRef"
         class="upload-demo"
         drag
-        action="#"
+        :action="uploadAction"
+        :headers="headers"
         multiple
         :file-list="tempFileList"
         :before-upload="beforeUpload"
         :on-change="handleFileChange"
         :on-remove="handleTempRemove"
+        :on-success="handleUploadSuccess"
         :auto-upload="false"
       >
         <i class="el-icon-upload"></i>
-        <div class="el-upload__text">灏嗚瘎浼拌〃鏂囦欢鎷栧埌姝ゅ锛屾垨<em>鐐瑰嚮涓婁紶</em></div>
+        <div class="el-upload__text">
+          灏嗚瘎浼拌〃鏂囦欢鎷栧埌姝ゅ锛屾垨<em>鐐瑰嚮涓婁紶</em>
+        </div>
         <div class="el-upload__tip" slot="tip">
           鏀寔涓婁紶pdf銆乯pg銆乸ng銆乨oc銆乨ocx銆亁ls銆亁lsx鏍煎紡鏂囦欢锛屽崟涓枃浠朵笉瓒呰繃10MB
         </div>
@@ -226,10 +337,17 @@
 </template>
 
 <script>
-import { getDeathJudgmentDetail, updateDeathJudgment } from "./api/mockDeathJudgmentApi";
+import { deathinfoedit, queryDathInfoBaseInfo } from "@/api/businessApi";
+import { getToken } from "@/utils/auth";
 
 export default {
   name: "DeathJudgmentDetail",
+  props: {
+    infoid: {
+      type: String,
+      default: true
+    }
+  },
   data() {
     return {
       // 鏄惁缂栬緫妯″紡
@@ -239,31 +357,39 @@
       // 琛ㄥ崟鏁版嵁
       form: {
         id: undefined,
-        hospitalNo: "",
-        donorName: "",
-        gender: "",
+        infoid: undefined,
+        donorno: "",
+        name: "",
+        sex: "",
         age: "",
-        diagnosis: "",
-        deathReason: "",
-        deathTime: "",
-        judgmentDoctor: "",
-        judgmentDescription: "",
-        registrant: "",
-        registrationTime: ""
+        diagnosisname: "",
+        deathreason: "",
+        deathtime: "",
+        deathjudgedocto: "",
+        deathjudgedoctt: "",
+        gainhospitalno: "",
+        gainhospitalname: "",
+        isspendremember: 0,
+        isrestoreremains: 0,
+        rememberannex: "",
+        responsibleuserid: "",
+        responsibleusername: "",
+        recordstate: "0",
+        judgmentDescription: ""
       },
       // 琛ㄥ崟楠岃瘉瑙勫垯
       rules: {
-        donorName: [
+        name: [
           { required: true, message: "鎹愮尞鑰呭鍚嶄笉鑳戒负绌�", trigger: "blur" }
         ],
-        deathReason: [
+        deathreason: [
           { required: true, message: "姝讳骸鍘熷洜涓嶈兘涓虹┖", trigger: "change" }
         ],
-        deathTime: [
+        deathtime: [
           { required: true, message: "姝讳骸鏃堕棿涓嶈兘涓虹┖", trigger: "change" }
         ],
-        judgmentDoctor: [
-          { required: true, message: "鍒ゅ畾鍖荤敓涓嶈兘涓虹┖", trigger: "blur" }
+        deathjudgedocto: [
+          { required: true, message: "鍒ゅ畾鍖荤敓涓�涓嶈兘涓虹┖", trigger: "blur" }
         ]
       },
       // 闄勪欢鐩稿叧鏁版嵁
@@ -273,7 +399,10 @@
       uploadLoading: false,
       tempFileList: [],
       currentUploadType: "",
-
+      uploadAction: process.env.VUE_APP_BASE_API + "/common/upload",
+      headers: {
+        Authorization: "Bearer " + getToken()
+      },
       // 璇勪及琛ㄧ被鍨嬪畾涔�
       attachmentTypes: [
         { value: "1", label: "鑴戞浜″垽瀹氳〃" },
@@ -298,57 +427,89 @@
     }
   },
   created() {
-    const id = this.$route.query.id;
-    this.isEdit = this.$route.path.includes('/edit') || this.$route.path.includes('/add');
-    if (id && !this.$route.path.includes('/add')) {
-      this.getDetail(id);
-    } else if (this.$route.path.includes('/add')) {
-      this.generateHospitalNo();
-    }
+    this.getDetail(this.infoid);
     this.getAttachmentList();
   },
   methods: {
-    // 鐢熸垚妗堜緥缂栧彿
-    generateHospitalNo() {
-      // 妯℃嫙鐢熸垚妗堜緥缂栧彿锛欴 + 鏃堕棿鎴冲悗6浣�
+    // 鐢熸垚鎹愮尞鑰呯紪鍙�
+    generateDonorNo() {
       const timestamp = Date.now().toString();
-      this.form.hospitalNo = 'D' + timestamp.slice(-6);
+      this.form.donorno = "DONOR" + timestamp.slice(-8);
     },
     // 鑾峰彇璇︽儏
-    getDetail(id) {
-      getDeathJudgmentDetail(id).then(response => {
-        if (response.code === 200) {
-          this.form = response.data;
+    async getDetail(id) {
+      try {
+        const response = await queryDathInfoBaseInfo({ infoid: id });
+        let realData = {};
+
+        if (response && response.data) {
+          realData = response.data[0];
+        } else if (response) {
+          realData = response;
         }
-      });
+
+        // 鏄犲皠瀛楁鍒拌〃鍗�
+        this.form = {
+          ...this.form,
+          ...realData,
+          // 纭繚鏁板�肩被鍨嬪瓧娈垫纭浆鎹�
+          isspendremember: realData.isspendremember
+            ? parseInt(realData.isspendremember)
+            : 0,
+          isrestoreremains: realData.isrestoreremains
+            ? parseInt(realData.isrestoreremains)
+            : 0
+        };
+
+        // 瑙f瀽闄勪欢淇℃伅
+        if (realData.rememberannex) {
+          this.parseAttachmentData(realData.rememberannex);
+        }
+      } catch (error) {
+        console.error("鑾峰彇姝讳骸鍒ゅ畾璇︽儏澶辫触:", error);
+        this.$message.error("鏁版嵁鍔犺浇澶辫触");
+      }
+    },
+    // 瑙f瀽闄勪欢鏁版嵁
+    parseAttachmentData(attachmentJson) {
+      try {
+        if (attachmentJson) {
+          const attachments = JSON.parse(attachmentJson);
+          if (Array.isArray(attachments)) {
+            this.attachmentList = attachments;
+          }
+        }
+      } catch (error) {
+        console.error("瑙f瀽闄勪欢鏁版嵁澶辫触:", error);
+      }
+    },
+    // 鏋勫缓闄勪欢JSON鏁版嵁
+    buildAttachmentJson() {
+      return JSON.stringify(this.attachmentList);
+    },
+    // 鑾峰彇鐘舵�佹爣绛炬牱寮�
+    getStatusTag(status) {
+      const statusMap = {
+        "0": "warning", // 缁存姢涓�
+        "1": "success", // 宸插畬鎴�
+        "99": "danger" // 宸茬粓姝�
+      };
+      return statusMap[status] || "info";
+    },
+    // 鑾峰彇鐘舵�佹枃鏈�
+    getStatusText(status) {
+      const textMap = {
+        "0": "缁存姢涓�",
+        "1": "宸插畬鎴�",
+        "99": "宸茬粓姝�"
+      };
+      return textMap[status] || "鏈煡鐘舵��";
     },
     // 鑾峰彇闄勪欢鍒楄〃
     getAttachmentList() {
       this.attachmentLoading = true;
-      // 妯℃嫙闄勪欢鏁版嵁 - 瀹為檯椤圭洰涓粠鎺ュ彛鑾峰彇
+      // 瀹為檯椤圭洰涓粠鎺ュ彛鑾峰彇闄勪欢鏁版嵁
       setTimeout(() => {
-        this.attachmentList = [
-          {
-            id: 1,
-            type: "1",
-            typeName: "鑴戞浜″垽瀹氳〃",
-            fileName: "鑴戞浜″垽瀹氳〃_202512001.pdf",
-            fileSize: 2548321,
-            uploadTime: "2025-12-01 10:30:00",
-            uploader: "寮犲尰鐢�",
-            fileUrl: "/attachments/brain_death_1.pdf"
-          },
-          {
-            id: 2,
-            type: "2",
-            typeName: "鑴戠數鍥捐瘎浼拌〃",
-            fileName: "鑴戠數鍥捐瘎浼拌〃_202512001.docx",
-            fileSize: 512345,
-            uploadTime: "2025-12-01 14:20:00",
-            uploader: "鏉庡尰鐢�",
-            fileUrl: "/attachments/eeg_1.docx"
-          }
-        ];
         this.attachmentLoading = false;
       }, 500);
     },
@@ -358,16 +519,19 @@
     },
     // 鑾峰彇鏂囦欢绫诲瀷
     getFileType(fileName) {
-      const ext = fileName.split('.').pop().toLowerCase();
+      const ext = fileName
+        .split(".")
+        .pop()
+        .toLowerCase();
       const typeMap = {
-        'pdf': 'PDF',
-        'doc': 'DOC',
-        'docx': 'DOCX',
-        'xls': 'XLS',
-        'xlsx': 'XLSX',
-        'jpg': 'JPG',
-        'jpeg': 'JPEG',
-        'png': 'PNG'
+        pdf: "PDF",
+        doc: "DOC",
+        docx: "DOCX",
+        xls: "XLS",
+        xlsx: "XLSX",
+        jpg: "JPG",
+        jpeg: "JPEG",
+        png: "PNG"
       };
       return typeMap[ext] || ext.toUpperCase();
     },
@@ -385,36 +549,37 @@
     // 涓婁紶鍓嶆牎楠�
     beforeUpload(file) {
       const allowedTypes = [
-        'application/pdf',
-        'image/jpeg',
-        'image/png',
-        'application/msword',
-        'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
-        'application/vnd.ms-excel',
-        'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
+        "application/pdf",
+        "image/jpeg",
+        "image/png",
+        "application/msword",
+        "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
+        "application/vnd.ms-excel",
+        "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
       ];
 
       const maxSize = 10 * 1024 * 1024; // 10MB
 
-      // 鏍¢獙鏂囦欢绫诲瀷
-      const isTypeOk = allowedTypes.includes(file.type) ||
-                      file.name.endsWith('.pdf') ||
-                      file.name.endsWith('.jpg') ||
-                      file.name.endsWith('.jpeg') ||
-                      file.name.endsWith('.png') ||
-                      file.name.endsWith('.doc') ||
-                      file.name.endsWith('.docx') ||
-                      file.name.endsWith('.xls') ||
-                      file.name.endsWith('.xlsx');
+      const isTypeOk =
+        allowedTypes.includes(file.type) ||
+        file.name.endsWith(".pdf") ||
+        file.name.endsWith(".jpg") ||
+        file.name.endsWith(".jpeg") ||
+        file.name.endsWith(".png") ||
+        file.name.endsWith(".doc") ||
+        file.name.endsWith(".docx") ||
+        file.name.endsWith(".xls") ||
+        file.name.endsWith(".xlsx");
 
       if (!isTypeOk) {
-        this.$message.error('鏂囦欢鏍煎紡涓嶆敮鎸侊紝璇蜂笂浼爌df銆乯pg銆乸ng銆乨oc銆乨ocx銆亁ls鎴杧lsx鏍煎紡鏂囦欢');
+        this.$message.error(
+          "鏂囦欢鏍煎紡涓嶆敮鎸侊紝璇蜂笂浼爌df銆乯pg銆乸ng銆乨oc銆乨ocx銆亁ls鎴杧lsx鏍煎紡鏂囦欢"
+        );
         return false;
       }
 
-      // 鏍¢獙鏂囦欢澶у皬
       if (file.size > maxSize) {
-        this.$message.error('鏂囦欢澶у皬涓嶈兘瓒呰繃10MB');
+        this.$message.error("鏂囦欢澶у皬涓嶈兘瓒呰繃10MB");
         return false;
       }
 
@@ -428,17 +593,11 @@
     handleTempRemove(file, fileList) {
       this.tempFileList = fileList;
     },
-    // 鎻愪氦涓婁紶
-    async submitUpload() {
-      if (this.tempFileList.length === 0) {
-        this.$message.warning('璇峰厛閫夋嫨瑕佷笂浼犵殑鏂囦欢');
-        return;
-      }
-
-      this.uploadLoading = true;
-
-      try {
-        // 妯℃嫙涓婁紶杩囩▼ - 瀹為檯椤圭洰涓皟鐢ㄤ笂浼犳帴鍙�
+    /** 涓婁紶鎴愬姛澶勭悊 */
+    handleUploadSuccess(response, file, fileList) {
+      if (response.code === 200) {
+        file.url = response.data || response.url;
+        this.$message.success("鏂囦欢涓婁紶鎴愬姛");
         for (const file of this.tempFileList) {
           const newAttachment = {
             id: Date.now() + Math.random(),
@@ -447,101 +606,170 @@
             fileName: file.name,
             fileSize: file.size,
             uploadTime: new Date().toISOString(),
-            uploader: '褰撳墠鐢ㄦ埛',
-            fileUrl: URL.createObjectURL(file.raw)
+            uploader: "褰撳墠鐢ㄦ埛",
+            fileUrl: file.url
           };
 
           this.attachmentList.push(newAttachment);
         }
 
-        this.$message.success('鏂囦欢涓婁紶鎴愬姛');
+        // 鏇存柊闄勪欢JSON鏁版嵁鍒拌〃鍗�
+        this.form.rememberannex = this.buildAttachmentJson();
+
+        this.$message.success("鏂囦欢涓婁紶鎴愬姛");
         this.uploadDialogVisible = false;
-        this.tempFileList = [];
-      } catch (error) {
-        this.$message.error('鏂囦欢涓婁紶澶辫触');
-        console.error('涓婁紶澶辫触:', error);
-      } finally {
         this.uploadLoading = false;
+        this.tempFileList = [];
+      } else {
+        this.$message.error(response.msg || "鏂囦欢涓婁紶澶辫触");
       }
+    },
+    // 鎻愪氦涓婁紶
+    async submitUpload() {
+      if (this.tempFileList.length === 0) {
+        this.$message.warning("璇峰厛閫夋嫨瑕佷笂浼犵殑鏂囦欢");
+        return;
+      }
+      this.$refs.uploadRef.submit();
+      this.uploadLoading = true;
+
+      // try {
+      //   for (const file of this.tempFileList) {
+      //     const newAttachment = {
+      //       id: Date.now() + Math.random(),
+      //       type: this.currentUploadType,
+      //       typeName: this.getCurrentTypeLabel,
+      //       fileName: file.name,
+      //       fileSize: file.size,
+      //       uploadTime: new Date().toISOString(),
+      //       uploader: "褰撳墠鐢ㄦ埛",
+      //       fileUrl: URL.createObjectURL(file.raw)
+      //     };
+
+      //     this.attachmentList.push(newAttachment);
+      //   }
+
+      //   // 鏇存柊闄勪欢JSON鏁版嵁鍒拌〃鍗�
+      //   this.form.rememberannex = this.buildAttachmentJson();
+
+      //   this.$message.success("鏂囦欢涓婁紶鎴愬姛");
+      //   this.uploadDialogVisible = false;
+      //   this.tempFileList = [];
+      // } catch (error) {
+      //   this.$message.error("鏂囦欢涓婁紶澶辫触");
+      //   console.error("涓婁紶澶辫触:", error);
+      // } finally {
+      //   this.uploadLoading = false;
+      // }
     },
     // 鍒犻櫎闄勪欢
     handleRemoveAttachment(attachment) {
-      this.$confirm('纭畾瑕佸垹闄よ繖涓瘎浼拌〃闄勪欢鍚楋紵', '鎻愮ず', {
-        confirmButtonText: '纭畾',
-        cancelButtonText: '鍙栨秷',
-        type: 'warning'
-      }).then(() => {
-        const index = this.attachmentList.findIndex(item => item.id === attachment.id);
-        if (index !== -1) {
-          this.attachmentList.splice(index, 1);
-          this.$message.success('璇勪及琛ㄥ垹闄ゆ垚鍔�');
-        }
-      }).catch(() => {});
+      this.$confirm("纭畾瑕佸垹闄よ繖涓瘎浼拌〃闄勪欢鍚楋紵", "鎻愮ず", {
+        confirmButtonText: "纭畾",
+        cancelButtonText: "鍙栨秷",
+        type: "warning"
+      })
+        .then(() => {
+          const index = this.attachmentList.findIndex(
+            item => item.id === attachment.id
+          );
+          if (index !== -1) {
+            this.attachmentList.splice(index, 1);
+            // 鏇存柊闄勪欢JSON鏁版嵁鍒拌〃鍗�
+            this.form.rememberannex = this.buildAttachmentJson();
+            this.$message.success("璇勪及琛ㄥ垹闄ゆ垚鍔�");
+          }
+        })
+        .catch(() => {});
     },
     // 棰勮闄勪欢
     handlePreview(attachment) {
-      if (attachment.fileName.endsWith('.pdf')) {
-        window.open(attachment.fileUrl, '_blank');
+      if (attachment.fileName.endsWith(".pdf")) {
+        window.open(attachment.fileUrl, "_blank");
       } else if (attachment.fileName.match(/\.(jpg|jpeg|png)$/i)) {
-        this.$alert(`<img src="${attachment.fileUrl}" style="max-width: 100%;" alt="${attachment.fileName}">`,
-          '鍥剧墖棰勮', {
+        this.$alert(
+          `<img src="${attachment.fileUrl}" style="max-width: 100%;" alt="${attachment.fileName}">`,
+          "鍥剧墖棰勮",
+          {
             dangerouslyUseHTMLString: true,
-            customClass: 'image-preview-dialog'
-          });
+            customClass: "image-preview-dialog"
+          }
+        );
       } else {
-        this.$message.info('璇ユ枃浠剁被鍨嬫殏涓嶆敮鎸佸湪绾块瑙堬紝璇蜂笅杞藉悗鏌ョ湅');
+        this.$message.info("璇ユ枃浠剁被鍨嬫殏涓嶆敮鎸佸湪绾块瑙堬紝璇蜂笅杞藉悗鏌ョ湅");
       }
     },
     // 涓嬭浇闄勪欢
     handleDownload(attachment) {
-      // 瀹為檯椤圭洰涓皟鐢ㄤ笅杞芥帴鍙�
-      const link = document.createElement('a');
+      const link = document.createElement("a");
       link.href = attachment.fileUrl;
       link.download = attachment.fileName;
       link.click();
       this.$message.success(`寮�濮嬩笅杞�: ${attachment.fileName}`);
     },
+    // 缂栬緫淇℃伅
+    handleEdit() {
+      this.isEdit = true;
+    },
     // 淇濆瓨淇℃伅
-    handleSave() {
-      this.$refs.form.validate(valid => {
+    async handleSave() {
+      this.$refs.form.validate(async valid => {
         if (valid) {
           this.saveLoading = true;
 
-          // 妯℃嫙淇濆瓨杩囩▼
-          updateDeathJudgment(this.form)
-            .then(response => {
-              if (response.code === 200) {
-                this.$message.success('淇濆瓨鎴愬姛');
-                if (this.$route.path.includes('/add')) {
-                  this.$router.push('/case/deathJudgment');
-                } else {
-                  this.isEdit = false;
-                }
+          try {
+            // 鏋勫缓鎻愪氦鏁版嵁
+            const submitData = {
+              ...this.form,
+              // 纭繚闄勪欢鏁版嵁鏈�鏂�
+              rememberannex: this.buildAttachmentJson()
+            };
+
+            const response = await deathinfoedit(submitData);
+
+            if (response.code === 200) {
+              this.$message.success("淇濆瓨鎴愬姛");
+              this.isEdit = false;
+
+              if (this.$route.path.includes("/add")) {
+                this.$router.push("/case/deathJudgment");
               }
-            })
-            .catch(error => {
-              console.error('淇濆瓨澶辫触:', error);
-              this.$message.error('淇濆瓨澶辫触');
-            })
-            .finally(() => {
-              this.saveLoading = false;
-            });
+            } else {
+              this.$message.error(response.message || "淇濆瓨澶辫触");
+            }
+          } catch (error) {
+            console.error("淇濆瓨澶辫触:", error);
+            this.$message.error("淇濆瓨澶辫触");
+          } finally {
+            this.saveLoading = false;
+          }
         }
       });
     },
     // 鏂囦欢澶у皬鏍煎紡鍖�
     formatFileSize(size) {
-      if (size === 0) return '0 B';
+      if (size === 0) return "0 B";
       const k = 1024;
-      const sizes = ['B', 'KB', 'MB', 'GB'];
+      const sizes = ["B", "KB", "MB", "GB"];
       const i = Math.floor(Math.log(size) / Math.log(k));
-      return parseFloat((size / Math.pow(k, i)).toFixed(2)) + ' ' + sizes[i];
+      return parseFloat((size / Math.pow(k, i)).toFixed(2)) + " " + sizes[i];
     },
     // 鏃堕棿鏍煎紡鍖�
     parseTime(time) {
-      if (!time) return '';
+      if (!time) return "";
       const date = new Date(time);
-      return `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')} ${date.getHours().toString().padStart(2, '0')}:${date.getMinutes().toString().padStart(2, '0')}`;
+      return `${date.getFullYear()}-${(date.getMonth() + 1)
+        .toString()
+        .padStart(2, "0")}-${date
+        .getDate()
+        .toString()
+        .padStart(2, "0")} ${date
+        .getHours()
+        .toString()
+        .padStart(2, "0")}:${date
+        .getMinutes()
+        .toString()
+        .padStart(2, "0")}`;
     }
   }
 };

--
Gitblit v1.9.3