You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

300 lines
9.3 KiB

1 year ago
<template>
<div>
<!-- 选择物资编号 -->
1 year ago
<Modal v-model="isShowWuzi" :z-index="10000" width="70" title="库存选择" :loading="showLoading">
1 year ago
<div class="searchCompanys">
1 year ago
<el-input
v-model="wuzibianmakeyword"
style="margin-right:10px"
clearable
type="text"
1 year ago
placeholder="请输入种类编码查找库存"
1 year ago
@keyup.enter.native="getWuzi"
/>
<el-input
v-model="wuzimingchengkeyword"
style="margin-right:10px"
clearable
type="text"
placeholder="请输入物资名称查找"
@keyup.enter.native="getWuzi"
/>
1 year ago
<el-button type="primary" @click="getWuzi"></el-button>
</div>
1 year ago
<Table
ref="currentRowTable"
1 year ago
:loading="loadingtable"
1 year ago
highlight-row
:columns="wuziColumns"
:data="wzList"
@on-current-change="wuziSelect"
/>
<Page
:current="wuziPageIndex"
:total="wuziTotal"
simple
style="padding-top: 14px;display: flex;justify-content: center;"
@on-change="wuziPageChange"
/>
1 year ago
<div slot="footer" align="right">
<Button class="btn" size="default" type="default" @click="mingxiCancel"></Button>
<Button class="btn" size="default" type="primary" @click="mingxiConfirm"></Button>
</div>
</Modal>
</div>
</template>
<script>
1 year ago
// import {
// index,
// } from "@/api/system/baseForm.js"
import {
index
} from '@/api/inventory.js'
export default {
data() {
return {
// 物资
1 year ago
showLoading: false,
loadingtable:false,
1 year ago
isShowWuzi: false,
wuziPageIndex: 1,
wuzibianmakeyword: '',
wuzimingchengkeyword: '',
wuziTotal: 0,
wzList: [],
selectItem: {},
wuziColumns: [{
width: 60,
_isChecked: false,
key: 'isSelect',
resizable: true,
render: (h, params) => {
return h('div', [
h('Radio', {
props: {
value: params.row.isSelect
},
on: {
'on-change': (e) => {
this.wzList.forEach((items) => {
this.$set(items, 'isSelect', false)
})
this.wzList[params.index].isSelect = e
1 year ago
}
1 year ago
}
})
])
1 year ago
}
1 year ago
}, {
title: '物资名称',
key: 'zichanmingcheng'
1 year ago
}, {
title: '所属种类',
key: 'fenlei_detail.value',
render: (h, params) => {
return h('div', [
h('strong', params.row.wuzibianma_material_infos_wuzibianma_relation
? (params.row.wuzibianma_material_infos_wuzibianma_relation.fenlei_detail?
params.row.wuzibianma_material_infos_wuzibianma_relation.fenlei_detail.name:'') : '')
])
}
}, {
title: '种类编码',
key: 'wuzibianma'
1 year ago
}, {
title: '在库数量',
key: 'zaikushuliang'
}, {
title: '入库批次',
key: 'rukupici'
}, {
title: '物资类型',
key: 'wuzileixing'
}, {
title: '物资型号',
key: 'guigexinghao'
}, {
title: '物资规格',
key: 'wuziguige'
}, {
title: '单位',
key: 'jiliangdanwei'
}]
}
},
watch: {
isShowWuzi(newVal) {
if (newVal) {
this.getWuzi()
1 year ago
}else{
this.wzList = []
1 year ago
this.loadingtable = false
1 year ago
this.wuziPageIndex = 1
1 year ago
}
1 year ago
}
},
methods: {
async getWuzi() {
1 year ago
this.showLoading = true
this.loadingtable = true
1 year ago
const res = await index({
1 year ago
page_size: 40,
1 year ago
page: this.wuziPageIndex,
sort_type: 'DESC',
sort_name: 'wuzibianma',
// table_name: 'inventorys',
filter: [{
'key': 'zichanmingcheng',
'op': 'like',
'value': this.wuzimingchengkeyword
}, {
'key': 'wuzibianma',
'op': 'like',
'value': this.wuzibianmakeyword
}]
})
1 year ago
1 year ago
console.log("res.list.data",res.list.data)
1 year ago
let arr = this.processInventoryData(res.list.data)
for (var m of arr) {
m.isSelect = false
}
this.wzList = arr
console.log("this.wzList",this.wzList)
1 year ago
this.wuziTotal = res.list.total
1 year ago
this.showLoading = false
this.loadingtable = false
1 year ago
console.log('res', this.wzList)
},
wuziSelect(e) {
console.log(e)
this.wzList.forEach((items) => {
this.$set(items, 'isSelect', false)
if (items.id == e.id) {
this.$set(items, 'isSelect', true)
1 year ago
}
1 year ago
})
this.selectItem = e
},
wuziPageChange(e) {
console.log('e', e)
this.wuziPageIndex = e
this.selectItem = {}
this.getWuzi()
},
mingxiConfirm() {
if (Object.keys(this.selectItem).length === 0) {
1 year ago
this.isShowWuzi = false
1 year ago
return
}
this.$emit('refresh', this.selectItem)
this.isShowWuzi = false
},
mingxiCancel() {
this.selectItem = {}
this.wuziPageIndex = 1
this.isShowWuzi = false
1 year ago
},
// 合并 一物一码 物资编码相同,批次相同的数据
processInventoryData(data) {
1 year ago
// 筛选出wuzileixing = 一物一码的记录 且 没有等待出库的
1 year ago
const matchedData = data
1 year ago
.filter(item => item.wuzileixing === '一物一码' && parseFloat(item.zaikushuliang) !== 0 && parseFloat(item.wait_num) === 0 ); // 新增zaikushuliang !== 0条件
1 year ago
// 保存不匹配的记录(直接返回)
const unmatchedData = data
1 year ago
.filter(item => item.wuzileixing !== '一物一码' || (parseFloat(item.zaikushuliang)-parseFloat(item.wait_num) === 0))
.filter(item => (parseFloat(item.zaikushuliang)-parseFloat(item.wait_num)) !== 0) // 剔除zaikushuliang=0的记录
console.log("unmatchedData",unmatchedData)
unmatchedData.map(item=>{
item.zaikushuliang = parseFloat(item.zaikushuliang)-parseFloat(item.wait_num)
})
1 year ago
// 使用Map来存储合并后的结果
const mergedMap = new Map();
// 遍历筛选后的数据进行合并
matchedData.forEach(item => {
// 使用wuzibianma和rukupici的组合作为唯一键
const key = `${item.wuzibianma}_${item.rukupici}`;
// 如果Map中不存在该组合键创建新的合并项
if (!mergedMap.has(key)) {
// 提取需要保留的字段
const mergedItem = {
id:key,
zichanmingcheng: item.zichanmingcheng,
wuzibianma: item.wuzibianma,
rukupici: item.rukupici,
1 year ago
zaikushuliang: parseFloat(item.zaikushuliang) - parseFloat(item.wait_num) || 0, // 初始化为当前记录的在库数量
1 year ago
wuzileixing: item.wuzileixing,
guigexinghao: item.guigexinghao,
wuziguige: item.wuziguige,
jiliangdanwei: item.jiliangdanwei,
1 year ago
shengchanriqi:item.shengchanriqi,
1 year ago
wuzibianma_material_infos_wuzibianma_relation: item.wuzibianma_material_infos_wuzibianma_relation,
// 初始化其他元数据数组
otherMetadata: []
};
// 提取其他字段作为元数据
// const metadata = {};
// for (const [k, v] of Object.entries(item)) {
// if (![
// 'zichanmingcheng', 'wuzibianma', 'rukupici', 'zaikushuliang',
// 'wuzileixing', 'guigexinghao', 'wuziguige', 'jiliangdanwei',
// 'wuzibianma_material_infos_wuzibianma_relation'
// ].includes(k)) {
// metadata[k] = v;
// }
// }
mergedItem.otherMetadata.push(item);
mergedMap.set(key, mergedItem);
} else {
// 如果Map中已存在该组合键更新在库数量并添加到其他元数据数组
const mergedItem = mergedMap.get(key);
// 累加在库数量
if (item.zaikushuliang !== undefined) {
1 year ago
mergedItem.zaikushuliang += parseFloat(item.zaikushuliang);
1 year ago
}
// 提取其他字段作为元数据
// const metadata = {};
// for (const [k, v] of Object.entries(item)) {
// if (![
// 'zichanmingcheng', 'wuzibianma', 'rukupici', 'zaikushuliang',
// 'wuzileixing', 'guigexinghao', 'wuziguige', 'jiliangdanwei',
// 'wuzibianma_material_infos_wuzibianma_relation'
// ].includes(k)) {
// metadata[k] = v;
// }
// }
mergedItem.otherMetadata.push(item);
}
});
// 将合并后的结果转换为数组
const mergedArray = Array.from(mergedMap.values())
1 year ago
.filter(item => parseFloat(item.zaikushuliang) !== 0); // 再次过滤合并后zaikushuliang=0的情况
1 year ago
// 返回合并后的记录和未匹配的记录均不包含zaikushuliang=0
return [...mergedArray, ...unmatchedData]
1 year ago
.filter(item => parseFloat(item.zaikushuliang) !== 0); // 最终结果过滤
1 year ago
}
}
1 year ago
}
1 year ago
</script>
<style scoped>
.searchCompanys {
display: flex;
justify-content: space-between;
margin-bottom: 15px;
}
</style>