<template> <view class="page-wraper"> <view class="page-header"> <view class="header_job_top"> <job-top :dataContent="jobContent" ></job-top> </view> <view class="header_item" > 申请单号:{{jobContent.requestNumber}} </view> <u-line color="#D8D8D8"></u-line> <view class="cen_card" style="padding: 5rpx;"> <view class="cell_box uni-flex uni-row"> <view class="cell_info"> <view class="text_lightblue">客户代码</view> <view>{{jobContent.customerCode}}</view> </view> <view class="cell_info"> <view class="text_lightblue">客户寄售库</view> <view>{{toLocationCode}}</view> </view> </view> <u-line /> </view> </view> <view class="page-main"> <scroll-view scroll-y="true" class=""> <view v-for="(toLocation, index) in detailSource"> <comDeliverDetailCard ref='comIssueDetailCard' :dataContent="toLocation" @updateData='updateData'> </comDeliverDetailCard> </view> </scroll-view> </view> <div class="btn_bottom"> <view class="" style="display: flex;flex-direction: row;"> <view class=""> <button class="btn_commit" hover-class="btn_commit_after" @click="submit()">提交</button> </view> </view> </div> <win-scan-button @goScan='openScanDetailPopup'></win-scan-button> <comScanDeliverPack ref="comScanIssuePack" @closeScan='closeScan' @updateData='updateData'> </comScanDeliverPack> <comMessage ref="comMessage"></comMessage> </view> </template> <script> import { getDeliverDetail, getBasicLocationByCode, takeDeliverJob, cancleTakeDeliverJob, deliverJobSubmit } from '@/api/request2.js'; import { goHome, updateTitle, navigateBack, getRemoveOption, getCurrDateTime, getDirectoryItemArray, getPackingNumberAndBatch, } from '@/common/basic.js'; import { getDataSource } from '@/pages/issue/js/issue.js'; import { getManagementPrecisions } from '@/common/balance.js'; import jobDetailPopup from '@/mycomponents/job/jobDetailPopup.vue' import winScanButton from '@/mycomponents/scan/winScanButton.vue' import comDeliverDetailCard from '@/pages/deliver/coms/comDeliverDetailCard.vue' import comScanDeliverPack from '@/pages/deliver/coms/comScanDeliverPack.vue' import comMessage from '@/mycomponents/common/comMessage.vue' import jobTop from '@/mycomponents/job/jobTop.vue' export default { name: 'issueDetail', components: { jobDetailPopup, winScanButton, comDeliverDetailCard, comScanDeliverPack, comMessage, jobTop }, data() { return { id: '', jobContent: {}, //任务内容 subList: [], //接口返回的任务subList detailSource: [], //绑定在页面上的数据源 detailOptions: [], scanOptions: [], status:"", received :false, toLocationCode:"" }; }, props: { }, onLoad(option) { this.id = option.id; if (this.id != undefined) { //新建的任务自动接收 if (option.status == "1") { this.receive((callback => { this.received = true; this.getDetail(); })); } else { this.getDetail(); } } }, onNavigationBarButtonTap(e) { if (e.index === 0) { goHome(); } }, //拦截返回按钮事件 onBackPress(e) { //已经接收但是没提交任务 if (this.received) { //取消承接任务 cancleTakeDeliverJob(this.id).then(res => {}).catch(error => { this.showMessage(err); }) } }, methods: { //接收 receive(callback) { if (this.id != null) { takeDeliverJob(this.id).then(res => { callback(); }).catch(error => { this.showErrorMessage(error) }) } }, getDetail() { var that = this; uni.showLoading({ title: "加载中....", mask: true }); getDeliverDetail(that.id).then(res => { uni.hideLoading(); if (res.data == null) { that.showMessage('未获取到详情'); } else { if (res.data.subList.length > 0) { that.jobContent = res.data; that.subList = res.data.subList; that.detailSource = getDataSource(that.detailSource, that.subList) that.toLocationCode =that.subList[0].toLocationCode that.resizeCollapse(); } else { that.showMessage('列表数据为0'); } } }).catch(error => { uni.hideLoading() this.showErrorMessage(error) }) }, closeScan() { this.resizeCollapse(); }, resizeCollapse() { this.$nextTick(r => { this.$refs.comIssueDetailCard.forEach(r => { r.resizeCollapse(); }) }); }, submit() { uni.showLoading({ title: "提交中....", mask: true }); //目前任务只到一个库位 var itemCodes = [] let locationCode = this.detailSource[0].toLocationCode this.detailSource.forEach(toLocationCode => { toLocationCode.Items.forEach(item=>{ itemCodes.push(item.itemCode) }) }) //使用在途库,不查询管理模式 if (this.jobContent.useOnTheWayLocation == 'TRUE') { this.submitJob(); } else { //获取管理模式,封装参数 getManagementPrecisions(itemCodes, locationCode, res => { if (res.success) { this.managementList = res.list; this.submitJob(); } else { uni.hideLoading(); this.showErrorMessage(res.message); } }); } }, submitJob() { var params = this.setParams() console.log("提交参数", JSON.stringify(params)); deliverJobSubmit(params).then(res => { uni.hideLoading() if (res.data) { this.showCommitSuccessMessage("提交成功<br>生成发货记录" + res.data) } else { this.showErrorMessage("提交失败[" + res.msg+"]") } }).catch(error => { uni.hideLoading() this.showErrorMessage(error) }) }, setParams() { var subList = [] var createTime = getCurrDateTime(); var creator = this.$store.state.user.id this.detailSource.forEach(toLocationCode => { toLocationCode.Items.forEach(item => { item.Locations.forEach(fromLocation => { fromLocation.Batchs.forEach(batch => { let subItem = batch.detail; subItem.recordList = []; if (batch.Records.length > 0) { batch.Records.forEach(r => { let record = {}; record.handleQty = r.qty; record.toContainerNumber = r .ContainerNumber; record.toInventoryStatus = r .inventoryStatus; record.toLocationCode = subItem .toLocationCode; record.supplierCode = r.supplierCode; //使用在途库不改变管理模式 if (this.jobContent.useOnTheWayLocation == 'TRUE') { record.toPackingNumber = r .packingNumber; record.toBatch = r.batch; } else { var info = getPackingNumberAndBatch( this.managementList, r .itemCode, r.packingNumber, r .batch); record.toPackingNumber = info .packingNumber; record.toBatch = info.batch; } subItem.recordList.push(record); }) subList.push(subItem); } }) }) }) }) this.jobContent.subList = subList this.jobContent.createTime = createTime; this.jobContent.creator = creator; return this.jobContent; }, cancel() { let that = this; this.$refs.comMessage.showQuestionMessage('是否要清空已扫描的零件和目标库位信息?', res => { if (res) { that.clearInfo(); } }); }, clearInfo() { this.dataContent.itemCodeList.forEach(res => { if (res.recommendList != null) { res.recommendList.forEach(res1 => { if (res1.locationCodeList != null) { res1.locationCodeList.forEach(res2 => { if (res2.packingCodeList != null) { res2.packingCodeList.forEach(res3 => { res3.itemCode = ""; res3.qty = 0; }) } }) } }) } }) }, updateData(record) { let requestLocation = this.detailSource.find(r => r.toLocationCode == record.toLocationCode); let item = requestLocation.Items.find(r => r.itemCode == record.itemCode); let itemHandleQty = 0; if (item != undefined) { item.Locations.forEach(l => { let batch = l.Batchs.find(b => (b.packingNumber == record.packingNumber || b .packingNumber == null || b.packingNumber == '') && b.batch == record.batch); let handleQty = 0; if (batch != undefined) { batch.Records.forEach(res => { handleQty += Number(res.qty) }) batch.handleQty = handleQty; itemHandleQty += handleQty; } }) } // item.handleQty=itemHandleQty; }, scanPopupGetFocus() { if (this.$refs.scanPopup != undefined) { this.$refs.scanPopup.getfocus(); } }, showMessage(message) { this.$refs.comMessage.showMessage(message, res => { if (res) { this.afterCloseMessage() } }); }, showErrorMessage(message) { this.$refs.comMessage.showErrorMessage(message, res => { if (res) { this.afterCloseMessage() } }); }, showScanMessage(message) { this.$refs.comMessage.showScanMessage(message); }, showCommitSuccess() { this.$refs.comMessage.showCommitSuccess(); }, showCommitSuccessMessage(hint) { this.$refs.comMessage.showSuccessMessage(hint, res => { navigateBack(1) }) }, showRescanMessage(message) { this.$refs.comMessage.showRescanMessage(message); }, afterCloseMessage() { this.scanPopupGetFocus(); }, showScanMessage(message) { this.$refs.comMessage.showScanMessage(message); }, closeScanMessage() { this.scanPopupGetFocus(); }, confirm(data) { this.dataContent = data; }, confirmResult(result) { this.dataContent = result; this.$forceUpdate(); }, openScanDetailPopup() { var datacontent = {} //克隆对象,深度克隆,防止双向绑定同一个变量 // Object.assign(datacontent, this.detailSource); this.$refs.comScanIssuePack.openScanPopup(this.detailSource, this.jobContent); }, closeScanPopup() { this.updateCommitBtn(); }, } }; </script> <style scoped lang="scss"> .uni-numbox__value { width: 40px; } button[disabled] { background-color: #3C9CFF; color: #fff; opacity: 0.7; } // /deep/ .input-value { // font-size: 16px; // } // /deep/ .uni-collapse-item__title-text { // font-size: 16px; // } // /deep/ .uni-collapse-item--border { // border-bottom-width: 0px; // border-bottom-color: #ebeef5; // } // /deep/ .uni-collapse-item--border { // border-bottom-width: 1px; // border-bottom-color: #ebeef5; // } </style>