| <template> | 
|     <view> | 
|          | 
|     </view> | 
| </template> | 
|   | 
| <script> | 
|     export default { | 
|         data() { | 
|             return { | 
|                  | 
|             } | 
|         }, | 
|         methods: { | 
|              | 
|         } | 
|     } | 
| </script> | 
|   | 
| <style> | 
|   | 
| </style> | 
| <template> | 
|     <view> | 
|         <view class="code"> | 
|             <view class="item"> | 
|                 <view class="code-decs">原托盘:</view> | 
|                 <input type="text" placeholder=" 扫码 / 输入" v-model="barcode" :focus="barcodeFocus" | 
|                     @input="barcodeInput()"> | 
|             </view> | 
|             <view class="item"> | 
|                 <view class="code-decs">新托盘:</view> | 
|                 <input type="text" placeholder=" 扫码 / 输入" v-model="tBarcode" :focus="focus" @input="checkBarcode()"> | 
|             </view> | 
|         </view> | 
|         <view class="mat-list-title"> | 
|             商品列表 | 
|         </view> | 
|         <scroll-view> | 
|             <view class="list" v-for="(item,i) in dataList" :key="i"> | 
|                 <view class="list-left"> | 
|                     <view class="list-left-item"> | 
|                         <view class="desc">No:</view> | 
|                         <view class="left-item">{{i + 1}}</view> | 
|                     </view> | 
|                     <view class="list-left-item"> | 
|                         <view class="desc">编码:</view> | 
|                         <view class="left-item"> | 
|                             <uni-tag :text="item.matnr" type="primary"></uni-tag> | 
|                         </view> | 
|                     </view> | 
|                     <view class="list-left-item"> | 
|                         <view class="desc">品名:</view> | 
|                         <view class="left-item">{{item.maktx}}</view> | 
|                     </view> | 
|                     <view class="list-left-item"> | 
|                         <view class="desc">规格:</view> | 
|                         <view class="left-item">{{item.specs}}</view> | 
|                     </view> | 
|                     <view class="list-left-item"> | 
|                         <view class="desc">批号:</view> | 
|                         <view class="left-item"> | 
|                             <uni-tag :text="item.batch" type="warning"></uni-tag> | 
|                         </view> | 
|                     </view> | 
|                     <view class="list-left-item"> | 
|                         <view class="desc">数量:</view> | 
|                         <view class="left-item">{{item.anfme}}</view> | 
|                     </view> | 
|                 </view> | 
|             </view> | 
|         </scroll-view> | 
|         <!-- 底部操作按钮 --> | 
|         <view class="buttom"> | 
|             <button size="mini" @click="reset('warn')">重置</button> | 
|             <button size="mini" type="primary" @click="combConfirm('warn')">换板</button> | 
|         </view> | 
|         <!-- 弹窗 --> | 
|         <!-- 移除确认 --> | 
|         <view> | 
|             <!-- 提示窗示例 --> | 
|             <uni-popup ref="alertDialog" type="dialog"> | 
|                 <uni-popup-dialog :type="msgType" confirmText="移除" :title="title" :content="content" | 
|                     @confirm="removeConfirm()" @close="removeClose"></uni-popup-dialog> | 
|             </uni-popup> | 
|         </view> | 
|         <view> | 
|             <!-- 提示信息弹窗 --> | 
|             <uni-popup ref="message" type="message"> | 
|                 <uni-popup-message :type="msgType1" :message="messageText" :duration="2000"></uni-popup-message> | 
|             </uni-popup> | 
|         </view> | 
|         <!-- 确认组托 --> | 
|         <view> | 
|             <uni-popup ref="combConfirm" type="dialog"> | 
|                 <uni-popup-dialog :type="msgType" cancelText="取消" confirmText="确认" :title="title" :content="content" | 
|                     @confirm="changePallet" @close="combClose"></uni-popup-dialog> | 
|             </uni-popup> | 
|         </view> | 
|         <!-- 确认重置 --> | 
|         <view> | 
|             <uni-popup ref="resetConfirm" type="dialog"> | 
|                 <uni-popup-dialog :type="msgType" cancelText="取消" confirmText="确认" :title="title" :content="content" | 
|                     @confirm="resetConfirm" @close="resetClose"></uni-popup-dialog> | 
|             </uni-popup> | 
|         </view> | 
|     </view> | 
| </template> | 
|   | 
| <script> | 
|     export default { | 
|         data() { | 
|             return { | 
|                 baseUrl: '', | 
|                 token: '', | 
|                 barcode: '', | 
|                 dataList: [], | 
|                 count: 0, | 
|                 rowNum: '', | 
|                 tBarcode: '', | 
|                 batch: '', | 
|                 msgType1: 'success', | 
|                 msgType: 'success', | 
|                 messageText: '', | 
|                 title: '', | 
|                 content: '', | 
|                 barcodeFocus: true, | 
|                 focus: false, | 
|                 matData: '', | 
|                 removeNum: 0, | 
|             } | 
|         }, | 
|         onLoad() { | 
|   | 
|         }, | 
|         onShow() { | 
|             this.baseUrl = uni.getStorageSync('baseUrl'); | 
|             this.token = uni.getStorageSync('token'); | 
|         }, | 
|         methods: { | 
|             messageToggle(type) { | 
|                 this.msgType1 = type | 
|                 this.$refs.message.open() | 
|             }, | 
|             // barcode input 事件 | 
|             barcodeInput() { | 
|                 let that = this  | 
|                 if (this.barcode.length != 8) { | 
|                     uni.showToast({title: '托盘码长度异常,请重新扫描', icon: "none", position: 'top'}) | 
|                     this.barcodeFocuss() | 
|                 } | 
|                 if (that.barcode.length == 8) { | 
|                     uni.request({ | 
|                         url: that.baseUrl + '/mobile/piking/auth', | 
|                         header: { | 
|                             'token':uni.getStorageSync('token') | 
|                         }, | 
|                         data: {barcode:that.barcode}, | 
|                         success(res) { | 
|                             res = res.data | 
|                             if(res.code===200) { | 
|                                 that.dataList = res.data | 
|                                 that.focuss() | 
|                             } else if (res.code == 403) { | 
|                                 uni.showToast({title: res.msg, icon: "none", position: 'top'}) | 
|                                 setTimeout(() => { | 
|                                     uni.reLaunch({ | 
|                                         url: '../login/login' | 
|                                     }); | 
|                                 }, 1000); | 
|                             } else { | 
|                                 that.barcodeFocuss() | 
|                                 uni.showToast({title: res.msg, icon: "none",position: 'top'}) | 
|                             } | 
|                         } | 
|                     }) | 
|                      | 
|                 } | 
|             }, | 
|             // 托盘码有误重置 | 
|             barcodeFocuss() { | 
|                 let that = this; | 
|                 that.barcodeFocus = false; | 
|                 setTimeout(() => { | 
|                     that.barcode = ''; | 
|                     that.barcodeFocus = true; | 
|                 }, 100); | 
|             }, | 
|             checkBarcode() { | 
|                 if (this.tBarcode.length != 8) { | 
|                     uni.showToast({title: '托盘码长度异常,请重新扫描', icon: "none", position: 'top'}) | 
|                     this.focuss() | 
|                 } | 
|             }, | 
|             // 商品光标清空重置 | 
|             focuss() { | 
|                 this.focus = false; | 
|                 setTimeout(() => { | 
|                     this.tBarcode = ''; | 
|                     this.focus = true; | 
|                 }, 100); | 
|             }, | 
|             reset(type) { | 
|                 this.msgType = type | 
|                 this.title = '警告' | 
|                 this.content = '是否重置!' | 
|                 this.$refs.resetConfirm.open() | 
|             }, | 
|             combConfirm(type) { | 
|                 this.msgType = type | 
|                 this.title = '警告' | 
|                 this.content = '确认转换!' | 
|                 this.$refs.combConfirm.open() | 
|             }, | 
|             combClose() { | 
|                 this.$refs.combConfirm.close() | 
|             }, | 
|             // 确认重置 | 
|             resetConfirm() { | 
|                 this.dataList = [] | 
|                 this.barcode = '' | 
|                 this.tBarcode = '' | 
|                 this.messageText = "重置完成" | 
|                 this.messageToggle('success') | 
|             }, | 
|             // 取消重置 | 
|             resetClose() { | 
|   | 
|             }, | 
|             // 清空 | 
|             resst() { | 
|                 this.dataList = [] | 
|                 this.barcode = '' | 
|                 this.barcodeFocuss() | 
|             }, | 
|             changePallet() { | 
|                 let that = this | 
|                 uni.request({ | 
|                     url: that.baseUrl + '/mobile/piking/to/full', | 
|                     header: { | 
|                         'token':uni.getStorageSync('token') | 
|                     }, | 
|                     data: {sBarcode:that.barcode,tBarcode:that.tBarcode}, | 
|                     success(res) { | 
|                         res = res.data | 
|                         if (res.code === 200) { | 
|                             that.barcode = '' | 
|                             that.dataList = [] | 
|                             that.tBarcode = '' | 
|                             that.barcodeFocuss() | 
|                             uni.showToast({title: res.msg, icon: "none", position: 'top'}) | 
|                         } else if (res.code == 403) { | 
|                                 uni.showToast({title: res.msg, icon: "none", position: 'top'}) | 
|                                 setTimeout(() => { | 
|                                     uni.reLaunch({ | 
|                                         url: '../login/login' | 
|                                     }); | 
|                                 }, 1000); | 
|                             } else { | 
|                                 uni.showToast({title: res.msg, icon: "none",position: 'top'}) | 
|                             } | 
|                     } | 
|                 }) | 
|             }, | 
|         } | 
|     } | 
| </script> | 
|   | 
| <style> | 
|     @import url('@/static/css/wms.css/wms.css'); | 
|   | 
|     .code { | 
|         width: 100%; | 
|         position: fixed; | 
|         min-height: 200rpx; | 
|         background-color: #FFF; | 
|         z-index: 10; | 
|     } | 
|   | 
|     .item { | 
|         display: flex; | 
|         align-items: center; | 
|         height: 100rpx; | 
|         margin-left: 20rpx; | 
|         border-bottom: 1px solid #DCDFE6; | 
|     } | 
|   | 
|     .item input { | 
|         height: 50rpx; | 
|         line-height: 50rpx; | 
|         /* font-family: PingFang SC; uniapp 默认字体不居中 */ | 
|         font-size: 36upx; | 
|         font-family: PingFang SC; | 
|         width: 55vw; | 
|   | 
|     } | 
|   | 
|     .code-decs { | 
|         width: 20vw; | 
|         font-size: 18px; | 
|         color: #303133; | 
|     } | 
|   | 
|     .item-right { | 
|         margin-left: auto; | 
|         margin-right: 20rpx; | 
|     } | 
|   | 
|     .mat-list-title { | 
|         height: 80rpx; | 
|         line-height: 80rpx; | 
|         width: 100%; | 
|         background-color: white; | 
|         position: fixed; | 
|         margin-top: 200rpx; | 
|         z-index: 9; | 
|         /* border-top: 1px solid #DCDFE6; */ | 
|         text-align: center; | 
|         box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.5); | 
|     } | 
| </style> |