#
whycq
2023-11-07 59106f4f1c9e7daaf50da15b8d3f3b5fc329aa65
Monitor-APP/pages/home/home.vue
@@ -29,9 +29,9 @@
                                 <view class="flex-col" style="width: calc(100% - 5vw);">
                                    <view class="flex-row" style="position: relative;" >
                                       <view style="width: 2vw;padding-left: 2vw;;font-size: 2vw;">{{baseInfo.xDistance}}</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">m</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">KM</view>
                                    </view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计走行距离(米)</view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计走行距离(千米)</view>
                                 </view>
                              </view>
                              
@@ -40,9 +40,9 @@
                                 <view class="flex-col" style="width: calc(100% - 5vw);">
                                    <view class="flex-row" style="position: relative;" >
                                       <view style="width: 2vw;padding-left: 2vw;;font-size: 2vw;">{{baseInfo.yDistance}}</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">m</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">KM</view>
                                    </view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计升降距离(米)</view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计升降距离(千米)</view>
                                 </view>
                              </view>
                              
@@ -51,9 +51,9 @@
                                 <view class="flex-col" style="width: calc(100% - 5vw);">
                                    <view class="flex-row" style="position: relative;" >
                                       <view style="-width: 2vw;padding-left: 2vw;;font-size: 2vw;">{{baseInfo.xDuration}}</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">s</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">H</view>
                                    </view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计走行时长(秒)</view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计走行时长(小时)</view>
                                 </view>
                              </view>
                              
@@ -62,9 +62,9 @@
                                 <view class="flex-col" style="width: calc(100% - 5vw);">
                                    <view class="flex-row" style="position: relative;" >
                                       <view style="width: 2vw;padding-left: 2vw;;font-size: 2vw;">{{baseInfo.yDuration}}</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">s</view>
                                       <view style="position: absolute;bottom: 0;left: 10vw;">H</view>
                                    </view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计升降时长(秒)</view>
                                    <view style="height: 100%;text-align: left;text-indent: 2em;">累计升降时长(小时)</view>
                                 </view>
                              </view>
                              
@@ -186,9 +186,7 @@
                        <view style="height: 18%;">
                           <y-box>
                              <view class="flex-col" style="width: 100%;height: 100%;font-size: 4vh;justify-content: center;letter-spacing: 1vh;">
                                 <!-- 嘉善边锋机械股份有限公司 -->
                                 自动仓库WCS监控平台
                                 <!-- <image src="../../static/ruiyun.jpg" mode="" style="width: 100%;"></image> -->
                              </view>
                           </y-box>
                        </view>
@@ -217,11 +215,12 @@
                     <view class="text-content">
                        <!-- head -->
                        <view class="swiper-head">
                           <view>目标站:{{infoText.staNo}}</view>
                           <view>商品编号</view>
                           <view>商品名称</view>
                           <view>规格</view>
                           <view>数量</view>
                           <view style="width: 10vw;">目标站:{{infoText.staNo}}</view>
                           <view style="flex: 1;">商品编号</view>
                           <view style="flex: 1;">商品名称</view>
                           <view style="width: 10vw;">数量</view>
                           <view style="flex: 1;">箱码</view>
                           <view style="width: 10vw;">库存数量</view>
                        </view>
                        <!-- body -->
                        <view class="swiper-body">
@@ -233,11 +232,13 @@
                           display-multiple-items="8"
                           circular="true" :autoplay="true" :interval="3000" :duration="1000">
                              <swiper-item class="swiper-item" v-for="(item,i) in swiperList" :key="i">
                                 <view>No:{{i+1}}</view>
                                 <view>{{item.matnr}}</view>
                                 <view>{{item.maktx}}</view>
                                 <view>{{item.specs}}</view>
                                 <view>{{item.count}}</view>
                                 <view style="width: 10vw;">No:{{i+1}}</view>
                                 <view style="flex: 1;">{{item.matNo}}</view>
                                 <view style="flex: 1;">{{item.maknx}}</view>
                                 <!-- <view style="width: 20%;">{{item.specs}}</view> -->
                                 <view style="width: 10vw;">{{item.count}}</view>
                                 <view style="flex: 1;">{{item.zpallet}}</view>
                                 <view style="width: 10vw;">{{item.anfme}}</view>
                              </swiper-item>
                           </swiper>
                        </view>
@@ -245,6 +246,10 @@
                  </y-box>
               </view>
            </view>
         </view>
         <view class="btn">
            <!-- <button >拣料回库</button> -->
            <button  size="mini" type="primary" @click="">盘点回库</button>
         </view>
      </uni-transition>
      <!-- 异常信息 -->
