<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>