<template> <view> <!-- <requiredLocation title="需求库位" :locationCode="dataContent.toLocationCode" :isShowEdit="dataContent.allowModifyLocation==1"></requiredLocation> --> <view v-for="(item,index) in dataContent.Items"> <uni-collapse ref="collapse"> <uni-collapse-item :open="true" :show-animation="true"> <template v-slot:title> <!-- 物品 --> <item-qty :dataContent="item" :handleQty="item.handleQty"></item-qty> </template> <u-line /> <view v-for="(loacation,index) in item.Locations"> <view> <view class="uni-flex uni-row space-between"> <!-- 推荐库位 --> <location :locationCode="loacation.fromLocationCode"> </location> </view> <view v-for="(batch,index) in loacation.Batchs"> <recommend-balance style='margin-left: 20px;' :detail="batch" :isShowLocation="false" :isShowPack="batch.packingNumber!=null && batch.packingNumber!=''"> </recommend-balance> <view class="uni-flex uni-row" v-if='batch.Records.length>0'> <view class="center " style=" width: 20px; color: #0CC2B6; margin-left: 40px;"> 实际 </view> <view class="uni-flex uni-column" style="width: 100%;"> <view v-for="(record,index) in batch.Records"> <uni-swipe-action ref="swipeAction"> <uni-swipe-action-item @click="swipeClick($event,batch,record,index)" :right-options="scanOptions"> <handle-balance :detail="record" :isShowLocation="false" :isShowBatch="batch.packingNumber!=null"> </handle-balance> </uni-swipe-action-item> </uni-swipe-action> </view> </view> </view> </view> </view> </view> </uni-collapse-item> </uni-collapse> </view> </view> <balance-qty-edit ref="balanceQtyEdit" @confirm="confirm" :isShowStatus="true"></balance-qty-edit> <detail-info-popup ref="detailInfoPopup"></detail-info-popup> <comMessage ref="message"></comMessage> </template> <script> import itemQty from '@/mycomponents/item/itemQty.vue' import recommend from '@/mycomponents/recommend/recommend.vue' import recommendBalance from '@/mycomponents/balance/recommendBalance.vue' import handleBalance from '@/mycomponents/balance/handleBalance.vue' import recommendQtyEdit from '@/mycomponents/qty/recommendQtyEdit.vue' import jobDetailPopup from '@/mycomponents/job/jobDetailPopup.vue' import requiredLocation from '@/mycomponents/location/requiredLocation.vue' import balanceQtyEdit from '@/mycomponents/qty/balanceQtyEdit.vue' import location from '@/mycomponents/balance/location.vue' import comMessage from '@/mycomponents/common/comMessage.vue' import detailInfoPopup from '@/pages/productionReceipt/coms/detailInfoPopup.vue' import { getDetailOption, getEditRemoveOption } from '@/common/array.js'; export default { emits: ['updateData'], components: { itemQty, recommend, recommendBalance, handleBalance, recommendQtyEdit, requiredLocation, balanceQtyEdit, location, comMessage, detailInfoPopup }, props: { dataContent: { type: Object, default: {} }, settingParam: { type: Object, default: {} }, }, watch: { }, data() { return { option: [], showItem: {}, editItem: {}, batchItem: {}, detailOptions: [], scanOptions: [] } }, mounted() { this.detailOptions = getDetailOption(); this.scanOptions = getEditRemoveOption(); }, methods: { resizeCollapse() { this.$nextTick(() => { this.$refs.collapse.forEach(r => { r.childrens.forEach(i => { i.init(); }) r.resize(); }) }); }, swipeClick(e, batch, record, index) { if (e.content.text == "编辑") { this.edit(batch, record) } else if (e.content.text == "移除") { this.remove(batch, record, index) } }, edit(batch, record) { let that = this; that.editItem = record; that.batchItem = batch; record.balance.balanceQty = record.balance.qty; that.$refs.balanceQtyEdit.openEditPopup(record.balance, record.qty); }, detail(item) { this.showItem = item; this.$refs.receiptHint.openScanPopup() }, remove(batch, record, index) { this.$refs.message.showQuestionMessage("确定移除扫描信息?", res => { if (res) { batch.Records.splice(index, 1); this.resizeCollapse(); this.$emit('updateData', record) } }); }, confirm(val) { this.editItem.qty = val; this.$emit('updateData', this.editItem) // let qty = 0; // this.batchItem.Records.forEach(r => { // qty += Number(r.qty); // }) // this.batchItem.handleQty = qty; } } } </script> <style> </style>