qingyiay
2023-07-02 b034b3ca571447861a2c594c537eba59089fefcd
pages/driver-page/driver-index/bill-of-lading-details/weighingDevice/weighingDevice.vue
@@ -25,82 +25,6 @@
         </view>
         <view class="bottom"><text>TIP:当前状态为正常时可以称重</text></view>
      </view>
      <view class="middle-block"
         v-if="firstHairCustomernameShow || sideline">
         <view class="block-main"
            v-if="firstHairCustomernameShow">
            <view class="first-line"><combined-title title="原发信息"></combined-title></view>
            <view class="second-line">
               <view class="label-text"
                  :class="{ focusClass: isfocus1 }">皮重</view>
               <view class="input-container"
                  :class="{ inputClass: isfocus1, disabledClass: haveInputOrigin }">
                  <u--input placeholder="请输入皮重"
                     border="surround"
                     v-model="weighData.coalContactSkin"
                     @focus="inputFocus(1)"
                     @blur="inputBlur"
                     @change="inputChange"
                     :disabled="haveInputOrigin"></u--input>
               </view>
               <view class="unit"
                  :class="{ focusClass: isfocus1 }">吨</view>
            </view>
            <view class="second-line">
               <view class="label-text"
                  :class="{ focusClass: isfocus2 }">毛重</view>
               <view class="input-container"
                  :class="{ inputClass: isfocus2, disabledClass: haveInputOrigin }">
                  <u--input placeholder="请输入毛重"
                     border="surround"
                     v-model="weighData.coalContactHair"
                     @focus="inputFocus(2)"
                     @blur="inputBlur"
                     @change="inputChange"
                     :disabled="haveInputOrigin"></u--input>
               </view>
               <view class="unit"
                  :class="{ focusClass: isfocus2 }">吨</view>
            </view>
            <view class="second-line">
               <view class="label-text">净重</view>
               <view class="input-container"
                  :class="{ disabledClass: haveInputOrigin }">
                  <u--input placeholder="净重"
                     border="surround"
                     v-model="coalContactClean"
                     :disabled="haveInputOrigin"></u--input>
               </view>
               <view class="unit">吨</view>
            </view>
         </view>
         <view class="block-sideline"
            v-if="sideline">
            <view class="first-line"><combined-title title="原发信息"></combined-title></view>
            <view class="weigh-item">
               <view class="item">
                  <view class="concrete"
                     style="background: url('https://mx.jzeg.cn:9095/appimg/image/banner/skin.png') no-repeat;background-size: cover;">
                     皮</view>
                  <view class="num">{{ weighList.skinTwo }}</view>
               </view>
               <view class="item">
                  <view class="concrete"
                     style="background: url('https://mx.jzeg.cn:9095/appimg/image/banner/hair.png') no-repeat;background-size: cover;">
                     毛</view>
                  <view class="num">{{ weighList.hairTwo }}</view>
               </view>
               <view class="item">
                  <view class="concrete"
                     style="background: url('https://mx.jzeg.cn:9095/appimg/image/banner/clean.png') no-repeat;background-size: cover;">
                     净</view>
                  <view class="num">{{ weighList.cleanTwo }}</view>
               </view>
            </view>
         </view>
      </view>
      <view v-else
         style="width: 100%;height: 40rpx;"></view>
      <view class="bottom-block">
         <view class="block-main">
            <view class="main-information"
@@ -141,18 +65,25 @@
               <view class="suffix">{{ weighList.coalName || '' }}</view>
            </view>
            <view class="main-information">
               <view class="prefix">订单类型:</view>
               <view class="suffix">{{ weighList.orderType || '' }}</view>
            </view>
            <view class="main-information">
               <view class="prefix">皮重:</view>
               <view class="suffix">{{ temporaryWeighObj.skin == 0 ? weighList.skin : temporaryWeighObj.skin }}
               <view class="suffix">
                  {{temporaryWeighObj.skin||''}}
               </view>
            </view>
            <view class="main-information">
               <view class="prefix">毛重:</view>
               <view class="suffix">{{ temporaryWeighObj.hair == 0 ? weighList.hair : temporaryWeighObj.hair }}
               <view class="suffix">
                  {{temporaryWeighObj.hair?temporaryWeighObj.hair:showWeigh.skin?(showWeigh.skin||''):(showWeigh.hair||'')}}
               </view>
            </view>
            <view class="main-information">
               <view class="prefix">净重:</view>
               <view class="suffix">{{ temporaryWeighObj.clean == 0 ? weighList.clean : temporaryWeighObj.clean }}
               <view class="suffix">
                  {{ temporaryWeighObj.clean||''}}
               </view>
            </view>
            <view class="main-information">
