From 017886be8a6c07ccaaf6300b8c7652ddbd41d734 Mon Sep 17 00:00:00 2001
From: qushaowei <qushaowei@163.com>
Date: 星期一, 15 一月 2024 16:50:08 +0800
Subject: [PATCH] Merge branch 'master' of http://117.34.109.166:18448/r/vue_mdc_430 into develop

---
 src/views/mdc/base/modules/OEEAnalysis/OEEAnalysisList.vue |  242 +++++++++++++++++++-----------------------------
 1 files changed, 95 insertions(+), 147 deletions(-)

diff --git a/src/views/mdc/base/modules/OEEAnalysis/OEEAnalysisList.vue b/src/views/mdc/base/modules/OEEAnalysis/OEEAnalysisList.vue
index fd2560d..e9fec71 100644
--- a/src/views/mdc/base/modules/OEEAnalysis/OEEAnalysisList.vue
+++ b/src/views/mdc/base/modules/OEEAnalysis/OEEAnalysisList.vue
@@ -1,12 +1,21 @@
 <template>
-  <div style="width: 100%;">
-    <div :bordered="false">
+  <div class="device_list">
       <!-- 鏌ヨ鍖哄煙 -->
       <div class="seach-content">
         <div class="table-page-search-wrapper">
           <a-form layout="inline" @keyup.enter.native="searchQuery">
             <a-row :gutter="24">
               <a-col :md="5" :sm="5" :xs="5">
+                <a-form-item label="椹卞姩绫诲瀷">
+                  <a-auto-complete
+                    v-model="queryParam.driveType"
+                    :data-source="driveTypeList"
+                    placeholder="璇烽�夋嫨椹卞姩绫诲瀷"
+                    :filter-option="filterOption"
+                  />
+                </a-form-item>
+              </a-col>
+              <a-col :md="7" :sm="7" :xs="7">
                 <a-form-item label="鏃堕棿">
                   <a-range-picker
                     :placeholder="['寮�濮嬫椂闂�', '缁撴潫鏃堕棿']"
@@ -17,28 +26,7 @@
                   />
                 </a-form-item>
               </a-col>
-              <!--<a-col :md="5" :sm="5" :xs="5">-->
-              <!--<a-form-item label="鐝埗">-->
-              <!--<a-select v-model="queryParam.shiftId" placeholder="璇烽�夋嫨鐝埗"-->
-              <!--@change="initShiftSubList" :allowClear="allowClear">-->
-              <!--<a-select-option v-for="(em,index) in shiftList" :key="index" :value="em.value">-->
-              <!--{{ em.label }}-->
-              <!--</a-select-option>-->
-              <!--</a-select>-->
-              <!--</a-form-item>-->
-              <!--</a-col>-->
-              <!--<a-col :md="5" :sm="5" :xs="5">-->
-              <!--<a-form-item label="鐝">-->
-              <!--<a-select v-model="queryParam.shiftSubId" placeholder="璇烽�夋嫨鐝" @change="initShiftSubListChange"-->
-              <!--:allowClear="allowClearSu">-->
-              <!--<a-select-option v-for="(em,index) in shiftSubList" :key="index" :value="em.value">-->
-              <!--{{ em.label }}-->
-              <!--</a-select-option>-->
-              <!--</a-select>-->
-              <!--</a-form-item>-->
-              <!--</a-col>-->
-
-              <a-col :md="8" :sm="8" :xs="8">
+              <a-col :md="2" :sm="2" :xs="2">
                 <a-space>
                   <a-button type="primary" @click="searchQuery" icon="search">鏌ヨ</a-button>
                   <a-button type="primary" @click="searchReset" icon="reload">閲嶇疆</a-button>
@@ -51,27 +39,22 @@
         </div>
       </div>
 
-      <div class="container" id="EfficiencyShift" style="margin-top: 20px;">
-        <div class="table2">
-          <a-table :columns="columns" :dataSource="dataSource.records" :pagination="false" bordered
-                   :scroll="{ x: 3200, y: false }">
-          </a-table>
-        </div>
+      <div id="EfficiencyShift" style="flex:1;overflow: hidden">
+        <a-table :columns="columns" rowKey="equipmentId" :dataSource="dataSource.records" :pagination="false" :scroll="{x:'max-content',y:scrollY}" bordered></a-table>
       </div>
