朱思禹提交:添加学校分析的第四个统计图

init
Administrator 4 years ago
parent 551150dabe
commit ff51b2c2d8

@ -32,6 +32,8 @@
:yearData="yearData" :reportData="reportData" :schoolData="schoolData"/>
<School_03 v-else-if="reportData.id === 'school_03'" :countyData="countyData"
:yearData="yearData" :reportData="reportData" :schoolData="schoolData"/>
<School_04 v-else-if="reportData.id === 'school_04'" :countyData="countyData"
:yearData="yearData" :reportData="reportData" :schoolData="schoolData"/>
</template>
<script>
@ -75,7 +77,8 @@
ASpin:Spin,
City_County_01:()=>import('./cityAnalysis/City_County_01.vue'),
School_01_02:()=>import('./schoolAnalysis/School_01_02.vue'),
School_03:()=>import('./schoolAnalysis/School_03.vue')
School_03:()=>import('./schoolAnalysis/School_03.vue'),
School_04:()=>import('./schoolAnalysis/School_04.vue')
},
mounted(){
this.$bus.on("ANALYSISRETURN",this.returnBack);
@ -338,6 +341,13 @@
}
condition.push({id:'report',title:'选择分析报告',isLoading:true,selectedId:'',data:[]});
if(vm.$store.state.role === 'county'){//
vm.countyData = {id:vm.$store.state.org_id,value:vm.$store.state.org_name}
}else if(vm.$store.state.role === 'school'){
vm.countyData = {id:vm.$store.state.district_id,value:vm.$store.state.district_name}
vm.schoolData = {id:vm.$store.state.org_id,value:vm.$store.state.org_name}
}
vm.dataAnalysisCondition = condition
vm.loadData = false;
});

@ -117,6 +117,50 @@ const interfaceConfig={
url:'intellioa/physicalHealth/statistic/school/getGradeProjectRankList',
method:'get',
isTestLogin:false,
},
/*
* 3.2.41学校分析 041.班级单项样本性别均值标准差对比表格
* "report_year":"必填 string 体质健康测试年份"
* "school_id":"必填 int 学校id"
* */
getClassProjectNumAvgList:{
url:'intellioa/physicalHealth/statistic/school/getClassProjectNumAvgList',
method:'get',
isTestLogin:false,
},
/*
* 3.2.42学校分析 041.班级单项样本性别均值标准差对比柱状图
* "report_year":"必填 string 体质健康测试年份"
* "school_id":"必填 int 学校id"
* "grade_no":"必填 int 年级编号"
* "project_key":"必填 string 项目"
* */
getClassProjectNumAvgChart:{
url:'intellioa/physicalHealth/statistic/school/getClassProjectNumAvgChart',
method:'get',
isTestLogin:false,
},
/*
* 3.2.43学校分析 042.班级单项等级分布对比表格
* "report_year":"必填 string 体质健康测试年份"
* "school_id":"必填 int 学校id"
* */
getClassProjectRankList:{
url:'intellioa/physicalHealth/statistic/school/getClassProjectRankList',
method:'get',
isTestLogin:false,
},
/*
* 3.2.44学校分析 042.班级单项等级分布对比柱状图
* "report_year":"必填 string 体质健康测试年份"
* "school_id":"必填 int 学校id"
* "grade_no":"必填 int 年级编号"
* "project_key":"必填 string 项目"
* */
getClassProjectRankChart:{
url:'intellioa/physicalHealth/statistic/school/getClassProjectRankChart',
method:'get',
isTestLogin:false,
}
}
export default interfaceConfig