@@ -161,6 +92,42 @@
            </view>
         </view>
      </view>
      <!--  称重历史-->
      <transition name="weighHistory">
         <view class="weigh-history"
            v-if="weighHistory.length!==0">
            <view class="block-main">
               <view class="weigh-item"
                  v-for='item in weighHistory'
                  :key="item.id">
                  <view class="weigh-time">
                     <u-tag :text="item.createTime.slice(-8,-3)"
                        plain></u-tag>
                  </view>
                  <view class="item-block">
                     <view class="item">
                        <view class="concrete"
                           style="background: url('https://mx.jzeg.cn:9095/appimg/image/banner/skin.png') no-repeat;background-size: cover;">
                           皮</view>
                        <view class="num">{{ item.skin }}</view>
                     </view>
                     <view class="item">
                        <view class="concrete"
                           style="background: url('https://mx.jzeg.cn:9095/appimg/image/banner/hair.png') no-repeat;background-size: cover;">
                           毛</view>
                        <view class="num">{{ item.hair }}</view>
                     </view>
                     <view class="item">
                        <view class="concrete"
                           style="background: url('https://mx.jzeg.cn:9095/appimg/image/banner/clean.png') no-repeat;background-size: cover;">
                           净</view>
                        <view class="num">{{ item.clean }}</view>
                     </view>
                  </view>
               </view>
            </view>
         </view>
      </transition>
      <view class="three">
         <!-- 放空 -->
         <u-button type="primary"
@@ -172,7 +139,7 @@
         <!-- 外销订单称皮时,返回加减吨按钮置灰。称毛时可用.外购订单,不出现返回加减吨的按钮 -->
         <u-button type="primary"
            text="确定称重"
            :disabled="realTimeWeigh == 0 || globalinfraredStatus || isweigh || !isInputOrigin"
            :disabled="realTimeWeigh == 0 || globalinfraredStatus || isweigh "
            :loading="isConfirmWeighLoading"
            loadingText="确认"
            @click="confirmWeigh"></u-button>
@@ -182,8 +149,13 @@
            @click="addAndSubtractCoal"
            class="jiajian"
            v-if="outBuy"></u-button>
         <u-button type="primary"
            text="继续卸货"
            @click="UnloadingAgainHandle"
            :loading="UnloadingAgainLoading"
            loadingText="确认"
            v-if='canUnload'></u-button>
      </view>
      <!-- <view class="four" v-if="weighList.orderType !== '外购'">如您需要调整装载货品吨数,请点击返回加减吨</view> -->
      <!-- 放空弹窗 -->
      <view class="evacuationModal">
         <u-modal :show="evacuationModalShow"
@@ -233,9 +205,9 @@
               weigh: 0,
               tmCode: '',
               sceneInOut: '',
               coalContactClean: 0,
               coalContactHair: 0,
               coalContactSkin: 0
               // coalContactClean: 0,
               // coalContactHair: 0,
               // coalContactSkin: 0
            },
            // 是否填写原发信息
            isInputOrigin: false,
@@ -248,9 +220,9 @@
            weighList: {},
            // 临时称重对象
            temporaryWeighObj: {
               skin: 0,
               hair: 0,
               clean: 0
               skin: null,
               hair: null,
               clean: null
            },
            infraredStatus: false, // 红外状态,
            // 放空控制