@@ -276,7 +281,7 @@
            <!-- 弹出title -->
            <view class="eject-title">修改 / 配置</view>
            <!-- input -->
            <view class="eject-input">
            <scroll-view scroll-y class="eject-input">
               <view class="item">
                  <view class="desc">ip:</view>
                  <view class="input">
@@ -307,7 +312,7 @@
                     <input type="text" v-model="baseUrl">
                  </view>
               </view>
            </view>
            </scroll-view>
            <!-- button -->
            <view class="eject-button">
               <view class="button-item" @click="ejectClose">取 消</view>
@@ -315,15 +320,19 @@
            </view>
         </view>
      </view>
      <view style="color: #FFF;position: fixed;bottom: 10px;left: 10px;" v-show="timeOut">
         连接超时: {{times}} s
      </view>
   </view>
</template>
<!-- {"msg":"操作成功","code":200,"data":[{"title":"全板出库","workNo":7460,"staNo":110,"sourceStaNo":null,"locNo":null,"sourceLocNo":"0807102","matDtos":[{"matNo":"50460834","maknx":"200x60桌面","count":26.0}],"emptyMk":false,"ioType":101}]} -->
<script>
   import demodata from '@/mockdata/demodata.json';
   import ycqdata from '@/pages/index/data.json';
   export default {
      data() {
         return {
            commonUrl: '',
            series: [],
            homeViewShow: true,
            infoViewShow: false   ,
@@ -378,9 +387,21 @@
               maknx: "",
               specs: "",
               count: "",
               error: ""
               error: "",
               barcode: "",
               orderNo: '',
               batch: '',
               doneOfTray: '',
               totalOfTray: '',
               doneOfUnit: '',
               totalOfUnit: '',
               ctnNo: '1'
            },
            swiperList: []
            swiperList: [],
            timeOut: false,
            times: 0,
            currDate: '',
            textred: 'textred'
         }
      },
      onShow() {
@@ -401,26 +422,55 @@
         that.baseLedId = BaseLedId
         that.basePort = BasePort
         that.baseCrnId = BaseCrnId
         // this.getUrl()
         this.getDate2()
         setTimeout(()=>{
            // this.getServerData()
            // this.initlineChart()
            // this.initPieChart()
            // this.getOther()
            setTimeout(()=>{
               this.getServerData()
               this.initlineChart()
               this.initPieChart()
               this.getOther()
               setTimeout(()=>{
                  this.getServerData()
                  this.initlineChart()
                  this.initPieChart()
                  this.getOther()
               },3000)
            },1000)
         },1000)
      },
      onLoad() {
         setInterval(()=>{
            this.getServerData()
            this.initlineChart()
            this.initPieChart()
            this.getOther()
            this.getDate()
            this.getDate2()
            this.getUrl()
            this.getInfo()
            this.getError()
            // this.getInfo2()
            // this.getError2()
            this.getUrl()
            this.controller()
            // 测试用
         },1000)
         setInterval(()=>{
            this.getDate2()
            this.getUrl()
            this.getInfo()
            this.getError()
            // this.getInfo2()
            // this.getError2()
            this.controller()
         },600000)
      },
      methods: {
         timeOuts() {
            console.log(this.times);
         },
         getUrl() {
            this.commonUrl = this.baseHttp + this.baseIP + ':' +this.basePort + "/" +this.baseUrl
         },
@@ -433,29 +483,7 @@
            let that = this
            var result = ycqdata.dataInfo2
            var   res = result.data
            if (res.data && res.data !== "") {
               if (that.infoType == 2 || that.infoType == 3) {
                  return;
               }
               // infoType1:只有拣料等信息
               that.infoType = 1
               if (res.data[0].ioType === 101) {
                  that.infoText.title = '全板出库'
               } else if(res.data[0].ioType === 103) {
                  that.infoText.title = '检料出库'
               }
               that.infoText.staNo = res.data[0].staNo
               that.swiperList = res.data[0].matDtos
               // that.infoText.matnr = res.data[0].matDtos[0].matnr
               // that.infoText.specs = res.data[0].matDtos[0].specs
               // that.infoText.maknx = res.data[0].matDtos[0].maknx
               // that.infoText.count = res.data[0].matDtos[0].count
            } else {
               if (that.infoType == 2 || that.infoType == 3) {
                  return;
               }
               that.infoType = 0
            }
            that.infoModel(res)
         },
         getError2 () {
            let that = this
@@ -487,28 +515,7 @@
               data: {ledId:that.baseLedId},
               success(result) {
                  var   res = result.data
                  if (res.data && res.data !== "") {
                     if (that.infoType == 2 || that.infoType == 3) {
                        return;
                     }
                     // infoType1:只有拣料等信息
                     that.infoType = 1
                     if (res.data[0].ioType === 101) {
                        that.infoText.title = '全板出库'
                     } else if(res.data[0].ioType === 103) {
                        that.infoText.title = '检料出库'
                     }
                     that.infoText.staNo = res.data[0].staNo
                     that.infoText.matnr = res.data[0].matDtos[0].matnr
                     that.infoText.specs = res.data[0].matDtos[0].specs
                     that.infoText.maknx = res.data[0].matDtos[0].maknx
                     that.infoText.count = res.data[0].matDtos[0].count
                  } else {
                     if (that.infoType == 2 || that.infoType == 3) {
                        return;
                     }
                     that.infoType = 0
                  }
                  that.infoModel(res)
               }
            })
            
