From 41d50b20c975faeaa9e5277bdcff13b5acecb575 Mon Sep 17 00:00:00 2001
From: qushaowei <qushaowei@163.com>
Date: 星期三, 13 十二月 2023 16:57:37 +0800
Subject: [PATCH] Merge branch 'master' of http://117.34.109.166:18448/r/vue_mdc_430 into develop

---
 src/views/mdc/base/modules/efficiencyPOReport/EfficiencyPOList.vue |  195 +++++++++++++++++++++++++++++++-----------------
 1 files changed, 124 insertions(+), 71 deletions(-)

diff --git a/src/views/mdc/base/modules/efficiencyPOReport/EfficiencyPOList.vue b/src/views/mdc/base/modules/efficiencyPOReport/EfficiencyPOList.vue
index d5c0b4a..6e8d49e 100644
--- a/src/views/mdc/base/modules/efficiencyPOReport/EfficiencyPOList.vue
+++ b/src/views/mdc/base/modules/efficiencyPOReport/EfficiencyPOList.vue
@@ -5,19 +5,26 @@
       <div class="table-page-search-wrapper">
         <a-form layout="inline" @keyup.enter.native="searchQuery">
           <a-row :gutter="24">
+            <a-col :md="4" :sm="4">
+              <a-form-item label="璁惧绫诲瀷">
+                <a-select placeholder="璇烽�夋嫨璁惧绫诲瀷" :triggerChange="true" v-model="queryParam.equipmentType" :allowClear="true">
+                  <a-select-option v-for='item in selectList' :key='item.id' :value='item.equipmentTypeName'>
+                    {{item.equipmentTypeName}}
+                  </a-select-option>
+                </a-select>
+              </a-form-item>
+            </a-col>
             <a-col :md="6" :sm="6">
               <a-form-item label="鏃堕棿">
                 <a-range-picker @change="dateParamChange" :disabledDate="disabledDate" format="YYYYMMDD" v-model="dates"/>
               </a-form-item>
             </a-col>
-            <a-col :lg="2" :md="3" :sm="3" :xs="3">
-              <a-button type="primary" @click="searchQuery" icon="search">鏌ヨ</a-button>
-            </a-col>
-            <a-col :lg="2"  :md="3" :sm="3" :xs="3">
-              <a-button type="primary" @click="searchReset" icon="reload">閲嶇疆</a-button>
-            </a-col>
-            <a-col :lg="2" :md="3" :sm="3" :xs="3">
-              <a-button type="primary" @click="exportExcel" icon="download">瀵煎嚭</a-button>
+            <a-col :md="14" :sm="14">
+              <a-space>
+                <a-button type="primary" @click="searchQuery" icon="search">鏌ヨ</a-button>
+                <a-button type="primary" @click="searchReset" icon="reload">閲嶇疆</a-button>
+                <a-button type="primary" @click="exportExcel" icon="download">瀵煎嚭</a-button>
+              </a-space>
             </a-col>
           </a-row>
           <a-row :gutter="24">
@@ -42,65 +49,73 @@
           </tr>
         </table>
       </div>
