refactor(wms/report): 提取计算逻辑到公共模块并修复数据展示问题
将各报表页面的统计计算逻辑提取到公共模块calc.js中 修复损失列表数据展示错误问题 增加异常统计功能展示 统一各报表页面的计算逻辑 修复日期格式化错误 调整页面大小限制从999到9999
This commit is contained in:
99
klp-ui/src/views/wms/report/js/calc.js
Normal file
99
klp-ui/src/views/wms/report/js/calc.js
Normal file
@@ -0,0 +1,99 @@
|
||||
const calcSummary = (list) => {
|
||||
// 总钢卷数量、总重、均重
|
||||
const outCount = list.length
|
||||
const outTotalWeight = list.reduce((acc, cur) => acc + (parseFloat(cur.netWeight) || 0), 0) // 增加容错
|
||||
const outAvgWeight = outCount > 0 ? (outTotalWeight / outCount)?.toFixed(2) : 0
|
||||
|
||||
// 损失钢卷数量、总重、均重
|
||||
const lossCount = list.length
|
||||
const lossTotalWeight = list.reduce((acc, cur) => acc + (parseFloat(cur.netWeight) || 0), 0) // 增加容错
|
||||
const lossAvgWeight = lossCount > 0 ? (lossTotalWeight / lossCount)?.toFixed(2) : 0
|
||||
// 合计数量、总重、均重
|
||||
const totalCount = outCount + lossCount
|
||||
const totalWeight = parseFloat((outTotalWeight + lossTotalWeight).toFixed(2))
|
||||
const totalAvgWeight = totalCount > 0 ? (totalWeight / totalCount)?.toFixed(2) : 0
|
||||
|
||||
// 成品比率
|
||||
const passRate = outCount > 0 ? (outCount / lossCount) : 0
|
||||
// 损失比率
|
||||
const lossRate = totalCount > 0 ? (1 - passRate) : 0
|
||||
// 异常率,成品在warehouseId在'2019583656787259393',
|
||||
// '2019583325311414274',
|
||||
// '2019583429955104769',
|
||||
// '2019583137616310273',这四个库中的占比
|
||||
const abRate = totalCount != 0 ? list.filter(item => {
|
||||
return item.warehouseId == '2019583656787259393' || item.warehouseId == '2019583325311414274' || item.warehouseId == '2019583429955104769' || item.warehouseId == '2019583137616310273'
|
||||
}).length / totalCount : 0
|
||||
|
||||
return {
|
||||
outCount,
|
||||
outTotalWeight: outTotalWeight.toFixed(2),
|
||||
outAvgWeight,
|
||||
lossCount,
|
||||
lossTotalWeight: lossTotalWeight.toFixed(2),
|
||||
lossAvgWeight,
|
||||
totalCount,
|
||||
totalWeight: totalWeight.toFixed(2),
|
||||
totalAvgWeight,
|
||||
passRate: (passRate * 100)?.toFixed(2) + '%',
|
||||
lossRate: (lossRate * 100)?.toFixed(2) + '%',
|
||||
abRate: (abRate * 100)?.toFixed(2) || 0,
|
||||
}
|
||||
}
|
||||
|
||||
const calcAbSummary = (list) => {
|
||||
// 异常统计,统计四个异常库中的各自的数量和总重
|
||||
let o = {
|
||||
jishuCount: 0,
|
||||
jishuWeight: 0,
|
||||
miniCount: 0,
|
||||
miniWeight: 0,
|
||||
rubbishCount: 0,
|
||||
rubbishWeight: 0,
|
||||
returnCount: 0,
|
||||
returnWeight: 0,
|
||||
}
|
||||
for (let i = 0; i < list.length; i++) {
|
||||
// { label: '技术部', value: '2019583656787259393' },
|
||||
// { label: '小钢卷库', value: '2019583325311414274' },
|
||||
// { label: '废品库', value: '2019583429955104769' },
|
||||
// { label: '退货库', value: '2019583137616310273' },
|
||||
// 技术部
|
||||
const coil = list[i];
|
||||
// 技术部
|
||||
if (coil.warehouseId == '2019583656787259393') {
|
||||
o['jishuCount'] = o['jishuCount'] + 1
|
||||
o['jishuWeight'] = o['jishuWeight'] + parseFloat(coil.netWeight) || 0
|
||||
}
|
||||
// 小刚卷库
|
||||
if (coil.warehouseId == '2019583325311414274') {
|
||||
o['miniCount'] = o['miniCount'] + 1
|
||||
o['miniWeight'] = o['miniWeight'] + parseFloat(coil.netWeight) || 0
|
||||
}
|
||||
// 废品库
|
||||
if (coil.warehouseId == '2019583429955104769') {
|
||||
o['rubbishCount'] = o['rubbishCount'] + 1
|
||||
o['rubbishWeight'] = o['rubbishWeight'] + parseFloat(coil.netWeight) || 0
|
||||
}
|
||||
// 退货库
|
||||
if (coil.warehouseId == '2019583137616310273') {
|
||||
o['returnCount'] = o['returnCount'] + 1
|
||||
o['returnWeight'] = o['returnWeight'] + parseFloat(coil.netWeight) || 0
|
||||
}
|
||||
}
|
||||
return [
|
||||
{ label: '技术部钢卷数', value: o['jishuCount'] },
|
||||
{ label: '技术部钢卷重量', value: o['jishuWeight'] },
|
||||
{ label: '小钢卷库钢卷数', value: o['miniCount'] },
|
||||
{ label: '小钢卷库钢卷重量', value: o['miniWeight'] },
|
||||
{ label: '废品库钢卷数', value: o['rubbishCount'] },
|
||||
{ label: '废品库钢卷重量', value: o['rubbishWeight'] },
|
||||
{ label: '退货库钢卷数', value: o['returnCount'] },
|
||||
{ label: '退货库钢卷重量', value: o['returnWeight'] },
|
||||
]
|
||||
}
|
||||
|
||||
export {
|
||||
calcSummary,
|
||||
calcAbSummary,
|
||||
}
|
||||
Reference in New Issue
Block a user