@ -0,0 +1,817 @@
<template>
<a-spin :spinning="isLoading">
<div class="school-04-style">
<div class="title-style">
长春市{{year.value}}{{countyData.value}}{{schoolData.value}}学生体质健康报告
</div>
<div class="report-tips-style">
{{countyData.value}}{{schoolData.value}}本年度学生体质健康数据中成绩满分120分累计参与测评学段包括{{primaryCount !== ''?'小学' + primaryCount+'个年级'+(middleCount !== ''?'、':'') :''}}{{middleCount !== ''?'初中' + middleCount+'个年级'+(highCount !== ''?'、':''):''}}{{highCount !== ''?'高中' + highCount + '个年级':''}}累计班级{{totalClass}}学生总人数{{totalStudent}}
从身体形态身体机能和身体素质等方面综合评定学生的体质健康水平适用对象划分为以下组别小学初中高中按每个年级为一组其中小学为6组初中为3组高中为3组
学年总分由标准分与附加分之和构成满分为120分标准分由各单项指标得分与权重乘积之和组成满分为100分附加分根据实测成绩确定即对成绩超过100分的加分指标进行加分满分为20分;小学的加分指标为1分钟跳绳加分幅度为20分;初中高中和大学的加分指标为男生引体向上和1000米跑女生1分钟仰卧起坐和800米跑各指标加分幅度均为10分
根据学生学年总分评定等级90.0分及以上为优秀8089.9分为良好60.079.9分为及格59.9分及以下为不及格
</div>
<div class="analysis-container-style clearfix">
<div class="analysis-title-style">
单项样本平均分等级分布分析
</div>
<div class="module-title-style">1.班级单项样本性别均值标准差对比</div>
<a-table :columns="sampleColumn" size="small" bordered :pagination="false" :dataSource="sampleTableData" rowKey="id"
:scroll="sampleTableData.length > 0?{x:2800,y:500}:{x:2800}">
</a-table>
<div class="sample-chart clearfix">
<div v-if="!gradeList || gradeList.length === 0" class="nodata-style"></div>
<a-radio-group v-if="gradeList && gradeList.length > 0" button-style="solid" v-model="sampleGrade"
style="margin-bottom: 20px" @change="sampleGradeChange">
<a-radio-button v-for="grade in gradeList" :key="grade.grade_no" :value="grade.grade_no">
{{grade.grade_name}}
</a-radio-button>
</a-radio-group>
<a-tabs type="card" :activeKey="sampleTabkey" @change="onSampleTabChange">
<template v-for="tab in IndexObject">
<a-tab-pane v-if="tab.obj_id !== 'bmi'" :key="tab.obj_id" :tab="tab.obj_name"></a-tab-pane>
</template>
</a-tabs>
<div class="type-list-style">
<div class="type-style" :data-selected="sampleTypeSelect === 'sample'" @click="onTypeChange('sample')"></div>
<div class="type-style" :data-selected="sampleTypeSelect === 'average'" @click="onTypeChange('average')"></div>
<div class="type-style" :data-selected="sampleTypeSelect === 'standard'" @click="onTypeChange('standard')"></div>
</div>
<div class="sample-echart-style" id="sampleEChart"></div>
</div>
<div class="module-title-style">2.学校单项等级分布对比</div>
<a-table :columns="gradeColumn" size="small" bordered :pagination="false" :dataSource="gradeTableData" rowKey="id"
:scroll="gradeTableData.length>0?{x:3480,y:500}:{x:3480}">
</a-table>
<div class="sample-chart clearfix">
<div v-if="!gradeList || gradeList.length === 0" class="nodata-style" style="width: 100%;left: 0"></div>
<a-radio-group v-if="gradeList && gradeList.length > 0" button-style="solid" v-model="gradeGrade"
style="margin-bottom: 20px" @change="gradeGradeChange">
<a-radio-button v-for="grade in gradeList" :key="grade.grade_no" :value="grade.grade_no">
{{grade.grade_name}}
</a-radio-button>
</a-radio-group>
<a-tabs type="card" :activeKey="gradeTabkey" @change="onGradeTabChange">
<template v-for="tab in IndexObject">
<a-tab-pane v-if="tab.obj_id !== 'height' && tab.obj_id !== 'weight'" :key="tab.obj_id" :tab="tab.obj_name"></a-tab-pane>
</template>
</a-tabs>
<div class="grade-echart-style" id="gradeEChart"></div>
</div>
</div>
<year-select :selected-year="year" @yearChange="onYearChange"/>
</div>
</a-spin>
</template>
<script>
import {Spin,Table,Tabs,Radio} from 'ant-design-vue';
import Interface from '../../../../global-llibs/axios-config';
import InterfaceConfig from '../interfaceConfig';
import YearSelect from '../common/YearSelect';
import IndexObject from '../commonParams';
import * as echarts from 'echarts';
import _ from 'lodash';
export default {
name: "School_04",
props:{
yearData:{
type:Object,
},
countyData:{
type:Object,
},
reportData:{
type:Object,
},
schoolData:{
type:Object,
}
},
data:function () {
return{
IndexObject,
year:_.cloneDeep(this.yearData),
primaryCount:'',//
middleCount:'',//
highCount:'',//
totalClass:'0',//
totalStudent:'0',//
isLoading:true,
sampleData:null,
sampleColumn:this.getSampleColumns('sample'),
sampleTableData:[],
sampleTabkey:IndexObject[1].obj_id,
sampleTypeSelect:'sample',//sample: average: standard:
sampleEChart:null,
sampleEChartData:{
title: {
show:false
},
tooltip: {
trigger: 'axis'
},
legend: {
bottom:0,
data: ['男生', '女生'],
},
grid:{
left: 30,
right: 30,
bottom: 30,
containLabel: true
},
xAxis: [
{
type: 'category',
}
],
yAxis: [
{
type: 'value'
}
],
series: [
{
name: '男生',
type: 'bar',
},
{
name: '女生',
type: 'bar',
}
]
},
sampleGrade:'',
gradeData:null,
gradeColumn:this.getSampleColumns('grade'),
gradeTableData:[],
gradeTabkey:IndexObject[0].obj_id,
gradeEChart:null,
gradeEChartData:{
tooltip: {
trigger: 'axis',
axisPointer: { //
type: 'shadow' // 线'line' | 'shadow'
}
},
legend: {
bottom: 0,
},
grid: {
top:'12%',
left: '2%',
right: '2%',
bottom: 25,
containLabel: true
},
xAxis: [
{
type: 'category',
}
],
yAxis: [
{
type: 'value'
}
],
series: [
{
name: '优秀',
type: 'bar',
stack:'等级',
},
{
name: '良好',
type: 'bar',
stack: '等级',
},
{
name: '及格',
type: 'bar',
stack: '等级',
},
{
name: '不及格',
type: 'bar',
stack: '等级',
},
]
},//
gradeGrade:'',
gradeList:[],
}
},
components:{
ASpin:Spin,
ATable:Table,
YearSelect,
ATabs:Tabs,
ATabPane:Tabs.TabPane,
ARadioGroup:Radio.Group,
ARadioButton:Radio.Button
},
methods:{
onYearChange:function(){
this.isLoading = true;
this.sampleTabkey = IndexObject[1].obj_id;
this.sampleTypeSelect = 'sample';
this.gradeTabkey = IndexObject[0].obj_id;
this.sampleGrade = '';
this.gradeGrade = '';
this.getData();
},
onGradeTabChange:function(type){
if (!this.gradeList || this.gradeList.length === 0){
return ;
}
this.gradeTabkey = type;
this.getClassProjectRankChart();
},
gradeGradeChange:function(){
if (!this.gradeList || this.gradeList.length === 0){
return ;
}
this.gradeTabkey = 'bmi';
this.getClassProjectRankChart();
},
sampleGradeChange:function(){
if (!this.gradeList || this.gradeList.length === 0){
return ;
}
this.sampleTabkey = IndexObject[1].obj_id;
this.sampleTypeSelect = 'sample';
this.getClassProjectNumAvgChart();
},
onSampleTabChange:function(key){
if (!this.gradeList || this.gradeList.length === 0){
return ;
}
this.sampleTabkey = key;
this.sampleTypeSelect = 'sample';
this.getClassProjectNumAvgChart();
},
onTypeChange:function(type){
if (!this.gradeList || this.gradeList.length === 0){
return ;
}
if (type !== this.sampleTypeSelect){
this.isLoading = true;
this.sampleTypeSelect = type;
this.sampleEChartData.series[0].data = [];
this.sampleEChartData.series[1].data = [];
this.sampleData.forEach((item)=>{
this.sampleEChartData.series[0].data.push(type === 'sample'?(item.psn_num_boy?item.psn_num_boy:''):
(type === 'average'?(item.res_avg_boy?item.res_avg_boy:''):(item.res_std_boy?item.res_std_boy:'')));
this.sampleEChartData.series[1].data.push(type === 'sample'?(item.psn_num_girl?item.psn_num_girl:''):
(type === 'average'?(item.res_avg_girl?item.res_avg_girl:''):(item.res_std_girl?item.res_std_girl:'')));
})
if (this.sampleEChart !== null){
this.sampleEChart.setOption(this.sampleEChartData)
this.isLoading = false;
}
}
},
getSampleColumns:function (type) {
let column = [
{title:'序号',key:'index',fixed: 'left',width:45,align:'center',customRender:(text,record,index)=>{
let obj = {
children:index % 2 === 0?(index + 2) / 2:'',
attrs:{},
}
if (index % 2 === 0){
obj.attrs.rowSpan = 2;
}else{
obj.attrs.rowSpan = 0;
}
return obj;
}},
{title:'年级',key:'grade',width:88,align:'center',dataIndex:'grade_name',fixed: 'left'},
{title:'班级',key:'class',width:112,align:'center',dataIndex:'class_name',fixed: 'left',customRender:(text,record,index)=>{
let obj = {
children:text,
attrs:{},
}
if (index % 2 === 0){
obj.attrs.rowSpan = 2;
}else{
obj.attrs.rowSpan = 0;
}
return obj;
}
},
{title:'性别',key:'gender',width:45,align:'center',dataIndex:'gender',fixed:'left'}
];
for (let i = 0; i < IndexObject.length; i ++){
let obj = IndexObject[i];
if (type === 'sample' && obj.obj_id !== 'bmi'){
column.push({
title:obj.obj_name,
key:obj.obj_id,
children:[
{title:'样本数',width:70,key:obj.obj_id + "_sample",align:'center',dataIndex:obj.obj_id + "_sample"},
{title:'平均值',width:70,key:obj.obj_id + "_average",align:'center',dataIndex:obj.obj_id + "_average"},
{title:'标准差',width:70,key:obj.obj_id + "_std",align:'center',dataIndex:obj.obj_id + "_std"}
]
})
}else if (type === 'grade' && obj.obj_id !== 'height' && obj.obj_id !== 'weight'){
column.push({
title:obj.obj_name,
key:obj.obj_id,
children:[
{title:obj.obj_id === 'bmi'?'低体重':'优秀',width:70,key:obj.obj_id + "_a",align:'center',dataIndex:obj.obj_id + "_a"},
{title:obj.obj_id === 'bmi'?'标准体重':'良好',width:80,key:obj.obj_id + "_b",align:'center',dataIndex:obj.obj_id + "_b"},
{title:obj.obj_id === 'bmi'?'超重':'及格',width:70,key:obj.obj_id + "_c",align:'center',dataIndex:obj.obj_id + "_c"},
{title:obj.obj_id === 'bmi'?'肥胖':'不及格',width:70,key:obj.obj_id + "_d",align:'center',dataIndex:obj.obj_id + "_d"}
]
})
}
}
return column;
},
getData:function () {
let params = {
report_year:this.year.id,
school_id:this.schoolData.id
}
let config = [InterfaceConfig.getSchoolStatisticsSummary,InterfaceConfig.getSchoolStageGradeList,
InterfaceConfig.getClassProjectNumAvgList,InterfaceConfig.getClassProjectRankList];
config.forEach((item)=>{
item.params = params;
});
Interface.callInterface(config,(result)=>{
// this.isLoading = false;
if (result[0].data.code === 2000){
let summary = result[0].data.data;
this.totalClass = summary.total_class_number?summary.total_class_number:'0';
this.totalStudent = summary.total_student_number?summary.total_student_number:'0';
if(summary.stage_list && Array.isArray(summary.stage_list)){
if (summary.stage_list.some((item)=>{return parseInt(item.stage_id) === 1})){
this.primaryCount = summary.stage_list.filter((item)=>{return parseInt(item.stage_id) === 1})[0].grade_number;
}else{
this.primaryCount = "";
}
if (summary.stage_list.some((item)=>{return parseInt(item.stage_id) === 2})){
this.middleCount = summary.stage_list.filter((item)=>{return parseInt(item.stage_id) === 2})[0].grade_number;
}else{
this.middleCount = "";
}
if (summary.stage_list.some((item)=>{return parseInt(item.stage_id) === 3})){
this.highCount = summary.stage_list.filter((item)=>{return parseInt(item.stage_id) === 3})[0].grade_number;
}else{
this.highCount = "";
}
}else{
this.primaryCount = "";
this.middleCount = "";
this.highCount = "";
}
}
if (result[1].data.code === 2000){
this.gradeList = result[1].data.data.grade_list;
if (this.gradeList && this.gradeList.length > 0){
this.sampleGrade = this.gradeList[0].grade_no;
this.gradeGrade = this.gradeList[0].grade_no;
if (result[2].data.code === 2000){
let data = result[2].data.data;
let tableData = [];
let list = [];
data.forEach((item,index)=>{
if (list.every((grade)=>{return grade.grade_no !== item.grade_no})){
list.push({grade_no:item.grade_no,grade_name:item.grade_name,index:index * 2,
length:data.filter((data)=>{return data.grade_no === item.grade_no}).length * 2})
}
let male = {
id:item.grade_no + "_" + item.class_no + '_male',
grade_name:item.grade_name,
class_name:item.class_name,
gender:'男'
}
let female = {
id:item.grade_no + "_" + item.class_no + 'female',
grade_name:item.grade_name,
class_name:item.class_name,
gender:'女'
}
IndexObject.forEach((obj)=>{
if (obj.obj_id !== 'bmi'){
if (item[obj.obj_id] && Object.keys(item[obj.obj_id]).length > 0){
male[obj.obj_id + "_sample"] = item[obj.obj_id].psn_num_boy;
male[obj.obj_id + "_average"] = item[obj.obj_id].res_avg_boy;
male[obj.obj_id + "_std"] = item[obj.obj_id].res_std_boy;
female[obj.obj_id + "_sample"] = item[obj.obj_id].psn_num_girl;
female[obj.obj_id + "_average"] = item[obj.obj_id].res_avg_girl;
female[obj.obj_id + "_std"] = item[obj.obj_id].res_std_girl;
}else{
male[obj.obj_id + "_sample"] = '';
male[obj.obj_id + "_average"] = '';
male[obj.obj_id + "_std"] = '';
female[obj.obj_id + "_sample"] = '';
female[obj.obj_id + "_average"] = '';
female[obj.obj_id + "_std"] = '';
}
}
});
tableData.push(male);
tableData.push(female);
});
let column = _.cloneDeep(this.sampleColumn[1]);
column.customRender=(text,record,index)=>{
const obj = {
children: text,
attrs: {},
};
if (list.some((item)=>{return item.index === index})){
let grade = list.filter((item)=>{return item.index === index});
obj.attrs.rowSpan = grade[0]['length'];
}else{
obj.attrs.rowSpan = 0;
}
return obj;
}
this.$set(this.sampleColumn,1,column);
this.sampleTableData = tableData;
this.getClassProjectNumAvgChart();
}else{
this.sampleTableData = [];
}
if (result[3].data.code === 2000){
let data = result[3].data.data;
let tableData = [];
let list = [];
data.forEach((item,index)=>{
if (list.every((grade)=>{return grade.grade_no !== item.grade_no})){
list.push({grade_no:item.grade_no,grade_name:item.grade_name,index:index * 2,
length:data.filter((data)=>{return data.grade_no === item.grade_no}).length * 2})
}
let male = {
id:item.grade_no + "_" + item.class_no + '_male',
grade_name:item.grade_name,
class_name:item.class_name,
gender:'男'
}
let female = {
id:item.grade_no + "_" + item.class_no + 'female',
grade_name:item.grade_name,
class_name:item.class_name,
gender:'女'
}
IndexObject.forEach((obj)=>{
if (obj.obj_id !== 'height' && obj.obj_id !== 'weight'){
if (item[obj.obj_id] && Object.keys(item[obj.obj_id]).length > 0){
male[obj.obj_id + "_a"] = item[obj.obj_id].rnk_rto_a_boy;
male[obj.obj_id + "_b"] = item[obj.obj_id].rnk_rto_b_boy;
male[obj.obj_id + "_c"] = item[obj.obj_id].rnk_rto_c_boy;
male[obj.obj_id + "_d"] = item[obj.obj_id].rnk_rto_d_boy;
female[obj.obj_id + "_a"] = item[obj.obj_id].rnk_rto_a_girl;
female[obj.obj_id + "_b"] = item[obj.obj_id].rnk_rto_b_girl;
female[obj.obj_id + "_c"] = item[obj.obj_id].rnk_rto_c_girl;
female[obj.obj_id + "_d"] = item[obj.obj_id].rnk_rto_d_girl;
}else{
male[obj.obj_id + "_a"] = '';
male[obj.obj_id + "_b"] = '';
male[obj.obj_id + "_c"] = '';
male[obj.obj_id + "_d"] = '';
female[obj.obj_id + "_a"] = '';
female[obj.obj_id + "_b"] = '';
female[obj.obj_id + "_c"] = '';
female[obj.obj_id + "_d"] = '';
}
}
});
tableData.push(male);
tableData.push(female);
});
let column = _.cloneDeep(this.gradeColumn[1]);
column.customRender=(text,record,index)=>{
const obj = {
children: text,
attrs: {},
};
if (list.some((item)=>{return item.index === index})){
let grade = list.filter((item)=>{return item.index === index});
obj.attrs.rowSpan = grade[0]['length'];
}else{
obj.attrs.rowSpan = 0;
}
return obj;
}
this.$set(this.gradeColumn,1,column);
this.gradeTableData = tableData;
this.getClassProjectRankChart();
}else{
this.gradeTableData = [];
}
}else{
this.isLoading = false;
this.sampleGrade = '';
this.gradeGrade = '';
this.sampleTableData = [];
this.gradeTableData = [];
this.sampleData = null;
this.gradeData = null;
if (this.sampleEChart){
this.sampleEChart.clear();
this.sampleEChart = null;
}
if (this.gradeEChart){
this.gradeEChart.clear();
this.gradeEChart = null;
}
}
}
})
},
/*
* 样本平均数标准差统计图
* */
getClassProjectNumAvgChart:function () {
this.isLoading = true;
let params = {
report_year:this.year.id,
school_id:this.schoolData.id,
grade_no:this.sampleGrade,
project_key:this.sampleTabkey,
}
Interface.callInterface([{
url:InterfaceConfig.getClassProjectNumAvgChart.url,
params:params,
method:InterfaceConfig.getClassProjectNumAvgChart.method,
isTestLogin:InterfaceConfig.getClassProjectNumAvgChart.isTestLogin
}],(result)=>{
this.isLoading = false;
if (result[0].data.code === 2000){
this.sampleData = result[0].data.data;
this.sampleEChartData.xAxis[0].data = [];////
this.sampleEChartData.series[0].data = [];
this.sampleEChartData.series[1].data = [];
if (this.sampleData && Array.isArray(this.sampleData)){
this.sampleData.forEach((item)=>{
this.sampleEChartData.xAxis[0].data.push(item.class_name);
this.sampleEChartData.series[0].data.push(item.psn_num_boy?item.psn_num_boy:'');
this.sampleEChartData.series[1].data.push(item.psn_num_girl?item.psn_num_girl:'')
})
if (this.sampleEChart === null){
this.sampleEChart = echarts.init(document.getElementById('sampleEChart'));
this.sampleEChart.setOption(this.sampleEChartData);
}else{
this.sampleEChart.setOption(this.sampleEChartData);
}
}else{
this.sampleData = null;
if (this.sampleEChart){
this.sampleEChart.clear();
this.sampleEChart = null;
}
}
}else{
this.sampleData = null;
if (this.sampleEChart){
this.sampleEChart.clear();
this.sampleEChart = null;
}
}
})
},
/*
* 等级分布柱状统计图
* */
getClassProjectRankChart:function () {
this.isLoading = true;
let params = {
report_year:this.year.id,
school_id:this.schoolData.id,
grade_no:this.gradeGrade,
project_key:this.gradeTabkey,
}
Interface.callInterface([{
url:InterfaceConfig.getClassProjectRankChart.url,
params:params,
method:InterfaceConfig.getClassProjectRankChart.method,
isTestLogin:InterfaceConfig.getClassProjectRankChart.isTestLogin
}],(result)=>{
this.isLoading = false;
if (result[0].data.code === 2000){
this.gradeData = result[0].data.data;
this.gradeEChartData.xAxis[0].data = [];//
if (this.gradeTabkey === "bmi"){
this.gradeEChartData.legend.data=["低体重",'标准体重','超重','肥胖'];
this.gradeEChartData.series[0].name = '低体重';
this.gradeEChartData.series[1].name = '标准体重';
this.gradeEChartData.series[2].name = '超重';
this.gradeEChartData.series[3].name = '肥胖';
}else{
this.gradeEChartData.legend.data=["优秀",'良好','及格','不及格'];
this.gradeEChartData.series[0].name = '优秀';
this.gradeEChartData.series[1].name = '良好';
this.gradeEChartData.series[2].name = '及格';
this.gradeEChartData.series[3].name = '不及格';
}
this.gradeEChartData.series[0].data = [];
this.gradeEChartData.series[1].data = [];
this.gradeEChartData.series[2].data = [];
this.gradeEChartData.series[3].data = [];
if (this.gradeData && Array.isArray(this.gradeData)){
this.gradeData.forEach((item)=>{
this.gradeEChartData.xAxis[0].data.push(item.class_name);
this.gradeEChartData.series[0].data.push(item.rnk_rto_a_stu);
this.gradeEChartData.series[1].data.push(item.rnk_rto_b_stu)
this.gradeEChartData.series[2].data.push(item.rnk_rto_c_stu);
this.gradeEChartData.series[3].data.push(item.rnk_rto_d_stu)
})
if (this.gradeEChart === null){
this.gradeEChart = echarts.init(document.getElementById('gradeEChart'));
this.gradeEChart.setOption(this.gradeEChartData);
}else{
this.gradeEChart.setOption(this.gradeEChartData);
}
}else{
this.gradeData = null;
if (this.gradeEChart){
this.gradeEChart.clear();
this.gradeEChart = null;
}
}
}else{
this.gradeData = null;
if (this.gradeEChart){
this.gradeEChart.clear();
this.gradeEChart = null;
}
}
})
}
},
mounted() {
this.getData();
}
}
</script>
<style scoped lang="scss">
.ant-spin-nested-loading {
/deep/ div{
.ant-spin{
position: fixed;
top:calc(50vh - 200px);
}
}
}
.school-04-style{
min-height: calc(100vh - 136px);
background-color: white;
padding-bottom: 20px;
.title-style{
height: 80px;
line-height: 80px;
text-align: center;
font-size: 24px;
font-weight: bold;
letter-spacing: 2px;
}
.report-tips-style{
margin-top: 20px;
padding: 15px 30px;
background-color: rgba(255,147,31,0.5);
font-size: 16px;
line-height: 25px;
}
.analysis-container-style{
margin-top: 20px;
padding: 0 20px;
/deep/.total-tr-style{
background-color: rgba(49,168,250,0.3);
}
.analysis-title-style{
height: 40px;
line-height: 40px;
font-size: 18px;
font-weight: bold;
padding-left: 10px;
border-left: 10px solid #31a8fa;
margin-bottom: 20px;
}
.module-title-style{
font-size: 16px;
color: white;
width: 400px;
height: 50px;
text-align: center;
line-height: 50px;
font-weight: bold;
background-image: url();
background-size: 400px 50px;
margin: 0 auto 20px auto;
background-repeat: no-repeat;
}
.sample-chart{
margin-top: 30px;
position: relative;
margin-bottom: 30px;
.type-list-style{
width: 200px;
float: left;
height: 600px;
padding-top: 100px;
padding-left: 110px;
.type-style{
width: 90px;
letter-spacing: 10px;
text-align: center;
height: 40px;
margin-bottom: 30px;
border:1px solid #31a8fa;
cursor: pointer;
line-height: 40px;
border-right: none;
color:#31a8fa;
&:hover{
color:white;
background-color: #31a8fa;
}
&[data-selected=true]{
color:white;
background-color: #31a8fa;
}
}
}
.sample-echart-style{
float: left;
width: calc(100% - 200px);
height: 600px;
}
.grade-echart-style{
height: 600px;
width: 100%;
}
.nodata-style{
position: absolute;
width: calc(100% - 200px);
height: 600px;
left:200px;
top:56px;
line-height: 600px;
text-align: center;
font-size: 20px;
font-weight: bold;
color:#999999;
}
}
/deep/.ant-table-small{
border: 1.5px dashed rgba(255,147,31,1);
.td{
white-space: nowrap;
}
}
/deep/.ant-table-fixed,/deep/.ant-table-fixed-left{
margin: 0!important;
.ant-table-thead{
background-color: rgba(49,168,250,0.6);
}
}
}
}
</style>

@ -81,11 +81,11 @@
}],(result)=>{
if (result[0].data.code === 2000){
storeData.person_name = result[0].data.data.person_info.user_name;
storeData.org_id = result[0].data.data.org_info.org_name;
storeData.org_id = result[0].data.data.org_info.org_id;
storeData.org_name = result[0].data.data.org_info.org_name;
Cookie.set('person_name',Base64.encode(result[0].data.data.person_info.user_name));
Cookie.set('org_id',result[0].data.data.org_info.org_name);
Cookie.set('org_id',result[0].data.data.org_info.org_id);
Cookie.set('org_name',Base64.encode(result[0].data.data.org_info.org_name));
let orgLevel = parseInt(result[0].data.data.org_info.org_level);

Loading…
Cancel
Save