@@ -270,48 +242,38 @@
            // 聚焦时改变样式
            isfocus1: false,
            isfocus2: false,
            // 外购第一次称毛重不需要加减吨
            outBuy: true
            // 外购类型
            outBuy: true,
            // 继续卸货按钮
            canUnload: false,
            UnloadingAgainLoading: false
         };
      },
      watch: {
         realTimeWeigh(newV, oldV) {
            if (this.weighList.orderType == '外销' || this.weighList.orderType == '内销' || this.weighList.orderType ==
               '转出') {
               if (this.weighList.skin == 0) {
                  // this.temporaryWeighObj.skin = this.realTimeWeigh;
               if (!this.showWeigh.skin) {
                  this.temporaryWeighObj.skin = newV;
                  this.isweigh = this.temporaryWeighObj.skin > this.weighList.orderSurplus;
               } else {
                  // this.temporaryWeighObj.hair = this.realTimeWeigh;
                  this.temporaryWeighObj.hair = newV;
                  this.temporaryWeighObj.clean = (this.temporaryWeighObj.hair - this.weighList.skin).toFixed(2);
                  this.temporaryWeighObj.clean = (this.temporaryWeighObj.hair - this.showWeigh.skin).toFixed(2);
                  this.isweigh = this.temporaryWeighObj.clean > this.weighList.orderSurplus || this.temporaryWeighObj
                     .clean < 0;
               }
            } else if (this.weighList.orderType == '外购' || this.weighList.orderType == '内购' || this.weighList
               .orderType == '转入') {
               if (this.weighList.hair == 0) {
                  // this.temporaryWeighObj.hair = this.realTimeWeigh;
               if (!this.showWeigh.hair) {
                  this.temporaryWeighObj.hair = newV;
                  this.isweigh = this.temporaryWeighObj.hair > this.weighList.orderSurplus;
               } else {
                  // this.temporaryWeighObj.skin = this.realTimeWeigh;
                  this.temporaryWeighObj.skin = newV;
                  this.temporaryWeighObj.clean = (this.weighList.hair - this.temporaryWeighObj.skin).toFixed(2);
                  this.temporaryWeighObj.clean = (this.showWeigh.skin - newV).toFixed(2);
                  this.isweigh = this.temporaryWeighObj.clean > this.weighList.orderSurplus || this.temporaryWeighObj
                     .clean < 0;
                     .clean < 0 || this.showWeigh.skin < newV && this.showWeigh.skin > 0;
               }
            }
         },
         // 监听重量变化
         // globalweigh: {
         //    handler(v) {
         //       this.weighData.weigh = this.realTimeWeigh = v;
         //       console.log(this.realTimeWeigh, '真实重量改变了');
         //    },
         //    deep: true
         // },
         globalweigh(newV) {
            this.weighData.weigh = this.realTimeWeigh = newV;
            console.log(this.realTimeWeigh, '真实重量改变了');
@@ -322,27 +284,17 @@
         this.changeisLogin(true)
         this.realTimeWeigh = 0
      },
      onHide() {
      },
      computed: {
         ...mapState(['globalweigh', 'globalinfraredStatus']),
         coalContactClean() {
            return (Number(this.weighData.coalContactHair) - Number(this.weighData.coalContactSkin)).toFixed(2);
         },
         // coalContactClean() {
         //    return (Number(this.weighData.coalContactHair) - Number(this.weighData.coalContactSkin)).toFixed(2);
         // },
         token() {
            return uni.getStorageSync('token');
         },
         // 加减煤按钮禁用与否
         addAndSubtractCoalDisabled() {
            return this.realTimeWeigh == 0;
            // if (this.weighList.orderType == '外销' || this.weighList.orderType == '内销' || this.weighList.orderType == '转出') {
            //    if (this.weighList.hair == 0) {
            //       return true;
            //    } else if (this.weighList.hair != 0) {
            //       return false;
            //    }
            // }
         },
         // 是否放空按钮禁用
         isEvacuation() {
@@ -350,27 +302,34 @@
               '转出') {
               return (this.weighList.skin === 0 ? this.temporaryWeighObj.skin : this.weighList.skin) == this
                  .temporaryWeighObj.hair;
               // return this.weighList.skin == this.temporaryWeighObj.hair || this.temporaryWeighObj.skin == this
               //    .temporaryWeighObj.hair;
            }
            if (this.weighList.orderType == '外购' || this.weighList.orderType == '内购' || this.weighList.orderType ==
               '转入') {
               return (this.weighList.hair === 0 ? this.temporaryWeighObj.skin : this.weighList.hair) == this
                  .temporaryWeighObj.hair;
               // return this.weighList.hair == this.temporaryWeighObj.skin || this.temporaryWeighObj.skin == this
               //    .temporaryWeighObj.hair;
            }
         },
         sideline() {
            return this.weighList.orderType == '内购' || this.weighList.orderType == '转入';
         },
         showWeigh() {
            return this.weighList.tmTaskCoalItems ? (this.weighList.tmTaskCoalItems[0] ? this
               .weighList.tmTaskCoalItems[0] : {}) : {}
         },
         weighHistory() {
            return this.weighList.tmTaskCoalItems ? this.weighList.tmTaskCoalItems : []
         }
      },
      methods: {
         ...mapMutations(['changeweighHouseCode', 'changeisLogin']),
         init() {
            uni.showLoading({
               title: '加载中'
            })
            // 获取称重信息
            this.$reqGet('weighList', { id: this.takeCoalId }).then(res => {
               console.log(res, '获取称重信息');
               uni.hideLoading()
               if (res.code == 0) {
                  this.weighList = res.data;
                  this.weighData.deptId = res.data.deptId;
@@ -378,20 +337,9 @@
                  this.weighData.carNo = res.data.carNo;
                  this.weighData.tmCode = res.data.code;
                  this.weighData.filedId = res.data.filedId;
                  this.weighData.coalContactHair = res.data.hairTwo ? res.data.hairTwo : 0;
                  this.weighData.coalContactSkin = res.data.skinTwo ? res.data.skinTwo : 0;
                  if (this.weighList.orderType == '外购') {
                     this.firstHairCustomernameShow = true;
                     if (this.weighList.hair > 0) {
                        this.haveInputOrigin = true;
                        this.isInputOrigin = true;
                     }
                     if (this.weighList.hair == 0) {
                        this.outBuy = false;
                     }
                  } else {
                     this.isInputOrigin = true;
                  }
                  this.outBuy = (this.weighList.orderType.indexOf('销') !== -1) && this.showWeigh.skin > 0;
                  // 继续卸货只有外购类型第二次会有
                  this.canUnload = this.weighList.orderType === '外购' && this.showWeigh.hair > 0;
               }
            });
         },
@@ -420,7 +368,7 @@
         },
         // 确认称重接口
         saveWeigh() {
            this.weighData.coalContactClean = this.coalContactClean;
            // this.weighData.coalContactClean = this.coalContactClean;
            this.$reqPost('saveWeigh', this.weighData, 'json')
               .then(res => {
                  console.log(res, '称重接口');
@@ -449,6 +397,11 @@
               carNo: this.weighData.carNo,
               tmId: this.weighData.tmId,
               filedId: this.weighData.filedId,
               tmId: this.weighData.tmId,
               gateCameraId: this.weighData.gateCameraId,
               equipmentCode: this.weighData.equipmentCode,
               tmCode: this.weighData.tmCode,
               sceneInOut: this.weighData.sceneInOut,
               weigh: this.realTimeWeigh
            }, 'json').then(res => {
               if (res.code == 0) {
@@ -460,8 +413,39 @@
                     this.isConfirmWeighLoading = false;
                  }, 1000);
                  console.log(res, '加减煤');
               } else {
                  this.$u.toast('操作失败,请稍候重试');
               }
            });
         },
         // 继续卸货
         UnloadingAgainHandle() {
            this.UnloadingAgainLoading = true
            this.$reqPost('continueWeigh', {
               deptId: this.weighData.deptId,
               sceneId: this.weighData.sceneId,
               carNo: this.weighData.carNo,
               tmId: this.weighData.tmId,
               filedId: this.weighData.filedId,
               tmId: this.weighData.tmId,
               gateCameraId: this.weighData.gateCameraId,
               equipmentCode: this.weighData.equipmentCode,
               tmCode: this.weighData.tmCode,
               sceneInOut: this.weighData.sceneInOut,
               weigh: this.realTimeWeigh
            }, 'json').then(res => {
               this.UnloadingAgainLoading = false
               if (res.code == 0) {
                  this.$u.toast('操作成功,即将返回上一页');
                  setTimeout(() => {
                     uni.navigateBack({
                        delta: 1
                     });
                  }, 1000);
               } else {
                  this.$u.toast('操作失败,请稍候重试');
               }
            })
         },
         // 放空
         evacuation() {
@@ -484,24 +468,6 @@
         evacuationCancel() {
            this.evacuationModalShow = false;
         },
         // input聚焦
         inputFocus(v) {
            if (v == 1) {
               this.isfocus1 = true;
            } else {
               this.isfocus2 = true;
            }
         },
         // input失焦
         inputBlur() {
            this.isfocus1 = false;
            this.isfocus2 = false;
         },
         inputChange() {
            if (this.weighData.coalContactHair > 0 && this.weighData.coalContactSkin > 0) {
               this.isInputOrigin = true;
            }
         }
      }
   };
