Analytics: add the first graph (task repartition)

This commit is contained in:
Frédéric Guillot
2014-11-09 17:59:02 -05:00
parent 3df63e051f
commit e89ba5e9e6
29 changed files with 392 additions and 10 deletions

58
assets/js/analytic.js Normal file
View File

@@ -0,0 +1,58 @@
Kanboard.Analytic = (function() {
return {
Init: function() {
if (Kanboard.Exists("analytic-repartition")) {
Kanboard.Analytic.Repartition.Init();
}
}
};
})();
Kanboard.Analytic.Repartition = (function() {
function fetchData()
{
jQuery.getJSON($("#chart").attr("data-url"), function(data) {
drawGraph(data.metrics, data.labels);
});
}
function drawGraph(metrics, labels)
{
var series = prepareSeries(metrics, labels);
var svg = dimple.newSvg("#chart", 700, 350);
var chart = new dimple.chart(svg, series);
chart.addMeasureAxis("p", labels["nb_tasks"]);
var ring = chart.addSeries(labels["column_title"], dimple.plot.pie);
ring.innerRadius = "50%";
chart.addLegend(0, 0, 100, 100, "left");
chart.draw();
}
function prepareSeries(metrics, labels)
{
var series = [];
for (var i = 0; i < metrics.length; i++) {
var serie = {};
serie[labels["nb_tasks"]] = metrics[i]["nb_tasks"];
serie[labels["column_title"]] = metrics[i]["column_title"];
series.push(serie);
}
return series;
}
return {
Init: fetchData
};
})();

View File

@@ -18,6 +18,15 @@ var Kanboard = (function() {
return {
// Return true if the element#id exists
Exists: function(id) {
if (document.getElementById(id)) {
return true;
}
return false;
},
// Display a popup
Popover: function(e, callback) {
e.preventDefault();
@@ -264,15 +273,76 @@ Kanboard.Task = (function() {
}
};
})();// Initialization
})();
Kanboard.Analytic = (function() {
return {
Init: function() {
if (Kanboard.Exists("analytic-repartition")) {
Kanboard.Analytic.Repartition.Init();
}
}
};
})();
Kanboard.Analytic.Repartition = (function() {
function fetchData()
{
jQuery.getJSON($("#chart").attr("data-url"), function(data) {
drawGraph(data.metrics, data.labels);
});
}
function drawGraph(metrics, labels)
{
var series = prepareSeries(metrics, labels);
var svg = dimple.newSvg("#chart", 700, 350);
var chart = new dimple.chart(svg, series);
chart.addMeasureAxis("p", labels["nb_tasks"]);
var ring = chart.addSeries(labels["column_title"], dimple.plot.pie);
ring.innerRadius = "50%";
chart.addLegend(0, 0, 100, 100, "left");
chart.draw();
}
function prepareSeries(metrics, labels)
{
var series = [];
for (var i = 0; i < metrics.length; i++) {
var serie = {};
serie[labels["nb_tasks"]] = metrics[i]["nb_tasks"];
serie[labels["column_title"]] = metrics[i]["column_title"];
series.push(serie);
}
return series;
}
return {
Init: fetchData
};
})();
// Initialization
$(function() {
Kanboard.Init();
if ($("#board").length) {
if (Kanboard.Exists("board")) {
Kanboard.Board.Init();
}
else if ($("#task-section").length) {
else if (Kanboard.Exists("task-section")) {
Kanboard.Task.Init();
}
else if (Kanboard.Exists("analytic-section")) {
Kanboard.Analytic.Init();
}
});

View File

@@ -3,6 +3,15 @@ var Kanboard = (function() {
return {
// Return true if the element#id exists
Exists: function(id) {
if (document.getElementById(id)) {
return true;
}
return false;
},
// Display a popup
Popover: function(e, callback) {
e.preventDefault();

5
assets/js/d3.v3.4.8.min.js vendored Normal file

File diff suppressed because one or more lines are too long

3
assets/js/dimple.v2.1.0.min.js vendored Normal file

File diff suppressed because one or more lines are too long

View File

@@ -3,10 +3,13 @@ $(function() {
Kanboard.Init();
if ($("#board").length) {
if (Kanboard.Exists("board")) {
Kanboard.Board.Init();
}
else if ($("#task-section").length) {
else if (Kanboard.Exists("task-section")) {
Kanboard.Task.Init();
}
else if (Kanboard.Exists("analytic-section")) {
Kanboard.Analytic.Init();
}
});