You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
331 lines
7.1 KiB
JavaScript
331 lines
7.1 KiB
JavaScript
2 years ago
|
var EgretFunnelChart = (function() {
|
||
|
|
||
|
var title = '';
|
||
|
var subtext = '';
|
||
|
var legend = {};
|
||
|
var series = [];
|
||
|
var legendData = [];
|
||
|
|
||
|
function EgretFunnelChart() {
|
||
|
}
|
||
|
|
||
|
EgretFunnelChart.init = function(title, subtext) {
|
||
|
this.title = title;
|
||
|
this.subtext = subtext;
|
||
|
this.series = [];
|
||
|
this.legendData = [];
|
||
|
}
|
||
|
|
||
|
EgretFunnelChart.setData = function(data, width, x, itemStyle) {
|
||
|
var seriesItem = {"type":"funnel", "data":[]};
|
||
|
if (width != undefined && width != '' && width != null) {
|
||
|
seriesItem["width"] = width;
|
||
|
}
|
||
|
|
||
|
if (x != undefined && x != '' && x != null) {
|
||
|
seriesItem["x"] = x;
|
||
|
}
|
||
|
|
||
|
if (itemStyle != undefined && itemStyle != '' && itemStyle != null) {
|
||
|
seriesItem["itemStyle"] = itemStyle;
|
||
|
}
|
||
|
|
||
|
for (m in data) {
|
||
|
var row = {};
|
||
|
row.name = m;
|
||
|
row.value = data[m];
|
||
|
seriesItem.data.push(row);
|
||
|
if (this.legendData.indexOf(m) == -1) {
|
||
|
this.legendData.push(m);
|
||
|
}
|
||
|
}
|
||
|
this.series.push(seriesItem);
|
||
|
}
|
||
|
|
||
|
EgretFunnelChart.show = function(id) {
|
||
|
var myChart = echarts.init(document.getElementById(id));
|
||
|
myChart.setOption({
|
||
|
title : {
|
||
|
text : this.title,
|
||
|
subtext : this.subtext,
|
||
|
x : 'center'
|
||
|
},
|
||
|
tooltip : {
|
||
|
trigger : 'item',
|
||
|
formatter : "{b} : {c} ({d}%)",
|
||
|
showDelay : 0,
|
||
|
transitionDuration : 0.2
|
||
|
},
|
||
|
legend : {
|
||
|
orient : 'vertical',
|
||
|
x : 'left',
|
||
|
y : 'center',
|
||
|
show : true,
|
||
|
data : this.legendData,
|
||
|
},
|
||
|
calculable : true,
|
||
|
series : this.series
|
||
|
});
|
||
|
}
|
||
|
|
||
|
return EgretFunnelChart;
|
||
|
})();
|
||
|
|
||
|
EgretFunnelChart.prototype.__class__ = "EgretFunnelChart";
|
||
|
|
||
|
var EgretPieChart = (function() {
|
||
|
|
||
|
var title = '';
|
||
|
var subtext = '';
|
||
|
var legend = {};
|
||
|
var series = [];
|
||
|
var legendData = [];
|
||
|
var noLegend = false;
|
||
|
|
||
|
function EgretPieChart() {
|
||
|
}
|
||
|
|
||
|
EgretPieChart.init = function(title, subtext, noLegend) {
|
||
|
this.title = title;
|
||
|
this.subtext = subtext;
|
||
|
this.series = [];
|
||
|
this.legendData = [];
|
||
|
this.noLegend = noLegend;
|
||
|
}
|
||
|
|
||
|
EgretPieChart.setData = function(data, radius, center, itemStyle) {
|
||
|
var seriesItem = {"type":"pie", "radius":"", "center":"", "data":[], "itemStyle":""};
|
||
|
if (radius != undefined && radius != '' && radius != null) {
|
||
|
seriesItem["radius"] = radius;
|
||
|
} else {
|
||
|
seriesItem["radius"] = '70%';
|
||
|
}
|
||
|
|
||
|
if (center != undefined && center != '' && center != null) {
|
||
|
seriesItem["center"] = center;
|
||
|
} else {
|
||
|
seriesItem["center"] = [ '50%', '50%' ];
|
||
|
}
|
||
|
|
||
|
if (itemStyle != undefined && itemStyle != '' && itemStyle != null) {
|
||
|
seriesItem["itemStyle"] = itemStyle;
|
||
|
} else {
|
||
|
seriesItem["itemStyle"] = {};
|
||
|
}
|
||
|
|
||
|
for (m in data) {
|
||
|
var row = {};
|
||
|
row.name = m;
|
||
|
row.value = data[m];
|
||
|
seriesItem.data.push(row);
|
||
|
if (this.noLegend != true) {
|
||
|
if (this.legendData.indexOf(m) == -1) {
|
||
|
this.legendData.push(m);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
this.series.push(seriesItem);
|
||
|
}
|
||
|
|
||
|
EgretPieChart.show = function(id) {
|
||
|
var myChart = echarts.init(document.getElementById(id), 'macarons');
|
||
|
myChart.setOption({
|
||
|
title : {
|
||
|
text : this.title,
|
||
|
subtext : this.subtext,
|
||
|
x : 'center'
|
||
|
},
|
||
|
tooltip : {
|
||
|
trigger : 'item',
|
||
|
formatter : "{b} <br/> {c} ({d}%)",
|
||
|
showDelay : 0,
|
||
|
transitionDuration : 0.2
|
||
|
},
|
||
|
legend : {
|
||
|
orient : 'vertical',
|
||
|
x : 'left',
|
||
|
y : 'center',
|
||
|
show : false,
|
||
|
data : this.legendData,
|
||
|
},
|
||
|
calculable : true,
|
||
|
series : this.series,
|
||
|
});
|
||
|
|
||
|
return myChart;
|
||
|
}
|
||
|
|
||
|
return EgretPieChart;
|
||
|
})();
|
||
|
|
||
|
EgretPieChart.prototype.__class__ = "EgretPieChart";
|
||
|
|
||
|
var EgretChart = (function() {
|
||
|
|
||
|
var title = '';
|
||
|
var subtext = '';
|
||
|
var legend = {};
|
||
|
var series = [];
|
||
|
var xAxis = [];
|
||
|
var yAxis = [];
|
||
|
var grid = {};
|
||
|
var xyChange = false;
|
||
|
var dataSort = true;
|
||
|
function EgretChart() {
|
||
|
}
|
||
|
|
||
|
EgretChart.init = function(title, subtext, grid, xyChange, dataSort) {
|
||
|
this.title = title;
|
||
|
this.subtext = subtext;
|
||
|
this.legend = {
|
||
|
"data" : []
|
||
|
};
|
||
|
this.series = [];
|
||
|
this.xAxis = [];
|
||
|
this.yAxis = [];
|
||
|
if (grid) {
|
||
|
this.grid = grid;
|
||
|
}
|
||
|
this.xyChange = xyChange;
|
||
|
if (dataSort == false) {
|
||
|
this.dataSort = dataSort;
|
||
|
} else {
|
||
|
this.dataSort = true;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
EgretChart.setYAxis = function(yAxis) {
|
||
|
this.yAxis = yAxis;
|
||
|
}
|
||
|
|
||
|
EgretChart.setData = function(charType, legendName, data, stack, yAxisIndex, itemStyle) {
|
||
|
this.legend.data.push(legendName);
|
||
|
if (stack == true) {
|
||
|
var seriesData = {
|
||
|
"name" : legendName,
|
||
|
"type" : charType,
|
||
|
"data" : [],
|
||
|
"itemStyle" : {},
|
||
|
"stack" : "总量"
|
||
|
};
|
||
|
} else {
|
||
|
var seriesData = {
|
||
|
"name" : legendName,
|
||
|
"type" : charType,
|
||
|
"itemStyle" : {},
|
||
|
"data" : []
|
||
|
};
|
||
|
}
|
||
|
|
||
|
if (itemStyle != undefined) {
|
||
|
seriesData.itemStyle = itemStyle;
|
||
|
}
|
||
|
|
||
|
if (yAxisIndex != undefined) {
|
||
|
if (this.xyChange != true) {
|
||
|
seriesData.yAxisIndex = yAxisIndex;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
for (m in data) {
|
||
|
seriesData.data.push(data[m]);
|
||
|
}
|
||
|
this.series.push(seriesData);
|
||
|
|
||
|
if (this.xAxis == '') {
|
||
|
var xAxisData = {
|
||
|
"type" : "category",
|
||
|
"boundaryGap":true,
|
||
|
"data" : []
|
||
|
};
|
||
|
for (m in data) {
|
||
|
xAxisData.data.push(m);
|
||
|
}
|
||
|
this.xAxis.push(xAxisData);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
EgretChart.show = function(id) {
|
||
|
if (this.xyChange == true) {
|
||
|
var yAxis = this.yAxis;
|
||
|
this.yAxis = this.xAxis;
|
||
|
this.xAxis = [{type : 'value',boundaryGap : [0, 0.01]}];
|
||
|
if (yAxis.length > 0) {
|
||
|
this.xAxis = yAxis;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
var tooltip = {};
|
||
|
if (this.dataSort == true) {
|
||
|
tooltip = {
|
||
|
trigger : 'axis',
|
||
|
showDelay : 0,
|
||
|
transitionDuration : 0.1,
|
||
|
formatter: function (params,ticket,callback) {
|
||
|
var index = {}, data = [];
|
||
|
var l = params.length;
|
||
|
for (var i = 0; i < l; i++) {
|
||
|
data.push(params[i].value);
|
||
|
// dataGame[] = params[i].seriesName;
|
||
|
}
|
||
|
data.sort(function(a,b){return a<b?1:-1});
|
||
|
var getName = function(v) {
|
||
|
for (var k = 0; k < l; k ++) {
|
||
|
if (v == params[k].value && typeof index[params[k].seriesIndex] == "undefined") {
|
||
|
index[params[k].seriesIndex] = 1;
|
||
|
return params[k].seriesName;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
var res = params[0].name;
|
||
|
for (var j = 0; j < l; j ++) {
|
||
|
getName();
|
||
|
res += '<br/>' + getName(data[j]) + ' : ' + EgretChart.String.numberFormat(data[j]);
|
||
|
}
|
||
|
setTimeout(function (){
|
||
|
callback(ticket, res);
|
||
|
}, 300)
|
||
|
return 'loading...';
|
||
|
}
|
||
|
};
|
||
|
} else {
|
||
|
tooltip = {
|
||
|
trigger : 'axis',
|
||
|
showDelay : 0,
|
||
|
transitionDuration : 0.2
|
||
|
};
|
||
|
}
|
||
|
|
||
|
var myChart = echarts.init(document.getElementById(id), 'macarons');
|
||
|
myChart.setOption({
|
||
|
title : {
|
||
|
text : this.title,
|
||
|
subtext : this.subtext
|
||
|
},
|
||
|
tooltip : tooltip,
|
||
|
legend : this.legend,
|
||
|
calculable : true,
|
||
|
xAxis : this.xAxis,
|
||
|
yAxis : this.yAxis,
|
||
|
series : this.series,
|
||
|
grid : this.grid,
|
||
|
});
|
||
|
|
||
|
this.grid = {};
|
||
|
return myChart;
|
||
|
}
|
||
|
|
||
|
EgretChart.String = {
|
||
|
//格式化数字
|
||
|
numberFormat:function (s,l){
|
||
|
if (!l || l < 1)l = 3;
|
||
|
s=String(s).split(".");
|
||
|
s[0]=s[0].replace(new RegExp('(\\d)(?=(\\d{'+l+'})+$)','ig'),"$1,");
|
||
|
return s.join(".");
|
||
|
}
|
||
|
};
|
||
|
|
||
|
return EgretChart;
|
||
|
})();
|
||
|
|
||
|
EgretChart.prototype.__class__ = "EgretChart";
|