New file |
| | |
| | | <template> |
| | | <view> |
| | | <view class="code"> |
| | | <view class="item"> |
| | | <view class="code-decs">库位号:</view> |
| | | <input type="text" placeholder=" 扫码 / 输入" v-model="locNo" :focus="locNoFocus" |
| | | @input="findLocno()"> |
| | | </view> |
| | | <view class="item"> |
| | | <view class="code-decs">出库口:</view> |
| | | <uni-combox :candidates="siteNos" placeholder="请选择出库口" v-model="siteNo"></uni-combox> |
| | | </view> |
| | | </view> |
| | | <view class="mat-list-title"> |
| | | 商品列表 |
| | | </view> |
| | | <scroll-view> |
| | | <view class="" style="margin-bottom: 240rpx;"> |
| | | <view class="list" v-for="(item,i) in dataList" :key="i" :class="'bg-'+item.color_new"> |
| | | <view class="list-left"> |
| | | <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"> |
| | | <uni-tag :text="item.orderNo" 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"> |
| | | <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> |
| | | </view> |
| | | <view class="list-right" v-show="item.color_new"> |
| | | <uni-icons type="compose" color="#9add8b" size="24" @click="revise(item,i)"></uni-icons> |
| | | <uni-icons type="trash" color="#f58a8a" size="24" @click="remove(item,i,'warn')"></uni-icons> |
| | | </view> |
| | | <view class="index-no">{{i + 1}}</view> |
| | | </view> |
| | | |
| | | <view style="text-align: center;"> |
| | | <button size="mini" type="primary" @click="addMat()">新增物料</button> |
| | | </view> |
| | | </view> |
| | | |
| | | </scroll-view> |
| | | <!-- 底部操作按钮 --> |
| | | <view class="buttom"> |
| | | <button size="mini" @click="reset('warn')">重置</button> |
| | | <button size="mini" type="primary" @click="mergeOut()">并板出库</button> |
| | | </view> |
| | | <!-- 修改 --> |
| | | <view> |
| | | <uni-popup ref="revise" type="dialog"> |
| | | <view class="popup"> |
| | | <!-- 标题 --> |
| | | <view class="title">修改</view> |
| | | <view class="popup-item"> |
| | | <view class="popup-item-left">编码:</view> |
| | | <view class="popup-item-right"> |
| | | <input type="text" v-model="matnr" disabled="true" |
| | | style="background-color: #f7f7f7;padding: 0;color: #d5d5d5;"> |
| | | </view> |
| | | </view> |
| | | <view class="popup-item"> |
| | | <view class="popup-item-left">批号:</view> |
| | | <view class="popup-item-right"><input type="text" v-model="batch"></view> |
| | | </view> |
| | | <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" @change="changeValue" /> |
| | | </view> |
| | | </view> |
| | | <view class="btn"> |
| | | <view class="btn-left" @click="reviseClose">取消</view> |
| | | <view class="btn-right" @click="reviseConfirm()">修改</view> |
| | | </view> |
| | | </view> |
| | | </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="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="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: '', |
| | | locNo: '', |
| | | locNoFocus:true, |
| | | dataList: [], |
| | | siteNo: '', |
| | | siteNos: [], |
| | | orderNo: '', |
| | | count: 0, |
| | | batch: '', |
| | | matnr: '', |
| | | msgType1: '', |
| | | messageText: '', |
| | | content: '', |
| | | msgType: '', |
| | | title: '' |
| | | } |
| | | }, |
| | | onShow() { |
| | | this.baseUrl = uni.getStorageSync('baseUrl'); |
| | | this.token = uni.getStorageSync('token'); |
| | | this.getOutBound(); |
| | | this.locNoFocus = false |
| | | setTimeout(()=>{ |
| | | this.locNoFocus = true |
| | | },100) |
| | | }, |
| | | methods: { |
| | | // 获取出库口 |
| | | getOutBound() { // 获取出库口 |
| | | let that = this |
| | | uni.request({ |
| | | url: that.baseUrl + '/available/take/check/site', |
| | | method: 'POST', |
| | | header: {'token':uni.getStorageSync('token')}, |
| | | success(result) { |
| | | var res = result.data |
| | | if (res.code === 200) { |
| | | that.siteNos = res.data |
| | | } 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'}) |
| | | } |
| | | }, |
| | | }); |
| | | }, // getOutBound |
| | | findLocno() { |
| | | let that = this |
| | | that.dataList = [] |
| | | uni.request({ |
| | | url: that.baseUrl + '/locDetl/list/auth', |
| | | header:{'token':uni.getStorageSync('token')}, |
| | | data: { |
| | | curr: 1, |
| | | limit: 100, |
| | | loc_no: that.locNo, |
| | | zpallet: that.barcode, |
| | | matnr: that.matnr |
| | | }, |
| | | method:"GET", |
| | | success(res) { |
| | | res = res.data |
| | | if (res.code === 200) { |
| | | var item |
| | | for (item in res.data.records) { |
| | | that.dataList.push(res.data.records[item]) |
| | | } |
| | | } |
| | | } |
| | | }) |
| | | |
| | | }, |
| | | addMat() { |
| | | let that = this |
| | | uni.navigateTo({ |
| | | url: "../order/orderList", |
| | | success: function(res) { |
| | | // 通过eventChannel向被打开页面传送数据 向另外一个页面传递值的 |
| | | res.eventChannel.emit('commonUrl', { |
| | | commonUrl: '' |
| | | }) |
| | | }, |
| | | events: { |
| | | // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据 另外一个页面传过来的 |
| | | acceptDataFromOpenedPage: function(data) { |
| | | that.orderNo = data.data |
| | | that.findOrder(that.orderNo) |
| | | }, |
| | | }, |
| | | }); |
| | | }, |
| | | findOrder() { |
| | | let that = this |
| | | uni.request({ |
| | | url: that.baseUrl + '/order/list/orderNo', |
| | | data: {orderNo: that.orderNo} , |
| | | method: 'GET', |
| | | success(res) { |
| | | res = res.data; |
| | | if (res.code === 200) { |
| | | uni.navigateTo({ |
| | | url: "../order/orderDetil", |
| | | success: function(res) { |
| | | // 通过eventChannel向被打开页面传送数据 向另外一个页面传递值的 |
| | | res.eventChannel.emit('orderNo', { |
| | | orderNo: that.orderNo |
| | | }) |
| | | }, |
| | | events: { |
| | | // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据 另外一个页面传过来的 |
| | | orderList: function(data) { |
| | | for(var item in data.data) { |
| | | data.data[item]['color_new'] = 'new' |
| | | that.dataList.push(data.data[item]) |
| | | } |
| | | that.orderNo = '' |
| | | }, |
| | | }, |
| | | }); |
| | | } |
| | | } |
| | | }) |
| | | }, |
| | | // 并板出库 |
| | | mergeOut() { |
| | | let that = this |
| | | let newList = [] |
| | | // that.siteNo = Number(that.siteNo) |
| | | for (var k in that.dataList) { |
| | | if (that.dataList[k].color_new) { |
| | | that.dataList[k].count = that.dataList[k].anfme |
| | | newList.push(that.dataList[k]) |
| | | } |
| | | } |
| | | uni.request({ |
| | | url: that.baseUrl + '/mobile/bin/comb/auth', |
| | | header: {'token':uni.getStorageSync('token')}, |
| | | data: JSON.stringify({ |
| | | locno: that.locNo, |
| | | evp: that.siteNo, |
| | | combMats: newList |
| | | }), |
| | | method: 'POST', |
| | | success(res) { |
| | | res = res.data |
| | | if (res.code === 200) { |
| | | this.resst() |
| | | this.messageText = "出库成功" |
| | | this.messageToggle('success') |
| | | } else if (res.code == 403) { |
| | | that.messageText = res.msg |
| | | that.messageToggle('error') |
| | | setTimeout(() => { |
| | | uni.reLaunch({ |
| | | url: '../login/login' |
| | | }); |
| | | }, 1000); |
| | | } else { |
| | | that.messageText = res.msg |
| | | that.messageToggle('error') |
| | | } |
| | | } |
| | | |
| | | }) |
| | | }, |
| | | // 列表修改 |
| | | revise(item, i) { |
| | | this.matnr = this.dataList[i].matnr |
| | | this.count = this.dataList[i].anfme |
| | | this.batch = this.dataList[i].batch |
| | | this.weight = this.dataList[i].weight |
| | | this.rowNum = i |
| | | this.eject() |
| | | }, |
| | | eject(type) { |
| | | this.type = type |
| | | this.$refs.revise.open(type) |
| | | }, |
| | | changeValue(value) { |
| | | this.count = value |
| | | }, |
| | | // 确认修改 |
| | | reviseConfirm() { |
| | | this.dataList[this.rowNum].anfme = this.count |
| | | this.dataList[this.rowNum].batch = this.batch |
| | | this.dataList[this.rowNum].weight = this.weight |
| | | this.matnr = '' |
| | | this.messageText = "修改成功" |
| | | this.messageToggle('success') |
| | | this.$refs.revise.close() |
| | | }, |
| | | // 取消修改 |
| | | reviseClose() { |
| | | this.$refs.revise.close() |
| | | }, |
| | | messageToggle(type) { |
| | | this.msgType1 = type |
| | | this.$refs.message.open() |
| | | }, |
| | | // 列表移除按钮 |
| | | remove(item, i, type) { |
| | | this.removeNum = i |
| | | this.msgType = type |
| | | this.title = '警告' |
| | | this.content = '是否移除当前商品!' |
| | | this.$refs.alertDialog.open(i) |
| | | }, |
| | | // 确认移除 |
| | | removeConfirm() { |
| | | this.messageText = "移除成功" |
| | | this.messageToggle('success') |
| | | this.dataList.splice(this.removeNum, 1) |
| | | }, |
| | | reset(type) { |
| | | this.msgType = type |
| | | this.title = '警告' |
| | | this.content = '是否重置!' |
| | | this.$refs.resetConfirm.open() |
| | | }, |
| | | // 确认重置 |
| | | resetConfirm() { |
| | | this.dataList = [] |
| | | this.locNo = '' |
| | | this.siteNo = '' |
| | | this.locNoFocus = false |
| | | setTimeout(()=>{ |
| | | this.locNoFocus = true |
| | | },100) |
| | | this.messageText = "重置完成" |
| | | this.messageToggle('success') |
| | | }, |
| | | // 取消重置 |
| | | resetClose() { |
| | | |
| | | }, |
| | | // 清空 |
| | | resst() { |
| | | this.dataList = [] |
| | | this.locNo = '' |
| | | this.siteNo = '' |
| | | this.locNoFocus = false |
| | | setTimeout(()=>{ |
| | | this.locNoFocus = true |
| | | },100) |
| | | }, |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style> |
| | | @import url('../../static/css/wms.css/wms.css'); |
| | | .code { |
| | | width: 100%; |
| | | position: fixed; |
| | | min-height: 100rpx; |
| | | background-color: #FFF; |
| | | z-index: 10; |
| | | } |
| | | .list:first-child { |
| | | margin-top: 320rpx; |
| | | } |
| | | .list:last-child { |
| | | margin-bottom: 420rpx; |
| | | } |
| | | .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 10px 0px rgba(0, 0, 0, 0.5); |
| | | } |
| | | .index-no { |
| | | position: relative; |
| | | right: 15px; |
| | | top: 10px; |
| | | font-size: 1em; |
| | | color: #909399; |
| | | } |
| | | .bg-new { |
| | | background-color: #fdffe0; |
| | | |
| | | } |
| | | </style> |