yyb
2025-06-10 4d98f85da66a261583894af65ad9f53d8017bbf6
pages/wareHouse/moveWareHouse/index.vue
@@ -1,525 +1,417 @@
<template>
   <view class="page">
      <view class="movewarehouse-index-bg"/>
      <u-navbar title="移库" :background="background" :border-bottom="false" :title-bold="true" title-color="#000" back-icon-color="#000"/>
      <view class="movewarehouse-index-search">
         <!--<u-search v-model="keywords" shape="square" bg-color="rgba(250,252,255,0.36)" :show-action="false" placeholder="请输入库位号" @clear="search" @custom="search" @search="search">
         </u-search>-->
         <view class="movewarehouse-index-search-view">
            <view class="movewarehouse-index-search-view-item">
               <text class="item-one">至库位号</text>
              <text class="item-one-content">{{tolocationNo}}</text>
             </view>
            <view class="movewarehouse-index-search-view-item" @click="seachLocationNo()">
               <text class="item-two">请选择</text>
                <u-icon name="arrow-right" color="#2979ff" size="28"></u-icon>
            </view>
         </view>
      </view>
       <view class="wrap">
         <scroll-view class="movewarehouse-index-scroll-list" scroll-y="true">
            <u-cell-group class="movewarehouse-index-scroll-list-group" :border="false">
               <view class="content" v-for="(item, index) in list" :key="item.id" :index="index">
                  <view class="content-header">
                     <view class="header-item">
                        <view class="content-header-icon-one"></view>
                        <view class="content-header-title">{{ item.partNo }}</view>
                     </view>
                     <view class="header-item">
                        <view class="content-header-icon-two"></view>
                        <view class="content-header-title">{{ item.partBatchNo }}</view>
                     </view>
                     <view class="header-item-toolbar" @click="deleteHandle(item)">
                        <view class="header-item-toolbar-del-icon">
                        </view>
                        <view class="header-item-toolbar-del-text">
                           删除
                        </view>
                     </view>
                  </view>
                  <!--<view class="row-img" @click="deleteHandle(item)">
                     <u-image width="18px" height="18px" src="@/static/custom/delete.png"></u-image>
                  </view>-->
                  <view class="content-body">
                     <view class="row-list">
                        <view class="_label">
                           零件名称:
                        </view>
                        <view class="_content">
                           {{ item.partName }}
                        </view>
                     </view>
                     <view class="row-list">
                        <view class="_label">
                           从库位号:
                        </view>
                        <view class="_content">
                           {{ item.locationNo }}
                        </view>
                     </view>
                     <view class="row-list">
                        <view class="_label">
                           至库位号:
                        </view>
                        <view class="_content">
                           {{ item.arriveLocationNo }}
                        </view>
                     </view>
                     <view class="row-list">
                        <view class="_label">
                           可用库存:
                        </view>
                        <view class="_content">
                           <text class="_content-text">{{ item.availableStockQuantity }}</text>
                            ({{ item.unit }})
                        </view>
                     </view>
                     <view class="row-list">
                        <view class="_label">
                           移库库存:
                        </view>
                        <view class="_content _input">
                           <u-input placeholder="请输入移库数量" v-model="item.moveQty" type="digit"></u-input>
                           <view class="edit_icon"></view>
                        </view>
                     </view>
                  </view>
               </view>
            </u-cell-group>
         </scroll-view>
         <scan></scan>
         <view class="new-form-footer" v-if="list.length>0">
            <u-button class="btn" type="primary" @click="submit">提交</u-button>
         </view>
      </view>
  <view class="page">
    <view class="movewarehouse-index-bg" />
    <u-navbar
      title="移库"
      :background="background"
      :border-bottom="false"
      :title-bold="true"
      title-color="#000"
      back-icon-color="#000"
    />
    <view class="packing-registration-param">
      <view class="packing-registration-param-view">
        <view class="packing-registration-param-item param-extra">
          <view class="packing-registration-param-item-left">
            <text class="item-one">库位</text>
          </view>
          <view class="packing-registration-param-item-right">
            <text class="item-one item-two">{{ registerInfo.storageLocation == '' ? "请扫描库位" : registerInfo.storageLocation }}</text>
          </view>
        </view>
        <view class="packing-registration-param-item param-extra">
          <view class="packing-registration-param-item-left">
            <text class="item-one">{{
              `移库记录(${registerInfo.num}条):`
            }}</text>
          </view>
        </view>
      </view>
    </view>
    <view class="wrap">
      <scroll-view class="packing-registration-scroll-list" scroll-y="true">
        <u-cell-group
          class="packing-registration-scroll-list-group"
          :border="false"
        >
          <!-- <div class="tip" style="text-align: center;" v-if="hasScanSnList.length==0">-请扫码-</div> -->
          <view
            class="content"
            v-for="(item, index) in hasScanSnList"
            :key="index"
            :index="index"
          >
            <view class="content-header">
              <view class="content-header-title">{{ index + 1 }}</view>
            </view>
            <view class="content-body">
              <view class="row-list">
                <view class="_label">
                  <view class="_label-name">零件号:</view>
                </view>
                <view class="_content">
                  {{ item.value0 }}
                </view>
              </view>
              <view class="row-list">
                <view class="_label">
                  <view class="_label-name">批次号:</view>
                </view>
                <view class="_content">
                  {{ item.value1 }}
                </view>
              </view>
              <view class="row-list">
                <view class="_label">
                  <view class="_label-name">库位号:</view>
                </view>
                <view class="_content">
                  {{ item.value0 }}
                </view>
              </view>
              <view class="row-list">
                <view class="_label">
                  <view class="_label-name">盘点数量:</view>
                </view>
                <view class="_content">
                  {{ item.value1 }}
                </view>
              </view>
            </view>
          </view>
        </u-cell-group>
      </scroll-view>
    </view>
    <u-modal
      v-model="showModal"
      title=""
      :show-cancel-button="true"
      :show-confirm-button="true"
      @confirm="confirm"
      @cancel="cancel"
    >
      <view class="popup-content">
        <view class="packing-registration-param">
          <view class="packing-registration-param-view">
            <view class="packing-registration-param-item param-extra">
              <view class="packing-registration-param-item-left">
                <text class="item-one">批号</text>
              </view>
              <view class="packing-registration-param-item-right">
                <text class="item-one item-two">{{ 111 }}</text>
              </view>
            </view>
            <view class="packing-registration-param-item param-extra">
              <view class="packing-registration-param-item-left">
                <text class="item-one">零件描述</text>
              </view>
              <view class="packing-registration-param-item-right">
                <text class="item-one item-two">{{ 111 }}</text>
              </view>
            </view>
            <view class="packing-registration-param-item param-extra">
              <view class="packing-registration-param-item-left">
                <text class="item-one">WDR</text>
              </view>
              <view class="packing-registration-param-item-right">
                <text class="item-one item-two">{{ 111 }}</text>
              </view>
            </view>
            <view class="packing-registration-param-item param-extra">
              <view class="packing-registration-param-item-left">
                <text class="item-one">现有数量</text>
              </view>
              <view class="packing-registration-param-item-right">
                <text class="item-one item-two">{{ 111 }}</text>
              </view>
            </view>
            <view class="packing-registration-param-item param-extra">
              <view class="packing-registration-param-item-left">
                <text class="item-one">当前库位</text>
              </view>
              <view class="packing-registration-param-item-right">
                <text class="item-one item-two">{{ 111 }}</text>
              </view>
            </view>
          </view>
        </view>
      </view>
    </u-modal>
    <scan></scan>
  </view>
