|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <view> | 
|---|
|  |  |  | <view class="status_bar"> | 
|---|
|  |  |  | <!-- 这里是状态栏 --> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <uni-nav-bar left-icon="left" background-color="#f8f8f8" title="订单组托" @clickLeft="back"  :fixed="true" | 
|---|
|  |  |  | :border="false" rightWidth="160rpx" leftWidth="160rpx" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <block slot="right"> | 
|---|
|  |  |  | <view class="city"> | 
|---|
|  |  |  | <view> | 
|---|
|  |  |  | <text class="uni-nav-bar-text">{{store}}</text> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | </block> | 
|---|
|  |  |  | </uni-nav-bar> | 
|---|
|  |  |  | <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="item"> | 
|---|
|  |  |  | <view class="code-decs">订单号:</view> | 
|---|
|  |  |  | <uni-combox :candidates="orderNoList" placeholder="请选择订单" v-model="orderNo" @input="getOrderDet"></uni-combox> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | </view> --> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <view class="mat-list-title"> | 
|---|
|  |  |  | <view style="width: 200rpx;"></view> | 
|---|
|  |  |  | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <scroll-view> | 
|---|
|  |  |  | <checkbox-group class="list" v-for="(item,i) in dataList" :key="i" @change="checkboxChange"> | 
|---|
|  |  |  | <view class="aside"> | 
|---|
|  |  |  | <checkbox :value="item.matnr" :checked="item.checked" @click="set(i)"/> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <view class="list-left" style="margin: 0;"> | 
|---|
|  |  |  | <view class="list-left-item"> | 
|---|
|  |  |  | <view class="desc">No:</view> | 
|---|
|  |  |  | <view class="left-item">{{i + 1}}</view> | 
|---|
|  |  |  | <view class="desc">No:{{i + 1}}</view> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <view class="list-left-item"> | 
|---|
|  |  |  | <view class="desc">订单号:</view> | 
|---|
|  |  |  | <view class="left-item"> | 
|---|
|  |  |  | <uni-tag :text="item.orderNo" type="primary"></uni-tag> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <view class="desc">订单号:{{item.orderNo}}</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 class="desc">料号:{{item.matnr}}</view> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <view class="list-left-item"> | 
|---|
|  |  |  | <view class="desc">名称:</view> | 
|---|
|  |  |  | <view class="left-item">{{item.maktx}}</view> | 
|---|
|  |  |  | <view class="desc">批号:{{item.batch}}</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"> | 
|---|
|  |  |  | <uni-tag :text="item.weight" type="warning"></uni-tag> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | </view> --> | 
|---|
|  |  |  | <view class="list-left-item"> | 
|---|
|  |  |  | <view class="desc">剩余数量:</view> | 
|---|
|  |  |  | <view class="left-item">{{item.anfme}}</view> | 
|---|
|  |  |  | <view class="list-left-item" > | 
|---|
|  |  |  | <view class="desc">数量:{{item.anfme}}</view> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | <view class="list-right"> | 
|---|
|  |  |  | 
|---|
|  |  |  | <view class="popup-item"> | 
|---|
|  |  |  | <view class="popup-item-left">数量:</view> | 
|---|
|  |  |  | <view class="popup-item-right" style="border: none;justify-content: center;"> | 
|---|
|  |  |  | <uni-number-box :value="count" :step='0.01' :max="9999999" color="#747474" | 
|---|
|  |  |  | <uni-number-box :value="count" :step='1' :max="maxCount" color="#747474" | 
|---|
|  |  |  | @change="changeValue" /> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | </view> | 
|---|
|  |  |  | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | baseUrl: '', | 
|---|
|  |  |  | token: '', | 
|---|
|  |  |  | storeId: 0, | 
|---|
|  |  |  | store: '', | 
|---|
|  |  |  | order: '', | 
|---|
|  |  |  | barcode: '', | 
|---|
|  |  |  | barcodeFocus: '', | 
|---|
|  |  |  | 
|---|
|  |  |  | removeNum: 0, | 
|---|
|  |  |  | orderNoList: [], | 
|---|
|  |  |  | orderNo: '', | 
|---|
|  |  |  | maxCount: 0 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | onShow() { | 
|---|
|  |  |  | this.baseUrl = uni.getStorageSync('baseUrl'); | 
|---|
|  |  |  | this.token = uni.getStorageSync('token'); | 
|---|
|  |  |  | this.getOrderNoList() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | this.baseUrl = uni.getStorageSync('baseUrl'); | 
|---|
|  |  |  | this.token = uni.getStorageSync('token'); | 
|---|
|  |  |  | this.getOrderNoList() | 
|---|
|  |  |  | this.storeId = uni.getStorageSync('store') | 
|---|
|  |  |  | if (this.storeId == 1) { | 
|---|
|  |  |  | this.store = '宁波仓' | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (this.storeId == 2) { | 
|---|
|  |  |  | this.store = '新昌仓' | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | back() { uni.navigateBack({}) }, | 
|---|
|  |  |  | set(e) { | 
|---|
|  |  |  | var ck = this.dataList[e].checked | 
|---|
|  |  |  | this.dataList[e].checked = ck ? false:true | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getChecked() { | 
|---|
|  |  |  | var checkedList = [] | 
|---|
|  |  |  | for(var i = 0; i < this.dataList.length; i++) { | 
|---|
|  |  |  | var t = !this.dataList[i].checked | 
|---|
|  |  |  | if (this.dataList[i].checked) { | 
|---|
|  |  |  | checkedList.push(this.dataList[i]) | 
|---|
|  |  |  | let _this = this | 
|---|
|  |  |  | uni.navigateTo({ | 
|---|
|  |  |  | url: './orderSelect', | 
|---|
|  |  |  | success(res) { | 
|---|
|  |  |  | res.eventChannel.emit('matList', { | 
|---|
|  |  |  | matList: _this.dataList | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | events: { | 
|---|
|  |  |  | pickList: function(data) { | 
|---|
|  |  |  | for (let k of data.data) { | 
|---|
|  |  |  | let add = true | 
|---|
|  |  |  | if (_this.dataList.length == 0) { | 
|---|
|  |  |  | _this.dataList.push(k) | 
|---|
|  |  |  | continue | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (let m of _this.dataList) { | 
|---|
|  |  |  | if (k.matnr == m.matnr && k.orderNo == k.orderNo) { | 
|---|
|  |  |  | add = false | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (add) { | 
|---|
|  |  |  | k['maxCount'] = k.anfme | 
|---|
|  |  |  | _this.dataList.push(k) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.dataList = checkedList | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getOrderDet() { | 
|---|
|  |  |  | let that = this | 
|---|
|  |  |  | 
|---|
|  |  |  | getOrderNoList() { | 
|---|
|  |  |  | let that = this | 
|---|
|  |  |  | uni.request({ | 
|---|
|  |  |  | url: this.baseUrl + '/order/list/all', | 
|---|
|  |  |  | url: this.baseUrl + '/order/comb/list/all', | 
|---|
|  |  |  | header: { | 
|---|
|  |  |  | 'token': uni.getStorageSync('token') | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | uni.vibrateShort(); | 
|---|
|  |  |  | let that = this; | 
|---|
|  |  |  | if (that.barcode === '') { | 
|---|
|  |  |  | this.messageText = "请扫描托盘条码" | 
|---|
|  |  |  | this.messageToggle('error') | 
|---|
|  |  |  | uni.showToast({ title: "请扫描托盘条码", icon: "error", position: 'center' }) | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (that.dataList.length === 0) { | 
|---|
|  |  |  | this.messageText = "请添加商品列表" | 
|---|
|  |  |  | this.messageToggle('error') | 
|---|
|  |  |  | uni.showToast({ title: "请添加商品列表", icon: "error", position: 'center' }) | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (var i = 0; i < that.dataList.length; i++) { | 
|---|
|  |  |  | if (that.dataList[i].anfme == 0 || that.dataList[i].anfme == '') { | 
|---|
|  |  |  | this.messageText = that.dataList[i].matnr + '组托数量不能为0' | 
|---|
|  |  |  | this.messageToggle('error') | 
|---|
|  |  |  | uni.showToast({ title: that.dataList[i].matnr + '组托数量不能为0', icon: "error", position: 'center' }) | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | var res = result.data | 
|---|
|  |  |  | if (res.code === 200) { | 
|---|
|  |  |  | that.resst(); | 
|---|
|  |  |  | that.messageText = "组托成功" | 
|---|
|  |  |  | that.messageToggle('success') | 
|---|
|  |  |  | uni.showToast({ title: "组托成功", icon: "success", position: 'center' }) | 
|---|
|  |  |  | } else if (res.code == 403) { | 
|---|
|  |  |  | that.messageText = res.msg | 
|---|
|  |  |  | that.messageToggle('error') | 
|---|
|  |  |  | uni.showToast({ title: res.msg, icon: "error", position: 'center' }) | 
|---|
|  |  |  | setTimeout(() => { | 
|---|
|  |  |  | uni.reLaunch({ | 
|---|
|  |  |  | url: '../login/login' | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, 1000); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | that.messageText = res.msg | 
|---|
|  |  |  | that.messageToggle('error') | 
|---|
|  |  |  | uni.showToast({ title: res.msg, icon: "error", position: 'center' }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | 
|---|
|  |  |  | this.dataList = [] | 
|---|
|  |  |  | this.orderNo = '' | 
|---|
|  |  |  | this.barcode = '' | 
|---|
|  |  |  | this.messageText = "重置完成" | 
|---|
|  |  |  | this.messageToggle('success') | 
|---|
|  |  |  | uni.showToast({ title:"重置完成", icon: "success", position: 'center' }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 取消重置 | 
|---|
|  |  |  | resetClose() { | 
|---|
|  |  |  | 
|---|
|  |  |  | this.count = this.dataList[i].anfme | 
|---|
|  |  |  | this.batch = this.dataList[i].batch | 
|---|
|  |  |  | this.weight = this.dataList[i].weight | 
|---|
|  |  |  | this.maxCount = this.dataList[i].maxCount | 
|---|
|  |  |  | this.rowNum = i | 
|---|
|  |  |  | this.eject() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 确认移除 | 
|---|
|  |  |  | removeConfirm(i) { | 
|---|
|  |  |  | this.messageText = "移除成功" | 
|---|
|  |  |  | this.messageToggle('success') | 
|---|
|  |  |  | uni.showToast({ title:"移除成功", icon: "success", position: 'center' }) | 
|---|
|  |  |  | this.dataList.splice(this.removeNum, 1) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | reviseConfirm() { | 
|---|
|  |  |  | this.dataList[this.rowNum].anfme = this.count | 
|---|
|  |  |  | this.dataList[this.rowNum].batch = this.batch | 
|---|
|  |  |  | this.dataList[this.rowNum].weight = this.weight | 
|---|
|  |  |  | this.messageText = "修改成功" | 
|---|
|  |  |  | this.messageToggle('success') | 
|---|
|  |  |  | uni.showToast({ title:"修改成功", icon: "success", position: 'center' }) | 
|---|
|  |  |  | this.$refs.revise.close() | 
|---|
|  |  |  | this.$forceUpdate() // 强制刷新 | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .list:first-child { | 
|---|
|  |  |  | margin-top: 360rpx; | 
|---|
|  |  |  | margin-top: 240rpx; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .list:last-child { | 
|---|
|  |  |  | 
|---|
|  |  |  | .code { | 
|---|
|  |  |  | width: 100%; | 
|---|
|  |  |  | position: fixed; | 
|---|
|  |  |  | min-height: 200rpx; | 
|---|
|  |  |  | min-height: 100rpx; | 
|---|
|  |  |  | background-color: #FFF; | 
|---|
|  |  |  | z-index: 10; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | width: 100%; | 
|---|
|  |  |  | background-color: white; | 
|---|
|  |  |  | position: fixed; | 
|---|
|  |  |  | margin-top: 200rpx; | 
|---|
|  |  |  | margin-top: 100rpx; | 
|---|
|  |  |  | z-index: 9; | 
|---|
|  |  |  | /* border-top: 1px solid #DCDFE6; */ | 
|---|
|  |  |  | text-align: center; | 
|---|