-      <div class="pagination">
-        <a-pagination
-          :total=dataSource.total
-          :show-total="(total, range) => `${range[0]}-${range[1]} 鍏� ${total} 鏉"
-          :page-size="+queryParam.pageSize"
-          :default-current="1"
-          :current=+queryParam.pageNo
-          show-size-changer
-          :pageSizeOptions="['20','30','40','50']"
-          @change="handlePageNoChange"
-          @showSizeChange="handlePageSizeChange"
-        />
-      </div>
-    </div>
+     <!--<div class="pagination">-->
+       <!--<a-pagination-->
+         <!--:total=dataSource.total-->
+         <!--:show-total="(total, range) => `${range[0]}-${range[1]} 鍏� ${total} 鏉"-->
+         <!--:page-size="+queryParam.pageSize"-->
+         <!--:default-current="1"-->
+         <!--:current=+queryParam.pageNo-->
+         <!--show-size-changer-->
+         <!--:pageSizeOptions="['20','30','40','50']"-->
+         <!--@change="handlePageNoChange"-->
+         <!--@showSizeChange="handlePageSizeChange"-->
+       <!--/>-->
+     <!--</div>-->
   </div>
 </template>
 
@@ -81,21 +64,16 @@
   import $ from 'jquery'
   import '@/components/table2excel/table2excel'
   import { ajaxGetDictItems, getDictItemsFromCache, duplicateCheck } from '@/api/api'
