17 changed files with 2122 additions and 19 deletions
@ -0,0 +1,123 @@ |
|||
<template> |
|||
<view class=""> |
|||
<view class="detail-content"> |
|||
<view class="choose_main"> |
|||
<view class="ljh_box"> |
|||
<view class="tit_ljh">{{ dataContent.itemCode }}</view> |
|||
<view class="ljh_left desc_ljh"> |
|||
<view class="font_xs text_lightblue">{{ dataContent.itemName }}</view> |
|||
<view class="font_xs text_lightblue">{{ dataContent.itemDesc1 }}</view> |
|||
</view> |
|||
</view> |
|||
扫描{{dataContent.scaned}} |
|||
|
|||
<view class="list_form"> |
|||
<view class="uni-container"> |
|||
<uni-table style="overflow-x: hidden;"> |
|||
<uni-tr> |
|||
<!-- <uni-th width="90"></uni-th> |
|||
<uni-th width="100" align="center">推荐</uni-th> |
|||
<uni-th width="100" align="center">实际</uni-th> --> |
|||
<uni-th width="50"></uni-th> |
|||
<uni-th width="120" align="center">推荐</uni-th> |
|||
<uni-th width="120" align="center">实际</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="50">器具码</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view class="text_packingCode"> |
|||
{{ dataContent.recommendContainerCode }} |
|||
</view> |
|||
</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view v-if="dataContent.scaned" class="text_packingCode"> |
|||
{{ dataContent.containerCode }} |
|||
</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="50">数量</text></uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<text class="text_black">{{dataContent.recommendQty}}({{dataContent.uom}})</text> |
|||
</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view v-if="dataContent.scaned" |
|||
style="display: flex;flex-direction: row;justify-content:center;align-items: center;"> |
|||
|
|||
<com-number-box ref="comNumberBox" v-model="dataContent.handledQty" |
|||
:max="99999" :min="0" style='width: 100px;' |
|||
@change="qtyChanged($event,dataContent)"> |
|||
</com-number-box> |
|||
<text class="text_black">({{dataContent.uom}})</text> |
|||
</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
</uni-table> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
<view class="choose_marked" v-if="dataContent.scaned"> |
|||
<image src="@/static/image_marked.svg"></image> |
|||
</view> |
|||
<view class="fr" v-if="isShowPacking"> |
|||
<button class="btn_single" hover-class="btn_single_after" @click="unPacking(dataContent)">拆箱</button> |
|||
</view> |
|||
</view> |
|||
<comUnPacking ref='comUnPacking' |
|||
@getvalue="getUnPackingCount" title="拆箱"> |
|||
</comUnPacking> |
|||
<com-message ref="comMessage" @afterCloseCommitMessage='closeCommitMessage()' |
|||
@afterCloseScanMessage='closeScanMessage'></com-message> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import comNumberBox from '@/mycomponents/common/comNumberBox.vue'; |
|||
import comUnPacking from '@/mycomponents/coms/comUnPacking.vue' |
|||
import comMessage from '@/mycomponents/common/comMessage.vue' |
|||
|
|||
export default { |
|||
name: "", |
|||
components: { |
|||
comNumberBox, |
|||
comUnPacking, |
|||
comMessage |
|||
}, |
|||
data() { |
|||
return {}; |
|||
}, |
|||
// 此处定义传入的数据 |
|||
props: { |
|||
dataContent: { |
|||
type: Object, |
|||
value: {} |
|||
}, |
|||
isShowPacking: { |
|||
type: Boolean, |
|||
value: false |
|||
}, |
|||
}, |
|||
methods: { |
|||
unPacking(item) { |
|||
this.$refs.comUnPacking.openPopup3(item,item.handledQty,item.recommendQty,false); |
|||
}, |
|||
qtyChanged(value, item) { |
|||
if (value <= 0) { |
|||
this.showMessage('数量不能小于或等于0') |
|||
item.handledQty = item.defaultHandleQty |
|||
this.$refs.comNumberBox.setValue(item.handledQty); |
|||
} else if (value > item.defaultHandleQty) { |
|||
item.handledQty = item.defaultHandleQty |
|||
this.showMessage('数量不能大于库存数量:' + item.handledQty) |
|||
this.$refs.comNumberBox.setValue(item.handledQty); |
|||
} |
|||
}, |
|||
showMessage(message) { |
|||
this.$refs.comMessage.showMessage(message); |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style> |
|||
</style> |
@ -0,0 +1,84 @@ |
|||
<!--发料任务卡片--> |
|||
<template> |
|||
<view class="device-detail issuelist"> |
|||
<!-- <view class="card_task issuecard nopad uni-flex space-between"> --> |
|||
<view class="card_task nopad space-between"> |
|||
<com-job-top-info :jobContent="dataContent"></com-job-top-info> |
|||
<image v-if="dataContent.useOnTheWayLocation" class="tag_icon" src="@/static/icons_ui/icon_kw_use.svg"> |
|||
</image> |
|||
</view> |
|||
<view class="margin_xs_bottom" style="clear: both;"> |
|||
<view class="label_order"> |
|||
<image class="icon_normal" src="@/static/icons_ui/icon_apply_num.svg"></image> |
|||
<text>{{dataContent.materialRequestNumber}}</text> |
|||
<!-- <text>申请单:{{dataContent.materialRequestNumber}}</text> --> |
|||
</view> |
|||
<view class="label_order"> |
|||
<image class="icon_normal" src="@/static/icons_ui/icon_prod_line.svg"></image> |
|||
<text>{{dataContent.prodLine}}</text> |
|||
<!-- <text>生产线:{{dataContent.prodLine}}</text> --> |
|||
</view> |
|||
</view> |
|||
<view class="uni-flex uni-row receipt_bot"> |
|||
<view class="label_order"> |
|||
<image class="icon_normal" src="@/static/icons_ui/icon_date.svg"> |
|||
</image> |
|||
<text |
|||
class="text_darkblue">{{dataContent.creationTime===null?'无':dataContent.creationTime| formatDate}}</text> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
getJobStatuStyle, |
|||
getJobStatuDesc, |
|||
getInventoryTypeStyle, |
|||
getInventoryStatusDesc, |
|||
dateFormat |
|||
} from '@/common/basic.js'; |
|||
import comItemTop from '@/mycomponents/comItem/comItemTop.vue' |
|||
import comItemBottom from '@/mycomponents/comItem/comItemBottom.vue' |
|||
import comJobTopInfo from '@/mycomponents/comjob/comJobTopInfo.vue' |
|||
|
|||
export default { |
|||
name: "comissue", |
|||
components: { |
|||
comItemTop, |
|||
comItemBottom, |
|||
comJobTopInfo |
|||
}, |
|||
data() { |
|||
return {}; |
|||
}, |
|||
computed: {}, |
|||
// 此处定义传入的数据 |
|||
props: { |
|||
dataContent: { |
|||
type: Object, |
|||
value: null |
|||
} |
|||
}, |
|||
filters: { |
|||
jobStatusStyle: function(val) { |
|||
return getJobStatuStyle(val); |
|||
}, |
|||
jobStatusColor: function(val) { |
|||
return getJobStatuDesc(val); |
|||
}, |
|||
statusStyle: function(val) { |
|||
return getInventoryTypeStyle(val); |
|||
}, |
|||
statusColor: function(val) { |
|||
return getInventoryStatusDesc(val); |
|||
}, |
|||
formatDate: function(val) { |
|||
return dateFormat(val) |
|||
} |
|||
}, |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
</style> |
@ -0,0 +1,170 @@ |
|||
<template> |
|||
<view> |
|||
<uni-popup ref="popup" @change="change" @maskClick="closeScanPopup()"> |
|||
<view class="popup_box"> |
|||
<view class="pop_title"> |
|||
扫描器具码 |
|||
<text class="fr" @click="closeScanPopup()">关闭</text> |
|||
</view> |
|||
<view class="pop_tab"> |
|||
<view class="tab_info"> |
|||
<win-com-scan ref="comscan" @getScanResult="getScanResult" placeholder="器具码" |
|||
:clearResult="true"></win-com-scan> |
|||
<view class="uni-flex"> |
|||
<button class="clean_scan_btn" @click="cancelClick()">清空</button> |
|||
<button class="scan_btn" @click="scanClick()">扫描</button> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</uni-popup> |
|||
<com-message ref="comMessage" @afterClose="getfocus"></com-message> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import winComScan from '@/mycomponents/wincom/winComScan.vue' |
|||
import comMessage from '@/mycomponents/common/comMessage.vue' |
|||
import { |
|||
getContainerCodeInfo |
|||
} from '@/api/index.js'; |
|||
|
|||
export default { |
|||
name: 'winScanByPack', |
|||
components: { |
|||
winComScan, |
|||
comMessage |
|||
}, |
|||
props: { |
|||
title: { |
|||
type: String, |
|||
default: '' |
|||
}, |
|||
}, |
|||
data() { |
|||
return { |
|||
scanResult: {}, |
|||
show: false, |
|||
} |
|||
}, |
|||
created() { |
|||
|
|||
}, |
|||
methods: { |
|||
openScanPopup(content) { |
|||
this.$refs.popup.open('bottom'); |
|||
}, |
|||
|
|||
closeScanPopup(content) { |
|||
this.$refs.popup.close(); |
|||
this.$emit("close", ''); |
|||
}, |
|||
|
|||
scanClick() { |
|||
this.$refs.comscan.handelScanMsg(); |
|||
}, |
|||
cancelClick() { |
|||
this.$refs.comscan.clearScanValue(); |
|||
}, |
|||
|
|||
getScanResult(result) { |
|||
console.log("扫描",result.data.code) |
|||
if (result != null) { |
|||
if(result.data.code[0].toUpperCase()!="C"){ |
|||
this.showMessage("标签格式不正确") |
|||
return; |
|||
} |
|||
// uni.showLoading({ |
|||
// title: '扫描中...', |
|||
// mask: true |
|||
// }) |
|||
// getContainerCodeInfo(code).then(res=>{ |
|||
// uni.hideLoading(); |
|||
//this.scanResult=res.data |
|||
// }).catch(error=>{ |
|||
// uni.hideLoading(); |
|||
// this.showMessage(error.message) |
|||
// }) |
|||
var data = |
|||
{ |
|||
containerCode: "C19", |
|||
partCode: "TMDLYA0AFM6A", |
|||
partName: "P000000000000015", |
|||
partDesc: "MY前保总成件售后件(冲孔)", |
|||
basicUom: "PC", |
|||
locationCode: "W", |
|||
locationName: "原物料库位", |
|||
stdPackQty: 100, |
|||
remark: null, |
|||
tenantId: null, |
|||
concurrencyStamp: "b3f2cf7ba3e14166bb97dac768d91741", |
|||
lastModificationTime: null, |
|||
lastModifierId: null, |
|||
creationTime: "2024-02-28T14:47:08.6878607", |
|||
creatorId: null, |
|||
qty:0, |
|||
id: "4c40f72b-a86d-54be-aed2-3a1100a46436" |
|||
} |
|||
this.scanResult = data; |
|||
this.callBack() |
|||
// this.closeScanPopup() |
|||
|
|||
} |
|||
}, |
|||
|
|||
getLabelResult(label) { |
|||
let labelResult = { |
|||
sucess: true, |
|||
message: "", |
|||
data: label, |
|||
// data: { |
|||
// isPack: true, |
|||
// // scanType: null, |
|||
// itemCode: label.itemCode, |
|||
// itemName: label.itemName, |
|||
// itemDesc1: label.itemDesc1, |
|||
// itemDesc2: label.itemDesc2, |
|||
// lot: label.lot, |
|||
// qty: label.qty, |
|||
// uom: label.uom, |
|||
// poNumber: label.poNumber, |
|||
// // asn: null, |
|||
// packingCode: label.code, |
|||
// supplierBatch: label.supplierBatch, |
|||
// // order: null, |
|||
// // poLine: null, |
|||
// code: label.code, |
|||
// } |
|||
|
|||
}; |
|||
labelResult.data.isPack = true; |
|||
labelResult.data.packingCode = label.code; |
|||
return labelResult; |
|||
}, |
|||
|
|||
callBack() { |
|||
this.$refs.comscan.clear(); |
|||
this.$emit("getScanResult", this.scanResult); |
|||
}, |
|||
getfocus() { |
|||
if (this.$refs.comscan != undefined) { |
|||
this.$refs.comscan.getfocus(); |
|||
} |
|||
}, |
|||
losefocus() { |
|||
if (this.$refs.comscan != undefined) { |
|||
this.$refs.comscan.losefocus(); |
|||
} |
|||
}, |
|||
showMessage(message) { |
|||
this.$refs.comMessage.showMessage(message); |
|||
}, |
|||
change(e) { |
|||
this.show = e.show |
|||
} |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style> |
|||
</style> |
@ -0,0 +1,212 @@ |
|||
<template> |
|||
<page-meta root-font-size="18px"></page-meta> |
|||
<view class=""> |
|||
|
|||
<win-empty-view v-if="issueList.length==0"></win-empty-view> |
|||
|
|||
<view hover-class="uni-list-cell-hover" v-for="(item, index) in issueList" :key="item.id" |
|||
@click="openDetail(item)"> |
|||
<comDeliverBoard :dataContent="item"></comDeliverBoard> |
|||
</view> |
|||
<uni-load-more :status="loadingType" v-if="issueList.length>0" /> |
|||
<!-- <win-scan-button @goScan='openScanPopup'></win-scan-button> --> |
|||
<win-mulit-scan ref="scanPopup" :titleArray="titleArray" @getScanResult='getScanResult'> |
|||
</win-mulit-scan> |
|||
<com-scan-issue-list ref="scanList" @selectedItem="selectedItem"></com-scan-issue-list> |
|||
<!-- com-message必须放在最下层 --> |
|||
<com-message ref="comMessage"></com-message> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
getDeliverBoardList, |
|||
getIssueJobByNumber, |
|||
getIssueListByRequest |
|||
} from '@/api/index.js'; |
|||
|
|||
import { |
|||
goHome |
|||
} from '@/common/basic.js'; |
|||
|
|||
import winEmptyView from '@/mycomponents/wincom/winEmptyView.vue' |
|||
import comDeliverBoard from '@/mycomponents/coms/task/comDeliverBoard.vue'; |
|||
import comMessage from '@/mycomponents/common/comMessage.vue' |
|||
import winScanButton from '@/mycomponents/wincom/winScanButton.vue' |
|||
import winMulitScan from '@/mycomponents/wincom/winMulitScan.vue' |
|||
import comScanIssueList from '@/mycomponents/scan/comScanIssueList.vue' |
|||
|
|||
export default { |
|||
name: 'issue', |
|||
components: { |
|||
winEmptyView, |
|||
comDeliverBoard, |
|||
comMessage, |
|||
winScanButton, |
|||
winMulitScan, |
|||
comScanIssueList |
|||
}, |
|||
data() { |
|||
return { |
|||
//popup |
|||
type: '', |
|||
issueList: [], |
|||
reload: false, |
|||
status: '', |
|||
contentText: { |
|||
contentdown: '上拉加载更多', |
|||
contentrefresh: '加载中', |
|||
contentnomore: '没有更多' |
|||
}, |
|||
pageSize: this.modelConfig, |
|||
pageIndex: 1, |
|||
isIssueTimeChange: false, |
|||
isToday: false, |
|||
titleArray: ['任务编号'], |
|||
loadingType: "nomore" |
|||
}; |
|||
}, |
|||
props: { |
|||
datacontent: { |
|||
type: Object, |
|||
value: null |
|||
}, |
|||
isByFIFO: { |
|||
type: Boolean, |
|||
value: false |
|||
} |
|||
}, |
|||
onShow() { |
|||
this.getList('refresh'); |
|||
}, |
|||
methods: { |
|||
openScanPopup() { |
|||
this.$refs.scanPopup.openScanPopup(); |
|||
}, |
|||
|
|||
//查询发料任务 |
|||
getList(type) { |
|||
let that = this; |
|||
uni.showLoading({ |
|||
title: "加载中....", |
|||
mask: true |
|||
}); |
|||
this.loadingType = "loading"; |
|||
if (type === "refresh") { |
|||
this.pageIndex = 1; |
|||
this.issueList = []; |
|||
} |
|||
let params = { |
|||
pageSize: that.pageSize, |
|||
pageIndex: that.pageIndex, |
|||
isCreationTimeSorting: that.isIssueTimeChange, |
|||
isToday: that.isToday |
|||
}; |
|||
getDeliverBoardList(params) |
|||
.then(res => { |
|||
uni.hideLoading(); |
|||
if (type === "refresh") { |
|||
uni.stopPullDownRefresh(); |
|||
} |
|||
var list = res.items; |
|||
this.loadingType = "loadmore"; |
|||
if (list == null || list.length == 0) { |
|||
//没数据了 |
|||
this.loadingType = "nomore"; |
|||
return; |
|||
} |
|||
that.issueList = type === "refresh" ? list : this.issueList.concat(list); |
|||
that.pageIndex++; |
|||
}) |
|||
.catch(err => { |
|||
this.showMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
getScanResult(type, result) { |
|||
let code = result.data.code; |
|||
if (code == '') { |
|||
this.showMessage('扫描的内容不能为空') |
|||
return; |
|||
} |
|||
if (type == '任务编号') { |
|||
this.scanByNumber(code, type); |
|||
} |
|||
}, |
|||
|
|||
//扫描申请单号 |
|||
scanByRequesNumber(code, type) { |
|||
let that = this; |
|||
uni.showLoading({ |
|||
title: "加载中....", |
|||
mask: true |
|||
}); |
|||
getIssueListByRequest(code).then(res => { |
|||
uni.hideLoading(); |
|||
let items = res.items; |
|||
if (res.totalCount > 0) { |
|||
if (res.totalCount == 1) { |
|||
that.openDetail(items[0]); |
|||
} else { |
|||
that.showItemList(items); |
|||
} |
|||
} else { |
|||
that.showMessage('未查找到' + type + '为【' + code + '】的发料任务'); |
|||
} |
|||
}).catch(err => { |
|||
that.showMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
//扫描申请单号 |
|||
scanByNumber(code, type) { |
|||
let that = this; |
|||
uni.showLoading({ |
|||
title: "加载中....", |
|||
mask: true |
|||
}); |
|||
getIssueJobByNumber(code).then(res => { |
|||
uni.hideLoading(); |
|||
if (res != null) { |
|||
that.openDetail(res); |
|||
} else { |
|||
that.showMessage('未查找到' + type + '为【' + code + '】的发料任务'); |
|||
} |
|||
}).catch(err => { |
|||
that.showMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
openDetail(item) { |
|||
uni.navigateTo({ |
|||
url: './deliverBoard_detail?id=' + item.id + '&jobStatus=' + item.jobStatus |
|||
}); |
|||
}, |
|||
|
|||
showMessage(message) { |
|||
this.$refs.comMessage.showMessage(message); |
|||
}, |
|||
onPull() { |
|||
this.getList('refresh'); |
|||
}, |
|||
onReach() { |
|||
//避免多次触发 |
|||
if (this.loadingType == 'loading' || this.loadingType == 'nomore') { |
|||
return; |
|||
} |
|||
this.getList('more'); |
|||
}, |
|||
showItemList(itemList) { |
|||
this.$refs.scanList.openPopup(itemList); |
|||
}, |
|||
selectedItem(item) { |
|||
this.openDetail(item); |
|||
} |
|||
} |
|||
}; |
|||
</script> |
|||
<style scoped lang="scss"> |
|||
</style> |
@ -0,0 +1,386 @@ |
|||
<!-- 发料任务详情 --> |
|||
<template> |
|||
<page-meta root-font-size="16px"></page-meta> |
|||
<view class=""> |
|||
<view class="top_card"> |
|||
<com-job-scan-detail :jobContent="datacontent" :allCount="allCount" :scanCount="scanCount"> |
|||
</com-job-scan-detail> |
|||
</view> |
|||
<scroll-view :scroll-top="scrollTop" scroll-y="true" @scrolltoupper="upper" @scrolltolower="lower" |
|||
@scroll="scroll" class="scroll-detail"> |
|||
|
|||
<view class="detail-list margin_top" v-for="(item, index) in details" :key="item.id"> |
|||
<!-- <comDeliverBoardDetail :dataContent="item" :isShowPacking="true"></comDeliverBoardDetail> --> |
|||
<view class="detail-content"> |
|||
<view class="choose_main"> |
|||
<view class="ljh_box"> |
|||
<view class="tit_ljh">{{ item.itemCode }}</view> |
|||
<view class="ljh_left desc_ljh"> |
|||
<view class="font_xs text_lightblue">{{ item.itemName }}</view> |
|||
<view class="font_xs text_lightblue">{{ item.itemDesc1 }}</view> |
|||
</view> |
|||
</view> |
|||
<view class="list_form"> |
|||
<view class="uni-container"> |
|||
<uni-table style="overflow-x: hidden;"> |
|||
<uni-tr> |
|||
<!-- <uni-th width="90"></uni-th> |
|||
<uni-th width="100" align="center">推荐</uni-th> |
|||
<uni-th width="100" align="center">实际</uni-th> --> |
|||
<uni-th width="50"></uni-th> |
|||
<uni-th width="120" align="center">推荐</uni-th> |
|||
<uni-th width="120" align="center">实际</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="50">器具码</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view class="text_packingCode"> |
|||
{{ item.recommendContainerCode }} |
|||
</view> |
|||
</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view v-if="item.scaned" class="text_packingCode"> |
|||
{{ item.containerCode }} |
|||
</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="50">数量</text></uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<!-- <text class="text_black">{{item.recommendQty}}({{item.uom}})</text> --> |
|||
</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view v-if="item.scaned" |
|||
style="display: flex;flex-direction: row;justify-content:center;align-items: center;"> |
|||
|
|||
<com-number-box ref="comNumberBox" v-model="item.handledQty" |
|||
:max="99999" :min="0" style='width: 100px;' |
|||
@change="qtyChanged($event,item,index)"> |
|||
</com-number-box> |
|||
<text class="text_black">({{item.uom}})</text> |
|||
</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
</uni-table> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
<view class="choose_marked" v-if="item.scaned"> |
|||
<image src="@/static/image_marked.svg"></image> |
|||
</view> |
|||
<view class="fr" > |
|||
<button class="btn_single" hover-class="btn_single_after" @click="unPacking(item)">拆箱</button> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</scroll-view> |
|||
<view class="uni-flex uni-row new_btn_bot"> |
|||
<button class="new_clear_btn btn_double" @click="clear()">清空</button> |
|||
<button class="new_save_btn btn_double" @click="submit()">提交</button> |
|||
</view> |
|||
<com-balance ref='issueitems' @selectedItem='selectedBalanceItem'></com-balance> |
|||
<win-scan-button @goScan='openScanPopup'></win-scan-button> |
|||
<winScanByContainer ref="scanPopup" @getScanResult='getScanResult'></winScanByContainer> |
|||
<comUnPacking ref='comUnPacking' |
|||
@getvalue="getUnPackingCount" title="拆箱"> |
|||
</comUnPacking> |
|||
<com-message ref="comMessage" @afterCloseCommitMessage='closeCommitMessage()' |
|||
@afterCloseScanMessage='closeScanMessage'></com-message> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
getDeliverJobDetail, |
|||
takeDeliverBoardJob, |
|||
cancelTakeDeliverBoardJob, |
|||
finshIssueJob, |
|||
issueBalances |
|||
} from '@/api/index.js'; |
|||
import { |
|||
getJobStatuStyle, |
|||
getJobStatuDesc, |
|||
showConfirmMsg, |
|||
goHome, |
|||
compareDesc, |
|||
compareStr, |
|||
getCurrDateTime, |
|||
navigateBack |
|||
} from '@/common/basic.js'; |
|||
import comMessage from '@/mycomponents/common/comMessage.vue' |
|||
import winScanButton from '@/mycomponents/wincom/winScanButton.vue' |
|||
import winScanByContainer from '@/mycomponents/wincom/winScanByContainer.vue' |
|||
import comBalance from '@/mycomponents/common/comBalance.vue' |
|||
import comJobScanDetail from '@/mycomponents/comjob/comJobScanDetail.vue' |
|||
import comDeliverBoardDetail from '@/mycomponents/coms/comDeliverBoardDetail.vue' |
|||
import comNumberBox from '@/mycomponents/common/comNumberBox.vue'; |
|||
import comUnPacking from '@/mycomponents/coms/comUnPacking.vue' |
|||
|
|||
export default { |
|||
components: { |
|||
comMessage, |
|||
winScanButton, |
|||
winScanByContainer, |
|||
comBalance, |
|||
comJobScanDetail, |
|||
comDeliverBoardDetail, |
|||
comNumberBox, |
|||
comUnPacking |
|||
}, |
|||
data() { |
|||
return { |
|||
id: "", |
|||
datacontent: {}, |
|||
details: {}, |
|||
toLocation: '', |
|||
scrollTop: 0, |
|||
old: { |
|||
scrollTop: 0 |
|||
}, |
|||
ispending: false, |
|||
balancesItem: null, |
|||
currentItem: null, |
|||
received: false, |
|||
allCount: 0, |
|||
scanCount: 0, |
|||
jobStatus: "" |
|||
|
|||
} |
|||
}, |
|||
onLoad(param) { |
|||
this.id = param.id; |
|||
if (param.jobStatus == 1) { |
|||
this.receive((callback => { |
|||
this.received = true; |
|||
this.getDetail(); |
|||
})); |
|||
} else { |
|||
this.getDetail(); |
|||
} |
|||
}, |
|||
//返回首页 |
|||
onNavigationBarButtonTap(e) { |
|||
if (e.index === 0) { |
|||
goHome(); |
|||
} else if (e.index === 1) { |
|||
window.location.reload(); |
|||
} |
|||
}, |
|||
|
|||
onBackPress(e) { |
|||
//已经接收但是没提交任务 |
|||
if (e.from == 'backbutton') { |
|||
if (this.jobStatus == 2) { |
|||
//取消承接任务 |
|||
cancelTakeDeliverBoardJob(this.id).then(res => { |
|||
uni.navigateBack(); |
|||
}).catch(error => { |
|||
uni.navigateBack(); |
|||
}) |
|||
} else { |
|||
uni.navigateBack(); |
|||
} |
|||
return true; |
|||
} |
|||
}, |
|||
|
|||
mounted() { |
|||
uni.setNavigationBarColor({ |
|||
frontColor: '#ffffff', |
|||
backgroundColor: "#5A7CF3 !important" |
|||
}) |
|||
}, |
|||
methods: { |
|||
openScanPopup() { |
|||
this.$refs.scanPopup.openScanPopup(); |
|||
}, |
|||
//加载零件信息 |
|||
getDetail() { |
|||
let that = this; |
|||
if (that.id == undefined) { |
|||
return; |
|||
} |
|||
uni.showLoading({ |
|||
title: '加载中...', |
|||
mask: true |
|||
}) |
|||
let params = { |
|||
id: that.id, |
|||
}; |
|||
getDeliverJobDetail(params) |
|||
.then(item => { |
|||
console.log('item', item); |
|||
that.datacontent = item; |
|||
that.details = item.details; |
|||
that.details[0].recommendContainerCode = "C19" |
|||
that.jobStatus = item.jobStatus |
|||
if (that.details != null) { |
|||
that.details.forEach( |
|||
r => { |
|||
r.scaned = false; |
|||
r.scanDate = new Date() |
|||
} |
|||
); |
|||
that.ispending = item.jobStatus === 2; |
|||
// if (that.toLocation === '') { |
|||
// that.toLocation = item.details[0].requestLocationCode; |
|||
// } |
|||
this.allCount = that.details.length; |
|||
this.scanCount = 0; |
|||
|
|||
} |
|||
uni.hideLoading(); |
|||
}) |
|||
.catch(err => { |
|||
this.showMessage('未查找到详细信息') |
|||
|
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
getScanResult(result) { |
|||
//零件是否已经被扫描过 |
|||
let item = this.details.find(r => r.recommendContainerCode == result.containerCode); |
|||
if (item == undefined) { |
|||
this.showMessage("器具码【" + result.containerCode + "】不在列表中") |
|||
} else { |
|||
if (item.scaned) { |
|||
this.showMessage("器具码【" + result.containerCode + "】已经扫描") |
|||
} else { |
|||
if (this.allCount == this.scanCount) { |
|||
this.showMessage("零件已经全部扫描完成"); |
|||
return; |
|||
} |
|||
item.containerCode = result.containerCode; |
|||
item.scaned = true; |
|||
item.handleQty = 10; |
|||
this.calcScanCount() |
|||
this.$forceUpdate(); |
|||
} |
|||
} |
|||
}, |
|||
|
|||
// //接收 |
|||
receive(callback) { |
|||
let params = { |
|||
id: this.id |
|||
}; |
|||
takeDeliverBoardJob(params) |
|||
.then(res => { |
|||
callback(true); |
|||
}) |
|||
.catch(err => { |
|||
this.showMessage(err.message); |
|||
callback(false); |
|||
}); |
|||
}, |
|||
calcScanCount() { |
|||
this.scanCount = this.details.filter(r => r.scaned === true).length; |
|||
this.closeScanPopup(); |
|||
}, |
|||
|
|||
submit() { |
|||
this.calcScanCount() |
|||
if (this.scanCount != this.allCount) { |
|||
this.showMessage('当前扫描数量【'+this.scanCount+"】,总数量为【"+this.allCount+"】,未全部扫描"); |
|||
return; |
|||
} |
|||
uni.showLoading({ |
|||
title: "提交中...", |
|||
mask: true |
|||
}); |
|||
let params = that.datacontent; |
|||
// finshIssueJob(that.id, params) |
|||
// .then(res => { |
|||
// uni.hideLoading(); |
|||
// if (res != null) { |
|||
// that.showCommitSuccessMessage(); |
|||
// that.backJobList(); |
|||
// } |
|||
// }) |
|||
// .catch(err => { |
|||
// that.showMessage(err.message); |
|||
// uni.hideLoading(); |
|||
// }); |
|||
}, |
|||
|
|||
//返回任务列表页 |
|||
backJobList() { |
|||
navigateBack(1) |
|||
}, |
|||
|
|||
clear() { |
|||
this.scanCount = 0; |
|||
this.getDetail(); |
|||
}, |
|||
showMessage(message) { |
|||
this.$refs.comMessage.showMessage(message); |
|||
}, |
|||
showScanMessage(message) { |
|||
this.$refs.comMessage.showScanMessage(message); |
|||
}, |
|||
|
|||
closeScanMessage() { |
|||
this.$refs.scanPopup.getfocus(); |
|||
}, |
|||
|
|||
calcScanCount() { |
|||
this.scanCount = this.details.filter(r => r.scaned === true).length; |
|||
this.closeScanPopup(); |
|||
}, |
|||
|
|||
showCommitSuccessMessage() { |
|||
this.$refs.comMessage.showCommitSuccess(); |
|||
}, |
|||
|
|||
closeCommitMessage() { |
|||
this.backJobList(0); //点关闭直接返回列表 |
|||
uni.hideLoading(); |
|||
}, |
|||
|
|||
closeScanPopup() { |
|||
if (this.allCount == this.scanCount) { |
|||
this.$refs.scanPopup.closeScanPopup(); |
|||
} |
|||
}, |
|||
|
|||
closeScanMessage() { |
|||
this.scanPopupGetFocus(); |
|||
}, |
|||
|
|||
scanPopupGetFocus() { |
|||
this.$refs.scanPopup.getfocus(); |
|||
}, |
|||
|
|||
scrollToTop() { |
|||
let that = this; |
|||
// 解决view层不同步的问题 |
|||
that.scrollTop = that.old.scrollTop |
|||
this.$nextTick(function() { |
|||
that.scrollTop = 0 |
|||
}); |
|||
}, |
|||
|
|||
upper: function(e) { |
|||
// console.log(e) |
|||
}, |
|||
lower: function(e) { |
|||
// console.log(e) |
|||
}, |
|||
scroll: function(e) { |
|||
// console.log(e) |
|||
this.old.scrollTop = e.detail.scrollTop; |
|||
}, |
|||
qtyChanged(value, item, index) { |
|||
if (value <= 0) { |
|||
this.showMessage('发料数量不能小于或等于0') |
|||
this.$refs['comNumberBox_' + index][0].setValue(item.handledQty); |
|||
} |
|||
}, |
|||
|
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
</style> |
@ -0,0 +1,240 @@ |
|||
<template> |
|||
<page-meta root-font-size="18px"></page-meta> |
|||
<view class=""> |
|||
<!-- <view class="uni-flex uni-row require_wrap"> |
|||
<button @click="isTodayChange" :class="[isToday==true?'require_cell require_active':'require_cell']"> |
|||
<text></text> |
|||
只看当天发料 |
|||
</button> |
|||
<button @click="timeSortingChange" |
|||
:class="[isIssueTimeChange==true?'require_cell require_active':'require_cell']"> |
|||
<text></text> |
|||
按发料时间排序 |
|||
</button> |
|||
</view> --> |
|||
|
|||
<win-empty-view v-if="issueList.length==0"></win-empty-view> |
|||
|
|||
<view hover-class="uni-list-cell-hover" v-for="(item, index) in issueList" :key="item.id" |
|||
@click="openDetail(item)"> |
|||
<com-issue :dataContent="item"></com-issue> |
|||
</view> |
|||
<uni-load-more :status="loadingType" v-if="issueList.length>0" /> |
|||
<win-scan-button @goScan='openScanPopup'></win-scan-button> |
|||
<win-mulit-scan ref="scanPopup" :titleArray="titleArray" @getScanResult='getScanResult'> |
|||
</win-mulit-scan> |
|||
<com-scan-issue-list ref="scanList" @selectedItem="selectedItem"></com-scan-issue-list> |
|||
<!-- com-message必须放在最下层 --> |
|||
<com-message ref="comMessage"></com-message> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
getIssueList, |
|||
getIssueJobByNumber, |
|||
getIssueListByRequest |
|||
} from '@/api/index.js'; |
|||
|
|||
import { |
|||
goHome |
|||
} from '@/common/basic.js'; |
|||
|
|||
import winEmptyView from '@/mycomponents/wincom/winEmptyView.vue' |
|||
import issueDetail from './issue_detail.vue'; |
|||
import comIssue from '@/mycomponents/coms/task/comIssue.vue'; |
|||
import comMessage from '@/mycomponents/common/comMessage.vue' |
|||
import winScanButton from '@/mycomponents/wincom/winScanButton.vue' |
|||
import winMulitScan from '@/mycomponents/wincom/winMulitScan.vue' |
|||
import comScanIssueList from '@/mycomponents/scan/comScanIssueList.vue' |
|||
|
|||
export default { |
|||
name: 'issue', |
|||
components: { |
|||
winEmptyView, |
|||
comIssue, |
|||
issueDetail, |
|||
comMessage, |
|||
winScanButton, |
|||
winMulitScan, |
|||
comScanIssueList |
|||
}, |
|||
data() { |
|||
return { |
|||
//popup |
|||
type: '', |
|||
issueList: [], |
|||
reload: false, |
|||
status: '', |
|||
contentText: { |
|||
contentdown: '上拉加载更多', |
|||
contentrefresh: '加载中', |
|||
contentnomore: '没有更多' |
|||
}, |
|||
pageSize: this.modelConfig, |
|||
pageIndex: 1, |
|||
isIssueTimeChange: false, |
|||
isToday: false, |
|||
titleArray: ['任务编号'], |
|||
loadingType: "nomore" |
|||
}; |
|||
}, |
|||
props: { |
|||
datacontent: { |
|||
type: Object, |
|||
value: null |
|||
}, |
|||
isByFIFO: { |
|||
type: Boolean, |
|||
value: false |
|||
} |
|||
}, |
|||
mounted() { |
|||
this.getList('refresh'); |
|||
}, |
|||
methods: { |
|||
openScanPopup() { |
|||
this.$refs.scanPopup.openScanPopup(); |
|||
}, |
|||
|
|||
//按时间窗口排序 |
|||
timeSortingChange() { |
|||
this.isIssueTimeChange = !this.isIssueTimeChange; |
|||
this.getList() |
|||
}, |
|||
//只看当天到货 |
|||
isTodayChange() { |
|||
this.isToday = !this.isToday |
|||
this.getList() |
|||
}, |
|||
|
|||
//查询发料任务 |
|||
getList(type) { |
|||
let that = this; |
|||
uni.showLoading({ |
|||
title: "加载中....", |
|||
mask: true |
|||
}); |
|||
this.loadingType = "loading"; |
|||
if (type === "refresh") { |
|||
this.pageIndex = 1; |
|||
this.issueList = []; |
|||
} |
|||
let params = { |
|||
pageSize: that.pageSize, |
|||
pageIndex: that.pageIndex, |
|||
isCreationTimeSorting: that.isIssueTimeChange, |
|||
isToday: that.isToday |
|||
}; |
|||
getIssueList(params) |
|||
.then(res => { |
|||
uni.hideLoading(); |
|||
if (type === "refresh") { |
|||
uni.stopPullDownRefresh(); |
|||
} |
|||
var list = res.items; |
|||
this.loadingType = "loadmore"; |
|||
if (list == null || list.length == 0) { |
|||
//没数据了 |
|||
this.loadingType = "nomore"; |
|||
return; |
|||
} |
|||
that.issueList = type === "refresh" ? list : this.issueList.concat(list); |
|||
that.pageIndex++; |
|||
}) |
|||
.catch(err => { |
|||
this.showMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
getScanResult(type, result) { |
|||
let code = result.data.code; |
|||
if (code == '') { |
|||
this.showMessage('扫描的内容不能为空') |
|||
return; |
|||
} |
|||
if (type == '申请单号') { |
|||
this.scanByRequesNumber(code, type); |
|||
} else if (type == '任务编号') { |
|||
this.scanByNumber(code, type); |
|||
} |
|||
}, |
|||
|
|||
//扫描申请单号 |
|||
scanByRequesNumber(code, type) { |
|||
let that = this; |
|||
uni.showLoading({ |
|||
title: "加载中....", |
|||
mask: true |
|||
}); |
|||
getIssueListByRequest(code).then(res => { |
|||
uni.hideLoading(); |
|||
let items = res.items; |
|||
if (res.totalCount > 0) { |
|||
if (res.totalCount == 1) { |
|||
that.openDetail(items[0]); |
|||
} else { |
|||
that.showItemList(items); |
|||
} |
|||
} else { |
|||
that.showMessage('未查找到' + type + '为【' + code + '】的发料任务'); |
|||
} |
|||
}).catch(err => { |
|||
that.showMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
//扫描申请单号 |
|||
scanByNumber(code, type) { |
|||
let that = this; |
|||
uni.showLoading({ |
|||
title: "加载中....", |
|||
mask: true |
|||
}); |
|||
getIssueJobByNumber(code).then(res => { |
|||
uni.hideLoading(); |
|||
if (res != null) { |
|||
that.openDetail(res); |
|||
} else { |
|||
that.showMessage('未查找到' + type + '为【' + code + '】的发料任务'); |
|||
} |
|||
}).catch(err => { |
|||
that.showMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
openDetail(item) { |
|||
uni.navigateTo({ |
|||
url: './issue_detail?id=' + item.id + '&jobStatus=' + item.jobStatus + '&isByFIFO=' + |
|||
this |
|||
.isByFIFO |
|||
}); |
|||
}, |
|||
|
|||
showMessage(message) { |
|||
this.$refs.comMessage.showMessage(message); |
|||
}, |
|||
onPull() { |
|||
this.getList('refresh'); |
|||
}, |
|||
onReach() { |
|||
//避免多次触发 |
|||
if (this.loadingType == 'loading' || this.loadingType == 'nomore') { |
|||
return; |
|||
} |
|||
this.getList('more'); |
|||
}, |
|||
showItemList(itemList) { |
|||
this.$refs.scanList.openPopup(itemList); |
|||
}, |
|||
selectedItem(item) { |
|||
this.openDetail(item); |
|||
} |
|||
} |
|||
}; |
|||
</script> |
|||
<style scoped lang="scss"> |
|||
</style> |
@ -0,0 +1,760 @@ |
|||
<!-- 发料任务详情 --> |
|||
<template> |
|||
<page-meta root-font-size="16px"></page-meta> |
|||
<view class=""> |
|||
<view class="top_card"> |
|||
<com-job-scan-detail :jobContent="datacontent" :allCount="allCount" :scanCount="scanCount"> |
|||
</com-job-scan-detail> |
|||
</view> |
|||
<scroll-view :scroll-top="scrollTop" scroll-y="true" @scrolltoupper="upper" @scrolltolower="lower" |
|||
@scroll="scroll" class="scroll-detail"> |
|||
|
|||
<view class="detail-list margin_top" v-for="(item, index) in details" :key="item.id"> |
|||
<view class="detail-content"> |
|||
<view class="choose_main"> |
|||
<view class="ljh_box"> |
|||
<view class="tit_ljh">{{ item.itemCode }}</view> |
|||
<view class="ljh_left desc_ljh"> |
|||
<view class="font_xs text_lightblue">{{ item.itemName }}</view> |
|||
<view class="font_xs text_lightblue">{{ item.itemDesc1 }}</view> |
|||
</view> |
|||
</view> |
|||
|
|||
<view class="list_form"> |
|||
<view class="uni-container"> |
|||
<uni-table style="overflow-x: hidden;"> |
|||
<uni-tr> |
|||
<!-- <uni-th width="90"></uni-th> |
|||
<uni-th width="100" align="center">推荐</uni-th> |
|||
<uni-th width="100" align="center">实际</uni-th> --> |
|||
<uni-th width="50"></uni-th> |
|||
<uni-th width="120" align="center">推荐</uni-th> |
|||
<uni-th width="120" align="center">实际</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="50">数量</text></uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<text class="text_black">{{item.recommendQty}}({{item.uom}})</text> |
|||
</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view v-if="item.scaned" |
|||
style="display: flex;flex-direction: row;justify-content:center;align-items: center;"> |
|||
|
|||
<com-number-box :ref="'comNumberBox_'+index" v-model="item.handledQty" |
|||
:max="99999" :min="0" style='width: 100px;' |
|||
@change="qtyChanged($event,item,index)"> |
|||
</com-number-box> |
|||
<text class="text_black">({{item.uom}})</text> |
|||
</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="50">箱码</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view class="text_packingCode"> |
|||
{{ item.recommendPackingCode }} |
|||
</view> |
|||
</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view v-if="item.scaned" class="text_packingCode"> |
|||
{{ item.handledPackingCode }} |
|||
</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="50">批次</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view class="text_black">{{item.recommendLot }}</view> |
|||
</uni-th> |
|||
<uni-th width="120" align="center"> |
|||
<view v-if="item.scaned" class="text_black">{{item.handledLot }}</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
<uni-tr> |
|||
<uni-th width="60">库位</uni-th> |
|||
<uni-th width="100" align="center"> |
|||
<view class="text_black">{{ item.recommendFromLocationCode }}</view> |
|||
</uni-th> |
|||
<uni-th width="100" align="center"> |
|||
<view class="text_black" v-if="item.scaned"> |
|||
{{ item.handledFromLocationCode }} |
|||
</view> |
|||
</uni-th> |
|||
</uni-tr> |
|||
</uni-table> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
<view class="choose_marked" v-if="item.scaned"> |
|||
<image src="@/static/image_marked.svg"></image> |
|||
</view> |
|||
<view class="fr" |
|||
> |
|||
<button class="btn_single" hover-class="btn_single_after" @click="unPacking(item)">拆箱</button> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</scroll-view> |
|||
<view class="uni-flex uni-row new_btn_bot"> |
|||
<button class="new_clear_btn btn_double" @click="clear()">清空</button> |
|||
<button class="new_save_btn btn_double" @click="submit()">提交</button> |
|||
</view> |
|||
<com-balance ref='issueitems' @selectedItem='selectedBalanceItem'></com-balance> |
|||
<win-scan-button @goScan='openScanPopup'></win-scan-button> |
|||
<win-scan-by-pack ref="scanPopup" @getScanResult='getScanResult'></win-scan-by-pack> |
|||
|
|||
<com-balance ref="balanceItems" @selectedItem='selectedBalanceItem'></com-balance> |
|||
<comUnPacking ref='comUnPacking' |
|||
@getvalue="getUnPackingCount" title="拆箱"> |
|||
</comUnPacking> |
|||
<com-message ref="comMessage" @afterCloseCommitMessage='closeCommitMessage()' |
|||
@afterCloseScanMessage='closeScanMessage'></com-message> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import { |
|||
getIssueDetail, |
|||
takeIssueJob, |
|||
cancelTakeIssueJob, |
|||
finshIssueJob, |
|||
issueBalances |
|||
} from '@/api/index.js'; |
|||
import { |
|||
getJobStatuStyle, |
|||
getJobStatuDesc, |
|||
showConfirmMsg, |
|||
goHome, |
|||
compareDesc, |
|||
compareStr, |
|||
getCurrDateTime |
|||
} from '@/common/basic.js'; |
|||
import comMessage from '@/mycomponents/common/comMessage.vue' |
|||
import winScanButton from '@/mycomponents/wincom/winScanButton.vue' |
|||
import winMulitScan from '@/mycomponents/wincom/winMulitScan.vue' |
|||
import comBalance from '@/mycomponents/common/comBalance.vue' |
|||
import comJobScanDetail from '@/mycomponents/comjob/comJobScanDetail.vue' |
|||
import winScanByPack from '@/mycomponents/wincom/winScanByPack.vue' |
|||
import comNumberBox from '@/mycomponents/common/comNumberBox.vue'; |
|||
import comUnPacking from '@/mycomponents/coms/comUnPacking.vue' |
|||
|
|||
export default { |
|||
components: { |
|||
comMessage, |
|||
winScanButton, |
|||
winMulitScan, |
|||
comBalance, |
|||
comJobScanDetail, |
|||
winScanByPack, |
|||
comNumberBox, |
|||
comUnPacking |
|||
}, |
|||
data() { |
|||
return { |
|||
id: "", |
|||
datacontent: {}, |
|||
details: {}, |
|||
toLocation: '', |
|||
scrollTop: 0, |
|||
old: { |
|||
scrollTop: 0 |
|||
}, |
|||
ispending: false, |
|||
balancesItem: null, |
|||
currentItem: null, |
|||
received: false, |
|||
currentScanLebel: null, |
|||
allCount: 0, |
|||
scanCount: 0, |
|||
byFIFO: false, |
|||
isPack: true, |
|||
titleArray: ['箱标签'], |
|||
} |
|||
}, |
|||
filters: { |
|||
statusStyle: function(val) { |
|||
return getJobStatuStyle(val); |
|||
}, |
|||
statusColor: function(val) { |
|||
return getJobStatuDesc(val); |
|||
} |
|||
}, |
|||
props: { |
|||
itemCode: "", |
|||
}, |
|||
onLoad(param) { |
|||
this.id = param.id; |
|||
this.byFIFO = param.isByFIFO === 'true' ? true : false; |
|||
if (param.jobStatus == 1) { |
|||
this.receive((callback => { |
|||
this.received = true; |
|||
this.getDetail(); |
|||
})); |
|||
} else { |
|||
this.getDetail(); |
|||
} |
|||
}, |
|||
onReady() { |
|||
// if (this.byFIFO) { |
|||
// uni.setNavigationBarTitle({ |
|||
// title: '发料任务详情' |
|||
// }) |
|||
// } else { |
|||
// uni.setNavigationBarTitle({ |
|||
// title: '非FIFO发料任务详情' |
|||
// }) |
|||
// } |
|||
}, |
|||
//返回首页 |
|||
onNavigationBarButtonTap(e) { |
|||
if (e.index === 0) { |
|||
goHome(); |
|||
}else if(e.index === 1){ |
|||
window.location.reload(); |
|||
} |
|||
}, |
|||
//拦截返回按钮事件 |
|||
onBackPress(e) { |
|||
if (this.received) { |
|||
//取消承接任务 |
|||
cancelTakeIssueJob(this.id) |
|||
.then(res => {}) |
|||
.catch(err => { |
|||
this.showMessage(err.message); |
|||
}); |
|||
} |
|||
}, |
|||
mounted() { |
|||
uni.setNavigationBarColor({ |
|||
frontColor: '#ffffff', |
|||
backgroundColor: "#5A7CF3 !important" |
|||
}) |
|||
}, |
|||
methods: { |
|||
openScanPopup() { |
|||
// if (this.allCount === this.scanCount) { |
|||
// this.showMessage("零件已经全部扫描完成"); |
|||
// return; |
|||
// } |
|||
this.$refs.scanPopup.openScanPopup(); |
|||
}, |
|||
//加载零件信息 |
|||
getDetail() { |
|||
let that = this; |
|||
if (that.id == undefined) { |
|||
return; |
|||
} |
|||
uni.showLoading({ |
|||
title: '加载中...', |
|||
mask: true |
|||
}) |
|||
let params = { |
|||
id: that.id, |
|||
}; |
|||
getIssueDetail(params) |
|||
.then(item => { |
|||
console.log('item', item); |
|||
that.datacontent = item; |
|||
that.details = item.details; |
|||
if (that.details != null) { |
|||
that.details.forEach( |
|||
r => { |
|||
r.scaned = false; |
|||
r.scanDate = new Date() |
|||
} |
|||
); |
|||
that.ispending = item.jobStatus === 2; |
|||
// if (that.toLocation === '') { |
|||
// that.toLocation = item.details[0].requestLocationCode; |
|||
// } |
|||
this.allCount = that.details.length; |
|||
this.scanCount = 0; |
|||
|
|||
} |
|||
uni.hideLoading(); |
|||
}) |
|||
.catch(err => { |
|||
this.showMessage('未查找到详细信息') |
|||
|
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
getScanResult(result) { |
|||
//零件是否已经被扫描过 |
|||
let item = this.details.find(r => r.recommendPackingCode === result.data.packingCode && r |
|||
.scanPackingCode != result.data.packingCode); |
|||
if (item != undefined && item.scaned) { |
|||
showConfirmMsg('扫描的箱码【' + result.data.packingCode + '】匹配到任务中的【' + item.scanPackingCode + |
|||
'】箱,是否要重新匹配任务中的【' + item.scanPackingCode + '】箱?', |
|||
confirm => { |
|||
if (confirm) { |
|||
this.handledPackCode(result, true); |
|||
} else { |
|||
return; |
|||
} |
|||
}) |
|||
} else { |
|||
if (this.allCount === this.scanCount) { |
|||
this.showMessage("零件已经全部扫描完成"); |
|||
return; |
|||
} |
|||
this.handledPackCode(result, false); |
|||
} |
|||
this.scrollToTop(); |
|||
}, |
|||
|
|||
//处理箱标签 |
|||
//scaned是否是重新匹配 |
|||
handledPackCode(result, scaned) { |
|||
//获取标签信息 |
|||
let that = this; |
|||
that.currentScanLebel = result; |
|||
let scanItem = this.details.find(r => r.scanItemCode === that.currentScanLebel.data.itemCode && |
|||
r.scanPackingCode === that.currentScanLebel.data.packingCode && |
|||
r.scanLot === that.currentScanLebel.data.lot && |
|||
r.scaned == true) |
|||
if (scanItem != undefined) { |
|||
this.showScanMessage('箱码【' + that.currentScanLebel.data.packingCode + '】已经扫描,请扫描下一箱零件'); |
|||
} else { |
|||
this.dyIssue(result, scaned); |
|||
} |
|||
}, |
|||
|
|||
dyIssue(result, scaned) { |
|||
let that = this; |
|||
var itemCode = that.details.find(r => { |
|||
return r.itemCode === result.data.itemCode&& |
|||
r.scaned === scaned |
|||
}) |
|||
if (itemCode == undefined) { |
|||
that.showScanMessage('所扫描的箱码【' + result.data.code + '】对应的物料【' + result.data.itemCode + '】不在任务中'); |
|||
}else { |
|||
//零件号相同、箱码相同 |
|||
var itemCode1 = that.details.find(r => { |
|||
return r.itemCode === result.data.itemCode&& |
|||
r.recommendPackingCode === result.data.code |
|||
r.scaned === scaned |
|||
}) |
|||
//零件号相同、箱码不相同 |
|||
if(itemCode1 == undefined){ |
|||
var itemCode2 = that.details.find(r => { |
|||
return r.itemCode === result.data.itemCode&& |
|||
r.recommendLot === result.data.lot |
|||
&&r.scaned === scaned |
|||
}) |
|||
//零件号相同、箱码不相同、批次相同 |
|||
if(itemCode2==undefined){ |
|||
//零件号相同、箱码不相同、批次不相同 |
|||
console.log("零件号相同、箱码不相同、批次不相同") |
|||
setTimeout(res => { |
|||
showConfirmMsg(itemCode.recommendPackingCode+'未执行先进先出或不是最先批次,是否继续?', confirm => { |
|||
if (confirm) { |
|||
that.currentItem = itemCode; |
|||
that.afterScanPackLabel(result); |
|||
} else { |
|||
that.scanPopupGetFocus(); |
|||
} |
|||
}); |
|||
}, 100) |
|||
|
|||
}else { |
|||
console.log("零件号相同、箱码不相同、批次相同") |
|||
//零件号相同、箱码不相同、批次相同 |
|||
that.currentItem = itemCode2; |
|||
that.afterScanPackLabel(result); |
|||
} |
|||
|
|||
|
|||
}else { |
|||
//零件号相同、箱码相同、批次相同 |
|||
var itemCode3 = that.details.find(r => { |
|||
return r.itemCode === result.data.itemCode&& |
|||
r.recommendPackingCode === result.data.code&& |
|||
r.recommendLot === result.data.lot |
|||
&&r.scaned === scaned |
|||
}) |
|||
if(itemCode3==undefined){ |
|||
//零件号相同、箱码相同、批次不同 |
|||
console.log("零件号相同、箱码相同、批次不同") |
|||
setTimeout(res => { |
|||
showConfirmMsg(itemCode1.recommendPackingCode+'未执行先进先出或不是最先批次,是否继续?', confirm => { |
|||
if (confirm) { |
|||
that.currentItem = itemCode1; |
|||
that.afterScanPackLabel(result); |
|||
} else { |
|||
that.scanPopupGetFocus(); |
|||
} |
|||
}); |
|||
}, 100) |
|||
|
|||
}else { |
|||
console.log("零件号相同、箱码相同、批次相同") |
|||
//零件号相同、箱码相同、批次相同 |
|||
that.currentItem = itemCode3; |
|||
that.afterScanPackLabel(result); |
|||
} |
|||
} |
|||
} |
|||
|
|||
|
|||
// that.currentItem = that.details.find(r => { |
|||
// return r.itemCode === result.data.itemCode && |
|||
// r.recommendPackingCode === result.data.code && |
|||
// r.recommendLot === result.data.lot && |
|||
// r.scaned === scaned |
|||
// }); |
|||
|
|||
|
|||
|
|||
// //没找到符合的箱码、零件号、箱码、批次都相等 |
|||
// if (that.currentItem === undefined) { |
|||
// var itemCode = that.details.find(res => { |
|||
// return res.itemCode === result.data.itemCode && |
|||
// res.scaned === scaned |
|||
// }) |
|||
// //零件号相等 |
|||
// if (itemCode != undefined) { |
|||
// var lot = that.details.find(res => { |
|||
// return res.itemCode === result.data.itemCode && |
|||
// res.recommendLot === result.data.lot && |
|||
// res.scaned === scaned |
|||
// }) |
|||
// if (lot != undefined) { |
|||
// //通过 |
|||
// that.currentItem = lot; |
|||
// that.afterScanPackLabel(result); |
|||
// } else { |
|||
// //批次不相等 |
|||
// // 提示未执行先进先出或者不是最先批次。 |
|||
// setTimeout(res => { |
|||
// showConfirmMsg('未执行先进先出或不是最先批次,是否继续?', confirm => { |
|||
// if (confirm) { |
|||
// that.currentItem = itemCode; |
|||
// that.afterScanPackLabel(result); |
|||
// } else { |
|||
// that.scanPopupGetFocus(); |
|||
// } |
|||
// }); |
|||
// }, 100) |
|||
|
|||
// } |
|||
// } else { |
|||
// //零件号不相等 |
|||
// var lot = that.details.find(res => { |
|||
// return res.recommendLot === result.data.lot && |
|||
// res.scaned === scaned |
|||
// }) |
|||
// //批次相等 |
|||
// if (lot != undefined) { |
|||
// // 在该任务中未找到零件。 |
|||
// that.showScanMessage('在该任务中未找到零件'); |
|||
// } else { |
|||
// //零件号不相等,批次不相等 |
|||
// that.showScanMessage('所扫描的物料不在任务中'); |
|||
// } |
|||
// } |
|||
// } else { |
|||
// that.afterScanPackLabel(result); |
|||
// } |
|||
}, |
|||
|
|||
afterScanPackLabel(result) { |
|||
let that = this; |
|||
that.getBalance(result, res => { |
|||
if (res.totalCount === 1) { |
|||
that.balancesItem = res.items[0]; |
|||
if (that.balancesItem != null || that.balancesItem != undefined) { |
|||
that.setBalanceInfo(this.currentItem, that.balancesItem); |
|||
that.scanPopupGetFocus(); |
|||
} |
|||
} else { |
|||
this.$refs['issueitems'].openPopup(res.items); |
|||
} |
|||
}); |
|||
}, |
|||
|
|||
//查询库存记录 |
|||
getBalance(result, callback) { |
|||
uni.showLoading({ |
|||
title: '扫描中...', |
|||
mask: true |
|||
}) |
|||
let params = { |
|||
pageSize: 1000, |
|||
pageIndex: 1, |
|||
packingCode: result.data.code, |
|||
itemCode: result.data.itemCode, |
|||
lot: result.data.lot, |
|||
inventoryStatus: 2, //库存状态默认2 |
|||
locationTypes: [2, 3], |
|||
sortBy: 'PackingCode asc' |
|||
}; |
|||
issueBalances(params) |
|||
.then(res => { |
|||
if (res.totalCount === 0) { |
|||
this.showScanMessage('按零件号【' + result.data.itemCode + '】箱码【' + result.data.code + '】批次【' + |
|||
result |
|||
.data.lot + '】在【原料库、半成品库】未查询到库存信息'); |
|||
} else { |
|||
callback(res); |
|||
} |
|||
uni.hideLoading(); |
|||
}) |
|||
.catch(err => { |
|||
this.showScanMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
setBalanceInfo(item, balanceItem) { |
|||
item.scaned = true; |
|||
item.scanDate = new Date() //增加扫描信息属性 |
|||
item.fromLocationCode = balanceItem.locationCode; |
|||
item.fromLocationErpCode = balanceItem.locationErpCode; |
|||
item.toLocationCode = item.locationCode; |
|||
item.toLocationErpCode = item.locationErpCode; |
|||
|
|||
//实际库存数量 |
|||
item.handledContainerCode = balanceItem.containerCode; |
|||
item.handledPackingCode = balanceItem.packingCode; |
|||
item.handledBatch = balanceItem.batch; |
|||
item.handledLot = balanceItem.lot; |
|||
|
|||
item.defaultHandleQty = balanceItem.qty; |
|||
item.handledQty = balanceItem.qty; |
|||
item.handledFromLocationCode = balanceItem.locationCode; |
|||
item.handledFromLocationArea = balanceItem.locationArea; |
|||
item.handledFromLocationGroup = balanceItem.locationErpCode; |
|||
item.handledFromLocationErpCode = balanceItem.locationGroup; |
|||
item.handledFromWarehouseCode = balanceItem.warehouseCode; |
|||
|
|||
item.toLocationArea = balanceItem.locationArea; |
|||
item.toLocationGroup = balanceItem.locationGroup; |
|||
item.toLocationErpCode = balanceItem.locationErpCode; |
|||
|
|||
//当前扫描标签的信息 |
|||
item.scanItemCode = this.currentScanLebel.data.itemCode; |
|||
item.scanPackingCode = this.currentScanLebel.data.code; |
|||
item.scanLot = this.currentScanLebel.data.lot; |
|||
|
|||
item.worker = localStorage.userName_CN ==""?localStorage.userName:localStorage.userName_CN; |
|||
item.uom = balanceItem.uom; |
|||
|
|||
this.details.sort(compareDesc('scanDate')); //按扫描信息排 |
|||
this.calcScanCount(); //计算扫描的数量 |
|||
this.$forceUpdate(); |
|||
}, |
|||
|
|||
selectedBalanceItem(balanceItem) { |
|||
this.setBalanceInfo(this.currentItem, balanceItem); |
|||
|
|||
}, |
|||
// //接收 |
|||
receive(callback) { |
|||
let params = { |
|||
id: this.id |
|||
}; |
|||
takeIssueJob(params) |
|||
.then(res => { |
|||
callback(true); |
|||
}) |
|||
.catch(err => { |
|||
this.showMessage(err.message); |
|||
callback(false); |
|||
}); |
|||
}, |
|||
|
|||
submit() { |
|||
let that = this; |
|||
if (that.datacontent.details.length === 0) { |
|||
this.showMessage('该任务没有要上架的零件'); |
|||
return; |
|||
} |
|||
let checkItems = that.details.filter(r => r.scaned === true); |
|||
if (checkItems.length < that.details.length) { |
|||
showConfirmMsg('还有未扫描的零件,是否继续发料', confirm => { |
|||
if (confirm) { |
|||
that.finsh(); |
|||
} |
|||
}); |
|||
} else { |
|||
that.finsh(); |
|||
} |
|||
}, |
|||
|
|||
handleLocation() { |
|||
let that = this; |
|||
if (that.details[0].requestLocationCode != that.toLocation) { |
|||
showConfirmMsg('目标库位【' + that.toLocation + '】与需求库位不一致,是否要将以上零件发到目标库位?', confirm => { |
|||
if (confirm) { |
|||
that.handledPackingCode(); |
|||
} else { |
|||
that.clearScanLocation(); |
|||
} |
|||
}); |
|||
} else { |
|||
showConfirmMsg('是否要将以上零件发到目标库位:【' + that.toLocation + "】", confirm => { |
|||
if (confirm) { |
|||
that.handledPackingCode(); |
|||
} else { |
|||
that.clearScanLocation(); |
|||
} |
|||
}); |
|||
} |
|||
}, |
|||
|
|||
//判断是否有推荐箱码为空的情况 |
|||
handledPackingCode() { |
|||
let that = this; |
|||
let items = this.details.filter(r => { |
|||
return r.scaned && (r.handledPackingCode === null || r.handledPackingCode === '') |
|||
}) |
|||
|
|||
if (items.length > 0) { |
|||
let packingCodes = ''; |
|||
items.forEach(r => { |
|||
packingCodes += r.recommendPackingCode + ',' |
|||
}) |
|||
showConfirmMsg('以下箱码对应的实际箱码为空,是否要继续发料?【' + packingCodes + "】", confirm => { |
|||
if (confirm) { |
|||
that.finsh(); |
|||
} else { |
|||
that.clearScanLocation(); |
|||
} |
|||
}); |
|||
} else { |
|||
that.finsh(); |
|||
} |
|||
}, |
|||
|
|||
finsh() { |
|||
let that = this; |
|||
uni.showLoading({ |
|||
title: "提交中...", |
|||
mask: true |
|||
}); |
|||
that.datacontent.completeUserId = localStorage.getItem('userId') |
|||
that.datacontent.completeUserName = localStorage.getItem('userName_CN') |
|||
that.datacontent.completeTime = getCurrDateTime(); |
|||
that.datacontent.worker = localStorage.userName_CN ==""?localStorage.userName:localStorage.userName_CN; |
|||
that.datacontent.details = that.details; |
|||
let params = JSON.stringify(that.datacontent); |
|||
finshIssueJob(that.id, params) |
|||
.then(res => { |
|||
uni.hideLoading(); |
|||
if (res != null) { |
|||
that.showCommitSuccessMessage(); |
|||
that.backJobList(1000); |
|||
} |
|||
}) |
|||
.catch(err => { |
|||
that.showMessage(err.message); |
|||
uni.hideLoading(); |
|||
}); |
|||
}, |
|||
|
|||
//返回任务列表页 |
|||
backJobList(delay) { |
|||
if (this.byFIFO) { |
|||
setTimeout(() => { |
|||
uni.navigateTo({ |
|||
url: './issueByFIFO' |
|||
}) |
|||
}, 1000) |
|||
} else { |
|||
setTimeout(() => { |
|||
uni.navigateTo({ |
|||
url: './issueNoFIFO' |
|||
}) |
|||
}, 1000) |
|||
} |
|||
}, |
|||
|
|||
clear() { |
|||
this.scanCount = 0; |
|||
this.currentItem = null; |
|||
this.currentScanLebel = null; |
|||
this.getDetail(); |
|||
}, |
|||
clearScanLocation() { |
|||
this.currentItem = null; |
|||
}, |
|||
unPacking(item) { |
|||
this.$refs.comUnPacking.openPopup3(item,item.handledQty,item.recommendQty,false); |
|||
}, |
|||
showMessage(message) { |
|||
this.$refs.comMessage.showMessage(message); |
|||
}, |
|||
showScanMessage(message) { |
|||
this.$refs.comMessage.showScanMessage(message); |
|||
}, |
|||
|
|||
closeScanMessage() { |
|||
this.$refs.scanPopup.getfocus(); |
|||
}, |
|||
|
|||
calcScanCount() { |
|||
this.scanCount = this.details.filter(r => r.scaned === true).length; |
|||
this.closeScanPopup(); |
|||
}, |
|||
|
|||
showCommitSuccessMessage() { |
|||
this.$refs.comMessage.showCommitSuccess(); |
|||
}, |
|||
|
|||
closeCommitMessage() { |
|||
this.backJobList(0); //点关闭直接返回列表 |
|||
uni.hideLoading(); |
|||
}, |
|||
|
|||
closeScanPopup() { |
|||
if (this.allCount == this.scanCount) { |
|||
this.$refs.scanPopup.closeScanPopup(); |
|||
} |
|||
}, |
|||
|
|||
closeScanMessage() { |
|||
this.scanPopupGetFocus(); |
|||
}, |
|||
|
|||
scanPopupGetFocus() { |
|||
this.$refs.scanPopup.getfocus(); |
|||
}, |
|||
|
|||
scrollToTop() { |
|||
let that = this; |
|||
// 解决view层不同步的问题 |
|||
that.scrollTop = that.old.scrollTop |
|||
this.$nextTick(function() { |
|||
that.scrollTop = 0 |
|||
}); |
|||
}, |
|||
|
|||
upper: function(e) { |
|||
// console.log(e) |
|||
}, |
|||
lower: function(e) { |
|||
// console.log(e) |
|||
}, |
|||
scroll: function(e) { |
|||
// console.log(e) |
|||
this.old.scrollTop = e.detail.scrollTop; |
|||
}, |
|||
qtyChanged(value, item, index) { |
|||
if (value <= 0) { |
|||
this.showMessage('发料数量不能小于或等于0') |
|||
item.handledQty = item.defaultHandleQty |
|||
this.$refs['comNumberBox_' + index][0].setValue(item.handledQty); |
|||
} else if (value > item.defaultHandleQty) { |
|||
item.handledQty = item.defaultHandleQty |
|||
this.showMessage('发料数量不能大于库存数量:' + item.handledQty) |
|||
this.$refs['comNumberBox_' + index][0].setValue(item.handledQty); |
|||
} |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style scoped lang="scss"> |
|||
</style> |
Loading…
Reference in new issue