-      <div class="container" id="EfficiencyPO" style="margin-top: 20px;">
-        <div class="table2">
-          <table class="dataContent table" border="1" cellspacing="0" cellpadding="0" style="white-space: nowrap">
-            <thead>
-            <tr class="thead fixed equipname">
-              <th class="thgu dong1 name" rowspan="2" style="min-width: 50px; max-width: 50px;width: 50px;"></th>
-              <th  class="thgu dong2 name" rowspan="2" style="min-width: 50px; max-width: 50px;width: 50px;"></th>
-              <th  class="thgu dong3 name" rowspan="2" style="min-width: 50px; max-width: 50px;width: 50px;"></th>
-              <th class="thgu dong4 name" rowspan="2" style="min-width: 100px; max-width: 100px;width: 100px;">璁惧缂栧彿</th>
-              <th class="thgu dong5 name" rowspan="2" style="min-width: 150px; max-width: 150px;width: 150px;">璁惧鍚嶇О</th>
-              <th class="thgu dong6 name" rowspan="2" style="min-width: 100px; max-width: 100px;width: 100px;">璁惧绫诲瀷</th>
-              <!--<th rowspan="2">缁勫埆</th>-->
-              <template v-for="(tableHead, index) in tableHeads">
-                <th class="timeth" :colspan="checkedList.length">{{tableHead}}</th>
-              </template>
-            </tr>
-            <tr class="thead notfixed gudingth">
-              <template v-for="(tableHead, index) in tableHeads">
-                <th>寮�鍔ㄧ巼(%)</th>
-                <th v-if="checkedList.indexOf('kjl') > -1">寮�鏈虹巼(%)</th>
-                <th v-if="checkedList.indexOf('kjsj') > -1">寮�鏈烘椂闂�(s)</th>
-                <th v-if="checkedList.indexOf('jgsj') > -1">鍔犲伐鏃堕棿(s)</th>
-                <th v-if="checkedList.indexOf('djsj') > -1">寰呮満鏃堕棿(s)</th>
-                <th v-if="checkedList.indexOf('gjsj') > -1">鍏虫満鏃堕棿(s)</th>
-              </template>
-            </tr>
-            </thead>
-            <tbody>
-            <tr class="mathData" v-for="(item, index) in dataList">
-              <td  class="tdgu kaitou wenzi" :rowspan="item.level1span" :class="{hidden: item.level1dis,noExl:item.level1dis}"  v-show="!item.level1dis">{{item.level1}}</td>
-              <td  class="tdgu1 kaitou wenzi" :rowspan="item.level2span" :class="{hidden: item.level2dis,noExl:item.level2dis}"  v-show="!item.level2dis">{{item.level2}}</td>
-              <td  class="tdgu2 kaitou wenzi" :rowspan="item.level3span" :class="{hidden: item.level3dis,noExl:item.level3dis}"  v-show="!item.level3dis">{{item.level3}}</td>
-              <td  class="tdgu3  kaitou">{{item.equipmentId}}</td>
-              <td  class="tdgu4 kaitou">{{item.equipmentName}}</td>
-              <td  class="tdgu5 kaitou">{{item.equipmentType}}</td>
-              <!--<td>{{item.tierType}}</td>-->
-              <template v-for="(tableHead, index) in item.dataList">
-                <td :style="{background:tableHead.color }">{{tableHead.startRate | numFilter}}</td>
-                <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('kjl') > -1">
-                  {{tableHead.openRate | numFilter}}
-                </td>
-                <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('kjsj') > -1">
-                  {{tableHead.openLong}}
-                </td>
-                <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('jgsj') > -1">
-                  {{tableHead.processLong}}
-                </td>
-                <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('djsj') > -1">
-                  {{tableHead.waitLong}}
-                </td>
-                <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('gjsj') > -1">
-                  {{tableHead.closeLong}}
-                </td>
-              </template>
-            </tr>
-            </tbody>
-          </table>
+      <a-spin :spinning="spinning">
+        <div class="container" id="EfficiencyPO" style="margin-top: 20px;" >
+          <div class="table2">
+            <table class="dataContent table" border="1" cellspacing="0" cellpadding="0" style="white-space: nowrap" v-if="dataList.length>0">
+              <thead>
+              <tr class="thead fixed equipname">
+                <th class="thgu dong1 name" rowspan="2" style="min-width: 50px; max-width: 50px;width: 50px;">鍏徃</th>
+                <th  class="thgu dong2 name" rowspan="2" style="min-width: 50px; max-width: 50px;width: 50px;">杞﹂棿</th>
+                <th  class="thgu dong3 name" rowspan="2" style="min-width: 50px; max-width: 50px;width: 50px;">宸ユ</th>
+                <th class="thgu dong4 name" rowspan="2" style="min-width: 100px; max-width: 100px;width: 100px;">璁惧缂栧彿</th>
+                <th class="thgu dong5 name" rowspan="2" style="min-width: 162px; max-width: 162px;width: 162px;">璁惧鍚嶇О</th>
+                <th class="thgu dong6 name" rowspan="2" style="min-width: 100px; max-width: 100px;width: 100px;">璁惧绫诲瀷</th>
+                <!--<th rowspan="2">缁勫埆</th>-->
+                <template v-for="(tableHead, index) in tableHeads">
+                  <th class="timeth" :colspan="checkedList.length">{{tableHead}}</th>
+                </template>
+              </tr>
+              <tr class="thead notfixed gudingth">
+                <template v-for="(tableHead, index) in tableHeads">
+                  <th>寮�鍔ㄧ巼(%)</th>
+                  <th v-if="checkedList.indexOf('kjl') > -1">寮�鏈虹巼(%)</th>
+                  <th v-if="checkedList.indexOf('kjsj') > -1">寮�鏈烘椂闂�(灏忔椂)</th>
+                  <th v-if="checkedList.indexOf('jgsj') > -1">鍔犲伐鏃堕棿(灏忔椂)</th>
+                  <th v-if="checkedList.indexOf('djsj') > -1">寰呮満鏃堕棿(灏忔椂)</th>
+                  <th v-if="checkedList.indexOf('gjsj') > -1">鍏虫満鏃堕棿(灏忔椂)</th>
+                </template>
+              </tr>
+              </thead>
+              <tbody>
+              <tr class="mathData" v-for="(item, index) in dataList">
+                <template v-if="item.level1!=='鍚堣'&&item.level1!=='骞冲潎鍊�'">
+                  <td  class="tdgu kaitou wenzi" :rowspan="item.level1span" :class="{hidden: item.level1dis,noExl:item.level1dis}"  v-show="!item.level1dis">{{item.level1}}</td>
+                  <td  class="tdgu1 kaitou wenzi" :rowspan="item.level2span" :class="{hidden: item.level2dis,noExl:item.level2dis}"  v-show="!item.level2dis">{{item.level2}}</td>
+                  <td  class="tdgu2 kaitou wenzi" :rowspan="item.level3span" :class="{hidden: item.level3dis,noExl:item.level3dis}"  v-show="!item.level3dis">{{item.level3}}</td>
+                  <td  class="tdgu3  kaitou">{{item.equipmentId}}</td>
+                  <td style="min-width: 162px; max-width: 162px;width: 162px;"  class="tdgu4 kaitou">{{item.equipmentName}}</td>
+                  <td  class="tdgu5 kaitou">{{item.equipmentType}}</td>
+                </template>
+
+                <template v-else>
+                  <td colspan="6" class="tdgu kaitou">{{item.level1}}</td>
+                </template>
+                <!--<td>{{item.tierType}}</td>-->
+                <template v-for="(tableHead, index) in item.dataList">
+                  <td :style="{background:tableHead.color }">{{tableHead.startRate | numFilter}}</td>
+                  <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('kjl') > -1">
+                    {{tableHead.openRate | numFilter}}
+                  </td>
+                  <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('kjsj') > -1">
+                    {{tableHead.openLong | getFormattedTime}}
+                  </td>
+                  <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('jgsj') > -1">
+                    {{tableHead.processLong | getFormattedTime}}
+                  </td>
+                  <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('djsj') > -1">
+                    {{tableHead.waitLong | getFormattedTime}}
+                  </td>
+                  <td :style="{background:tableHead.color }" v-if="checkedList.indexOf('gjsj') > -1">
+                    {{tableHead.closeLong | getFormattedTime}}
+                  </td>
+                </template>
+              </tr>
+              </tbody>
+            </table>
+          </div>
         </div>