</script>
@@ -514,16 +480,91 @@
      align-items: center;
   }
   // 称重历史
   .weighHistory-enter-active,
   .weighHistory-leave-active {
      transition: opacity 0.5s ease;
   }
   .weighHistory-enter-from,
   .weighHistory-leave-to {
      opacity: 0;
   }
   .weigh-history {
      width: 690rpx;
      height: 100%;
      min-height: 420rpx;
      margin: vww(10) auto vww(20);
      background: #ffffff;
      box-shadow: 4rpx 6rpx 51rpx 0rpx rgba(73, 120, 240, 0.11);
      border-radius: 20rpx;
      position: relative;
      font-size: 30rpx;
      font-weight: 300;
      color: #303030;
      overflow: hidden;
      .block-main {
         display: grid;
         grid-template-columns: auto;
         grid-template-rows: repeat(auto-fit, minmax(40rpx, 1fr));
         width: 94%;
         height: 100%;
         min-height: 380rpx;
         margin: vww(18) vww(7) vww(11) vww(17);
         gap: 10rpx 20rpx;
         .weigh-item {
            width: 100%;
            height: vww(80);
            @include flex;
            flex-direction: column;
            justify-content: space-around;
            align-items: flex-start;
            .item-block {
               width: 100%;
               height: vww(36);
               @include flex;
               justify-content: space-around;
               .item {
                  min-width: vww(50);
                  height: vww(45);
                  font-size: 21rpx;
                  font-weight: 400;
                  color: #ffffff;
                  text-align: center;
                  line-height: vww(30);
                  @include flex;
                  .concrete {
                     width: vww(36);
                     height: vww(36);
                  }
                  .num {
                     font-size: 40rpx;
                     font-weight: 300;
                     color: #303030;
                  }
               }
            }
         }
      }
   }
   ::v-deep.weighingDevice {
      width: 100%;
      height: 100vh;
      height: 100%;
      display: flex;
      flex-direction: column;
      .one {
         // flex: 3;
         height: 290rpx;
         margin: vww(20) vww(20) 0 vww(20);
         margin: vww(20);
         border-radius: vww(15);
         .top {
@@ -676,7 +717,7 @@
         width: calc(100% - 60rpx);
         box-sizing: border-box;
         height: 630rpx;
         margin: 0 vww(15) vww(45) vww(15);
         margin: 0 vww(15) vww(15) vww(15);
         background: #ffffff;
         box-shadow: 0rpx 0rpx 14rpx 0rpx rgba(73, 120, 240, 0.14), 0rpx 7rpx 45rpx 0rpx rgba(73, 120, 240, 0.12);
         border-radius: 20rpx;
@@ -718,19 +759,16 @@
      }
      .three {
         margin: 0 auto vww(20);
         flex: 0.7;
         display: flex;
         margin: 0 auto vww(5);
         width: 96%;
         display: grid;
         grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
         justify-content: center;
         gap: vww(10);
         color: #939393;
         .u-button {
            &:nth-of-type(2) {
               margin-left: vww(10);
            }
            &:nth-of-type(3) {
               margin-left: vww(10);
            }
            width: vww(90);
         }
      }