<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.asnNumber}}
			</view>
			<u-line color="#D8D8D8" />
		</view>
		<view class="page-main">
			<scroll-view scroll-y="true" class="page-main-scroll">
				<view class="detail-list" v-for="(item, index) in detailSource" :key="item.id">
					<view class="">
						<com-receipt-detail-card :dataContent="item" :index="index" :settingParam="jobContent"
							@remove="updateData" @updateData="updateData" :locationTypeList='toLocationTypeList'>
						</com-receipt-detail-card>
					</view>
				</view>
			</scroll-view>
		</view>

		<view class="page-footer">
			<view class="uni-flex u-col-center space-between padding_10"
				style="background-color:ghostwhite; width: 100%; ">
				<view class="">
					<required-location ref="requiredLocation" title="默认收货库位" :locationCode="toLocationCode"
						:isShowEdit="jobContent.allowModifyLocation=='TRUE'" @getLocation='scanLocationCode'
						:locationTypeList="toLocationTypeList"></required-location>
				</view>
				<view class=" uni-flex uni-row">
					<button class="btn_single_commit" hover-class="btn_commit_after" @click="commit">提交</button>
				</view>
			</view>
		</view>

		<win-scan-button @goScan='openScanPopup'></win-scan-button>
		<win-scan-pack ref="scanPopup" @getResult='getScanResult'></win-scan-pack>
		<com-message ref="comMessage"></com-message>
	</view>
</template>

