Compare commits

..

No commits in common. "8672012b06a764cabdd2dae35abb771e8840d06e" and "742f1bde16419a9fbbf476edad79e10664827a12" have entirely different histories.

2 changed files with 35 additions and 303 deletions

View File

@ -1,67 +1,10 @@
import request from '@/utils/request' import request from '@/utils/request'
// 客户来源分析饼图 // 客户来源分析饼图
export function chartLineInspectionAmount(params) { export function chartLineInspectionAmount() {
return request({ return request({
url: '/partnerOwn/partner/newChartLineInspectionAmount', url: '/partnerOwn/partner/chartLineInspectionAmount',
method: 'get', method: 'get',
params: params
})
}
// 已收款金额
export function getServerData1(params) {
return request({
url: '/partnerOwn/partner/newChartInfoAmount',
method: 'get',
params: params
})
}
// 数量统计
export function chartInfoNum(params) {
return request({
url: '/partnerOwn/partner/newChartInfoNum',
method: 'get',
params: params
})
}
// 数量统计
export function chartLineInspectionNum(params) {
return request({
url: '/partnerOwn/partner/newChartLineInspectionNum',
method: 'get',
params: params
})
}
// 检测合格率
export function chartInfoRatio(params) {
return request({
url: '/partnerOwn/partner/newChartInfoRatio',
method: 'get',
params: params
})
}
// 五条
export function getfive1(params) {
return request({
url: '/partnerOwn/partner/newStaticsTable1',
method: 'get',
params: params
})
}
// 五条
export function getfive2(params) {
return request({
url: '/partnerOwn/partner/newStaticsTable2',
method: 'get',
params: params
})
}
// 五条
export function getfive3(params) {
return request({
url: '/partnerOwn/partner/newStaticsTable3',
method: 'get',
params: params
}) })
} }

View File

