mirror of
https://gitlab.com/crafty-controller/crafty-4.git
synced 2025-01-22 03:05:28 +01:00
580 lines
11 KiB
JavaScript
Executable File
580 lines
11 KiB
JavaScript
Executable File
(function ($) {
|
|
'use strict';
|
|
|
|
function labelFormatter(label, series) {
|
|
return "<div style='font-size:8pt; text-align:center; padding:2px; color:white;'>" + label + "<br/>" + Math.round(series.percent) + "%</div>";
|
|
}
|
|
|
|
if ($("#curved-line-chart").length) {
|
|
var data = [{
|
|
data: 18000,
|
|
color: '#FABA66',
|
|
label: 'Linda'
|
|
},
|
|
{
|
|
data: 20000,
|
|
color: '#F36368',
|
|
label: 'John'
|
|
},
|
|
{
|
|
data: 13000,
|
|
color: '#76C1FA',
|
|
label: 'Margaret'
|
|
},
|
|
{
|
|
data: 15000,
|
|
color: '#63CF72',
|
|
label: 'Richard'
|
|
}
|
|
];
|
|
var d1 = [
|
|
[0, 6],
|
|
[1, 14],
|
|
[2, 10],
|
|
[3, 14],
|
|
[4, 5]
|
|
];
|
|
var d2 = [
|
|
[0, 6],
|
|
[1, 7],
|
|
[2, 11],
|
|
[3, 8],
|
|
[4, 11]
|
|
];
|
|
var d3 = [
|
|
[0, 6],
|
|
[1, 5],
|
|
[2, 6],
|
|
[3, 10],
|
|
[4, 5]
|
|
];
|
|
var curvedLineOptions = {
|
|
series: {
|
|
shadowSize: 0,
|
|
curvedLines: { //This is a third party plugin to make curved lines
|
|
apply: true,
|
|
active: true,
|
|
monotonicFit: true
|
|
},
|
|
lines: {
|
|
show: false,
|
|
lineWidth: 0
|
|
}
|
|
},
|
|
grid: {
|
|
borderWidth: 0,
|
|
labelMargin: 10,
|
|
hoverable: true,
|
|
clickable: true,
|
|
mouseActiveRadius: 6
|
|
},
|
|
xaxis: {
|
|
tickDecimals: 0,
|
|
ticks: false
|
|
},
|
|
yaxis: {
|
|
tickDecimals: 0,
|
|
ticks: false
|
|
},
|
|
legend: {
|
|
// show: true,
|
|
container: $("#chartLegend")
|
|
}
|
|
}
|
|
|
|
$.plot($("#curved-line-chart"), [{
|
|
data: d1,
|
|
lines: {
|
|
show: true,
|
|
fill: 0.98
|
|
},
|
|
label: 'Plans',
|
|
stack: true
|
|
},
|
|
{
|
|
data: d2,
|
|
lines: {
|
|
show: true,
|
|
fill: 0.98
|
|
},
|
|
label: 'Purchase',
|
|
stack: true
|
|
},
|
|
{
|
|
data: d3,
|
|
lines: {
|
|
show: true,
|
|
fill: 0.98
|
|
},
|
|
label: 'Services',
|
|
stack: true
|
|
}
|
|
], curvedLineOptions);
|
|
}
|
|
|
|
if ($("#pie-chart").length) {
|
|
$.plot("#pie-chart", data, {
|
|
series: {
|
|
pie: {
|
|
show: true,
|
|
radius: 1,
|
|
label: {
|
|
show: true,
|
|
radius: 3 / 4,
|
|
formatter: labelFormatter,
|
|
background: {
|
|
opacity: 0.5
|
|
}
|
|
}
|
|
}
|
|
},
|
|
legend: {
|
|
show: false
|
|
}
|
|
});
|
|
}
|
|
|
|
if ($("#line-chart").length) {
|
|
var d1 = [
|
|
[0, 30],
|
|
[1, 35],
|
|
[2, 35],
|
|
[3, 30],
|
|
[4, 30]
|
|
];
|
|
var d2 = [
|
|
[0, 50],
|
|
[1, 40],
|
|
[2, 45],
|
|
[3, 60],
|
|
[4, 50]
|
|
];
|
|
var d3 = [
|
|
[0, 40],
|
|
[1, 50],
|
|
[2, 35],
|
|
[3, 25],
|
|
[4, 40]
|
|
];
|
|
|
|
var stackedData = [{
|
|
data: d1,
|
|
color: "#76C1FA"
|
|
},
|
|
{
|
|
data: d2,
|
|
color: "#63CF72"
|
|
},
|
|
{
|
|
data: d3,
|
|
color: "#F36368"
|
|
}
|
|
];
|
|
/*---------------------------------------------------
|
|
Make some random data for Recent Items chart
|
|
---------------------------------------------------*/
|
|
|
|
|
|
var options = {
|
|
series: {
|
|
shadowSize: 0,
|
|
lines: {
|
|
show: true,
|
|
},
|
|
},
|
|
grid: {
|
|
borderWidth: 1,
|
|
labelMargin: 10,
|
|
mouseActiveRadius: 6,
|
|
borderColor: 'rgba(255,255,255,0.1)',
|
|
show: true,
|
|
hoverable: true,
|
|
clickable: true
|
|
|
|
},
|
|
xaxis: {
|
|
tickColor: 'rgba(255,255,255,0.3)',
|
|
tickDecimals: 0,
|
|
axisLabelColour: '#fff',
|
|
font: {
|
|
lineHeight: 15,
|
|
style: "normal",
|
|
color: "#fff"
|
|
},
|
|
shadowSize: 0,
|
|
ticks: [
|
|
[0, "Jan"],
|
|
[1, "Feb"],
|
|
[2, "Mar"],
|
|
[3, "Apr"],
|
|
[4, "May"],
|
|
[5, "Jun"],
|
|
[6, "Jul"],
|
|
[7, "Aug"],
|
|
[8, "Sep"],
|
|
[9, "Oct"],
|
|
[10, "Nov"],
|
|
[11, "Dec"]
|
|
]
|
|
},
|
|
|
|
yaxis: {
|
|
tickColor: 'rgba(255,255,255,0.3)',
|
|
tickDecimals: 0,
|
|
font: {
|
|
lineHeight: 15,
|
|
style: "normal",
|
|
color: "#fff",
|
|
},
|
|
shadowSize: 0
|
|
},
|
|
|
|
legend: {
|
|
container: '.flc-line',
|
|
backgroundOpacity: 0.5,
|
|
noColumns: 0,
|
|
backgroundColor: "white",
|
|
lineWidth: 0
|
|
},
|
|
colors: ["#F36368", "#63CF72", "#68B3C8"]
|
|
};
|
|
$.plot($("#line-chart"), [{
|
|
data: d1,
|
|
lines: {
|
|
show: true
|
|
},
|
|
label: 'Product A',
|
|
stack: true,
|
|
color: '#F36368'
|
|
},
|
|
{
|
|
data: d2,
|
|
lines: {
|
|
show: true
|
|
},
|
|
label: 'Product B',
|
|
stack: true,
|
|
color: '#FABA66'
|
|
},
|
|
{
|
|
data: d3,
|
|
lines: {
|
|
show: true
|
|
},
|
|
label: 'Product C',
|
|
stack: true,
|
|
color: '#68B3C8'
|
|
}
|
|
], options);
|
|
}
|
|
|
|
if ($(".flot-chart-line").length) {
|
|
$(".flot-chart-line").bind("plothover", function (event, pos, item) {
|
|
if (item) {
|
|
var x = item.datapoint[0].toFixed(2),
|
|
y = item.datapoint[1].toFixed(2);
|
|
$(".flot-tooltip").html(item.series.label + " Sales " + " : " + y).css({
|
|
top: item.pageY + 5,
|
|
left: item.pageX + 5
|
|
}).show();
|
|
} else {
|
|
$(".flot-tooltip").hide();
|
|
}
|
|
});
|
|
|
|
$("<div class='flot-tooltip' class='chart-tooltip'></div>").appendTo("body");
|
|
}
|
|
|
|
if ($("#area-chart").length) {
|
|
var d1 = [
|
|
[0, 0],
|
|
[1, 35],
|
|
[2, 35],
|
|
[3, 30],
|
|
[4, 30],
|
|
[5, 5],
|
|
[6, 32],
|
|
[7, 37],
|
|
[8, 30],
|
|
[9, 35],
|
|
[10, 30],
|
|
[11, 5]
|
|
];
|
|
var options = {
|
|
series: {
|
|
shadowSize: 0,
|
|
curvedLines: { //This is a third party plugin to make curved lines
|
|
apply: true,
|
|
active: true,
|
|
monotonicFit: true
|
|
},
|
|
lines: {
|
|
show: false,
|
|
fill: 0.98,
|
|
lineWidth: 0,
|
|
},
|
|
},
|
|
grid: {
|
|
borderWidth: 0,
|
|
labelMargin: 10,
|
|
hoverable: true,
|
|
clickable: true,
|
|
mouseActiveRadius: 6,
|
|
|
|
},
|
|
xaxis: {
|
|
tickDecimals: 0,
|
|
tickLength: 0
|
|
},
|
|
|
|
yaxis: {
|
|
tickDecimals: 0,
|
|
tickLength: 0
|
|
},
|
|
|
|
legend: {
|
|
show: false
|
|
}
|
|
};
|
|
var curvedLineOptions = {
|
|
series: {
|
|
shadowSize: 0,
|
|
curvedLines: { //This is a third party plugin to make curved lines
|
|
apply: true,
|
|
active: true,
|
|
monotonicFit: true
|
|
},
|
|
lines: {
|
|
show: false,
|
|
lineWidth: 0,
|
|
},
|
|
},
|
|
grid: {
|
|
borderWidth: 0,
|
|
labelMargin: 10,
|
|
hoverable: true,
|
|
clickable: true,
|
|
mouseActiveRadius: 6,
|
|
|
|
},
|
|
xaxis: {
|
|
tickDecimals: 0,
|
|
ticks: false
|
|
},
|
|
|
|
yaxis: {
|
|
tickDecimals: 0,
|
|
ticks: false
|
|
},
|
|
|
|
legend: {
|
|
noColumns: 4,
|
|
container: $("#chartLegend")
|
|
}
|
|
};
|
|
$.plot($("#area-chart"), [{
|
|
data: d1,
|
|
lines: {
|
|
show: true,
|
|
fill: 0.6
|
|
},
|
|
label: 'Product 1',
|
|
stack: true,
|
|
color: '#76C1FA'
|
|
}], options);
|
|
}
|
|
|
|
if ($("#column-chart").length) {
|
|
var data = [
|
|
["January", 10],
|
|
["February", 8],
|
|
["March", 4],
|
|
["April", 13],
|
|
["May", 17],
|
|
["June", 9]
|
|
];
|
|
$.plot("#column-chart", [data], {
|
|
series: {
|
|
bars: {
|
|
show: true,
|
|
barWidth: 0.6,
|
|
align: "center"
|
|
}
|
|
},
|
|
xaxis: {
|
|
mode: "categories",
|
|
tickLength: 0
|
|
},
|
|
|
|
grid: {
|
|
borderWidth: 0,
|
|
labelMargin: 10,
|
|
hoverable: true,
|
|
clickable: true,
|
|
mouseActiveRadius: 6,
|
|
}
|
|
|
|
});
|
|
}
|
|
|
|
if ($("#stacked-bar-chart").length) {
|
|
var d1 = [];
|
|
for (var i = 0; i <= 10; i += 1) {
|
|
d1.push([i, parseInt(Math.random() * 30)]);
|
|
}
|
|
|
|
var d2 = [];
|
|
for (var i = 0; i <= 10; i += 1) {
|
|
d2.push([i, parseInt(Math.random() * 30)]);
|
|
}
|
|
|
|
var d3 = [];
|
|
for (var i = 0; i <= 10; i += 1) {
|
|
d3.push([i, parseInt(Math.random() * 30)]);
|
|
}
|
|
$.plot("#stacked-bar-chart", stackedData, {
|
|
series: {
|
|
stack: 0,
|
|
lines: {
|
|
show: false,
|
|
fill: true,
|
|
steps: false
|
|
},
|
|
bars: {
|
|
show: true,
|
|
fill: true,
|
|
barWidth: 0.6
|
|
},
|
|
},
|
|
grid: {
|
|
borderWidth: 0,
|
|
labelMargin: 10,
|
|
hoverable: true,
|
|
clickable: true,
|
|
mouseActiveRadius: 6,
|
|
}
|
|
});
|
|
}
|
|
|
|
if ($("#realtime-chart").length) {
|
|
var data = [],
|
|
totalPoints = 300;
|
|
|
|
function getRandomData() {
|
|
|
|
if (data.length > 0)
|
|
data = data.slice(1);
|
|
|
|
// Do a random walk
|
|
|
|
while (data.length < totalPoints) {
|
|
|
|
var prev = data.length > 0 ? data[data.length - 1] : 50,
|
|
y = prev + Math.random() * 10 - 5;
|
|
|
|
if (y < 0) {
|
|
y = 0;
|
|
} else if (y > 100) {
|
|
y = 100;
|
|
}
|
|
|
|
data.push(y);
|
|
}
|
|
|
|
// Zip the generated y values with the x values
|
|
|
|
var res = [];
|
|
for (var i = 0; i < data.length; ++i) {
|
|
res.push([i, data[i]])
|
|
}
|
|
|
|
return res;
|
|
}
|
|
var updateInterval = 30;
|
|
|
|
var plot = $.plot("#realtime-chart", [getRandomData()], {
|
|
series: {
|
|
shadowSize: 0 // Drawing is faster without shadows
|
|
},
|
|
yaxis: {
|
|
min: 0,
|
|
max: 100
|
|
},
|
|
xaxis: {
|
|
show: false
|
|
},
|
|
grid: {
|
|
borderWidth: 0,
|
|
labelMargin: 10,
|
|
hoverable: true,
|
|
clickable: true,
|
|
mouseActiveRadius: 6,
|
|
}
|
|
|
|
});
|
|
|
|
function update() {
|
|
plot.setData([getRandomData()]);
|
|
// Since the axes don't change, we don't need to call plot.setupGrid()
|
|
plot.draw();
|
|
setTimeout(update, updateInterval);
|
|
}
|
|
update();
|
|
}
|
|
|
|
if ($("#curved-line-chart").length) {
|
|
var d1 = [
|
|
[0, 7],
|
|
[1, 11],
|
|
[2, 11],
|
|
[3, 13],
|
|
[4, 9]
|
|
];
|
|
var d2 = [
|
|
[0, 5],
|
|
[1, 9],
|
|
[2, 9],
|
|
[3, 9],
|
|
[4, 7]
|
|
];
|
|
var d3 = [
|
|
[0, 3],
|
|
[1, 6],
|
|
[2, 5],
|
|
[3, 6],
|
|
[4, 3]
|
|
];
|
|
$.plot($("#curved-line-chart"), [{
|
|
data: d1,
|
|
lines: {
|
|
show: true,
|
|
fill: 0.98
|
|
},
|
|
label: 'Plans',
|
|
stack: false,
|
|
color: '#A8B4FD'
|
|
},
|
|
{
|
|
data: d2,
|
|
lines: {
|
|
show: true,
|
|
fill: 0.98
|
|
},
|
|
label: 'Purchase',
|
|
stack: false,
|
|
color: '#8C95FC'
|
|
},
|
|
{
|
|
data: d3,
|
|
lines: {
|
|
show: true,
|
|
fill: 0.98
|
|
},
|
|
label: 'Services',
|
|
stack: false,
|
|
color: '#5E50F9'
|
|
}
|
|
], curvedLineOptions);
|
|
}
|
|
|
|
})(jQuery); |