<template>
	<view class="" style="background-color: #fff;">
		<uni-collapse ref="collapse1" @change="">
			<uni-collapse-item :open="true">
				<template v-slot:title>
					<uni-swipe-action ref="swipeAction">
						<uni-swipe-action-item @click="removeItem($event,dataContent)" :right-options="removeOptions">
							<item-qty :dataContent="dataContent" :handleQty="dataContent.handleQty"
								:isShowBalance="true"></item-qty>
						</uni-swipe-action-item>
					</uni-swipe-action>

				</template>
				<u-line />
				<view class="" v-for="(item,index) in dataContent.subList">
					<uni-swipe-action ref="swipeAction">
						<uni-swipe-action-item @click="swipeClick($event,item,index)"
							:right-options="item.scaned?scanOptions:detailOptions">
							<!-- 	<balance :dataContent="item" :isShowStdPack="false" :isShowPack="true"
								:isShowLocation="true"></balance> -->
							<purchase-label :dataContent="item" :packageContent="item.package" :isShowStdPack="false">
							</purchase-label>
						</uni-swipe-action-item>
					</uni-swipe-action>
					<u-line color="#D8D8D8"></u-line>
				</view>
			</uni-collapse-item>
		</uni-collapse>
		<balanceQtyEdit ref="balanceQtyEdit" @confirm="confirm"></balanceQtyEdit>
		<job-detail-popup ref="winHint" :dataContent="showItem"></job-detail-popup>
		<com-message ref="comMessage"></com-message>
	</view>
</template>

<script>
	import itemQty from '@/mycomponents/item/itemQty.vue'
	import recommend from '@/mycomponents/recommend/recommend.vue'
	import jobDetailPopup from '@/mycomponents/job/jobDetailPopup.vue'
	import purchaseLabel from '@/mycomponents/balance/purchaseLabel.vue'
	import record from '@/mycomponents/record/record.vue'
	import balanceQtyEdit from '@/mycomponents/qty/balanceQtyEdit.vue'
	import comMessage from '@/mycomponents/common/comMessage.vue'
	import {
		getDetailOption,
		getDetailEditRemoveOption,
		getClearOption
	} from '@/common/array.js';
	export default {
		components: {
			itemQty,
			recommend,
			jobDetailPopup,
			purchaseLabel,
			balanceQtyEdit,
			record,
			comMessage
		},
		props: {
			dataContent: {
				type: Object,
				default: {}
			},
			settingParam: {
				type: Object,
				default: {}
			},
			fromInventoryStatus: {
				type: String,
				default: ""
			},
			toInventoryStatus: {
				type: String,
				default: ""
			},
			isShowStatus: {
				type: Boolean,
				default: false
			}
		},
		watch: {
			dataContent: {
				handler(newName, oldName) {
					if (this.dataContent.subList.length > 0) {
						if (this.$refs.collapse1 != undefined) {
							this.$nextTick(res => {
								this.$refs.collapse1.resize()
							})
						}
					}
				},
				immediate: true,
				deep: true
			}
		},

		data() {
			return {
				option: [],
				title: "推荐详情",
				showItem: {},
				editItem: {},
				detailOptions: [],
				scanOptions: [],
				removeOptions: [],
				dataList: []
			}
		},

		mounted() {
			this.detailOptions = getDetailOption();
			this.scanOptions = getDetailEditRemoveOption();
			this.removeOptions = getClearOption();
		},

		methods: {
			removeItem(e, dataContent) {
				if (e.content.text == "清空") {
					this.$refs.comMessage.showQuestionMessage("确定清空零件及箱码信息?",
						res => {
							if (res) {
								this.$emit('removeItem')
								// this.$emit('removeItem', this.dataContent)
							}
						});
				}
			},
			swipeClick(e, item, index) {
				if (e.content.text == "详情") {
					this.detail(item)
				} else if (e.content.text == "编辑") {
					this.edit(item)
				} else if (e.content.text == "移除") {
					this.remove(item, index)
				}
			},

			edit(item) {
				this.editItem = item;
				this.$refs.balanceQtyEdit.openEditPopup(this.editItem, this.editItem.qty);
			},

			remove(item, index) {
				this.$refs.comMessage.showQuestionMessage("确定移除扫描信息?",
					res => {
						if (res) {
							this.dataContent.subList.splice(index, 1)
							this.$emit('updateData')
						}
					});
			},
			confirm(qty) {
				this.editItem.qty = qty;
				this.$emit('updateData')
			},
			detail(item) {
				this.showItem = item;
				this.dataList = [{
						title: "箱码",
						content: item.packingNumber
					},
					{
						title: "批次",
						content: item.batch
					},
					{
						title: "库位",
						content: item.locationCode
					},
					{
						title: "数量",
						content: item.qty
					},
					{
						title: "单位",
						content: item.uom
					}
				]
				this.$refs.winHint.openScanPopup()
			},
			remove(item, index) {
				this.$refs.comMessage.showQuestionMessage("确定移除扫描信息?",
					res => {
						if (res) {
							this.dataContent.subList.splice(index, 1)
							this.$emit('removePack')
						}
					});
			},
			confirm(qty) {
				this.editItem.qty = qty;
				this.$emit('updateData')
			}
		}
	}
</script>

<style>
</style>