@ -11,35 +11,21 @@
成交金额已收款 成交金额已收款
</div> </div>
<div class="echaets_box"> <div class="echaets_box">
<div id="khly" style="width: 400px; height: 267px;"></div> <!-- <div id="khly" style="width: 400px; height: 267px;"></div>-->
</div> </div>
</div> </div>
<div class="six_box"> <div class="six_box">
<div class="s_title"> <div class="s_title">
已收款金额(按车型) 已收款金额统计分析
</div>
<div class="dis-t">
<div class="lan-you">
<div class="yi" :class="{'er' : qhindex == index}" v-for="(item,index) in zilist" :key="index" @click="gbindex(index,item.unit)"> {{item.text}}</div>
</div>
</div> </div>
<div class="echaets_box"> <div class="echaets_box">
<div id="yskje" style="width: 400px; height: 267px;"></div>
</div> </div>
</div> </div>
<div class="six_box"> <div class="six_box">
<div class="s_title"> <div class="s_title">
数量统计(按车型) 订单数量统计分析
</div>
<div class="dis-t">
<div class="lan-you">
<div class="yi" :class="{'er' : qhindex1 == index}" v-for="(item,index) in zilist" :key="index" @click="gbindex1(index,item.unit)"> {{item.text}}</div>
</div>
</div> </div>
<div class="echaets_box"> <div class="echaets_box">
<div id="sltj" style="width: 400px; height: 267px;"></div>
</div> </div>
</div> </div>
</div> </div>
@ -144,24 +130,16 @@
<div class="c_right"> <div class="c_right">
<div class="six_box"> <div class="six_box">
<div class="s_title"> <div class="s_title">
检测数量 维修类型统计
</div> </div>
<div class="echaets_box"> <div class="echaets_box">
<div id="jcsl" style="width: 400px; height: 267px;"></div>
</div> </div>
</div> </div>
<div class="six_box"> <div class="six_box">
<div class="s_title"> <div class="s_title">
检测合格率 月工单金额走势
</div>
<div class="dis-t">
<div class="lan-you">
<div class="yi" :class="{'er' : qhindex2 == index}" v-for="(item,index) in zilist" :key="index" @click="gbindex2(index,item.unit)"> {{item.text}}</div>
</div>
</div> </div>
<div class="echaets_box"> <div class="echaets_box">
<div id="jchgl" style="width: 400px; height: 267px;"></div>
</div> </div>
</div> </div>
<div class="six_box"> <div class="six_box">
@ -178,237 +156,59 @@
<script> <script>
import * as echarts from 'echarts'; import * as echarts from 'echarts';
import * as jcBigScreen from '@/views/inspection/screen/api/jcBigScreen'; import * as jcBigScreen from '@/views/inspection/screen/api/jcBigScreen';
import {chartInfoNum, chartLineInspectionAmount} from "@/views/inspection/screen/api/jcBigScreen";
export default { export default {
name: 'Index', name: 'Index',
components: {}, components: {},
data() { data() {
return { return {
Amount: [],
unit: '',
unit1: '',
unit2: '',
chartData1: {},
params : {
unit:this.unit,
},
qhindex:0,
qhindex1:0,
qhindex2:0,
zilist:[
{text:'日',unit:'day'},
{text:'周',unit:'week'},
{text:'月',unit:'month'},
{text:'年',unit:'year'},
],
} }
}, },
created() { created() {
this.customerSource()
this.getServerData1()
this.chartInfoNum()
this.chartLineInspectionNum()
this.chartInfoRatio()
}, },
mounted() { mounted() {
}, },
methods: { methods: {
gbindex(index,unit){
this.qhindex = index
this.unit = unit
this.getServerData1()
},
gbindex1(index,unit){
console.log('22',unit);
this.qhindex1 = index
this.unit1 = unit
this.chartInfoNum()
},
gbindex2(index,unit){
console.log('33');
this.qhindex2 = index
this.unit2 = unit
this.chartInfoRatio()
},
/**
* 已收款金额
* @returns {Promise<void>}
*/
async getServerData1() {
const params = {
unit:this.unit,
}
let res = await jcBigScreen.getServerData1(params)
console.log('已收款金额',res)
res.data.series.forEach(item => {
item.type = 'bar'
})
var chartDom = document.getElementById('yskje');
var myChart = echarts.init(chartDom);
var option;
option = {
xAxis: {
type: 'category',
data: res.data.categories
},
yAxis: {
type: 'value'
},
series: res.data.series
};
option && myChart.setOption(option);
},
/**
* 数量统计
* @returns {Promise<void>}
*/
async chartInfoNum() {
const params = {
unit:this.unit1,
}
let res = await jcBigScreen.chartInfoNum(params)
console.log('数量统计',res)
res.data.series.forEach(item => {
item.type = 'bar'
})
var chartDom = document.getElementById('sltj');
var myChart = echarts.init(chartDom);
var option;
option = {
xAxis: {
type: 'category',
data: res.data.categories
},
yAxis: {
type: 'value'
},
series: res.data.series
};
option && myChart.setOption(option);
},
/**
* 检测合格率
* @returns {Promise<void>}
*/
async chartInfoRatio() {
const params = {
unit:this.unit2,
}
let res = await jcBigScreen.chartInfoRatio(params)
console.log('检测合格率',res)
res.data.series.forEach(item => {
item.type = 'bar'
})
var chartDom = document.getElementById('jchgl');
var myChart = echarts.init(chartDom);
var option;
option = {
xAxis: {
type: 'category',
data: res.data.categories
},
yAxis: {
type: 'value'
},
series: res.data.series
};
option && myChart.setOption(option);
},
/**
* 检测数量
* @returns {Promise<void>}
*/
async chartLineInspectionNum() {
const params = {
unit:this.unit,
}
let res = await jcBigScreen.chartLineInspectionNum(params)
console.log('检测数量',res)
res.data.series.forEach(item => {
item.type = 'bar'
})
const names = res.data.series.map(item => item.name)
var chartDom = document.getElementById('jcsl');
var myChart = echarts.init(chartDom);
var option;
// option = {
// xAxis: {
// type: 'category',
// data: res.data.categories
// },
// yAxis: {
// type: 'value'
// },
// series: res.data.series
// };
option = {
title: {
text: '最近七天'
},
tooltip: {
trigger: 'axis'
},
legend: {
data: names
},
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
toolbox: {
feature: {
saveAsImage: {}
}
},
xAxis: {
type: 'category',
boundaryGap: false,
data: res.data.categories
},
yAxis: {
type: 'value'
},
series: res.data.series
};
option && myChart.setOption(option);
},
/** /**
* 客户来源分析饼图 * 客户来源分析饼图
*/ */
async customerSource() { async customerSource() {
const params = { const res = await RepairBigScreenApi.customerSource();
unit:this.unit,
}
const res = await jcBigScreen.chartLineInspectionAmount(params);
res.data.series.forEach(item => {
item.type = 'line'
})
var chartDom = document.getElementById('khly'); var chartDom = document.getElementById('khly');
var myChart = echarts.init(chartDom); var myChart = echarts.init(chartDom);
var option; var option;
option = { option = {
xAxis: { toolbox: {
type: 'category', show: true,
data: res.data.categories
}, },
yAxis: { tooltip: {
type: 'value' trigger: 'item',
formatter: "{a} <br/>{b} : {c} ({d}%)"
}, },
series: res.data.series series: [
{
name: '客户来源分析',
type: 'pie',
radius: [20, 100],
center: ['50%', '50%'],
roseType: 'area',
itemStyle: {
borderRadius: 2
},
data: res.data,
}
]
}; };
option && myChart.setOption(option); option && myChart.setOption(option);
}, },
}
} }
}
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
@ -440,17 +240,6 @@ export default {
//align-items: center; //align-items: center;
justify-content: space-between; justify-content: space-between;
} }
.dis-t{
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
margin: 10px auto;
}
.lan-you{
display: flex;
align-items: center;
}
.c_left { .c_left {
width: 25%; width: 25%;