1、单据上传页面逻辑优化

20240912_adapter
qiuyt 2 weeks ago
parent 0dbcb716cb
commit 1d51fad628

@ -11,7 +11,7 @@
size="mini" label-width="100px" size="mini" label-width="100px"
> >
<el-row > <el-row >
<el-col :span="8"> <el-col :span="9">
<el-form-item label="时间统计:"> <el-form-item label="时间统计:">
<el-date-picker <el-date-picker
@ -30,22 +30,25 @@
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-form-item > <el-col :span="8">
<el-form-item >
<el-button-group>
<el-button <el-button-group>
type="primary" <el-button
icon="el-icon-refresh" type="primary"
@click="onReset" icon="el-icon-refresh"
>重置 @click="onReset"
</el-button> >重置
<el-button type="primary" icon="el-icon-search" @click="onSubmit(this)" </el-button>
>查询 <el-button type="primary" icon="el-icon-search" @click="onSubmit(this)"
</el-button >查询
> </el-button
</el-button-group> >
</el-button-group>
</el-form-item>
</el-col>
</el-form-item>
</el-row> </el-row>
</el-form> </el-form>
</el-row> </el-row>
@ -69,7 +72,7 @@
</div> </div>
<div class="height-full fr center mr20" @click="linkPage('/dept/use/prescribeDir/inout/split/tag/upload?status=2')"> <div class="height-full fr center mr20" @click="linkPage('/dept/use/prescribeDir/inout/split/tag/upload?status=2')">
<span class="header d-block"> <span class="header d-block">
已上传医保 已上传单据
</span> </span>
<span class="d-block mt10" :style="{'font-size': '32px','font-weight': 'bolder',color:'#394047'}"> <span class="d-block mt10" :style="{'font-size': '32px','font-weight': 'bolder',color:'#394047'}">
{{ stats.alreadyUploadingCount }} {{ stats.alreadyUploadingCount }}
@ -91,7 +94,7 @@
</div> </div>
<div class="height-full fr center mr20" @click="linkPage('/dept/use/prescribeDir/inout/split/tag/upload?status=1')"> <div class="height-full fr center mr20" @click="linkPage('/dept/use/prescribeDir/inout/split/tag/upload?status=1')">
<span class="header d-block"> <span class="header d-block">
未上传医保 未上传单据
</span> </span>
<span class="d-block mt10" :style="{'font-size': '32px','font-weight': 'bolder',color:'#394047'}"> <span class="d-block mt10" :style="{'font-size': '32px','font-weight': 'bolder',color:'#394047'}">
@ -113,7 +116,7 @@
</div> </div>
<div class="height-full fr center mr20" @click="linkPage('/dept/use/prescribeDir/inout/split/tag/upload?status=3')"> <div class="height-full fr center mr20" @click="linkPage('/dept/use/prescribeDir/inout/split/tag/upload?status=3')">
<span class="header d-block"> <span class="header d-block">
上传失败医保 上传失败单据
</span> </span>
<span class="d-block mt10" :style="{'font-size': '32px','font-weight': 'bolder',color:'#394047'}"> <span class="d-block mt10" :style="{'font-size': '32px','font-weight': 'bolder',color:'#394047'}">
{{ stats.uploadingFailCount }} {{ stats.uploadingFailCount }}
@ -122,7 +125,7 @@
</el-row> </el-row>
</el-card> </el-card>
</div> </div>
<div class="mt10 grid-container grid-container3" style="height: 500px"> <div class="mt10 grid-container" style="height: 480px; display: grid; grid-template-columns: 1fr 2fr;">
<el-card class="grid-item" body-style="padding:0px;height:100%" > <el-card class="grid-item" body-style="padding:0px;height:100%" >
@ -143,35 +146,29 @@
</el-row> </el-row>
</el-card> </el-card>
<el-card class="grid-item" body-style="padding:0px;height:100%" > <el-card class="grid-item" body-style="padding:0px;height:100%">
<el-row>
<el-row >
<div style="width: 100%; height:100%;
justify-content: center;
align-items: center;">
<Echart
:options="statsChart2"
></Echart>
</div>
<div style="width: 100%; height: 100%; display: flex; justify-content: center; align-items: center;">
<Echart :options="statsChart3"></Echart>
</div>
</el-row> </el-row>
</el-card> </el-card>
<el-card class="grid-item" body-style="padding:0px;height:100%" > <!-- <el-card class="grid-item" body-style="padding:0px;height:100%" >-->
<el-row > <!-- <el-row >-->
<div style="width: 100%; height:100%; <!-- <div style="width: 100%; height:100%;-->
justify-content: center; <!-- justify-content: center;-->
align-items: center;"> <!-- align-items: center;">-->
<Echart <!-- <Echart-->
:options="statsChart3" <!-- :options="statsChart3"-->
></Echart> <!-- ></Echart>-->
</div> <!-- </div>-->
</el-row> <!-- </el-row>-->
</el-card> <!-- </el-card>-->
</div> </div>
</div> </div>
<!-- 分割线 --> <!-- 分割线 -->
@ -248,11 +245,19 @@ export default {
buyerCentage: 0, buyerCentage: 0,
salesCentage: 0, salesCentage: 0,
codeCount: 0, codeCount: 0,
buyerScanCount: 0,
salesScanCount: 0,
fifoSplitOneCount:0, fifoSplitOneCount:0,
fifoSplitTwoCount:0, fifoSplitTwoCount:0,
buyerScanCount: 0,
salesScanCount: 0,
buyerScanCountReturn: 0,
salesScanCountReturn: 0,
buyerScanSumCount: 0,
salesScanSumCount: 0,
buyerScanSumCountReturn: 0,
salesScanSumCountReturn: 0,
}, },
// ================================================== // ==================================================
@ -371,11 +376,18 @@ export default {
buyerCentage:res.data.buyerCentage, buyerCentage:res.data.buyerCentage,
salesCentage:res.data.salesCentage, salesCentage:res.data.salesCentage,
codeCount:res.data.codeCount, codeCount:res.data.codeCount,
buyerScanCount: res.data.buyerScanCount,
salesScanCount: res.data.salesScanCount,
fifoSplitOneCount:res.data.fifoSplitOneCount, fifoSplitOneCount:res.data.fifoSplitOneCount,
fifoSplitTwoCount:res.data.fifoSplitTwoCount, fifoSplitTwoCount:res.data.fifoSplitTwoCount,
buyerScanCount: res.data.buyerScanCount,
salesScanCount: res.data.salesScanCount,
buyerScanCountReturn: res.data.buyerScanCountReturn,
salesScanCountReturn: res.data.salesScanCountReturn,
buyerScanSumCount: res.data.buyerScanSumCount,
salesScanSumCount: res.data.salesScanSumCount,
buyerScanSumCountReturn: res.data.buyerScanSumCountReturn,
salesScanSumCountReturn: res.data.salesScanSumCountReturn,
} }
this.initStatsChart1(); this.initStatsChart1();
@ -402,10 +414,19 @@ export default {
}, },
initStatsChart1(){ initStatsChart1(){
const dataArr = [ const dataArr = [
this.stats.buyerScanCount,this.stats.salesScanCount this.stats.buyerScanCount,this.stats.buyerScanCountReturn,
this.stats.salesScanCount,this.stats.salesScanCountReturn
]; ];
console.log('dataArr',dataArr); console.log('dataArr',dataArr);
this.statsChart1 = { this.statsChart1 = {
title: {
text: '单据已上传码数',
left: 'center',
textStyle: {
fontSize: 24, // 24
fontWeight: 'bold' //
}
},
color: ['#01c6fd'], color: ['#01c6fd'],
grid: { grid: {
left: '5%', left: '5%',
@ -421,7 +442,7 @@ export default {
xAxis: [ xAxis: [
{ {
type: 'category', type: 'category',
data: ['医保采购上传码数', '医保销售上传码数'], data: ['采购入库', '采购退货','销售出库','销售退货'],
axisLine: { axisLine: {
lineStyle: { lineStyle: {
color: '#01c6fd' color: '#01c6fd'
@ -480,47 +501,43 @@ export default {
] ]
}; };
}, },
initStatsChart2(){ initStatsChart2() {
let colors = ["#d30101","#ffca29", "#01c6fd"]; //
let piedata = { let colors = ["#d30101", "#ffca29", "#01c6fd"];
name: "医保上传率",
type: "pie", //
radius: ["40%", "65%", "65%"], let notUploadedCount = this.stats.codeCount - (this.stats.salesScanCount + this.stats.buyerScanCount);
avoidLabelOverlap: false, let buyerScanCount = this.stats.buyerScanCount;
itemStyle: { let salesScanCount = this.stats.salesScanCount;
borderRadius: 4,
borderColor: "rgba(0,0,0,0)", //
borderWidth: 2, let barData = [
{
value: notUploadedCount,
name: "医保未上传码数",
itemStyle: {
color: colors[0]
}
}, },
{
value: buyerScanCount,
name: "医保采购上传码数",
itemStyle: {
color: colors[1]
}
},
{
value: salesScanCount,
name: "医保销售上传码数",
itemStyle: {
color: colors[2]
}
}
];
color: colors, // ECharts
data: [
{
value: this.stats.codeCount -(this.stats.salesScanCount+this.stats.buyerScanCount) ,
name: "医保未上传码数",
label: {
shadowColor: colors[0],
},
},
{
value: this.stats.buyerScanCount,
name: "医保采购上传码数",
label: {
shadowColor: colors[1],
},
},
{
value: this.stats.salesScanCount,
name: "医保销售上传码数",
label: {
shadowColor: colors[2],
},
},
],
};
this.statsChart2 = { this.statsChart2 = {
title: { title: {
// zlevel: 0,
text: '医保上传率', text: '医保上传率',
top: "center", top: "center",
left: "center", left: "center",
@ -530,220 +547,176 @@ export default {
color: "#000000", color: "#000000",
fontSize: 24, fontSize: 24,
fontWeight: "bold", fontWeight: "bold",
lineHeight: 20, lineHeight: 20
}, },
name: { name: {
color: "#000000", color: "#000000",
lineHeight: 20, lineHeight: 20
}, }
}, }
}, }
}, },
tooltip: { tooltip: {
trigger: "item", trigger: "item",
backgroundColor: "rgba(0,0,0,.6)", backgroundColor: "rgba(0,0,0,.6)",
borderColor: "rgba(147, 235, 248, .8)", borderColor: "rgba(147, 235, 248, .8)",
textStyle: { textStyle: {
color: "#000000", color: "#fff"
}, }
}, },
legend: { legend: {
show: false, show: false,
top: "5%", top: "5%",
left: "center", left: "center"
},
xAxis: {
show: false
},
yAxis: {
type: 'category',
data: barData.map(item => item.name),
axisLabel: {
color: '#000000',
fontSize: 12
},
axisLine: {
show: false
},
axisTick: {
show: false
}
}, },
series: [ series: [
//
{ {
...piedata, name: '医保上传情况',
tooltip: {show: true}, type: 'bar',
data: barData,
label: { label: {
formatter: " {b|{b}} \n {c|{c}个}",
// position: "outside",
rich: {
b: {
color: "#000000",
fontSize: 12,
lineHeight: 26,
},
c: {
color: "#2b91c2",
fontSize: 14,
},
per: {
color: "#2b91c2",
fontSize: 14,
},
},
},
labelLine: {
length: 10, // 线
length2: 18, // 线
show: true, show: true,
position: 'right',
formatter: '{c}个',
color: '#2b91c2',
fontSize: 14
}, },
emphasis: { barWidth: 20
show: true, }
}, ]
},
{
...piedata,
tooltip: {show: true},
itemStyle: {},
label: {
backgroundColor: "inherit", //auto
height: 0,
width: 0,
lineHeight: 0,
borderRadius: 2.5,
shadowBlur: 8,
shadowColor: "auto",
padding: [2.5, -2.5, 2.5, -2.5],
normal: {
show: true,
position: 'inner',
formatter: "{d}%",
color: "#fff",
},
},
labelLine: {
length: 20, // 线
length2: 36, // 线
show: false,
},
},
],
}; };
}, },
initStatsChart3(){ initStatsChart3(){
let colors = ["#d30101", "#01c6fd"]; //
let piedata = { var data = [
name: "赋码方式", { name: '销售退货', uploaded: this.stats.salesScanCountReturn, total: this.stats.salesScanSumCountReturn },
type: "pie", { name: '销售出库', uploaded: this.stats.salesScanSumCount, total: this.stats.salesScanSumCount },
radius: ["42%", "65%", "65%"], { name: '采购退货', uploaded: this.stats.buyerScanSumCountReturn, total: this.stats.buyerScanSumCountReturn },
avoidLabelOverlap: false, { name: '采购入库', uploaded: this.stats.buyerScanSumCount, total: this.stats.buyerScanSumCount },
itemStyle: { ];
borderRadius: 4,
borderColor: "rgba(0,0,0,0)",
borderWidth: 2,
},
color: colors,
data: [
{
value: this.stats.fifoSplitOneCount ,
name: "拆零赋码数",
label: {
shadowColor: colors[0],
},
},
{
value: this.stats.fifoSplitTwoCount,
name: "整取赋码数",
label: {
shadowColor: colors[1],
},
},
], // y
}; var yAxisData = [];
this.statsChart3 = { data.forEach(item => {
yAxisData.push(item.name + ' - 未上传');
yAxisData.push(item.name + ' - 已上传');
});
//
var seriesData = [];
data.forEach(item => {
const total = item.total;
const uploaded = item.uploaded;
const notUploaded = total - uploaded;
if (total === 0) {
seriesData.push(0);
seriesData.push(0);
} else {
const uploadedPercentage = (uploaded / total) * 100;
const notUploadedPercentage = (notUploaded / total) * 100;
seriesData.push(notUploadedPercentage);
seriesData.push(uploadedPercentage);
}
});
//
this.statsChart3 = {
title: { title: {
// zlevel: 0, text: '单据上传率',
text: '赋码类型比率', left: 'center',
top: "center",
left: "center",
textStyle: { textStyle: {
rich: { fontSize: 24, // 24
value: { fontWeight: 'bold' //
color: "#000000", }
fontSize: 24,
fontWeight: "bold",
lineHeight: 20,
},
name: {
color: "#000000",
lineHeight: 20,
},
},
},
}, },
tooltip: { grid: {
trigger: "item", left: '15%',
backgroundColor: "rgba(0,0,0,.6)", top: '5%', //
borderColor: "rgba(147, 235, 248, .8)", bottom: '5%', //
textStyle: { right: '10%' //
color: "#000000",
},
}, },
legend: { xAxis: {
show: false, show: false,
top: "5%", min: 0,
left: "center", max: 100 // x
},
yAxis: {
type: 'category',
data: yAxisData,
axisTick: { show: false },
axisLine: { show: false },
axisLabel: { fontSize: 14 },
boundaryGap: [0, 0.1]
}, },
series: [ series: [
//
{ {
...piedata, type: 'bar',
tooltip: {show: true}, data: seriesData,
label: { barWidth: 20,
formatter: " {b|{b}} \n {c|{c}个}", barCategoryGap: '-90%',
// position: "outside", itemStyle: {
rich: { color: function (params) {
b: { return params.dataIndex % 2 === 0? '#01c6fd' : '#00b611';
color: "#000000", }
fontSize: 12,
lineHeight: 26,
},
c: {
color: "#2b91c2",
fontSize: 14,
},
per: {
color: "#2b91c2",
fontSize: 14,
},
},
},
labelLine: {
length: 20, // 线
length2: 36, // 线
show: true,
},
emphasis: {
show: true,
}, },
},
{
...piedata,
tooltip: {show: true},
itemStyle: {},
label: { label: {
backgroundColor: "inherit", //auto show: true,
height: 0, position: 'right',
width: 0, formatter: function (params) {
lineHeight: 0, var index = Math.floor(params.dataIndex / 2);
borderRadius: 2.5, // total 0 NaN
shadowBlur: 8, const total = data[index].total;
shadowColor: "auto", const value = params.value;
padding: [2.5, -2.5, 2.5, -2.5], const percentage = total === 0? '0.00' : value.toFixed(2);
normal: { return `${percentage}%`;
show: true, }
position: 'inner',
formatter: "{d}%",
color: "#fff",
},
},
labelLine: {
length: 20, // 线
length2: 36, // 线
show: false,
}, },
}, z: 10
], }
]
}; };
}, },
formatDate(date) {
const year = date.getFullYear();
const month = String(date.getMonth() + 1).padStart(2, '0');
const day = String(date.getDate()).padStart(2, '0');
return `${year}-${month}-${day}`;
},
initDate(){
//
const now = new Date();
const year = now.getFullYear();
const month = now.getMonth() + 1;
//
const firstDay = new Date(year, month - 1, 1);
const formattedFirstDay = this.formatDate(firstDay);
//
const lastDay = new Date(year, month, 0);
const formattedLastDay = this.formatDate(lastDay);
// actDateRange
this.actDateRange = [formattedFirstDay, formattedLastDay];
}
}, },
mounted() { mounted() {
@ -756,6 +729,8 @@ export default {
this.getList() this.getList()
}) })
console.log('this.actDateRange',this.actDateRange)
this.initDate()
} }
} }
</script> </script>

Loading…
Cancel
Save