#
whycq
2024-05-20 3248fb0c8bd02ae9fde9724b9c1f5d03216b0108
pages/AGV/AGVStart.vue
@@ -1,29 +1,19 @@
<template>
   <view>
      <view class="code">
         <!-- <view class="item">
            <view class="code-decs">托盘码:</view>
            <input type="text" placeholder=" 扫码 / 输入" v-model="barcode" :focus="barcodeFocus"
               @input="barcodeInput()">
         </view> -->
         <!-- <view class="item">
            <view class="code-decs">暂存位:</view>
            <input type="text" placeholder=" 扫码 / 输入" v-model="stationCode" :focus="matFocus" @input="stationCodeInput()">
            <view class="item-right">
               <button></button> -->
               <!-- <text style="text-align: right;color: #409EFF;" @click="selectMat()">提取+</text> -->
               <!-- <uni-icons type="right" color="#c1c1c1"></uni-icons> -->
            <!-- </view>
         </view> -->
         <view class="item">
            <view class="code-decs">楼号:</view>
            <uni-combox :candidates="floorList" placeholder="请选择楼号" v-model="floor" @input="getFloor"></uni-combox>
         </view>
         <view class="item">
            <view class="code-decs">暂存位:</view>
            <input type="text" placeholder=" 扫码 / 输入" v-model="stationCode" :focus="stationCodeFocus"
               @input="stationCodeInput()">
         </view>
      </view>
      <view class="mat-list-title">
         <view style="width: 200rpx;"></view>
         <view style="-webkit-flex: 1;flex: 1;">商品列表</view>
         <view style="width: 200rpx;"><button size="mini" type="primary" @click="getChecked">提取</button></view>
         <view style="-webkit-flex: 1;flex: 1;">站点列表</view>
      </view>
      <scroll-view>
         <view class="list" v-for="(item,i) in dataList" :key="i" :class="'bg-'+item.color">
@@ -118,6 +108,7 @@
            token: '',
            barcode: '',
            stationCode: '',
            stationCodeFocus: true,
            dataList: [],
            count: 0,
            rowNum: '',
@@ -145,6 +136,52 @@
         this.token = uni.getStorageSync('token');
      },
      methods: {
         stationCodeInput() {
            setTimeout(() => {
               var len = this.stationCode.length
               if (len != 15) {
                  this.stationCode = ''
                  this.stationCodeFocus = true
                  uni.showToast({
                     title: '暂存码有误请重试',
                     icon: "none",
                     position: 'top'
                  });
                  return;
               }
               this.pushDevNo()
               this.stationCodeFocuss()
            }, 200)
         },
         pushDevNo() {
            var devNo = {"devNo":this.stationCode}
            if (this.dataList.length == 0) {
               this.dataList.push(devNo)
               return
            }
            var flag = false
            for(var i = 0; i < this.dataList.length; i++ ) {
               if (this.dataList[i].devNo == devNo.devNo) {
                  this.messageText = "站点重复"
                  this.messageToggle('warn')
                  return
               } else {
                  flag = true
               }
            }
            if(flag) {
               this.dataList.push(devNo)
            }
         },
         stationCodeFocuss() {
            let that = this;
            this.stationCode = ''
            that.stationCodeFocus = false;
            setTimeout(() => {
               that.stationCodeFocus = true;
            }, 100);
         },
         getChecked() {
            var checkedList = []
            for(var i = 0; i < this.dataList.length; i++) {
@@ -161,6 +198,9 @@
         },
         getFloor() {
            let that = this
            if (this.floor == '') {
               return
            }
            uni.request({
               url: that.baseUrl + '/agvMobile/getBasDevp/auth',
               data: {
@@ -174,20 +214,16 @@
                  res = res.data
                  for(var i = 0; i < res.data.length; i++) {
                     if (res.data[i].locSts === 'F') {
                        res.data[i]["color"] = "red"
                        // res.data[i]["color"] = "red"
                        that.dataList.push(res.data[i])
                     }
                  }
                  that.dataList = res.data
                  console.log(that.dataList);
               }
            });
         },
         messageToggle(type) {
            this.msgType1 = type
            this.$refs.message.open()
         },
         stationCodeInput() {
            this.dataList.push(this.stationCode)
         },
         // barcode input 事件
         barcodeInput() {
@@ -388,10 +424,13 @@
            this.$refs.combConfirm.close()
         },
         comb() {
            this.devNo = []
            uni.vibrateShort();
            let that = this;
            for (var i = 0; i < that.dataList.length; i++) {
               that.devNo.push(that.dataList[i].devNo)
            for (var i = 0; i < this.dataList.length; i++) {
               if (this.dataList[i].checked) {
                  this.devNo.push(this.dataList[i].devNo)
               }
            }
            uni.request({
               url: that.baseUrl + '/agvMobile/pakin/auth',
@@ -408,9 +447,6 @@
                     that.resst();
                     that.messageText = "启动成功"
                     that.messageToggle('success')
                     // const innerAudioContext = uni.createInnerAudioContext();
                     // innerAudioContext.src = '/static/music/pakinOk.mp3';
                     // innerAudioContext.play()
                  } else if (res.code == 403) {
                     that.messageText = res.msg
                     that.messageToggle('error')
@@ -468,7 +504,7 @@
      color: #666666;
   }
   .list:first-child {
      margin-top: 260rpx;
      margin-top: 360rpx;
   }
   .aside {
      width: 100rpx;
@@ -521,7 +557,7 @@
      width: 100%;
      background-color: white;
      position: fixed;
      margin-top: 100rpx;
      margin-top: 200rpx;
      z-index: 9;
      /* border-top: 1px solid #DCDFE6; */
      text-align: center;