<script>
	import {
		purchaseReceiptJobSubmit,
		getPurchaseReceiptJobDetail,
		takePurchaseReceiptJob,
		cancleTakePurchaseReceiptJob
	} from '@/api/request2.js';

	import {
		goHome,
		getCurrDateTime,
		getPackingNumberAndBatch,
		updateTitle,
		compareAsc,
		navigateBack
	} from '@/common/basic.js';

	import {
		getDirectoryItemArray,
	} from '@/common/directory.js';

	import {
		getManagementPrecisions
	} from '@/common/balance.js';

	import {
		getDataSource,
		createRecordInfo,
		calcHandleQty,
		getScanCount
	} from '@/common/detail.js';


	import winScanButton from '@/mycomponents/scan/winScanButton.vue'
	import winScanPack from '@/mycomponents/scan/winScanPack.vue'
	import requiredLocation from '@/mycomponents/location/requiredLocation.vue'
	import comMessage from '@/mycomponents/common/comMessage.vue'
	import comReceiptDetailCard from '@/pages/purchaseReceipt/coms/comReceiptDetailCard.vue'
	import jobTop from '@/mycomponents/job/jobTop.vue'

	export default {
		name: 'receipt_detail',
		components: {
			winScanButton,
			winScanPack,
			comReceiptDetailCard,
			requiredLocation,
			comMessage,
			jobTop
		},
		data() {
			return {
				id: '',
				receiptJob: {},
				received: false,
				scanCount: 0,
				jobContent: {}, //任务内容
				subList: [], //接口返回的任务subList
				detailSource: [], //绑定在页面上的数据源
				toLocationTypeList: [],
				toLocationCode: '',
				toLocationInfo: {},
				businessTypeInfo: {},
				managementList: []
			};
		},
		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 (e.from == 'backbutton') {
				if (this.received) {
					//取消承接任务	
					cancleTakePurchaseReceiptJob(this.id).then(res => {
						uni.navigateBack();
					}).catch(error => {
						uni.navigateBack();
					})
				} else {
					uni.navigateBack();
				}
				return true;
			}
		},

		onPullDownRefresh() {
			this.getDetail();
			uni.stopPullDownRefresh();
		},

		mounted() {

		},
		methods: {
			//接收
			receive(callback) {
				uni.showLoading({
					title: "加载中....",
					mask: true
				});
				if (this.id != null) {
					takePurchaseReceiptJob(this.id).then(res => {
						uni.hideLoading();
						callback();
					}).catch(error => {
						uni.hideLoading();
						this.showErrorMessage(error)
					})
				}
			},

			getDetail() {
				var that = this;
				uni.showLoading({
					title: "加载中....",
					mask: true
				});
				getPurchaseReceiptJobDetail(this.id).then(res => {
					uni.hideLoading();
					if (res.data == null) {
						that.showMessage('未获取到详情');
					} else {
						if (res.data.subList.length > 0) {
							that.jobContent = res.data;
							that.toLocationTypeList = getDirectoryItemArray(that.jobContent.toLocationTypes);
							// that.jobContent.toLocationTypeList = that.toLocationTypeList;
							that.subList = res.data.subList;
							this.toLocationCode = that.subList[0].toLocationCode
							that.detailSource = getDataSource(that.subList)
						} else {
							that.showMessage('列表数据为0');
						}
						// updateTitle("采购收货-" + that.jobContent.number);
					}
				}).catch(error => {
					uni.hideLoading()
					this.showErrorMessage(error)
				})
			},


			getScanResult(result) {
				try {
					var packingNumber = result.label.packingNumber;
					var batch = result.label.batch;
					var qty = result.label.qty;
					var itemCode = result.label.itemCode;
					var detail = this.detailSource.find(r => r.itemCode == itemCode);
					if (detail == undefined) {
						this.showMessage("物料号【" + itemCode + "】不在列表中")
					} else {
						var itemDetail = detail.subList.find(r => r.packingNumber == packingNumber && r.batch == batch);
						if (itemDetail == undefined) {
							this.showMessage("箱码【" + packingNumber + "】、批次【" + batch + "】不在列表中")
						} else {
							if (itemDetail.scaned) {
								this.showMessage("箱码【" + packingNumber + "】已经扫描")
							} else {
								itemDetail.scaned = true;
								this.detailSource[0].subList.sort(compareAsc('scaned')); //按扫描信息排序
								itemDetail.handleQty = Number(result.label.qty);
								itemDetail.toLocationCode = this.toLocationCode;
								itemDetail.labelQty = Number(result.label.qty);
								calcHandleQty(this.detailSource);
								this.continueScan()
								this.$forceUpdate()
								var list = this.detailSource[0].subList;
							}
						}
					}

				} catch (e) {
					this.showErrorMessage(e.message)
				}
			},


			//继续扫描
			continueScan() {
				this.scanCount = getScanCount(this.subList);
				if (this.scanCount == this.subList.length) {
					this.closeScanPopup();
				} else {
					this.scanPopupGetFocus();
				}
			},

			updateData() {
				calcHandleQty(this.detailSource);
			},

			scanLocationCode(location, code) {
				this.$refs.comMessage.showQuestionMessage("是否把所有的目标库位都变成默认库位[" + code + "]", res => {
					this.toLocationCode = code
					this.detailSource.forEach(item => {
						item.subList.forEach(detail => {
							detail.toLocationCode = code
						})
					})
				})
			},

			commit() {
				this.scanCount = getScanCount(this.subList);
				if (this.scanCount == 0) {
					this.showErrorMessage("扫描数为0,请先扫描")
					return;
				}
				//校验库位、
				if (!this.checkLocation()) {
					return
				}

				//扫描数量和任务数量相等,直接提交
				if (this.scanCount == this.subList.length) {
					this.submitJob();
				} else if (this.scanCount < this.subList.length) {
					//扫描数量小于任务数量,判断是否允许部分提交
					if (this.jobContent.allowPartialComplete == "TRUE") {
						//提交
						this.submitJob();
					} else {
						//不允许部分提交,提示
						this.$refs.comMessage.showErrorMessage('请完成扫描后,再进行提交<br>' + "已经扫描[" + this.scanCount +
							"]箱总共[" + this
							.subList.length + "]箱", res => {
								if (res) {
									this.openScanPopup();
								}
							});
					}
				}

			},

			submitJob() {
				uni.showLoading({
					title: "提交中....",
					mask: true
				});
				var itemCodes = []
				this.detailSource.forEach(item => {
					itemCodes.push(item.itemCode)
				})

				//获取管理模式,封装参数
				getManagementPrecisions(itemCodes, this.toLocationCode, res => {
					if (res.success) {
						this.managementList = res.list;
						var params = this.setParams()
						console.log("提交参数", JSON.stringify(params));

						purchaseReceiptJobSubmit(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)
						})
					} else {
						uni.hideLoading();
						this.showErrorMessage(res.message);
					}
				});

			},

			setParams() {
				var subList = []
				var createTime = getCurrDateTime();
				var creator = this.$store.state.user.id

				this.detailSource.forEach(item => {
					item.subList.forEach(detail => {
						if (detail.scaned) {
							var info = getPackingNumberAndBatch(this.managementList, detail.itemCode,
								detail.packingNumber, detail.batch);
							detail.toPackingNumber = info.packingNumber;
							detail.toBatch = info.batch;
							subList.push(detail)
						}
					})
				})
				this.jobContent.subList = subList
				this.jobContent.createTime = createTime;
				this.jobContent.creator = creator;
				return this.jobContent;
			},

			checkLocation() {
				var isPass = true;
				if (this.toLocationCode == "" || this.toLocationCode == null) {
					this.$refs.comMessage.showMessage('请扫描收货库位', res => {
						if (res) {
							this.$refs.requiredLocation.showLocation();
						}
					});
					return isPass = false;
				}
				//空库位校验
				// var isHaveNullLocation = false;
				// var nullLocationList = [];
				// this.detailSource.forEach(item => {
				// 	item.subList.forEach(detail => {
				// 		if (detail.toLocationCode == null || detail.toLocationCode == "") {
				// 			nullLocationList.push(detail)
				// 		}
				// 	})
				// })

				// if (nullLocationList.length > 0) {
				// 	//弹出提示,是否把其他的库位都变成默认库位
				// 	this.$refs.comMessage.showQuestionMessage("是否把其他的库位都变成默认库位", res => {
				// 		nullLocationList.forEach(res => {
				// 			res.toLocationCode = this.toLocationCode
				// 		})
				// 	})
				// 	isPass = false;
				// }
				return isPass;
			},


			showMessage(message) {
				setTimeout(r => {
					this.scanPopupLoseFocus();
					this.$refs.comMessage.showMessage(message, res => {
						if (res) {
							this.scanPopupGetFocus()
						}
					});
				})
			},

			showErrorMessage(message) {
				setTimeout(r => {
					this.scanPopupLoseFocus();
					this.$refs.comMessage.showErrorMessage(message, res => {
						if (res) {
							this.scanPopupGetFocus()
						}
					});
				})
			},

			openScanPopup() {
				this.$refs.scanPopup.openScanPopup();
			},

			closeScanPopup() {
				this.$refs.scanPopup.closeScanPopup();
			},

			scanPopupGetFocus() {
				if (this.$refs.scanPopup != undefined) {
					this.$refs.scanPopup.getfocus();
				}
			},

			scanPopupLoseFocus() {
				if (this.$refs.scanPopup != undefined) {
					this.$refs.scanPopup.losefocus();
				}
			},


			showCommitSuccessMessage(hint) {
				this.$refs.comMessage.showSuccessMessage(hint, res => {
					navigateBack(1)
				})
			},
		}
	}
</script>

<style scoped lang="scss">
	page {
		width: 100%;
		height: 100%;
		background-color: #fff;
	}

	.page-wraper {
		display: flex;
		flex-direction: column;
		width: 100%;
		height: 100%;
	}


	.page-main {
		flex: 1;
		position: relative;
	}

	.page-main-scroll {
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
	}

	.page-main-list {
		/*  height: 80rpx;
	    line-height: 80rpx; */
		text-align: center;
		background: #e0e0e0;

	}
</style>