</template>
<script>
   import scan from "@/components/scan/scan.vue";
    import content_bg from '@/static/custom/moveWareHouse/locNoBg.png'
   export default {
      components: {
         scan
      },
      data() {
         return {
            background:{
               backgroundImage: `url(${content_bg})`,
               backgroundAttachment: 'fixed',
               backgroundSize: '100% auto',
               backgroundRepeat: 'no-repeat',
            },
            list: [],
            tolocationNo: "",
            keywords:''
         };
      },
      onLoad() {
         // this.loadList("221206000739N");
         // let data = '{"part_no":"88.118.1/A0047954","lot_batch_no":"221112000082N","qty_arrived":0.5,"wdr":"221112000082N"}'
         // let data = '221206000739N'
         // let sn = ''
         // if (data.indexOf('{') >= 0) {
         //    //大标签二位码
         //    sn = JSON.parse(data).lot_batch_no
         // } else {
         //    //小标签条码
         //    sn = data
         // }
         // console.log(sn);
      },
      onShow() {
import scan from "@/components/scan/scan.vue";
import content_bg from "@/static/custom/moveWareHouse/locNoBg.png";
export default {
  components: {
    scan,
  },
         let that = this
         uni.$off('scan') // 每次进来先 移除全局自定义事件监听器
         uni.$on('scan', function(data) {
            console.log('onscan');
            //扫码成功后的回调,你可以写自己的逻辑代码在这里
            console.log('扫码结果:', data.code);
            if (data.code != "" && (that.tolocationNo == "")) {
               uni.showToast({
                  title: '请选择至库位号',
                  icon: 'none'
               })
               return
            }
            let sn = ''
            if (data.code.indexOf('{') >= 0) {
               //大标签二位码
               let snNoIndex=data.code.indexOf('sn_no')
               if(snNoIndex>-1){
                  sn = JSON.parse(data.code).sn_no
               }else{
                  sn = JSON.parse(data.code).lot_batch_no
               }
            } else {
               //小标签条码
               sn = data.code
            }
            //判断数组中是否存在  SN 是否已经存在
            let initList = that.list.filter(item => item
               .partBatchNo == sn)
            if (initList.length > 0) {
               uni.showToast({
                  title: "SN:" + sn + ",已存在,请选择另一个SN号",
                  icon: "none"
               });
               return
            }
            that.loadList(sn);
         })
      },
      onNavigationBarButtonTap(e) {
         uni.scanCode({
            success: res => {
               try {
                  const result = JSON.parse(res.result)
               } catch (e) {}
            }
         });
      },
      methods: {
         //至库位
         seachLocationNo() {
            uni.navigateTo({
               url: '/pages/wareHouse/moveWareHouse/locNoList'
            })
         },
         loadList(sanCode) {
            uni.showLoading({
               mask: true,
               title: "加载中",
            });
            let that = this
            if (sanCode != "") {
               let data = {
                  sn: sanCode
               }
               //判断数组中是否存在 至库位号 SN
               let initList = that.list.filter(item => item.arriveLocationNo == that.tolocationNo).filter(item => item
                  .partBatchNo == sanCode)
               if (initList.length > 0) {
                  uni.showToast({
                     title: "库位号:" + that.tolocationNo + ",SN:" + sanCode + ",已经扫过码",
                     icon: "none"
                  });
                  return
               }
               // 查询移库信息
               that.$u.api.pigxWareHouse.list(data).then(res => {
                  let reList = []
                  reList = res.data
                  if (reList.length == 0) {
                     uni.showToast({
                        title: "库位号:" + that.tolocationNo + ",SN:" + sanCode + ",未扫到移库信息",
                        icon: "none"
                     });
                  } else {
                     for (let i = 0; i < reList.length; i++) {
                        if (reList[i].locationNo !== that.tolocationNo) {
                           let item = {
                              id: reList[i].id,
                              partNo: reList[i].partNo,
                              partName: reList[i].partName,
                              partBatchNo: reList[i].partBatchNo,
                              ifsBatchNo: reList[i].ifsBatchNo,
                              unit: reList[i].unit,
                              locationNo: reList[i].locationNo,
                              availableStockQuantity: reList[i].availableStockQuantity,
                              arriveLocationNo: that.tolocationNo,
                              moveQty: 0
                           }
                           that.list.push(item)
                        }
                     }
                  }
                  uni.hideLoading();
               })
            }
         },
         //至库位号设置
         setNo(no) {
            this.tolocationNo = no
         },
         deleteHandle(obj) {
            let that = this
            uni.showModal({
               title: '提示',
               content: '此操作将删除该移库信息, 是否继续?',
               success: function(res) {
                  if (res.confirm) {
                     that.list.map((item, index) => {
                        if (obj.id == item.id) {
                           that.list.splice(index, 1)
                        }
                     });
                  }
               }
            });
         },
         submit() {
            let that = this
            that.list.map((item) => {
               if (item.moveQty <= 0) {
                  uni.showToast({
                     title: '请移库数量必须大于0',
                     icon: "none"
                  });
                  return
               }
               if (item.moveQty > item.availableStockQuantity) {
                  uni.showToast({
                     title: '移库数量不能大于可用库存数量',
                     icon: "none"
                  });
                  return
               }
            });
            let subList = []
            that.list.map((item) => {
               let sub = {
                  stockId: item.id,
                  arriveLocationNo: item.arriveLocationNo,
                  moveQty: item.moveQty
               }
               subList.push(sub)
            });
            that.$u.api.pigxWareHouse.addList(subList).then(res => {
               if (res.code == 0) {
                  uni.showModal({
                     title: '提示',
                     content: '提交成功',
                     showCancel: false,
                     success: function() {
                        that.list = []
                        that.tolocationNo = ""
                     }
                  })
               } else {
                  uni.showModal({
                     title: '提示',
                     content: '提交失败',
                     showCancel: false,
                     success: function() {
                     }
                  })
               }
            })
         },
      }
   };
  data() {
    return {
      background: {
        backgroundImage: `url(${content_bg})`,
        backgroundAttachment: "fixed",
        backgroundSize: "100% auto",
        backgroundRepeat: "no-repeat",
      },
      registerInfo: {
        storageLocation: "",
        num: 0,
      },
      showModal: true, // 控制弹窗显示隐藏的变量
      hasScanSnList: [
        {
          value0: "11111111111111111111111",
          value1: "111",
          value2: "111",
          value3: "111",
        },
        {
          value0: "111",
          value1: "111",
          value2: "111",
          value3: "111",
        },
        {
          value0: "111",
          value1: "111",
          value2: "111",
          value3: "111",
        },
        {
          value0: "111",
          value1: "111",
          value2: "111",
          value3: "111",
        },
        {
          value0: "111",
          value1: "111",
          value2: "111",
          value3: "111",
        },
      ],
    };
  },
  onLoad() {},
  onShow() {
    let that = this;
    uni.$off("scan"); // 每次进来先 移除全局自定义事件监听器
    uni.$on("scan", function (data) {
      console.log("onscan");
      //扫码成功后的回调,你可以写自己的逻辑代码在这里
      console.log("页面扫码结果:", data.code);
      if (data.code) {
        let codeInfo = JSON.parse(data.code);
        if (codeInfo.WorkNo) {
          // 扫描报工单二维码
          that.saveForm(codeInfo);
        }
      }
    });
  },
  methods: {
    confirm() {
      // 处理确认逻辑
      this.show = false;
    },
    cancel() {
      this.show = false; // 关闭弹窗
    },
        // 回显扫码的信息-报工单
    saveForm(val) {
      let { WorkNo, ProcessName, ORDER_NO } = val
      this.form.value1 = WorkNo
      this.form.value2 = ProcessName
      this.form.value3 = ORDER_NO
    }
  },
};
</script>
<style lang="scss" scoped>
   .movewarehouse-index-bg{
      background-color: #F6F9FF;
      background-image: url('~@/static/custom/moveWareHouse/locNoBg.png');
      // background: linear-gradient(180deg,rgba(206,227,254,1),rgba(206,227,254,1) 20%,rgba(206,227,254,0.5) 40%,rgba(206,227,254,0.25) 60%,rgba(206,227,254,0.08) 80%,rgba(206,227,254,0));
      padding: 0 20rpx;
      background-attachment: fixed;
      background-size: 100% auto;
      background-repeat: no-repeat;
      position: fixed;
      top: 0;
      bottom: 0;
      width: 100%;
      z-index: -1;
   }
   .movewarehouse-index-search{
      padding: 40rpx 30rpx 20rpx 30rpx;
   }
   .movewarehouse-index-search-view{
      height: 66rpx;
      border: 1px solid #ADC8E4;
      border-radius: 8rpx;
      background: rgba(250,252,255,0.36);
      line-height: 66rpx;
      padding-left:33rpx;
      padding-right:10rpx;
      display:flex;
      justify-content: space-between;
      .movewarehouse-index-search-view-item{
         .item-one{
            font-size: 30rpx;
            color: #283E65;
         }
         .item-one-content{
            margin-left: 10rpx;
            color: #909399;
            font-size: 26rpx;
         }
         .item-two{
            font-size: 30rpx;
            color: #A6B4CC;
         }
      }
   }
   .wrap .movewarehouse-index-scroll-list{
      height:calc(100vh - var(--window-top) - var(--window-bottom) - 378rpx);
       width:100%;
   }
   .movewarehouse-index-scroll-list-group{
      ::v-deep .u-cell-item-box {
         background-color:rgba(250,252,255,0.36) !important;
         padding:0rpx 30rpx ;
       }
      .content {
         font-size: 12px;
         background-color: #FFFFFF;
         box-sizing: border-box;
         border-radius: 10rpx;
         margin: 0rpx 0rpx 16rpx;
         height: 432rpx;
         padding: 10rpx 20rpx;
         box-shadow:0rpx 6rpx 12rpx 2rpx rgba(127, 127, 127, 0.1) !important;
         position:relative;
         .content-header{
            .header-item{
               height: 50rpx;
               display: flex;
               align-items:center;
               .content-header-icon-one{
                  background-image: url('~@/static/custom/moveWareHouse/label-icon-1.png');
                  background-size: 100% auto;
                  background-repeat: no-repeat;
                  height:28rpx;
                  width:28rpx;
               }
               .content-header-icon-two{
                  background-image: url('~@/static/custom/moveWareHouse/header_icon.png');
                  background-size: 100% auto;
                  background-repeat: no-repeat;
                  height:28rpx;
                  width:28rpx;
               }
               .content-header-title{
                  margin-left: 11rpx;
                  font-size: 26rpx;
                  font-weight: bold;
                  color: #333333;
               }
             }
            .header-item-toolbar{
               position: absolute;
               background-image: url('~@/static/custom/moveWareHouse/del-icon.png');
               background-size: 100% auto;
               background-repeat: no-repeat;
               height:60rpx;
               width:140rpx;
               right:0;
               top:0;
               display: flex;
               justify-content: flex-end;
               padding-top: 10rpx;
               padding-right: 18rpx;
               .header-item-toolbar-del-icon{
                  background-image: url('~@/static/custom/moveWareHouse/icon_dele.png');
                  background-size: 100% auto;
                  background-repeat: no-repeat;
                  height:25rpx;
                  width:22rpx;
                  margin-top: 5rpx;
               }
               .header-item-toolbar-del-text{
                  margin-left:7rpx;
                  height: 23rpx;
                  font-size: 24rpx;
                  color: #FFFFFF;
               }
            }
         }
         .content-body{
            height:300rpx;
            background: #F5F9FF;
            border-radius: 10rpx;
            padding: 25rpx 23rpx;
            .row-list {
               height: 50rpx;
               display: flex;
               flex-direction: row;
               padding: 0px;
               align-items: center;
               justify-content: space-between;
            }
            .row-list ._label {
               display: flex;
               color: #666666;
               font-size:26rpx;
               align-items: center;
               width: 170rpx;
            }
            .row-list ._content {
               text-align: right;
               color: #909399;
               font-size: 24rpx;
               ._content-text{
                  color:#214ded;
               }
            }
            .row-list ._input {
               display: flex;
               justify-content: space-between;
               align-items: center;
               border-bottom: 1px solid #4FA0FF;
               height: 56rpx;
               .edit_icon{
                  background-image: url('~@/static/custom/finishProductIn/icon_edit.png');
                  background-size: 100% auto;
                  background-repeat: no-repeat;
                  height:26rpx;
                  width:26rpx;
               }
               ::v-deep .uni-input-input{
                  color:#D35651;
               }
            }
         }
      }
   }