-      </div>
+      </a-spin>
     </div>
   </div>
 </template>
@@ -120,6 +135,7 @@
       typeParent:1,
       typeEquipment:1,
       dates: [],
+      selectList:[],
       queryParam: {},
       queryParamEquip:{},
       queryParamPeople:{},
@@ -136,9 +152,11 @@
       dataList: [],
       url: {
         list: '/mdc/efficiencyReport/efficiencyPOList',
-        listByType: '/mdc/MdcUtilizationRate/getByType'
+        listByType: '/mdc/MdcUtilizationRate/getByType',
+        queryEquipmentType: '/mdc/mdcEquipmentType/queryEquipmentType'
       },
-      tableHeads: []
+      tableHeads: [],
+      spinning:false
     }
   },
   props: { nodeTree: '', Type:'',nodePeople: ''},
@@ -149,6 +167,7 @@
     this.queryParam.endTime = moment(this.dates[1]).format('YYYYMMDD')
     this.queryParam.typeTree = "1"
     this.loadData()
+    this.queryGroup()
   },
   watch: {
     Type(valmath){
@@ -187,7 +206,20 @@
       } else {
         return '0'
       }
-    }
+    },
+
+    /**
+     * 鏍煎紡鍖栨椂闂�
+     * @param seconds 绉掓暟
+     * @returns '' 鏍煎紡鍖栧悗鏃堕棿瀛楃涓�
+     */
+    getFormattedTime(seconds) {
+      if (seconds) {
+        return parseFloat((seconds / 3600).toFixed(2)) + '灏忔椂'
+      } else {
+        return '0'
+      }
+    },
   },
   methods: {
     checkSameData(dataList){
@@ -379,6 +411,7 @@
       // this.onClearSelected()
     },
     loadData() {
+      this.spinning=true
       this.tableHeads = []
       this.dataList = []
       getAction(this.url.list, this.queryParam).then(res => {
@@ -392,6 +425,26 @@
           this.combineCell();
           // this.initDeviceType(this.dataList)
         }
+      }).finally(()=>{
+        this.spinning=false
+      })
+    },
+    queryGroup() {
+      getAction(this.url.queryEquipmentType).then(res => {
+        if (res.success) {
+          this.selectList = res.result
+          // this.selectList = res.result.map((item, index, arr) => {
+          //   return { label: item.id, value: item.equipmentTypeName + '' }
+          // })
+        } else {
+          // this.$message.warning(res.message)
+          this.$notification.warning({
+            message: '娑堟伅',
+            description: res.message
+          })
+        }
+      }).finally(() => {
+        this.loading = false
       })
     }
   }
@@ -443,7 +496,7 @@
 }
 .table tbody tr .tdgu5{
   position: sticky;
-  left: 400px;
+  left: 412px;
   z-index: 2;
 }
 
@@ -484,7 +537,7 @@
 }
 .table2 thead .equipname .dong6{
   z-index: 5;
-  left: 400px;
+  left: 412px;
 }
 
 

--
Gitblit v1.9.3