@@ -521,17 +528,18 @@
               method:"GET",
               success(result) {
                  var   res = result.data
                  console.log(res);
                  if (res.data && res.data !== "") {
                     var errorInfo = res.data
                     if (that.infoType == 1) {
                        that.infoType = 3
                        that.infoText.title = "异常"
                        that.infoText.title = "其他信息"
                        // that.infoText.title = "异常"
                        that.infoText.error = errorInfo
                        return
                     }
                     that.infoType = 2
                     that.infoText.title = "异常"
                     that.infoText.title = "其他信息"
                     // that.infoText.title = "异常"
                     that.infoText.error = errorInfo
                  } else {
                     if (that.infoType == 1) {
@@ -543,10 +551,64 @@
            })
            
         },
         infoModel(res) {
            let that = this
            if (res.data && res.data !== "") {
               that.infoText.title = res.data[0].title
               if (that.infoType == 2 || that.infoType == 3) {
                  return;
               }
               // infoType1:只有拣料等信息
               that.infoType = 1
               if (res.data[0].ioType === 101) {
                  that.infoText.title = '全板出库'
               } else if(res.data[0].ioType === 103) {
                  that.infoText.title = '检料出库'
               } else if(res.data[0].ioType === 107) {
                  that.infoText.title = '盘点出库'
               }
               that.infoText.staNo = res.data[0].staNo
               that.swiperList = res.data[0].matDtos
               // that.infoText.matnr = res.data[0].matDtos[0].matnr
               // that.infoText.specs = res.data[0].matDtos[0].specs
               // that.infoText.maknx = res.data[0].matDtos[0].maknx
               // that.infoText.count = res.data[0].matDtos[0].count
            } else {
               if (that.infoType == 2 || that.infoType == 3) {
                  return;
               }
               that.infoType = 0
            }
         },
         // 控制器
         controller() {
            switch(this.infoType) {
               // 有信息 但 没有错误信息
               case 0:
                  if (this.errorInfoViewShow) {
                     this.errorInfoViewShow = false
                     this.errorInfoMode = ['fade', 'slide-bottom']
                     setTimeout(()=>{
                        this.homeViewShow = true
                        this.homeMode = ['fade', 'slide-bottom']
                     },1000)
                  } else if (this.infoViewShow) {
                     this.infoViewShow = false
                     this.infoMode = ['fade', 'slide-bottom']
                     setTimeout(()=>{
                        this.homeViewShow = true
                        this.homeMode = ['fade', 'slide-bottom']
                     },1000)
                  } else if (this.errorInfoViewShow && this.infoViewShow) {
                     this.errorInfoViewShow = false
                     this.infoViewShow = false
                     this.infoMode = ['fade', 'slide-bottom']
                     setTimeout(()=>{
                        this.homeViewShow = true
                        this.homeMode = ['fade', 'slide-bottom']
                     },1000)
                  }
                  return;
               case 1: 
                  if (this.homeViewShow) {
                     this.homeViewShow = false
@@ -601,23 +663,7 @@
                     },1000)
                  }
                  return;
               default :
                  if (this.errorInfoViewShow) {
                     this.errorInfoViewShow = false
                     this.errorInfoMode = ['fade', 'slide-bottom']
                     setTimeout(()=>{
                        this.homeViewShow = true
                        this.homeMode = ['fade', 'slide-bottom']
                     },1000)
                  } else if (this.infoViewShow) {
                     this.infoViewShow = false
                     this.infoMode = ['fade', 'slide-bottom']
                     setTimeout(()=>{
                        this.homeViewShow = true
                        this.homeMode = ['fade', 'slide-bottom']
                     },1000)
                  }
                  return;
            }
            
         },
