| <template> | 
|     <view class="overflow" style="padding-bottom: 100px"> | 
|         <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> --> | 
|         <!-- form --> | 
|         <u-form labelPosition="left" label-width="180rpx" :model="warehouse" ref="warehouseRef"> | 
|             <u-row class="border_bottom margin_top10rpx  background_fff padding_left25rpx padding_right30rpx"> | 
|                 <u-col span="12"> | 
|                     <u-form-item label="冻结/解冻:" prop="checkStatus" required | 
|                     class="uFormItem"> | 
|                         <u-input v-model="warehouse.checkStatusStr" placeholder="请选择" type="select" @click="show = true" | 
|                             style="font-weight: bolder; margin-left: 15rpx; font-size: 34rpx" | 
|                             class="width padding_left30rpx"> | 
|                         </u-input> | 
|                         <u-select v-model="show" :list="checkStatuEnums" @confirm="handlerConfirm"></u-select> | 
|                     </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="placeCode" class="uFormItem" | 
|                         > | 
|                         <u-input v-model="warehouse.placeCode" placeholder="请录入或扫码" | 
|                             style="font-weight: bolder; margin-left: 15rpx; font-size: 34rpx" | 
|                             class="width padding_left30rpx"> | 
|                         </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="containerCode" class="uFormItem" | 
|                         > | 
|                         <u-input v-model="warehouse.containerCode" placeholder="请录入或扫码" | 
|                             style="font-weight: bolder; margin-left: 15rpx; font-size: 34rpx" | 
|                             class="width padding_left30rpx"> | 
|                         </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="snCode" label-width="180rpx" class="uFormItem"> | 
|                         <u-input v-model="warehouse.snCode" ref="materialRef" placeholder="请扫码录入" | 
|                             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 padding_left25rpx" style="background-color: #fff"> | 
|                 <u-col span="12"> | 
|                     <u-form-item label="异常原因:" prop="reason" class="uFormItem"> | 
|                         <u-input @focus="warehouse.reason = ''" v-model.trim="warehouse.reason" placeholder="请填写异常原因" | 
|                             style="font-weight: bolder; margin-left: 15rpx" class="width padding_left25rpx"> | 
|                         </u-input> | 
|                     </u-form-item> | 
|                 </u-col> | 
|             </u-row> | 
|              | 
|         </u-form> | 
|         <!-- 列表 --> | 
|         <view> | 
|             <u-swipe-action :show="item.show" :index="eindex" v-for="(item, eindex) in singlist" :key="eindex" | 
|                 :options="options" @click="longpress" @open="open" @close="close" style="margin-bottom: 8rpx"> | 
|                 <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 border_radius margin_bottom10rpx relative box_sizing transition"> | 
|                             <u-row> | 
|                                 <u-col span="12" class="flex align-center"> | 
|                                     <view> | 
|                                         <u-checkbox v-model="item.checked" size="28px"></u-checkbox> | 
|                                     </view> | 
|                                     <view class="flex justify-center align-center" style=" | 
|                       background-color: #f18202; | 
|                       color: #fff; | 
|                       border-radius: 50vh; | 
|                       width: 20px; | 
|                       height: 20px; | 
|                     "> | 
|                                         {{ eindex + 1 }} | 
|                                     </view> | 
|                                     <view class="color_f18202 padding_left10rpx"> | 
|                                         物料编号:{{ item.materialCode }} | 
|                                     </view> | 
|                                 </u-col> | 
|                             </u-row> | 
|                             <u-row> | 
|                                 <u-col span="8"> | 
|                                     <view class="" style="padding: 10rpx 0 10rpx 10rpx; color: #808080"> | 
|                                         批次:{{ item.batchNo }} | 
|                                     </view> | 
|                                 </u-col> | 
|                                 <u-col span="4"> | 
|                                     <view class="" style="padding: 10rpx 0 10rpx 10rpx; color: #808080"> | 
|                                         数量:{{ item.quantity }} | 
|                                     </view> | 
|                                 </u-col> | 
|                             </u-row> | 
|   | 
|                             <u-row> | 
|                                 <u-col span="4"> 库位:{{ item.containerCode }} </u-col> | 
|                                 <u-col span="5"> SAP位置:{{ item.sap_Location }} </u-col> | 
|                                 <u-col span="3"> | 
|                                     <view class="" style="padding: 10rpx 0 10rpx 10rpx; color: #808080"> | 
|                                         <u-input | 
|                                             class="border_bottom_f18202 width text-left fontSize32rpx padding_left10rpx" | 
|                                             v-model="item.unBindQuantity" type="number" @blur="changeNum(item)" | 
|                                             placeholder="请输入移库数量"></u-input> | 
|                                     </view> | 
|                                 </u-col> | 
|                             </u-row> | 
|   | 
|                             <u-row> | 
|                                 <u-col span="12"> 检验状态: {{ item.checkStatusName }} </u-col> | 
|                             </u-row> | 
|                         </view> | 
|                     </view> | 
|                 </view> | 
|             </u-swipe-action> | 
|         </view> | 
|         <modal-code :rescode="rescode" :resmessage="resmessage" ref="resmodal" /> | 
|         <u-popup v-model="detailshow" border-radius="14" @close="detailshow = false" mode="bottom"> | 
|             <!-- <view class="pop "> --> | 
|             <h2 class="text_align_center padding_bottom18 padding15">物料信息</h2> | 
|             <view class="line flex justify-between"> | 
|                 <text class="text-gray">物料编号</text> | 
|                 <text>{{ materlist.materialCode }}</text> | 
|             </view> | 
|             <view class="line flex justify-between"> | 
|                 <text class="text-gray">物料名称</text> | 
|                 <text>{{ materlist.materialName }}</text> | 
|             </view> | 
|             <view class="line flex justify-between"> | 
|                 <text class="text-gray">批次</text> | 
|                 <text>{{ materlist.batchNo }}</text> | 
|             </view> | 
|             <view class="line flex justify-between"> | 
|                 <text class="text-gray">PO</text> | 
|                 <text>{{ materlist.purchaseNo }}</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.supplierNo }}{{ materlist.supplierName }}</text> | 
|             </view> | 
|             <view class="line flex justify-between"> | 
|                 <text class="text-gray">数量</text> | 
|                 <text>{{ materlist.unBindQuantity }}</text> | 
|             </view> | 
|             <!-- </view> --> | 
|             <view class="margin_top140rpx"> | 
|                 <!-- <button-modal :subShow='true' garmenTitle='打印' @submit='init' @reset='rest' /> --> | 
|   | 
|                 <button-modal :cleaningShow="true" allTitle="蓝牙打印" cleaningTitle="斑马打印" @allsubmit="init(1)" | 
|                     @submit="init(2)" /> | 
|             </view> | 
|         </u-popup> | 
|         <!-- 底部确定按钮 --> | 
|         <button-modal :empTytowerShow="true" cleaningTitle="返回" garmenTitle="确认" @submit="submit" @reset="rest" /> | 
|     </view> | 
| </template> | 
| <script> | 
| import { | 
|     getCheckAllMaterial, | 
|     inventoryFrozen, | 
|     inventoryUnFrozen, | 
| } from "@/api/putIn/untie.js"; | 
| import BluePrint from "@/pages/print/bluePrint.js"; | 
| import ButtonModal from "../../components/buttonModal.vue"; | 
| import ModalCode from "../../components/ModalCode.vue"; | 
| import { getAttrValue } from "@/utils/tool.js"; | 
| import { addPrintRecord } from "../../api/print.js"; | 
| import printComp from "@/mixins/printLabelSingle.js"; | 
| import printBanma from "@/mixins/printBanma.js"; | 
|   | 
| export default { | 
|     mixins: [printComp, printBanma], | 
|     data() { | 
|         return { | 
|             operator: "", | 
|             warehouse: { | 
|                 containerCode: "", | 
|                 materialCode: "", | 
|                 targetContainerCode: "", | 
|                 isUseForMove: true, //表示是 移库 【Editby shaocx,2023-05-14】 | 
|                 IsCheckAll: true, | 
|                 checkStatusStr: "", | 
|             }, | 
|             checkStatus: "", | 
|             singlist: [], //详情列表 | 
|             rescode: 0, | 
|             resmessage: "", | 
|             options: [ | 
|                 { | 
|                     text: "打印", | 
|                     style: { | 
|                         backgroundColor: "#fc9f35", | 
|                     }, | 
|                 }, | 
|             ], | 
|             detailshow: false, | 
|             materlist: {}, | 
|             checkStatuEnums: [], | 
|             show: false, | 
|             materialSlip: "", | 
|             headerTxt: "", | 
|         }; | 
|     }, | 
|     components: { | 
|         ButtonModal, | 
|         ModalCode, | 
|     }, | 
|     onLoad() { | 
|         this.operator = JSON.parse(uni.getStorageSync("userInfo")).name; | 
|     }, | 
|     created() { | 
|         this.checkStatuEnums = [ | 
|             { | 
|                 value: "1", | 
|                 label: "冻结", | 
|             }, | 
|             { | 
|                 value: "2", | 
|                 label: "解冻", | 
|             }, | 
|         ]; | 
|     }, | 
|     methods: { | 
|         //物料状态选择 | 
|         handlerConfirm(e) { | 
|             console.log(e); | 
|             this.warehouse.checkStatusStr = e[0].label; | 
|             this.checkStatus = e[0].value; | 
|         }, | 
|         //解析物料码 | 
|         analysisMaterialCode() { | 
|             // if(this.warehouse.containerCode == '') { | 
|             //     this.rescode = 400 | 
|             //     this.resmessage = `请先录入当前库位` | 
|             //     this.$refs.resmodal.show = true | 
|             //     return | 
|             // } | 
|             ////debugger | 
|             if (!this.warehouse.materialCode_Code) { | 
|                 // uni.showModal({ | 
|                 //     title: '提示', | 
|                 //     content: '物料编号不能为空', | 
|                 //     showCancel: false | 
|                 // }) | 
|                 this.warehouse.materialCode = ""; | 
|                 return; | 
|             } | 
|             if (this.warehouse.materialCode_Code.length > 50) { | 
|                 this.warehouse.materialCode = getAttrValue( | 
|                     this.warehouse.materialCode_Code, | 
|                     "PARTSNUMBER" | 
|                 ); | 
|                 //请求后台 | 
|                 this.containerBlur(); | 
|             } | 
|         }, | 
|         //回库 | 
|         rest() { | 
|             uni.navigateTo({ | 
|                 //url:`/pages/sort/return?containerCode=${this.warehouse.containerCode}` | 
|                 url: `/pages/index/index`, | 
|             }); | 
|         }, | 
|         //获取print date print time | 
|         getCurrentDate() { | 
|             let date = new Date(); | 
|             let year = date.getFullYear(); //年 | 
|             let month = date.getMonth() + 1; //月 | 
|             month = month >= 10 ? month : "0" + month; | 
|             let day = date.getDate(); //日 | 
|             day = day >= 10 ? day : "0" + day; | 
|             let hour = date.getHours(); //时 | 
|             hour = hour >= 10 ? hour : "0" + hour; | 
|             let min = date.getMinutes(); //分 | 
|             min = min >= 10 ? min : "0" + min; | 
|             let second = date.getSeconds(); //秒 | 
|             second = second >= 10 ? second : "0" + second; | 
|             return { | 
|                 date: `${day}.${month}.${year}`, | 
|                 time: `${hour}:${min}:${second}`, | 
|                 formate: `${year}/${month}/${day}`, | 
|             }; | 
|         }, | 
|         // 如果打开一个的时候,不需要关闭其他,则无需实现本方法 | 
|         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; | 
|         }, | 
|         //标签重新打印 | 
|         init(param) { | 
|             const arr = ["materialCode", "unBindQuantity"]; | 
|             const arrzw = ["物料编号", "本次下架数量"]; | 
|             let isAllow = ""; | 
|             Object.keys(this.materlist).forEach((item) => { | 
|                 if (arr.includes(item)) { | 
|                     if (!this.materlist[item]) { | 
|                         isAllow = arr.indexOf(item); | 
|                         // this.rescode = 400 | 
|                         // this.resmessage = `${arrzw[isAllow]}为空,不能继续打印` | 
|                         // this.resmessage = `${item}为空,不能继续打印` | 
|                         // this.$refs.resmodal.show = true | 
|                         return; | 
|                     } | 
|                 } | 
|             }); | 
|             if (isAllow != "") { | 
|                 this.detailshow = false; | 
|                 this.rescode = 400; | 
|                 this.resmessage = `${arrzw[isAllow]}为空,不能继续打印`; | 
|                 this.$refs.resmodal.show = true; | 
|                 return; | 
|             } | 
|             if ( | 
|                 this.materlist.unBindQuantity <= 0 || | 
|                 this.materlist.unBindQuantity > this.materlist.quantity | 
|             ) { | 
|                 this.detailshow = false; | 
|                 this.rescode = 400; | 
|                 this.resmessage = `数量不符合规范,不能继续打印`; | 
|                 this.$refs.resmodal.show = true; | 
|                 return; | 
|             } | 
|   | 
|             this.materlist.quantityLable = this.materlist.unBindQuantity; // 打印标贴数量 | 
|   | 
|             if (param == 1) { | 
|                 this.printComp("", "PO"); | 
|             } else { | 
|                 this.printBanma(); | 
|             } | 
|         }, | 
|         materialBlur() { | 
|             if (this.warehouse.materialCode == "") { | 
|                 return; | 
|             } | 
|             if (this.warehouse.materialCode.length < 50) { | 
|                 return; | 
|             } | 
|             // 错误码提示 | 
|             let str = this.warehouse.materialCode.replace(/\s/g, ""); | 
|             if (str.indexOf("LOTNO") == -1 || str.indexOf("PARTSNUMBER") == -1) { | 
|                 uni.showToast({ | 
|                     title: "二维码格式错误", | 
|                     icon: "none", | 
|                     duration: 2000, | 
|                 }); | 
|                 return; | 
|             } | 
|             // //debugger | 
|             //获取批次 | 
|             let lotNo = getAttrValue(this.warehouse.materialCode, "LOTNO"); | 
|             //物料编号 | 
|             this.warehouse.materialCode = getAttrValue( | 
|                 this.warehouse.materialCode, | 
|                 "PARTSNUMBER" | 
|             ); | 
|             // SAP --- && item.sap_Location == SAP | 
|             let SAP = getAttrValue(this.warehouse.materialCode, "SAP"); | 
|             //判断当前物料是否在盘点列表中 | 
|             const index = this.singlist.findIndex( | 
|                 (item) => | 
|                     item.materialCode == this.warehouse.materialCode && | 
|                     item.batchNo == lotNo | 
|             ); | 
|             if (index > -1) { | 
|                 this.singlist.unshift(...this.singlist.splice(index, 1)); | 
|             } else { | 
|                 this.rescode = 400; | 
|                 this.resmessage = "此批次的物料不在列表中"; | 
|                 this.$refs.resmodal.show = true; | 
|             } | 
|         }, | 
|         containerBlur() { | 
|             if (this.warehouse.materialCode == "" || this.singlist.length > 0) { | 
|                 return; | 
|             } | 
|             ////debugger | 
|             getCheckAllMaterial(this.warehouse).then((res) => { | 
|                 if (res.data == null || res.data.length == 0) { | 
|                     this.rescode = 400; | 
|                     this.resmessage = | 
|                         "该物料" + this.warehouse.materialCode + "没有找到库存"; | 
|                     this.$refs.resmodal.show = true; | 
|                     return; | 
|                 } | 
|                 //给所有的材料一个未选中的状态 | 
|                 res.data.map((item) => { | 
|                     (item.checked = false), (item.unBindQuantity = ""); | 
|                     item.IsChange = true; | 
|                     item.CheckStatus = ""; | 
|                 }); | 
|                 this.singlist = res.data; | 
|             }); | 
|         }, | 
|         //解绑数量失焦事件 | 
|         changeNum(option) { | 
|             // if(option.unBindQuantity > 0) { | 
|             //     option.unBindQuantity  = Number(option.unBindQuantity.toString().match(/^\d+(?:\.\d{0,2})?/)) // 保留两位小数 | 
|             // } | 
|   | 
|             //判断是否勾选,如果勾选了,就要对数量校验 | 
|             if (!option.checked) { | 
|                 return; | 
|             } | 
|             if (option.unBindQuantity == "") { | 
|                 this.rescode = 400; | 
|                 this.resmessage = "移库数量不能为空"; | 
|                 this.$refs.resmodal.show = true; | 
|             } | 
|   | 
|             if (option.unBindQuantity <= 0) { | 
|                 this.rescode = 400; | 
|                 this.resmessage = "移库数量必须大于0"; | 
|                 this.$refs.resmodal.show = true; | 
|             } | 
|   | 
|             if (option.unBindQuantity > option.quantity) { | 
|                 this.rescode = 400; | 
|                 this.resmessage = "移库数量不能大于库存数量"; | 
|                 this.$refs.resmodal.show = true; | 
|             } | 
|         }, | 
|         resetForm() { | 
|             this.warehouse.placeCode = ""; | 
|             this.warehouse.containerCode = ""; | 
|             this.warehouse.snCode = ""; | 
|             this.warehouse.reason ="" | 
|         }, | 
|         //确认解绑 | 
|         submit() { | 
|             var count = 0; | 
|             if (this.warehouse.placeCode) { | 
|                 count++; | 
|             } | 
|             if (this.warehouse.containerCode) { | 
|                 count++; | 
|             } | 
|             if (this.warehouse.snCode) { | 
|                 count++; | 
|             } | 
|             if (count != 1) { | 
|                 this.rescode = 400; | 
|                 this.resmessage = "地标/库位,容器编号,跟踪码只能输入一项!"; | 
|                 this.$refs.resmodal.show = true; | 
|                 return; | 
|             } | 
|             if (!this.warehouse.checkStatusStr) { | 
|                 this.rescode = 400; | 
|                 this.resmessage = "请选择冻结/解冻!"; | 
|                 this.$refs.resmodal.show = true; | 
|                 return; | 
|             } | 
|             if(!this.warehouse.reason){ | 
|                 this.rescode = 400; | 
|                 this.resmessage = "请填写异常原因!"; | 
|                 this.$refs.resmodal.show = true; | 
|                 return; | 
|             } | 
|             var str = ""; | 
|             const params = { | 
|                 placeCode: this.warehouse.placeCode, | 
|                 containerCode: this.warehouse.containerCode, | 
|                 snCode: this.warehouse.snCode, | 
|                 reason: this.warehouse.reason | 
|             }; | 
|              | 
|             // 冻结 | 
|             if (this.warehouse.checkStatusStr == '冻结') { | 
|                 str = "是否确认冻结?"; | 
|             } | 
|   | 
|             // 解冻 | 
|             if (this.warehouse.checkStatusStr == '解冻') { | 
|                 str = "是否确认解冻?"; | 
|             } | 
|             uni.showModal({ | 
|                 title: "提示", | 
|                 content: str, | 
|                 showCancel: true, | 
|                 cancelColor: "#333333", | 
|                 success: (res) => { | 
|                     if (res.confirm) { | 
|                         // 冻结 | 
|                         if (this.warehouse.checkStatusStr == '冻结') { | 
|                             inventoryFrozen(params).then((res) => { | 
|                                 this.resmessage = "冻结成功"; | 
|                                 this.rescode = 200; | 
|                                 this.$refs.resmodal.show = true; | 
|                                 this.resetForm(); | 
|                             }); | 
|                         } | 
|                         // 解冻 | 
|                         if (this.warehouse.checkStatusStr == '解冻') { | 
|                             inventoryUnFrozen(params).then((res) => { | 
|                                 this.resmessage = "解冻成功"; | 
|                                 this.rescode = 200; | 
|                                 this.$refs.resmodal.show = true; | 
|                                 this.resetForm(); | 
|                             }); | 
|                         } | 
|                     } | 
|                 }, | 
|             }); | 
|         }, | 
|     }, | 
| }; | 
| </script> | 
| <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: 16px; | 
|     } | 
| } | 
|   | 
|   | 
| </style> |