<template>
	<view class="">
		<com-empty-view v-if="jobList.length==0"></com-empty-view>
		<job-filter ref="filter" otherTitle="ASN" @switchChangeToday="switchChangeToday"
			@switchChangeWait="switchChangeWait" @onScanNumber="getScanNumber" :checkedToday="checkedToday"
			:checkedWaitTask="checkedWaitTask">
		</job-filter>

		<view v-if="jobList.length>0">
			<uni-swipe-action ref="swipeAction">
				<view v-for="(item, index) in jobList" :key="index">
					<uni-swipe-action-item :right-options="item.status=='2'?detailGiveupOptions:detailOptions"
						@click="swipeClick($event,item)">
						<com-putaway-job-card :dataContent="item" @click='openJobDetail(item)'></com-putaway-job-card>
					</uni-swipe-action-item>
				</view>
			</uni-swipe-action>

			<putaway-info-popup ref='jobInfoPopup'></putaway-info-popup>
			<putaway-job-list-popup ref="jobListPopup" @selectedItem="selectedItem"></putaway-job-list-popup>
			<uni-load-more :status="loadingType" v-if="jobList.length>0" />

		</view>
		<win-scan-button @goScan='openScanPopup' v-if="jobList.length>0"></win-scan-button>

		<winScanPackJob ref="scanPopup" @getResult='getScanResult'>
		</winScanPackJob>
		<jobList ref="jobList" @selectItem="selectItem"></jobList>

		<comMessage ref="comMessage"></comMessage>
	</view>
</template>