@@ -654,6 +700,27 @@
            this.getUrl()
            this.ejectShow = false
         },
         // 日历 服务器
         getDate2() {
            let that = this
            if(that.commonUrl == 'undefined') {
               return
            }
            uni.request({
               url: that.commonUrl + "/monitor/date",
               method:"GET",
               success(result) {
                  var res = result.data.data
                  that.calendar = res.year + "年" + res.month + "月" + res.day + "日 " + res.hour + ":" + res.minute + ":" + res.second + " " + res.week
                  that.currDate = res.year + "/" + res.month + "/" + res.day
               },
               fail(res) {
                  console.log(res);
               }
            })
         },
         // 日历
         getDate() {
            var dt = new Date();
@@ -677,7 +744,7 @@
            this.calendar = year + "年" + month + "月" + day + "日 " + hours + ":" + minutes + ":" + seconds + " " + weeks
         },
         getDateFormat(value) {
            var date = new Date();// 获取当前时间
            var date = new Date(this.currDate);// 获取当前时间
            date.setDate(date.getDate() + value);// 设置天数 -1 天
            var m = date.getMonth() + 1
            var d = date.getDate()
@@ -687,17 +754,23 @@
         /*************** 折线图 *****************************************************************************************************/
         initlineChart() {
            let that = this
            if(that.commonUrl == 'undefined') {
               return
            }
            uni.request({
               url: that.commonUrl + "/monitor/line/charts",
               method:'GET',
               success(result) {
                  var res = result.data
                  if (res.code === 200) {
                     that.chartsData.Line.categories = [
                        that.getDateFormat(-11),that.getDateFormat(-10),that.getDateFormat(-9),that.getDateFormat(-8),
                        that.getDateFormat(-7),that.getDateFormat(-6),that.getDateFormat(-5),that.getDateFormat(-4),
                        that.getDateFormat(-3),that.getDateFormat(-2),that.getDateFormat(-1),that.getDateFormat(0),]
                     that.chartsData.Line.series = res.data.rows
                     setTimeout(()=> {
                        that.chartsData.Line.categories = [
                           that.getDateFormat(-11),that.getDateFormat(-10),that.getDateFormat(-9),that.getDateFormat(-8),
                           that.getDateFormat(-7),that.getDateFormat(-6),that.getDateFormat(-5),that.getDateFormat(-4),
                           that.getDateFormat(-3),that.getDateFormat(-2),that.getDateFormat(-1),that.getDateFormat(0),]
                        that.chartsData.Line.series = res.data.rows
                     },1000)
                  }
               }
            })
@@ -705,6 +778,9 @@
         /*************** 饼图 *****************************************************************************************************/
         initPieChart() {
            let that = this
            if(that.commonUrl == 'undefined') {
               return
            }
            uni.request({
               url: that.commonUrl + "/monitor/loc/rep",
               method:'GET',
@@ -723,10 +799,13 @@
         },
         getOther() {
            let that = this
            if(that.commonUrl == 'undefined') {
               return
            }
            uni.request({
               url: that.commonUrl + "/monitor/other",
               data: {
                  crnId: that.baseCrnId,
                  crnId: that.baseCrnId,
                  ledId: that.baseLedId,
               },
               success(result) {
@@ -753,6 +832,15 @@
   /* @import url("../../static/css/common.css"); */
   @import url("home.css");
   /* 列 */
   .btn {
      position: fixed;
      width: 100%;
      height: 10vh;
      bottom: 0;
      display: flex;
      align-items: center;
      justify-content: center;
   }
   .flex-col {
      display: flex;
      flex-direction: column;
@@ -878,6 +966,9 @@
      width: 3.5vw;
      height: 3.5vw;
   }
   .red{
      color: red
   }
   
   
   
@@ -934,7 +1025,7 @@
   }
   .info-main {
      width: 100vw;
      height: 88vh;
      height: 80vh;
      display: flex;
      justify-content: center;
      align-items: center;
@@ -981,12 +1072,15 @@
      text-align: center;
   }
   .eject-input {
      margin-top: 2vh;
      height: 25vh;
      /* background-color: #00163E; */
      ::-webkit-scrollbar{display:none}
   }
   .item {
      display: flex;
      align-items: center;
      margin: 2vh 0 0 0;
      margin: 1vh 0 0 0;
      font-size: 1.5vw;
      color: #363636;
   }
@@ -1045,5 +1139,9 @@
   .info-box-text-item {
      height: 20%;font-size: 8vh;
      justify-content: center;
      white-space: pre-line;
   }
   .textred{
      color: red;
   }
</style>