From 93ceebf32acec9b4e52b6155408ba92ae151ecd0 Mon Sep 17 00:00:00 2001
From: liukangdong <898885815@qq.com>
Date: 星期六, 08 二月 2025 17:27:40 +0800
Subject: [PATCH] ll
---
 admin/src/views/contract/components/contractDetail.vue |   54 +++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 43 insertions(+), 11 deletions(-)
diff --git a/admin/src/views/contract/components/contractDetail.vue b/admin/src/views/contract/components/contractDetail.vue
index 730f2c2..5683288 100644
--- a/admin/src/views/contract/components/contractDetail.vue
+++ b/admin/src/views/contract/components/contractDetail.vue
@@ -16,7 +16,11 @@
           <el-tag type="info" v-if="info.status === 3">閫�绉熺粨绠椾腑</el-tag>
           <el-tag type="info" v-if="info.status === 4">宸查��绉�</el-tag>
         </div>
-        <el-button plain type="danger" v-if="[0, 1, 2].includes(info.status)" @click="refund">閫�绉�</el-button>
+        <div>
+          <el-button type="primary" @click="$refs.pendingBills.open('寰呭鐞嗚处鍗�', id)" v-if="info.status === 3">鏌ョ湅寰呭鐞嗚处鍗�</el-button>
+          <el-button @click="$refs.terminationAgreement.open('閫�绉熷崗璁�', id)" v-if="[3,4].includes(info.status)">鏌ョ湅閫�绉熷崗璁�</el-button>
+          <el-button plain type="danger" v-if="[0, 1, 2].includes(info.status)" @click="refund">閫�绉�</el-button>
+        </div>
       </div>
       <div class="remark" v-if="info">{{info.remark}}</div>
       <div class="remark" v-if="info && info.status === 3">{{info.btRemark}}</div>
@@ -113,12 +117,17 @@
         </div>
         <div class="item">
           <div class="la">鍏嶇鏈�</div>
-          <div class="val">{{ info.zlFreeStartDate }} ~ {{ info.zlFreeEndDate }}</div>
+          <div class="val" v-if="info.zlFreeStartDate && info.zlFreeEndDate">
+            {{ info.zlFreeStartDate }} ~ {{ info.zlFreeEndDate }}
+          </div>
+          <div class="val" v-else>
+            -
+          </div>
         </div>
       </div>
       <el-table :data="info.zlDetailList" stripe style="margin-bottom: 20px;" v-if="info.type === 2 || info.type === 0">
-        <el-table-column prop="startDate" label="寮�濮嬫棩鏈�" min-width="100" show-overflow-tooltip />
-        <el-table-column prop="endDate" label="缁撴潫鏃ユ湡" min-width="100" show-overflow-tooltip />
+        <el-table-column prop="startDate" label="寮�濮嬫棩鏈�" :key="Date.now()" min-width="100" show-overflow-tooltip />
+        <el-table-column prop="endDate" label="缁撴潫鏃ユ湡" :key="Date.now()" min-width="100" show-overflow-tooltip />
         <el-table-column label="鍚堝悓鍗曚环" min-width="100" show-overflow-tooltip>
           <template slot-scope="{row}">
             {{row.price}} {{returnUnit(row.circleType)}}
@@ -126,7 +135,9 @@
         </el-table-column>
         <el-table-column label="浠樻鎻愬墠澶╂暟" min-width="100" show-overflow-tooltip>
           <template slot-scope="{row}">
-            {{row.advanceDays}}澶�
+            <template v-if="row.advanceDays">
+              {{row.advanceDays}}澶�
+            </template>
           </template>
         </el-table-column>
       </el-table>
@@ -149,8 +160,8 @@
         </div>
       </div>
       <el-table :data="info.wyDetailList" stripe style="margin-bottom: 20px;" v-if="info.type === 1 || info.type === 0">
-        <el-table-column prop="startDate" label="寮�濮嬫棩鏈�" min-width="100" show-overflow-tooltip />
-        <el-table-column prop="endDate" label="缁撴潫鏃ユ湡" min-width="100" show-overflow-tooltip />
+        <el-table-column prop="startDate" label="寮�濮嬫棩鏈�" :key="Date.now()" min-width="100" show-overflow-tooltip />
+        <el-table-column prop="endDate" label="缁撴潫鏃ユ湡" :key="Date.now()" min-width="100" show-overflow-tooltip />
         <el-table-column label="鍚堝悓鍗曚环" min-width="100" show-overflow-tooltip>
           <template slot-scope="{row}">
             {{row.price}} {{returnUnit(row.circleType)}}
@@ -185,6 +196,13 @@
         border
         v-loading="loading"
         style="width: 100%">
+        <el-table-column
+          width="150"
+          label="璐﹀崟缂栧彿">
+          <template slot-scope="{row}">
+            <el-button type="text" @click="openBill(row.id)">{{row.code}}</el-button>
+          </template>
+        </el-table-column>
         <el-table-column
           label="璐圭敤绫诲瀷">
           <template slot-scope="{row}">
@@ -228,7 +246,7 @@
           label="璐﹀崟鏉ユ簮">
           <template slot-scope="{row}">
             <span v-if="row.type === 0">鍚堝悓璐﹀崟</span>
-            <span v-if="row.type === 1">鑷缓璐﹀崟</span>
+            <span v-else>鑷缓璐﹀崟</span>
           </template>
         </el-table-column>
         <el-table-column
@@ -312,6 +330,12 @@
     </div>
     <!--  閫�绉�  -->
     <TerminateLease ref="terminateLease" @success="getData" />
+    <!--  寰呭鐞嗚处鍗�  -->
+    <PendingBills ref="pendingBills" />
+    <!--  閫�绉熷崗璁�  -->
+    <TerminationAgreement ref="terminationAgreement" />
+    <!--  璐﹀崟璇︽儏  -->
+    <BullDetail ref="bullDetail" />
   </GlobalWindow>
 </template>
 
@@ -319,12 +343,18 @@
 import GlobalWindow from '@/components/common/GlobalWindow'
 import BaseOpera from '@/components/base/BaseOpera'
 import TerminateLease from './terminateLease'
+import PendingBills from './pendingBills'
+import TerminationAgreement from './terminationAgreement'
+import BullDetail from '../../finance/components/bullDetail'
 import { getById } from '@/api/contract'
 import { fetchList } from '@/api/bill'
 export default {
   components: {
     GlobalWindow,
-    TerminateLease
+    TerminateLease,
+    PendingBills,
+    TerminationAgreement,
+    BullDetail
   },
   extends: BaseOpera,
   data() {
@@ -338,7 +368,7 @@
       page: 1,
       total: 0,
       tableData: [],
-      
+
       loading: false
     }
   },
@@ -355,6 +385,9 @@
     },
     xiazai (url) {
       window.open(url)
+    },
+    openBill(id) {
+      this.$refs.bullDetail.open('璐﹀崟璇︽儏', id)
     },
     returnUnit (type) {
       switch (type) {
@@ -402,7 +435,6 @@
       })
     },
     changeType (e) {
-      console.log(e)
       this.type = e
       this.page = 1
       this.pageSize = 10
--
Gitblit v1.9.3