222
schangxiang@126.com
2024-12-14 f1d82d4646a78092f04204995a01c381ed77242f
LA24030_LuLiPackageLine_Pda/pages/artificial/artificial.vue
@@ -1,799 +1,470 @@
<template>
   <view style="padding-bottom:150px" class="boxTip">
      <cu-custom bgColor="bg-white" :isBack="true">
         <block slot="backText">
         </block>
         <block slot="content">组盘</block>
      </cu-custom>
      <!-- <view class="flex justify-end align-center padding_right30rpx padding_top12rpx">
         <text class="fontSize12rpx"> 操作人:{{operator}} </text>
      </view> -->
      <u-form labelPosition="left" label-width="180rpx" :model="warehouse" ref="warehouseRef">
  <view class="overflow" style="padding-bottom: 150rpx">
    <cu-custom bgColor="bg-white" :isBack="true">
      <block slot="backText"> </block>
      <block slot="content">板件查看</block>
    </cu-custom>
    <u-form
      labelPosition="left"
      label-width="180rpx"
      :model="warehouse"
      ref="warehouseRef"
    >
      <!-- <u-row
        class="border_bottom margin_top10rpx padding_left25rpx"
        style="background-color: #fff"
      >
        <u-col span="12">
          <u-form-item
            label="包装号:"
            prop="packageCode"
            required
            class="uFormItem"
            <u-input
          >
              v-model.trim="warehouse.packageCode"
              @confirm="getContainerData(1)"
              placeholder="请录入或扫码"
              class="width"
              :focus="curFoucus"
            >
            </u-input>
          </u-form-item>
        </u-col>
      </u-row> -->
      <u-row
        class="border_bottom margin_top10rpx padding_left25rpx"
        style="background-color: #fff"
      >
        <u-col span="12">
          <u-form-item label="部件条码:" class="uFormItem">
            <u-input
              v-model="warehouse.upi"
              ref="materialRef"
              placeholder="请扫码录入"
              @focus="warehouse.upi = ''"
              :focus="curFoucus"
              @confirm="getContainerData"
              style="font-weight: bolder; margin-left: 15rpx"
              class="width padding_left25rpx"
            >
            </u-input>
          </u-form-item>
        </u-col>
      </u-row>
    </u-form>
    <!-- 列表 -->
    <view class="margin_top10rpx">
      <u-swipe-action
        :show="item.show"
        :index="eindex"
        v-for="(item, eindex) in singlist"
        :key="eindex"
        :options="options"
        @click="longpress"
        @open="open"
        @close="close"
        class="margin_bottom10rpx"
      >
        <view class="item u-border-bottom">
          <!-- 此层wrap在此为必写的,否则可能会出现标题定位错误 -->
          <view class="title-wrap">
            <view
              :class="item.checked ? 'bg_item' : ''"
              class="fontSize32rpx width margin_auto background_fff padding10 relative box_sizing transition"
            >
              <u-row>
                <u-col span="12" class="flex align-center">
                  <!-- <u-checkbox v-model="item.checked" size="50rpx"></u-checkbox> -->
                  <view
                    class="flex justify-center align-center"
                    style="
                      background-color: #f18202;
                      color: #fff;
                      border-radius: 50vh;
                      width: 40rpx;
                      height: 40rpx;
                    "
                  >
                    {{ eindex + 1 }}
                  </view>
                  <text class="color_f18202 padding_left10rpx">
                    {{ item.upi }}
                  </text>
                </u-col>
              </u-row>
           <u-row>
             <u-col span="12">
               <text class="color_80 padding_left25rpx">
                 <text class="color_80"> 次序:{{ item.shelf }} </text>
               </text>
             </u-col>
           </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    部件名称: {{ item.detailName }}
                  </text>
                </u-col>
              </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    位置:{{ getAreaCodeEnumName(item.areaCode) }}
                  </text>
                </u-col>
              </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    材料:{{ item.info18 }}
                  </text>
                </u-col>
              </u-row>
         <u-row class="border_bottom margin_top10rpx padding_left25rpx" style="background-color: #fff;">
            <u-col span="12">
               <u-form-item label="容器编号:" prop="containerCode" required class="uFormItem">
                  <u-input :focus="curFoucus" v-model.trim="warehouse.containerCode" @confirm="getMaterialDetails(1)"
                     placeholder="请扫码录入" :disabled="kwbhAllowed" style="font-weight: bolder;margin-left: 15rpx;"
                     class="width padding_left25rpx">
                  </u-input>
               </u-form-item>
            </u-col>
         </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    <text class="color_80"> 尺寸:{{ item.info16 }} </text>
                  </text>
                </u-col>
              </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    板件状态:{{ getEnumName(item.upiStatus) }}
                  </text>
                </u-col>
              </u-row>
            <u-row>
                        <u-col span="12">
                          <text class="color_80 padding_left25rpx">
                            标记:{{ getUpiFlagEnumName(item.upiFlag) }}
                          </text>
                        </u-col>
                      </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    <text class="color_80"> 生产单号:{{ item.info5 }} </text>
                  </text>
                </u-col>
              </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    <text class="color_80">
                      包装编号:{{ item.packageCode }}</text
                    >
                  </text>
                </u-col>
              </u-row>
              <u-row>
                <u-col span="12">
                  <text class="color_80 padding_left25rpx">
                    <text class="color_80"> 批次号:{{ item.planNo }}</text>
                  </text>
                </u-col>
              </u-row>
            </view>
          </view>
        </view>
      </u-swipe-action>
    </view>
    <modal-code :rescode="rescode" :resmessage="resmessage" ref="resmodal" />
         <u-row v-if="warehouse.containerCode" class="border_bottom margin_top10rpx padding_left25rpx"
            style="background-color: #fff;">
            <u-col span="12">
               <u-form-item label="物料跟踪码:" class="uFormItem">
                  <u-input v-model="warehouse.snCode" ref="materialRef" placeholder="请扫码录入"
                     @focus="warehouse.snCode = ''" @confirm="getMaterialDetails"
                     style="font-weight: bolder;margin-left: 15rpx;" class="width padding_left25rpx">
                  </u-input>
               </u-form-item>
            </u-col>
         </u-row>
         <u-row class="border_bottom margin_top10rpx  background_fff padding_left25rpx">
            <u-col span="12">
               <u-form-item label="目标库区:" prop="tray" class="uFormItem">
                  <input v-model="warehouse.areaCode" type="select" placeholder="请选择目标库区" @focus="containerFocus"
                     class="width"></input>
                  <u-action-sheet :list="wolist" v-model="modalshow" @click="confirmXl"></u-action-sheet>
                  <!-- <u-select v-model="modalshow" :list="wolist" @confirm="confirm" value-name="id" label-name="name"></u-select> -->
               </u-form-item>
            </u-col>
         </u-row>
         <u-row class="border_bottom margin_top10rpx padding_left25rpx" style="background-color: #fff;">
            <u-col span="10">
               <u-form-item label="目标库位:" class="uFormItem">
                  <u-input v-model="warehouse.placeCode" placeholder="请扫码录入"
                     style="font-weight: bolder;margin-left: 15rpx;" class="width padding_left25rpx">
                  </u-input>
               </u-form-item>
            </u-col>
            <u-col span="2" @tap="containerFocus2">
               <span class="fontSize15rpx">推荐</span>
               <u-icon name="arrow-right" size="14" class="fontSize15rpx"></u-icon>
            </u-col>
    <u-popup
      v-model="detailshow"
      border-radius="14"
      @close="detailshow = false"
      mode="bottom"
    >
      <h2 class="text_align_center padding_bottom18 padding15">信息</h2>
      <div style="height: 400px; overflow-y: auto; padding: 0 15rpx">
        <view class="line flex justify-between">
          <text class="text-gray">订单号</text>
          <text>{{ materlist.orderId }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">长</text>
          <text>{{ materlist.length }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">宽</text>
          <text>{{ materlist.width }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">厚</text>
          <text>{{ materlist.thk }}</text>
        </view>
        <!-- <view class="line flex justify-between">
          <text class="text-gray">行号</text>
          <text>{{ materlist.lineNumber }}</text>
        </view> -->
        <!-- <view class="line flex justify-between">
        <text class="text-gray">部件纹理</text>
        <text>{{ materlist.Matgrid }}</text>
      </view> -->
        <!-- <view class="line flex justify-between">
        <text class="text-gray">打孔设备编号</text>
        <text>{{ materlist.DRNum }}</text>
      </view> -->
            <view class="boxList" v-show="modalshow2" @click="modalshow2 = false" @touchmove.stop>
               <view class="innerWrap">
                  <ul v-for="(item, eindex) in containerList" :key="eindex">
                     <li @click="confirm2(eindex)"> {{ item.text }}</li>
                  </ul>
               </view>
            </view>
        <!-- <view class="line flex justify-between">
          <text class="text-gray">锯切图号</text>
          <text>{{ materlist.materialIndex }}</text>
        </view> -->
         </u-row>
      </u-form>
      <modal-code :rescode='rescode' :resmessage='resmessage' ref="resmodal" />
      <view style="margin-bottom: 200rpx;" class="margin_top10rpx">
         <view v-for="(item, eindex) in singlist" :key="eindex" class="margin_bottom10rpx">
            <u-swipe-action :show="item.show" :index="eindex" @click="longpress" @open="open" @close='close'
               :options="options" style="width: 100vw;">
               <view class="fontSize32rpx background_fff padding10" :class="item.enAbled == 0 ? 'bg_item' : ''">
                  <u-row>
                     <u-col span="12" class="flex">
                        <text class="flex justify-center align-center circkle06">{{ eindex + 1 }}</text>
                        <text class="color_f18202 padding_left10rpx">
                           {{ item.materialCode }}-{{ item.materialName }}
                        </text>
                        <!-- <u-icon name="plus-circle" v-if="item.enAbled!=1"></u-icon> -->
                     </u-col>
                  </u-row>
                  <u-row>
                     <u-col span="12">
                        <text class="color_80 padding_left25rpx">
                           质检状态:{{ item.qcStatusName }}
                        </text>
                     </u-col>
                  </u-row>
                  <u-row>
                     <u-col span="12">
                        <view class="color_80 padding_left25rpx">
                           <text style="display: inline-block">批次:{{ item.batch }}</text>
                        </view>
                     </u-col>
                  </u-row>
                  <u-row>
                     <u-col span="12">
                        <text class="color_80 padding_left25rpx">
                           跟踪码:{{ item.snCode }}
                        </text>
                     </u-col>
                  </u-row>
                  <u-row>
                     <u-col span="8">
                        <text class="color_80 padding_left25rpx">
        <view class="line flex justify-between">
          <text class="text-gray">包装X坐标</text>
          <text>{{ materlist.machineXCenter }}</text>
        </view>
                        </text>
                     </u-col>
                     <u-col span="4">
                        <text class="color_f18202 ">
                           数量:{{ item.quantity }}
                        </text>
                     </u-col>
                  </u-row>
                  <!-- <u-row>
                     <u-col span="7">
                     </u-col>
                     <u-col span="5" class="flex">
                        <view class="color_80">
                           数量:
                        </view>
                        <input :class="item.enAbled ? '' : 'border_bottom_f18202 inputGray'"
                           class="text-left color_f18202 fontSize32rpx inputGray2" v-model="item.quantity"
                           type="number" :disabled="item.enAbled == 1" @blur="changeNum(item)" @click="clicki(item)"
                           placeholder="0" />
                     </u-col>
                  </u-row> -->
               </view>
            </u-swipe-action>
         </view>
      </view>
      <button-modal :issueShow='true' issueTitle="重置" subTitle='组盘' restTiltle='组盘上架' @reset='goWarhouse' @submit='submit'
         @issue="reset" />
        <view class="line flex justify-between">
          <text class="text-gray">包装Y坐标</text>
          <text>{{ materlist.machineYCenter }}</text>
        </view>
   </view>
        <view class="line flex justify-between">
          <text class="text-gray">包装Z坐标</text>
          <text>{{ materlist.machineZCenter }}</text>
        </view>
        <!-- <view class="line flex justify-between">
          <text class="text-gray">转向角度</text>
          <text>{{ materlist.rotation }}</text>
        </view> -->
        <view class="line flex justify-between">
          <text class="text-gray">层数</text>
          <text>{{ materlist.sequence }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">销售合同单号</text>
          <text>{{ materlist.info4 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">生产单号</text>
          <text>{{ materlist.info5 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">第几包</text>
          <text>{{ materlist.info6 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">经销店名称</text>
          <text>{{ materlist.info7 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">产品名称</text>
          <text>{{ materlist.info8 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">包装编码</text>
          <text>{{ materlist.info9 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">客户名称</text>
          <text>{{ materlist.info10 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">自提或发货</text>
          <text>{{ materlist.info11 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">包装部件总数量</text>
          <text>{{ materlist.info12 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">包装面积</text>
          <text>{{ materlist.info13 }}</text>
        </view>
        <!-- <view class="line flex justify-between">
          <text class="text-gray">部件名称</text>
          <text>{{ materlist.info14 }}</text>
        </view> -->
        <view class="line flex justify-between">
          <text class="text-gray">部件数量</text>
          <text>{{ materlist.info15 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">部件尺寸</text>
          <text>{{ materlist.info16 }}</text>
        </view>
        <view class="line flex justify-between">
          <text class="text-gray">包装机械手旋转</text>
          <text>{{ materlist.info17 }}</text>
        </view>
      </div>
    </u-popup>
    <button-modal
      :subShow="true"
      garmenTitle="重置"
      @submit="rest"
      @reset="rest"
    />
  </view>
</template>
<script>
import ButtonModal from '../../components/buttonModal.vue'
import ModalCode from '../../components/ModalCode.vue'
import ButtonModal from "../../components/buttonModal.vue";
import ModalCode from "../../components/ModalCode.vue";
import {
   getOrderNo,
   addGroupDisk,
   onlyUpdateDutyCycle,
   getareaTypesList,
   getContainDetail,
   getContainerRecord,
   getBhbMaterialList,
   PdaBindListForSNCode,
   getRecommendList
} from '../../api/putIn/artificial.js'
import {
   getDate
} from '../../utils/dateTime.js'
import {
   getAttrValue
} from '../../utils/tool.js'
import {
   bindputawayConfirm
} from '../../api/putaway/putaway.js'
  querySingleUpiByUpi,
  getenumDataList,
} from "../../api/putIn/artificial.js";
export default {
   data() {
      return {
         containerList: [],
         curFoucus: true,
         rescode: 0,
         resmessage: "",
         putCode: '', //容器二维码
         detailshow: false,
         operator: '',
         focu: false, //清空按钮隐显
         focuM: false, //物料隐显按钮
         Datetime: getDate(),
         singlist: [], //物料详情
         wolist: [],
         options: [
            // {
            //    text: '详情',
            //    style: {
            //       backgroundColor: '#fc9f35'
            //    }
            // }
            {
               text: '删除',
               style: {
                  backgroundColor: '#fc4b4b'
               }
            }
         ],
         materlist: {},
         warehouse: {
            containerCode: '',
            materialCode: '',
            storehouseCode: "",
            snCode: "",
            // gridNumber: 1,
            // useNumber: 0,
            // exitNumber: 0,
            // dutyCycle:1
         },
         modalshow: false,
         modalshow2: false,
         gridable: true,
         gridFocus: false,
         detailable: false,
         detailableZb: false,
         batchNo: '', //扫码到的当前物料的批次
         warehouseRules: {
            containerCode: [{
               required: true,
               message: '容器编号不能为空',
               trigger: 'blur'
            }],
            materialCode: [{
               required: true,
               message: '物料编号不能为空',
               trigger: 'blur'
            }]
         },
         orderType: 1,
         warhouseTph: '',
         timerPrint: null,
         kwbhAllowed: false, //是否禁用库位编号
         arrD: [],
         statusTp: {
            'tpStatus': ''
         }
      };
   },
   components: {
      ButtonModal,
      ModalCode
   },
   onLoad(option) {
      if (option.orderType) {
         this.orderType = option.orderType
      }
   },
   onReady() {
      this.$refs.warehouseRef.setRules(this.warehouseRules)
   },
   mounted() {
      this.operator = JSON.parse(uni.getStorageSync('userInfo')).name
      this.getVehicleType()
   },
   computed: {
      containerCode() {
         return this.warehouse.containerCode
      }
   },
   watch: {
      containerCode(val) {
         if (!val) {
            this.detailable = false;
            this.detailableZb = false;
            this.warehouse.exitNumber = 0
         }
      },
      singlist(val) {
         this.warehouse.exitNumber = val.length
      }
   },
   methods: {
      //容器类型聚焦事件
      containerFocus() {
         uni.hideKeyboard()
         this.modalshow = true
      },
      gridBtnClick() {
         this.gridable = !this.gridable
         if (!this.gridable) {
            this.$nextTick(() => {
               this.gridFocus = true;
            })
         } else {
            this.$nextTick(() => {
               this.gridFocus = false;
            })
         }
      },
      //容器编号点击
      containerClick() {
         uni.scanCode({
            scanType: ['barCode', 'qrCode'],
            autoDecodeCharset: true,
            success: (res) => {
               this.warehouse.containerCode = res.result
               this.containerBlur()
            },
            fail: (err) => {
               this.rescode = 400
               this.resmessage = `扫描失败${err}`
               this.$refs.resmodal.show = true
            }
         })
      },
      //容器失焦事件
      containerBlur() {
         Promise.all([this.getContainerRecord(), this.getContainerData()])
      },
      //获取当前容器下组盘记录
      getContainerRecord() {
         this.kwbhAllowed = false
         //每次查询置空材料列表
         this.singlist = [];
         if (this.warehouse.containerCode == '') {
            return
         }
         getContainerRecord({
            containerCode: this.warehouse.containerCode
         }).then(res => {
            if (res.code == 200) {
               this.kwbhAllowed = true
               if (Array.isArray(res.data) && res.data.length > 0) {
                  if (res.data[0].orderNo) {
                     this.putCode = res.data[0].orderNo;
                  }
                  this.warehouse.dutyCycle = res.data[0].dutyCycle; //库存占比 【Editby shaocx,2023-05-22】
                  const recordArr = res.data.reduce((curr, item) => {
                     curr.push({
                        code: item.materialCode,
                        batchNo: item.batchNo,
                        quantityNow: item.quantity,
                        quantity: item.quantity,
                        materialName: item.materialName,
                        materialTypeName: item.materialTypeName,
                        specificationModel: item.specificationModel,
                        id: '',
                        unionCode: item.unionCode,
                        replaceMaterialCode: item.replaceMaterialCode,
                        stockFlagStatus: item.stockFlagStatus,
                        show: false,
                        enAbled: 1 //控制数量是否可以输入
                     })
                     return curr
                  }, [])
                  this.singlist.push(...recordArr)
               }
            } else {
               this.kwbhAllowed = false
            }
  data() {
    return {
      operator: "",
      warehouse: {
        packageCode: "",
        upi: "",
      },
      singlist: [], //详情列表
      ordersId: 0, //当前容器绑定的上架单
      rescode: 0,
      resmessage: "",
      options: [
        {
          text: "详情",
          style: {
            backgroundColor: "#fc9f35",
          },
        },
      ],
      detailshow: false,
      materlist: {},
      curFoucus: true,
      timer: null,
      timerSm: null,
      detailableZb: false,
      detailable: false,
      gridFocus: false,
      gridable: true,
      kwbhAllowed: false,
      enumList: [],
      areaCodeEnum: [],
     upiFlagEnum: [],
    };
  },
  components: {
    ButtonModal,
    ModalCode,
  },
  created() {
    getenumDataList({
      EnumName: "UpiStatusEnum",
    }).then((res) => {
      this.enumList = res.result || [];
    });
    getenumDataList({
      EnumName: "AreaCodeEnum",
    }).then((res) => {
      this.areaCodeEnum = res.result || [];
    });
      getenumDataList({
        EnumName: "UpiFlagEnum",
      }).then((res) => {
        this.upiFlagEnum = res.result || [];
      });
  },
  onLoad() {
    this.operator = JSON.parse(uni.getStorageSync("userInfo")).name;
  },
  mounted() {},
         })
  methods: {
    getEnumName(value) {
      const name = this.enumList.find((item) => item.value === value);
      return name ? name.name : "";
    },
    getAreaCodeEnumName(value) {
      const name = this.areaCodeEnum.find((item) => item.value === value);
      return name ? name.name : "";
    },
     getUpiFlagEnumName(value) {
        const name = this.upiFlagEnum.find((item) => item.value === value);
        return name ? name.name : "";
      },
    // 如果打开一个的时候,不需要关闭其他,则无需实现本方法
    open(index) {
      // 先将正在被操作的swipeAction标记为打开状态,否则由于props的特性限制,
      // 原本为'false',再次设置为'false'会无效
      this.singlist[index].show = true;
      this.singlist.map((val, idx) => {
        if (index != idx) this.singlist[idx].show = false;
      });
    },
    close(index) {
      this.singlist[index].show = false;
    },
    //物料详情
    longpress(index, eindex) {
      this.materlist = this.singlist[index];
      this.detailshow = true;
    },
      },
      //获取容器的信息
      getContainerData() {
         getContainDetail(this.warehouse.containerCode).then(res => {
            const result = res.data.rows;
            if (Array.isArray(result) && result.length == 1) {
               // 虚拟3个都不显示;料箱:显示栅格;钢托:不显示空间占比
               if (res.data.rows[0].isVirtual == 0) { //实物
                  if (res.data.rows[0].wareContainerType == '299120688255045' || res.data.rows[0]
                     .wareContainerType == '293486279884869') { // 钢制容器 塑料容器 -显示占比
                     this.detailableZb = true;
                     this.detailable = false;
                  } else { //料箱 - 显示栅格数
                     this.detailableZb = false;
                     this.detailable = true;
                  }
               } else {
                  this.detailable = false;
                  this.detailableZb = false;
               }
               this.warehouse.gridNumber = res.data.rows[0].gridNumber;
               this.warehouse.useNumber = res.data.rows[0].useNumber;
            } else {
               uni.showToast({
                  title: '库位不存在',
                  icon: 'none',
                  duration: 2000
               });
               this.kwbhAllowed = false
            }
    rest() {
      this.warehouse.upi = "";
      this.singlist = [];
    },
         })
      },
      //物料编码点击
      materialClick() {
         uni.scanCode({
            scanType: ['barCode', 'qrCode'],
            autoDecodeCharset: true,
            success: (res) => {
               this.warehouse.materialCode = getAttrValue(res.result, 'PARTSNUMBER')
               this.batchNo = getAttrValue(res.result, 'LOTNO')
               this.getMaterialDetails()
            },
            fail: (err) => {
               this.rescode = 400
               this.resmessage = `扫描失败${err}`
               this.$refs.resmodal.show = true
            }
         })
      },
      //物料查询
      getMaterialDetails(pram) {
         if (!this.warehouse.containerCode) {
            uni.showToast({
               title: '容器编号不能为空',
               icon: 'none',
               duration: 2000
            })
            return
         }
         //扫容器编号 加载所有物料
         if (pram == 1) {
            this.singlist = [];
            getBhbMaterialList({
               'containerCode': this.warehouse.containerCode,
               'SNCode': this.warehouse.snCode
            }).then((res) => {
               if (res.code == 200) {
                  if (res.result == null) {
                     this.rescode = 400
                     this.resmessage = '查无数据'
                     this.$refs.resmodal.show = true
                     return
                  } else {
                     if (res.result.length == 0) {
                        console.log("空托")
                        this.singlist = [];
                        return
                     } else {
                        console.log("有料")
                        res.result.forEach((item, index) => {
                           item.notDelete = 1 //已组盘的物料 不许删除 要去解绑页面解绑
                        })
                        this.singlist = res.result;
                     }
                  }
               } else {
                  this.resmessage = res.message
                  this.rescode = res.code
                  this.$refs.resmodal.show = true
    //获取
    getContainerData(param) {
      if (!this.warehouse.upi) {
        uni.showToast({
          title: "请扫部件条码",
          icon: "none",
          duration: 2000,
        });
        return;
      }
      querySingleUpiByUpi({
        packageCode: this.warehouse.packageCode,
        upi: this.warehouse.upi,
      }).then((res) => {
        const result = res.result;
        if (Array.isArray(result) && result.length == 0) {
          uni.showToast({
            title: "数据不存在",
            icon: "none",
            duration: 5000,
          });
         this.singlist = [];
          return;
        }
               }
            })
        this.singlist = res.result;
      });
    },
         } else {
            //物料查询
            PdaBindListForSNCode({
               'containerCode': this.warehouse.containerCode,
               'SNCode': this.warehouse.snCode
            }).then((res) => {
               if (res.code == 200) {
                  if (res.result == null || !res.result.stockQuanOutput) {
                     this.rescode = 400
                     this.resmessage = '查无数据'
                     this.$refs.resmodal.show = true
                     return
                  } else {
                     // 根据id 判断物料是否存在
                     var item = res.result.stockQuanOutput;
                     //debugger
                     let index = this.singlist.findIndex(v => v.snCode == item.snCode);
                     if (index == -1) {
                        if (!res.result.validateResult && res.result.validateFailReason) {
                           uni.showModal({
                              title: '提示',
                              content: res.result.validateFailReason,
                              showCancel: true,
                              cancelColor: '#333333',
                              success: (res => {
                                 if (res.confirm) {
                                    this.singlist.unshift({
                                       ...item
                                    })
                                 } else if (res.cancel) {
                                 }
                              })
                           });
                        } else {
                           this.singlist.unshift({
                              ...item
                           })
                        }
                     }
                  }
               } else {
                  this.resmessage = res.message
                  this.rescode = res.code
                  this.$refs.resmodal.show = true
               }
            })
         }
      },
      //删除详情
      longpress(index, eindex) {
         uni.showModal({
            title: '提示',
            content: '是否确认删除?',
            showCancel: true,
            cancelColor: '#333333',
            success: (res => {
               if (res.confirm) {
                  this.singlist[index].cardNum = true
                  if (eindex == 0) { //删除
                     if(this.singlist[index].notDelete==1){
                        uni.showToast({
                           title: '已组盘的物料 不许删除 要去解绑页面解绑',
                           icon: 'none',
                           duration: 2000
                        });
                        return
                     }
                     this.singlist.splice(index, 1)
                  } else {
                     this.materlist = this.singlist[index]
                     this.detailshow = true
                  }
               } else if (res.cancel) {
               }
            })
         });
      },
      //编辑状态样式
      dc(e) {
         e.cardNum = true
         this.$forceUpdate()
      },
      //卡片选中
      clicki(e) {
         e.cardNum = true
         this.$forceUpdate()
      },
      // 如果打开一个的时候,不需要关闭其他,则无需实现本方法
      open(index) {
         // 先将正在被操作的swipeAction标记为打开状态,否则由于props的特性限制,
         // 原本为'false',再次设置为'false'会无效
         this.singlist[index].cardNum = true;
         this.$forceUpdate()
         this.singlist[index].show = true;
         this.singlist.map((val, idx) => {
            if (index != idx) this.singlist[idx].show = false;
         })
      },
      close(index) {
         this.singlist[index].show = false;
         this.singlist[index].cardNum = false;
         this.$forceUpdate()
      },
      //改变组盘数量
      changeNum(val) {
         val.cardNum = false
         if (!val.quantity) {
            uni.showModal({
               title: '提示',
               content: '组盘数量不能为空',
               showCancel: false
            })
         }
         if (val.quantity < 0) {
            uni.showModal({
               title: '提示',
               content: '组盘数量必须大于0',
               showCancel: false
            })
         }
      },
      //全部取消
      reset() {
         this.singlist = [];
         this.warehouse.containerCode = ''
         this.warehouse.snCode = ''
         this.warehouse.areaCode = ''
         this.warehouse.placeCode = ''
         this.$refs.warehouseRef.resetFields();
         this.$forceUpdate()
         this.kwbhAllowed = false
      },
      //重置页面信息
      rest() {
         this.reset()
      },
      //确认
      submit() {
         this.$refs.warehouseRef.setRules(this.warehouseRules)
         this.$refs.warehouseRef.validate(valid => {
            if (valid) {
               let arrN1 = this.singlist.findIndex((v) => v.quantity == '' || v.quantity <= 0)
               if (arrN1 > -1) {
                  uni.showToast({
                     title: '物料数量需要大于0',
                     icon: 'none',
                     duration: 2000
                  });
                  return
               }
               //物料详情
               let matatilDetails = this.singlist;
               let arrSub = matatilDetails.filter((v) => v.enAbled != 1)
               //请求参数
               /// 标记
               /// 1:物料组盘
               /// 2:容器组盘
               /// 3:物料解绑
               /// 4:容器解绑
               let params = {
                  Flag: 1,
                  ContainerCode: this.warehouse.containerCode,
                  orderDetails: arrSub
               }
               uni.showModal({
                  title: '提示',
                  content: '是否确认组盘?',
                  showCancel: true,
                  cancelColor: '#333333',
                  success: (res => {
                     if (res.confirm) {
                        addGroupDisk(params).then(res => {
                           this.warhouseTph = this.warehouse.containerCode;
                           this.rescode = res.code;
                           this.resmessage = res.message || '组盘成功!';
                           this.$refs.resmodal.show = true;
                           this.rest();
                        })
                     } else if (res.cancel) {
                     }
                  })
               });
            }
         })
      },
      // 租盘上架
      goWarhouse() {
         //物料详情
         let matatilDetails = this.singlist;
         let arrSub = matatilDetails.filter((v) => v.enAbled != 1)
         bindputawayConfirm({
            flag:1, //
            "ActionType": 3004, //组盘上架
            "ContainerCode": this.warehouse.containerCode,
            "StorehouseCode": this.warehouse.storehouseCode,
            "areaCode": this.warehouse.areaCode || '',
            "placeCode": this.warehouse.placeCode || '',
            "orderDetails": arrSub
         }).then(res => {
            this.rescode = res.code;
            this.resmessage = res.message || '组盘上架成功!';
            this.$refs.resmodal.show = true;
            this.reset();
         })
         // if(this.warehouse.areaCode==''&&this.warehouse.placeCode){
         //    uni.showToast({
         //       title: '请填写目标库区或目标库位!',
         //       icon: 'none',
         //       duration: 2000
         //    })
         //    return;
         // }
         // if (this.warhouseTph == '') {
         //    uni.showToast({
         //       title: '组盘成功后,可入库!',
         //       icon: 'none',
         //       duration: 2000
         //    })
         //    return
         // }
         // uni.navigateTo({
         //    url: '/pages/putIn/three/three?type=入库单&containerCode=' + this.warhouseTph
         // })
      },
      getVehicleType() {
         getareaTypesList().then((res) => {
            // if (res.data.rows.length == 0) {
            //    this.rescode = 400
            //    this.resmessage = '暂无数据'
            //    this.$refs.resmodal.show = true
            //    return
            // }
            var arr = res.result.items;
            arr.map(item => {
               item.text = item.areaCode;
               return item;
            })
            this.wolist = arr
         })
      },
      confirmXl(index) {
         this.warehouse.areaCode = this.wolist[index].areaCode;
         // this.warehouse.ContainerTypeCode =  this.wolist[index].id;
      },
      filterMark(stockFlagStatus) {
         let str = ''
         let arr4 = this.arrD.filter(v => v.value == stockFlagStatus)
         if (arr4.length > 0) {
            str = arr4[0].title
         }
         return str
      },
      //------获取推荐
      containerFocus2() {
         // //debugger
         if (!this.warehouse.areaCode) {
            uni.showToast({
               title: '请选择目标库区!',
               icon: 'none',
               duration: 2000
            });
            return
         }
         getRecommendList({
            'containerCode': this.warehouse.containerCode,
            'areaCode': this.warehouse.areaCode
         }).then(res => {
            this.modalshow2 = true;
            this.containerList = res.result.reduce((curr, item) => {
               curr.push({
                  text: item.placeCode,
               })
               return curr;
            }, [])
         })
      },
      //------获取推荐类型选择
      confirm2(index) {
         this.warehouse.placeCode = this.containerList[index].text;
      },
   }
}
    //全部取消
    back() {
      this.ordersId = 0;
      this.singlist = [];
      this.$refs.warehouseRef.resetFields();
      this.warehouse.packageCode = "";
    },
  },
};
</script>
<style lang="scss" scoped>
<style lang="scss">
.content {
  height: 500rpx;
  overflow-y: scroll;
  width: 100%;
  padding: 15rpx;
  box-sizing: border-box;
  .content-item {
    padding: 15rpx;
    background-color: #fff;
    margin-bottom: 15rpx;
    border-radius: 8rpx;
    font-size: 32rpx;
  }
}
.bg_item {
   background: #FFEBCD !important;
  background: #ffebcd !important;
}
.inputGray2 {
   line-height: 30px;
   border-top: 10rpx solid transparent;
}
.inputGray {
   border-top: 0rpx solid transparent;
}
.boxList {
   transition: all ease 2s;
   position: fixed;
   bottom: 0;
   left: 0;
   top: 0;
   right: 0;
   width: 100%;
   height: 100%;
   z-index: 999;
   background: rgba(0, 0, 0, 0.6);
   .innerWrap {
      max-height: 50%;
      overflow-y: auto;
      background: white;
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      ul {
         padding: 0;
         margin: 0;
         li {
            padding: 0;
            margin: 0;
            border-bottom: 1px solid #e4e7ed;
            list-style-type: none;
            display: flex;
            flex-direction: row;
            line-height: 1;
            justify-content: center;
            align-items: center;
            font-size: 13px;
            padding: 14px 0;
            flex-direction: column;
         }
      }
   }
}
</style>
</style>