<script>
	import jobList from '@/mycomponents/jobList/jobList.vue'

	import {
		getPutawayJobList,
		cancleTakePutawayJob
	} from '@/api/request2.js';

	import {
		goHome,
		updateTitle
	} from '@/common/basic.js';

	import {
		getDetailOption,
		getDetailGiveupOption
	} from '@/common/array.js';
	import winScanButton from '@/mycomponents/scan/winScanButton.vue'

	import comEmptyView from '@/mycomponents/common/comEmptyView.vue'
	import jobFilter from '@/mycomponents/job/jobFilter.vue'
	import comPutawayJobCard from '@/pages/putaway/coms/comPutawayJobCard.vue'
	import putawayJobListPopup from '@/pages/putaway/coms/putawayJobListPopup.vue'
	import putawayInfoPopup from '@/pages/putaway/coms/putawayInfoPopup.vue'
	import winScanPackJob from "@/mycomponents/scan/winScanPackJob.vue"

	export default {
		name: 'Putaway',
		components: {
			comEmptyView,
			jobFilter,
			comPutawayJobCard,
			putawayJobListPopup,
			putawayInfoPopup,
			winScanButton,
			winScanPackJob,
			jobList
		},
		data() {
			return {
				jobList: [],
				pageNo: 1,
				pageSize: 10,
				totalCount: 0,
				loadingType: "nomore",
				checkedToday: false,
				checkedWaitTask: false,
				todayTime: "",
				status: '1,2', //待处理 、进行中
				detailOptions: [],
				detailGiveupOptions: [],
			};
		},

		onShow() {
			this.getList('refresh');
		},

		onReady() {
			this.detailOptions = getDetailOption();
			this.detailGiveupOptions = getDetailGiveupOption();
		},

		//后退按钮
		onBackPress(options) {
			if (options.from === 'navigateBack') {
				uni.navigateBack({
					delta: 1
				})
				return false;
			}
		},

		//返回首页
		onNavigationBarButtonTap(e) {
			if (e.index === 0) {
				goHome();
			} else if (e.index == 1) {
				this.$refs.filter.openFilter();
			}
		},
		onReachBottom() {
			//避免多次触发
			if (this.loadingType == 'loading' || this.loadingType == 'nomore') {
				return;
			}
			this.getList("more");
		},
		onPullDownRefresh() {
			this.getList('refresh');
		},

		methods: {
			getList(type) {
				let that = this;
				uni.showLoading({
					title: "加载中­....",
					mask: true
				});

				this.loadingType = "loading";
				if (type === "refresh") {
					this.pageNo = 1;
					this.jobList = [];
				}

				var filters = []
				if (this.checkedToday) {
					filters.push({
						column: "create_time",
						action: "betweeen",
						value: this.todayTime
					})
				}

				filters.push({
					column: "status",
					action: "in",
					value: this.status
				})

				var params = {
					filters: filters,
					pageNo: this.pageNo,
					pageSize: this.pageSize,
				}

				getPutawayJobList(params).then(res => {
					uni.hideLoading();
					if (type === "refresh") {
						uni.stopPullDownRefresh();
					}

					var list = res.data.list;
					this.totalCount = res.data.total
					updateTitle("采购上架(" + this.totalCount + ")");
					this.loadingType = "loadmore";
					if (list == null || list.length == 0) {
						this.loadingType = "nomore";
						return;
					}
					this.jobList = type === "refresh" ? list : this.jobList.concat(list);
					this.pageNo++;

				}).catch(error => {
					if (type === "refresh") {
						uni.stopPullDownRefresh();
					}
					this.loadingType = "";
					updateTitle("采购上架");
					uni.hideLoading();
					that.showMessage(error)
				})
			},

			openJobDetail(item) {
				uni.navigateTo({
					url: './putawayDetail?id=' + item.masterId + '&status=' + item.status
				});
			},

			showItemList(itemList) {
				this.$refs.scanList.openPopup(itemList);
			},

			selectedItem(item) {
				this.openJobDetail(item);
			},

			swipeClick(e, dataContent) {
				if (e.content.text == "详情") {
					this.openjobInfoPopup(dataContent);
				} else if (e.content.text == "放弃") {
					this.$refs.comMessage.showQuestionMessage("确定要放弃当前任务?",
						res => {
							if (res) {
								this.cancleJob(dataContent.masterId);
							}
						});
				}
			},

			openjobInfoPopup(item) {
				this.$refs.jobInfoPopup.openPopup(item)
			},

			cancleJob(id) {
				cancleTakePutawayJob(id).then(res => {
					if (res.data) {
						this.getList("refresh")
						uni.showToast({
							title: "放弃任务成功"
						})
					} else {
						this.showMessage("放弃任务失败")
					}
				}).catch(error => {
					this.showMessage(error)
				})
			},

			switchChangeToday(state, creationTime) {
				this.checkedToday = state;
				this.todayTime = creationTime;
				this.getList("refresh");
			},

			switchChangeWait(state, jobStatus) {
				this.checkedWaitTask = state;
				this.status = jobStatus;
				this.getList("refresh");
			},

			getScanNumber(code) {
				this.getDataListByType(code)
			},

			getDataListByType(code) {
				let that = this;
				uni.showLoading({
					title: "加载中....",
					mask: true
				});
				var filters = []
				filters.push({
					column: "status",
					action: "in",
					value: '1,2'
				})
				filters.push({
					column: "number",
					action: "==",
					value: code
				})

				var params = {
					filters: filters,
					pageNo: 1,
					pageSize: 100,
				}
				getPutawayJobList(params).then(res => {
					uni.hideLoading();
					if (res.data.list.length == 0) {
						that.showMessage('未查找到' + '【' + code + '】的收货任务');
					} else if (res.data.list.length == 1) {
						that.openJobDetail(res.data.list[0]);
					}
				}).catch(error => {
					uni.hideLoading();
					that.showMessage(error);
				})
			},


			showMessage(message) {
				this.$refs.comMessage.showErrorMessage(message, res => {
					if (res) {

					}
				});
			},
			openScanPopup() {
				this.$refs.scanPopup.openScanPopup();
			},
			selectItem(item) {
				this.$refs.scanPopup.closeScanPopup();
				uni.navigateTo({
					url: './putawayDetail?id=' + item.masterId + '&status=' + item.status
				});
			},
			getScanResult(result) {
				try {
					var filters = [{
							column: "packingNumber",
							action: "==",
							value: result.label.packingNumber
						},
						{
							column: "batch",
							action: "==",
							value: result.label.batch
						},
						// {
						// 	column: "qty",
						// 	action: "==",
						// 	value: result.label.qty
						// },
						{
							column: "itemCode",
							action: "==",
							value: result.label.itemCode
						},
						// {
						// 	column: "fromLocationCode",
						// 	action: "==",
						// 	value: result.label.fromLocationCode
						// },
					]
					getPutawayJobList({
						filters: filters,
						pageNo: 1,
						pageSize: 100,
					}).then(res => {
						console.log('getPutawayJobList', getPutawayJobList)
						let resultList = res.data.list;
						if (resultList.length > 0) {
							resultList.forEach(item => {
								item.title = item.number;
								item.selected = false
							})
							let list = []
							resultList.forEach(item=>{
								if(!list.find(subItem=>subItem.title==item.title)){
									list.push(item)
								}
							})
							if (list.length > 1) {
								this.$refs.jobList.openList(list)
							} else {
								this.selectItem(list[0])
							}
						} else {
							this.showMessage('未查找到任务')
						}
					}).catch(error => {
						this.showMessage(error)
					})

				} catch (e) {
					this.showMessage(e.message)
				}
			},
		}
	}
</script>

<style scoped lang="scss">

</style>