From 568e38a95cb6fb20fe16b53d17f610aefc6f744f Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期四, 09 十月 2025 18:29:29 +0800
Subject: [PATCH] 钉钉通知 与钥匙柜开发

---
 admin/src/views/task/visReportDetail.vue |   79 +++++++++++++++++++++++++++++++++------
 1 files changed, 66 insertions(+), 13 deletions(-)

diff --git a/admin/src/views/task/visReportDetail.vue b/admin/src/views/task/visReportDetail.vue
index 2ef8471..83c8ce0 100644
--- a/admin/src/views/task/visReportDetail.vue
+++ b/admin/src/views/task/visReportDetail.vue
@@ -1,13 +1,19 @@
 <template>
-  <GlobalWindow :title="title" :visible.sync="isShowModal" @confirm="confirm">
+  <GlobalWindow :title="title" :visible.sync="isShowModal" @close="close" @confirm="confirm">
     <div class="modal_wrap">
       <div class="modal_content">
         <div class="header">
+          <img v-if="info.businessStatus == '3'" class="head_bg" src="@/assets/task/bg_shenhe_fail@2x.png" alt="">
+          <img v-else-if="info.businessStatus == '2'" class="head_bg" src="@/assets/task/bg_shenhe_pass@2x.png" alt="">
+          <img v-else-if="info.businessStatus == '4'" class="head_bg" src="@/assets/task/bg_shenhe_chexiao@2x.png"
+            alt="">
+          <img v-else class="head_bg" src="@/assets/task/bg_shenhe@2x.png" alt="">
           <div class="left">
             <div class="h1">{{ cateList[type] }}</div>
             <div class="time">鎻愪氦鏃堕棿锛歿{ info.createDate }}</div>
           </div>
-          <div class="right">{{ statusMap[info.status] }}</div>
+          <div class="right" :class="{ scs: info.businessStatus == '2', msg: info.businessStatus == '3' }">{{
+            statusMap[info.businessStatus] }}</div>
         </div>
         <div class="info">
           <div class="title">璁垮鎶ュ淇℃伅</div>
@@ -73,9 +79,9 @@
                   <div class="company">
                     {{ item.memberName }}
                     <div style="display: inline" v-if="item.statusInfo != null && item.statusInfo != ''">
-                      锛�<span class="status-green">{{
+                      锛�<span :class="{ padding: item.statusInfo == '澶勭悊涓�' || item.status == '1' }">{{
                         item.statusInfo || ""
-                        }}</span>锛�
+                      }}</span>锛�
                     </div>
                   </div>
                 </div>
@@ -88,7 +94,7 @@
             " class="remark">
               {{ item.checkInfo || "" }}
             </div>
-            <div v-if="item.approveType == 1" class="childList">
+            <div v-if="item.approveType == 0 || item.type == 1 || item.approveType == 1" class="childList">
               <div class="m_content company" v-for="item1 in item.approveList" :key="item1.id">
                 <img v-if="item1.faceImg != null && item1.faceImg != ''" :src="item1.faceImg" class="avatar" alt="" />
                 <img v-if="item1.faceImg == null || item1.faceImg == ''" src="@/assets/avatar/man.png" class="avatar"
@@ -112,7 +118,7 @@
         info.approveDateVO.canBeApproved != null &&
         info.approveDateVO.canBeApproved == 1
       ">鎷掔粷</el-button>
-      <el-button @click="isShowModal = false">杩斿洖</el-button>
+      <el-button @click="close">杩斿洖</el-button>
     </template>
     <!--  鍚屾剰/鎷掔粷 -->
     <el-dialog append-to-body :title="apprTitle" :visible.sync="isShowAppr" width="480px">
@@ -184,10 +190,10 @@
         checkInfo: [{ required: true, message: '璇疯緭鍏�', trigger: 'blur' }]
       },
       statusMap: {
-        0: '寰呭鎵�',
-        1: '瀹℃壒涓�',
-        2: '瀹℃壒閫氳繃',
-        3: '瀹℃壒鏈�氳繃',
+        0: '寰呭鏍�',
+        1: '澶勭悊涓�',
+        2: '宸查�氳繃',
+        3: '宸叉嫆缁�',
         4: '宸插彇娑�',
         5: '浠栦汉鎴栫',
         6: '浠栦汉鎷掔粷'
@@ -220,6 +226,8 @@
                 this.subLoading = false
                 this.$tip.apiSuccess('澶勭悊鎴愬姛')
                 this.getDetail()
+                this.$emit('success')
+                this.$emit('close')
                 this.isShowAppr = false
               })
               .finally(() => {
@@ -228,10 +236,26 @@
           })
       })
     },
+    close() {
+      this.isShowModal = false
+      this.$emit('close')
+    },
     getDetail() {
       const { id } = this
       getVisitedReDetail({ id }).then(res => {
         this.info = res
+        if (this.info.approveDateVO && this.info.approveDateVO.approveList.length > 0) {
+          this.info.approveDateVO.approveList.forEach(item => {
+            if (item.approveList && item.approveList.length == 1 && item.type !== 1) {
+              item.title = item.approveList[0].title
+              item.faceImg = item.approveList[0].faceImg
+              item.memberName = item.approveList[0].memberName
+              item.statusInfo = item.approveList[0].statusInfo
+              item.status = item.approveList[0].status
+              item.approveList = []
+            }
+          })
+        }
       })
     },
     handleAppr(val) {
@@ -253,6 +277,8 @@
 </script>
 
 <style lang="scss" scoped>
+@import "@/assets/style/variables.scss";
+
 .upload_box {
   width: 84px;
   height: 84px;
@@ -335,7 +361,16 @@
       padding: 20px 30px;
       margin: 0 -30px;
       border-radius: 8px 8px 0 0;
-      background: linear-gradient(to right, #f2f6fe, #cadffa);
+      position: relative;
+
+      .head_bg {
+        position: absolute;
+        width: 100%;
+        height: 100%;
+        left: 0;
+        top: 0;
+        z-index: 9;
+      }
 
       .h1 {
         font-weight: 600;
@@ -358,6 +393,16 @@
         background: #207ff7;
         box-shadow: 4px 4px 0px 0px rgba(32, 127, 247, 0.16);
         border-radius: 16px 0px 16px 0px;
+        position: relative;
+        z-index: 99;
+      }
+
+      .scs {
+        background-color: #00BA67;
+      }
+
+      .msg {
+        background-color: #ED4545;
       }
     }
 
@@ -405,7 +450,7 @@
           position: absolute;
           border-left: 2px dashed #cccccc;
           left: 31px;
-          height: calc(100% - 36px);
+          height: calc(100% - 30px);
           top: 49px;
         }
 
@@ -428,7 +473,7 @@
           color: #888888;
 
           .status {
-            color: #00ba67;
+            color: $primaryColor;
           }
         }
 
@@ -487,6 +532,14 @@
               align-content: center;
               margin-bottom: 6px;
 
+              .status {
+                color: #888888;
+              }
+
+              .padding {
+                color: $primaryColor;
+              }
+
               .name {
                 font-weight: 600;
                 font-size: 16px;

--
Gitblit v1.9.3