From 28c3bcfbacc7af60e93210ba654fd681002a6849 Mon Sep 17 00:00:00 2001
From: lyh <925863403@qq.com>
Date: 星期四, 14 八月 2025 15:59:09 +0800
Subject: [PATCH] 加流程节点  维修工单添加 领取按钮 领取后 生成维修开始时间  提交后 生成维修结束时间 计算 维修时长  故障时长

---
 src/views/eam/repair/EamRepairOrderList.vue |   55 +++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 51 insertions(+), 4 deletions(-)

diff --git a/src/views/eam/repair/EamRepairOrderList.vue b/src/views/eam/repair/EamRepairOrderList.vue
index 3ba12e2..e1913f3 100644
--- a/src/views/eam/repair/EamRepairOrderList.vue
+++ b/src/views/eam/repair/EamRepairOrderList.vue
@@ -35,6 +35,7 @@
 
     <!-- 鎿嶄綔鎸夐挳鍖哄煙 -->
     <div class="table-operator" v-if="isDisplayOperation">
+      <a-button type="primary" icon="download" @click="handleExportXls('缁翠慨宸ュ崟鍙拌处')">瀵煎嚭</a-button>
       <a-dropdown :disabled="selectedRowKeys.length == 0">
         <a-menu slot="overlay">
           <a-menu-item key="1" @click="handleBatchSubmit">
@@ -62,9 +63,12 @@
                :scroll="{x:'max-content'}">
         <span slot="action" slot-scope="text, record">
           <template v-if="record.repairStatus=='PENDING_REPAIR'||record.repairStatus=='UNDER_MAINTENANCE' ||record.repairStatus=='REJECTED'">
-             <a @click="handleFillIn(record)">濉姤</a>
-             <a-divider type="vertical"/>
-             <a-popconfirm title="纭畾鎻愪氦鍚�?" @confirm="() => handleSubmit(record.id)">
+            <a-popconfirm v-if="record.claimStatus=='0' || record.claimStatus==null " title="纭畾鎻愪氦鍚�?" @confirm="() => handleClaim(record.id)">
+               <a>棰嗗彇</a>
+             </a-popconfirm>
+             <a v-if="record.claimStatus=='1'"  @click="handleFillIn(record)">缁翠慨</a>
+             <a-divider v-if="record.claimStatus=='1'"  type="vertical"/>
+             <a-popconfirm v-if="record.claimStatus=='1'" title="纭畾鎻愪氦鍚�?" @confirm="() => handleSubmit(record.id)">
                <a>鎻愪氦</a>
              </a-popconfirm>
           </template>
@@ -163,6 +167,12 @@
             fixed: 'left'
           },
           {
+            title: '棰嗗彇鐘舵��',
+            align: 'center',
+            dataIndex: 'claimStatus_dictText',
+            fixed: 'left'
+          },
+          {
             title: '宸ュ崟鍙�',
             align: 'center',
             dataIndex: 'repairCode',
@@ -187,6 +197,18 @@
             title: '缁翠慨缁撴潫鏃堕棿',
             align: 'center',
             dataIndex: 'actualEndTime',
+            width: 200
+          },
+          {
+            title: '缁翠慨鏃堕暱',
+            align: 'center',
+            dataIndex: 'repairDuration',
+            width: 200
+          },
+          {
+            title: '鏁呴殰鏃堕暱',
+            align: 'center',
+            dataIndex: 'faultDuration',
             width: 200
           },
           {
@@ -246,8 +268,10 @@
         url: {
           list: '/eam/eamRepairOrder/list',
           submit: '/eam/eamRepairOrder/submit',
+          claim: '/eam/eamRepairOrder/claim',
           delete: '/eam/eamRepairOrder/delete',
-          deleteBatch: '/eam/eamRepairOrder/deleteBatch'
+          deleteBatch: '/eam/eamRepairOrder/deleteBatch',
+          exportXlsUrl: "eam/eamRepairOrder/exportXls",
         }
       }
     },
@@ -300,6 +324,29 @@
           })
       },
 
+      /**
+       * 鐐瑰嚮棰嗗彇鏃惰Е鍙�
+       * @param id
+       */
+      handleClaim(id){
+        this.loading = true
+        getAction(this.url.claim, { id })
+          .then(res => {
+            if (res.success) {
+              this.$notification.success({
+                message: '娑堟伅',
+                description: res.message
+              })
+              this.loadData()
+            } else {
+              this.$notification.warning({
+                message: '娑堟伅',
+                description: res.message
+              })
+              this.loading = false
+            }
+          })
+      },
       // 鎵归噺鎻愪氦鏃惰Е鍙�
       handleBatchSubmit() {
 

--
Gitblit v1.9.3