.person-btn-view {
  display: flex;
  justify-content: space-between;
  margin-top: 300rpx;
}
    .new-form-footer{
      display: flex;
      margin-top: 10rpx;
      margin-bottom: 10rpx;
      margin-left: 20rpx;
      margin-right: 20rpx;
      padding-bottom: 14rpx;
      .btn {
        flex: 1;
        margin: 10rpx;
        background: #214DED;
        box-shadow: 0rpx 6rpx 8rpx 0rpx rgba(4,49,212,0.3);
        font-weight: bold;
        color: #FEFEFE;
        font-family: PingFang SC;
      }
   }
</style>
.popup-content {
  width: 600rpx;
  height: 500rpx;
  background-color: #fff;
  border-radius: 8px;
  z-index: 10;
  /* 确保内容在蒙版之上 */
}
.movewarehouse-index-bg {
  background-color: #f6f9ff;
  background-image: url("~@/static/custom/moveWareHouse/locNoBg.png");
  // background: linear-gradient(180deg,rgba(206,227,254,1),rgba(206,227,254,1) 20%,rgba(206,227,254,0.5) 40%,rgba(206,227,254,0.25) 60%,rgba(206,227,254,0.08) 80%,rgba(206,227,254,0));
  padding: 0 20rpx;
  background-attachment: fixed;
  background-size: 100% auto;
  background-repeat: no-repeat;
  position: fixed;
  top: 0;
  bottom: 0;
  width: 100%;
  z-index: -1;
}
.packing-registration-param {
  padding: 40rpx 30rpx 10rpx 30rpx;
  .packing-registration-param-title {
    display: flex;
    flex-direction: row;
    align-items: center;
    margin-bottom: 30rpx;
    .title-label {
      margin-left: 14rpx;
      font-size: 34rpx;
      font-weight: bold;
      color: #283e65;
    }
  }
  .packing-registration-param-view {
    height: 177rpx;
    background-color: #fff;
    border-radius: 10rpx;
    padding: 0rpx 23rpx;
    margin-bottom: 30rpx;
    .packing-registration-param-item {
      height: 90rpx;
      border: 1px solid #adc8e4;
      line-height: 90rpx;
      display: flex;
      justify-content: space-between;
      border: none;
      .packing-registration-param-item-left {
        .item-one {
          font-size: 30rpx;
          color: #666666;
        }
      }
      .packing-registration-param-item-right {
        display: flex;
        justify-content: space-between;
        .item-one {
          font-size: 30rpx;
          color: #333333;
          margin-right: 6rpx;
        }
        .item-two {
          font-size: 30rpx;
          color: #a6b4cc;
          margin-right: 6rpx;
        }
        .item-three {
          font-size: 30rpx;
          color: #214ded;
          margin-right: 6rpx;
        }
      }
    }
    .param-extra {
      border-bottom: 1px solid #ededed;
    }
  }
}
.wrap .packing-registration-scroll-list {
  height: calc(100vh - var(--window-top) - var(--window-bottom) - 360rpx);
  width: 100%;
}
.packing-registration-scroll-list-group {
  ::v-deep .u-cell-item-box {
    background-color: rgba(250, 252, 255, 0.36) !important;
    padding: 0rpx 30rpx;
  }
  .content {
    font-size: 12px;
    background-color: #ffffff;
    box-sizing: border-box;
    border-radius: 10rpx;
    margin: 0rpx 0rpx 16rpx;
    padding: 20rpx 8rpx;
    box-shadow: none;
    display: flex;
    align-items: center;
    .content-header {
      width: 40rpx;
      height: 90rpx;
      display: flex;
      align-items: center;
      .content-header-icon {
        background-image: url("~@/static/custom/moveWareHouse/header_icon.png");
        background-size: 100% auto;
        background-repeat: no-repeat;
        height: 28rpx;
        width: 28rpx;
      }
      .content-header-title {
        margin-left: 11rpx;
        font-size: 26rpx;
        font-weight: bold;
        color: #626369;
      }
    }
    .content-body {
      flex: 1;
      background-color: #ffffff;
      border-radius: 10rpx;
      padding: 0rpx 23rpx;
      .row-list {
        height: 60rpx;
        display: flex;
        flex-direction: row;
        padding: 0px;
        align-items: center;
      }
      .row-list ._label {
        display: flex;
        flex: 0.8;
        color: #909399;
        align-items: center;
        ._label-name {
          margin-left: 11rpx;
          font-size: 26rpx;
          font-weight: 500;
          color: #666666;
        }
      }
      .row-list ._content {
        flex: 1.5;
        text-align: right;
        color: #909399;
        font-size: 24rpx;
      }
      .row-list .s1 {
        color: #d35651;
      }
    }
  }
}
</style>