+  import api from '@api/mdc'
 
   export default {
     name: 'OEEAnalysisList',
     components: {},
     data() {
       return {
-        typeTree: '',
-        typeParent: 1,
-        typeEquipment: 1,
-        allowClear: true,
-        allowClearSu: true,
         dates: [moment().subtract('month', 1), moment().subtract('month', 1)],
-        identifying: [],
         queryParam: {
-          pageSize: 20,
+          pageSize: 10000,
           pageNo: 1
         },
         queryParamEquip: {},
@@ -117,21 +95,18 @@
             customRender: function(t, r, index) {
               return parseInt(index) + 1
             }
-            // fixed: 'left'
           },
           {
             title: '璁惧缁熶竴缂栧彿',
             align: 'center',
             dataIndex: 'equipmentId',
             width: 120
-            // fixed: 'left'
           },
           {
             title: '璁惧鍚嶇О',
             align: 'center',
             width: 200,
             dataIndex: 'equipmentName'
-            // fixed: 'left'
           },
           {
             title: '璁惧鍨嬪彿',
@@ -148,7 +123,7 @@
           {
             title: '鐝',
             align: 'center',
-            width: 300,
+            width: 100,
             dataIndex: 'shift',
             ellipsis: true,
           },
@@ -250,7 +225,7 @@
             dataIndex: 'timeActuationRate',
             align: 'center',
             width: 110,
-            customRender: text => text != 0 ? text * 100 + '%' : 0
+            customRender: text => text != 0 ? parseFloat((text * 100).toFixed(2)) + '%' : 0
           },
           {
             title: '鍔犲伐闆朵欢鏁帮紙浠讹級',
@@ -269,7 +244,7 @@
             dataIndex: 'performanceRate',
             align: 'center',
             width: 110,
-            customRender: text => text != 0 ? text * 100 + '%' : 0
+            customRender: text => text != 0 ? parseFloat((text * 100).toFixed(2)) + '%' : 0
           },
           {
             title: '搴熷搧鏁�',
@@ -282,26 +257,35 @@
             dataIndex: 'passRate',
             align: 'center',
             width: 100,
-            customRender: text => text != 0 ? text * 100 + '%' : 0
+            customRender: text => text != 0 ? parseFloat((text * 100).toFixed(2)) + '%' : 0
           },
           {
             title: '璁惧缁煎悎鏁堢巼',
             dataIndex: 'overallEquipmentEfficiency',
             align: 'center',
             width: 120,
-            customRender: text => text != 0 ? text * 100 + '%' : 0
+            customRender: text => text != 0 ? parseFloat((text * 100).toFixed(2)) + '%' : 0
           }
         ],
-        dataSource: []
+        dataSource: [],
+        driveTypeList: [],
+        scrollY:465,
       }
     },
     props: { nodeTree: '', Type: '', nodePeople: '' },
     created() {
-      this.initShiftList()
       this.queryParam.startTime = moment(this.dates[0]).format('YYYY-MM')
       this.queryParam.endTime = moment(this.dates[1]).format('YYYY-MM')
       this.queryParam.typeTree = '1'
       this.loadData()
+      this.getDriveTypeByApi()
+    },
+    mounted(){
+      window.addEventListener('resize',this.handleWindowResize)
+      this.handleWindowResize()
+    },
+    beforeDestroy(){
+      window.removeEventListener('resize',this.handleWindowResize)
     },
     watch: {
       Type(valmath) {
@@ -418,6 +402,15 @@
         this.loadData()
       },
 
+      /**
+       * 璋冪敤鎺ュ彛鑾峰彇鎺у埗绯荤粺绫诲瀷
+       */
+      getDriveTypeByApi() {
+        api.getDriveTypeApi().then((res) => {
+          this.driveTypeList = res.result.map(item => item.value)
+        })
+      },
+
       loadData() {
         getAction(this.url.list, this.queryParam).then(res => {
           if (res.success) {
@@ -444,112 +437,67 @@
       handlePageSizeChange(current, size) {
         this.queryParam.pageSize = size
         this.loadData()
+      },
+      /**
+       * 鑱旀兂杈撳叆妗嗙瓫閫夊姛鑳�
+       * @param input 杈撳叆鐨勫唴瀹�
+       * @param option 閰嶇疆
+       * @returns {boolean} 鍒ゆ柇鏄惁绛涢��
+       */
+      filterOption(input, option) {
+        return (
+          option.componentOptions.children[0].text.toUpperCase().indexOf(input.toUpperCase()) >= 0
+        )
+      },
+
+      /**
+       * 褰撴祻瑙堝櫒鍙绐楀彛灏哄鍙戠敓鏀瑰彉鏃惰Е鍙�
+       */
+      handleWindowResize(){
+        const boxHeight = +window.getComputedStyle(document.getElementById('EfficiencyShift')).height.slice(0,-2)
+        const tableHeadHeight = +window.getComputedStyle(document.querySelector('.ant-table-thead th')).height.slice(0,-2)
+        this.scrollY = boxHeight - tableHeadHeight
       }
     }
   }
 </script>
 <style scoped>
-  .table2 {
-    width: 100%;
-    height: 100%;
-    overflow: auto;
-  }
-
   .pagination {
     display: flex;
     justify-content: end;
     margin: 20px 0;
   }
 
-  @media screen and (min-width: 1920px) {
-    #EfficiencyShift {
-      height: 670px !important;
-      overflow: scroll;
+  .device_list{
+    overflow: hidden;
+    display: flex;
+    flex-direction: column;
+  }
+
+  @media screen and (min-width: 1920px){
+    .device_list{
+      height: 811px!important;
     }
   }
-
-  @media screen and (min-width: 1680px) and (max-width: 1920px) {
-    #EfficiencyShift {
-      height: 670px !important;
-      overflow: scroll;
+  @media screen and (min-width: 1680px) and (max-width: 1920px){
+    .device_list{
+      height: 811px!important;
     }
   }
-
-  @media screen and (min-width: 1400px) and (max-width: 1680px) {
-    #EfficiencyShift {
-      height: 522px !important;
-      overflow: scroll;
+  @media screen and (min-width: 1400px) and (max-width: 1680px){
+    .device_list{
+      height: 663px!important;
     }
   }
-
-  @media screen and (min-width: 1280px) and (max-width: 1400px) {
-    #EfficiencyShift {
-      height: 414px !important;
-      overflow: scroll;
+  @media screen and (min-width: 1280px) and (max-width: 1400px){
+    .device_list{
+      height: 564px!important;
     }
   }
-
-  @media screen and (max-width: 1280px) {
-    #EfficiencyShift {
-      height: 414px !important;
-      overflow: scroll;
+  @media screen and (max-width: 1280px){
+    .device_list{
+      height: 564px!important;
     }
-  }
-
-  .identifyingclass {
-    width: 55px;
-    height: 15px;
-    display: inline-block
-  }
-
-  .dataContent {
-    white-space: nowrap;
-    /*margin: 0;*/
-    /*border: none;*/
-    border-collapse: separate;
-    border-spacing: 0;
-    /*table-layout: fixed;*/
-    border: 1px solid #ccc;
-    /*border: 1px solid #ccc;*/
-    width: 100%;
-    /*height: 100%;*/
-    /*overflow: hidden;*/
-    /*overflow-y: auto;*/
-    text-align: center;
-  }
-
-  .dataContent .fixed th {
-    width: 50px;
-  }
-
-  .dataContent .thead th {
-    background-color: #fafafa;
-    text-align: center;
-    height: 30px;
-    padding: 5px;
-  }
-
-  .dataContent .notfixed th {
-    width: auto;
-  }
-
-  /*.dataContent tr td {*/
-  /*height: 35px*/
-  /*}*/
-
-  .dataContent .mathData td {
-    padding: 10px;
-    /*display: none;*/
-  }
-
-  .dataContent .mathData .td {
-    /*background-color: #ff9bd2;*/
-    display: inline-block;
-    padding: 10px;
-  }
-
-  .dataContent .mathData .tdd {
-    /*display: none;*/
   }
 
 </style>
\ No newline at end of file

--
Gitblit v1.9.3