mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-05 13:44:58 -06:00
289 lines
8.2 KiB
JavaScript
289 lines
8.2 KiB
JavaScript
/* globals $, Chart, currencySymbol */
|
|
|
|
/*
|
|
Make some colours:
|
|
*/
|
|
var colourSet = [
|
|
[53, 124, 165],
|
|
[0, 141, 76],
|
|
[219, 139, 11],
|
|
[202, 25, 90],
|
|
[85, 82, 153],
|
|
[66, 133, 244],
|
|
[219, 68, 55],
|
|
[244, 180, 0],
|
|
[15, 157, 88],
|
|
[171, 71, 188],
|
|
[0, 172, 193],
|
|
[255, 112, 67],
|
|
[158, 157, 36],
|
|
[92, 107, 192],
|
|
[240, 98, 146],
|
|
[0, 121, 107],
|
|
[194, 24, 91],
|
|
|
|
];
|
|
|
|
var fillColors = [];
|
|
var strokePointHighColors = [];
|
|
|
|
|
|
for (var i = 0; i < colourSet.length; i++) {
|
|
fillColors.push("rgba(" + colourSet[i][0] + ", " + colourSet[i][1] + ", " + colourSet[i][2] + ", 0.2)");
|
|
strokePointHighColors.push("rgba(" + colourSet[i][0] + ", " + colourSet[i][1] + ", " + colourSet[i][2] + ", 0.9)");
|
|
}
|
|
|
|
/*
|
|
Set default options:
|
|
*/
|
|
var defaultAreaOptions = {
|
|
scaleShowGridLines: false,
|
|
pointDotRadius: 2,
|
|
datasetStrokeWidth: 1,
|
|
pointHitDetectionRadius: 5,
|
|
datasetFill: true,
|
|
animation: false,
|
|
scaleFontSize: 10,
|
|
responsive: false,
|
|
scaleLabel: " <%= '" + currencySymbol + " ' + Number(value).toFixed(0).replace('.', ',') %>",
|
|
tooltipFillColor: "rgba(0,0,0,0.5)",
|
|
multiTooltipTemplate: "<%=datasetLabel%>: <%= '" + currencySymbol + " ' + Number(value).toFixed(2).replace('.', ',') %>"
|
|
};
|
|
|
|
|
|
var defaultPieOptions = {
|
|
scaleShowGridLines: false,
|
|
pointDotRadius: 2,
|
|
datasetStrokeWidth: 1,
|
|
pointHitDetectionRadius: 5,
|
|
datasetFill: false,
|
|
animation: false,
|
|
scaleFontSize: 10,
|
|
responsive: false,
|
|
tooltipFillColor: "rgba(0,0,0,0.5)",
|
|
tooltipTemplate: "<%if (label){%><%=label%>: <%}%>" + currencySymbol + " <%= value %>",
|
|
|
|
};
|
|
|
|
|
|
var defaultLineOptions = {
|
|
scaleShowGridLines: false,
|
|
pointDotRadius: 2,
|
|
datasetStrokeWidth: 1,
|
|
pointHitDetectionRadius: 5,
|
|
animation: false,
|
|
datasetFill: false,
|
|
scaleFontSize: 10,
|
|
responsive: false,
|
|
scaleLabel: "<%= '" + currencySymbol + " ' + Number(value).toFixed(0).replace('.', ',') %>",
|
|
tooltipFillColor: "rgba(0,0,0,0.5)",
|
|
tooltipTemplate: "<%if (label){%><%=label%>: <%}%>" + currencySymbol + " <%= value %>",
|
|
multiTooltipTemplate: "<%=datasetLabel%>: <%= '" + currencySymbol + " ' + Number(value).toFixed(2).replace('.', ',') %>"
|
|
};
|
|
|
|
var defaultColumnOptions = {
|
|
scaleShowGridLines: false,
|
|
pointDotRadius: 2,
|
|
barStrokeWidth: 1,
|
|
pointHitDetectionRadius: 5,
|
|
datasetFill: false,
|
|
scaleFontSize: 10,
|
|
responsive: false,
|
|
animation: false,
|
|
scaleLabel: "<%= '" + currencySymbol + " ' + Number(value).toFixed(0).replace('.', ',') %>",
|
|
tooltipFillColor: "rgba(0,0,0,0.5)",
|
|
tooltipTemplate: "<%if (label){%><%=label%>: <%}%>" + currencySymbol + " <%= value %>",
|
|
multiTooltipTemplate: "<%=datasetLabel%>: " + currencySymbol + " <%= Number(value).toFixed(2).replace('.', ',') %>"
|
|
};
|
|
|
|
var defaultStackedColumnOptions = {
|
|
scaleShowGridLines: false,
|
|
pointDotRadius: 2,
|
|
barStrokeWidth: 1,
|
|
pointHitDetectionRadius: 5,
|
|
datasetFill: false,
|
|
animation: false,
|
|
scaleFontSize: 10,
|
|
responsive: false,
|
|
scaleLabel: "<%= '" + currencySymbol + " ' + Number(value).toFixed(0).replace('.', ',') %>",
|
|
tooltipFillColor: "rgba(0,0,0,0.5)",
|
|
multiTooltipTemplate: "<%=datasetLabel%>: " + currencySymbol + " <%= Number(value).toFixed(2).replace('.', ',') %>"
|
|
|
|
};
|
|
|
|
/**
|
|
* Function to draw a line chart:
|
|
* @param URL
|
|
* @param container
|
|
* @param options
|
|
*/
|
|
function lineChart(URL, container, options) {
|
|
"use strict";
|
|
options = options || defaultLineOptions;
|
|
|
|
$.getJSON(URL).success(function (data) {
|
|
var ctx = document.getElementById(container).getContext("2d");
|
|
var newData = {};
|
|
newData.datasets = [];
|
|
|
|
for (var i = 0; i < data.count; i++) {
|
|
newData.labels = data.labels;
|
|
var dataset = data.datasets[i];
|
|
dataset.fillColor = fillColors[i];
|
|
dataset.strokeColor = strokePointHighColors[i];
|
|
dataset.pointColor = strokePointHighColors[i];
|
|
dataset.pointStrokeColor = "#fff";
|
|
dataset.pointHighlightFill = "#fff";
|
|
dataset.pointHighlightStroke = strokePointHighColors[i];
|
|
newData.datasets.push(dataset);
|
|
}
|
|
new Chart(ctx).Line(newData, options);
|
|
|
|
}).fail(function () {
|
|
$('#' + container).addClass('general-chart-error');
|
|
});
|
|
console.log('URL for line chart : ' + URL);
|
|
}
|
|
|
|
/**
|
|
* Function to draw an area chart:
|
|
*
|
|
* @param URL
|
|
* @param container
|
|
* @param options
|
|
*/
|
|
function areaChart(URL, container, options) {
|
|
"use strict";
|
|
options = options || defaultAreaOptions;
|
|
|
|
$.getJSON(URL).success(function (data) {
|
|
var ctx = document.getElementById(container).getContext("2d");
|
|
var newData = {};
|
|
newData.datasets = [];
|
|
|
|
for (var i = 0; i < data.count; i++) {
|
|
newData.labels = data.labels;
|
|
var dataset = data.datasets[i];
|
|
dataset.fillColor = fillColors[i];
|
|
dataset.strokeColor = strokePointHighColors[i];
|
|
dataset.pointColor = strokePointHighColors[i];
|
|
dataset.pointStrokeColor = "#fff";
|
|
dataset.pointHighlightFill = "#fff";
|
|
dataset.pointHighlightStroke = strokePointHighColors[i];
|
|
newData.datasets.push(dataset);
|
|
}
|
|
new Chart(ctx).Line(newData, options);
|
|
|
|
}).fail(function () {
|
|
$('#' + container).addClass('general-chart-error');
|
|
});
|
|
|
|
console.log('URL for area chart: ' + URL);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param URL
|
|
* @param container
|
|
* @param options
|
|
*/
|
|
function columnChart(URL, container, options) {
|
|
"use strict";
|
|
options = options || defaultColumnOptions;
|
|
|
|
$.getJSON(URL).success(function (data) {
|
|
|
|
var ctx = document.getElementById(container).getContext("2d");
|
|
var newData = {};
|
|
newData.datasets = [];
|
|
|
|
for (var i = 0; i < data.count; i++) {
|
|
newData.labels = data.labels;
|
|
var dataset = data.datasets[i];
|
|
dataset.fillColor = fillColors[i];
|
|
dataset.strokeColor = strokePointHighColors[i];
|
|
dataset.pointColor = strokePointHighColors[i];
|
|
dataset.pointStrokeColor = "#fff";
|
|
dataset.pointHighlightFill = "#fff";
|
|
dataset.pointHighlightStroke = strokePointHighColors[i];
|
|
newData.datasets.push(dataset);
|
|
}
|
|
new Chart(ctx).Bar(newData, options);
|
|
|
|
}).fail(function () {
|
|
$('#' + container).addClass('general-chart-error');
|
|
});
|
|
console.log('URL for column chart : ' + URL);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param URL
|
|
* @param container
|
|
* @param options
|
|
*/
|
|
function stackedColumnChart(URL, container, options) {
|
|
"use strict";
|
|
options = options || defaultStackedColumnOptions;
|
|
|
|
$.getJSON(URL).success(function (data) {
|
|
|
|
var ctx = document.getElementById(container).getContext("2d");
|
|
var newData = {};
|
|
newData.datasets = [];
|
|
|
|
for (var i = 0; i < data.count; i++) {
|
|
newData.labels = data.labels;
|
|
var dataset = data.datasets[i];
|
|
dataset.fillColor = fillColors[i];
|
|
dataset.strokeColor = strokePointHighColors[i];
|
|
dataset.pointColor = strokePointHighColors[i];
|
|
dataset.pointStrokeColor = "#fff";
|
|
dataset.pointHighlightFill = "#fff";
|
|
dataset.pointHighlightStroke = strokePointHighColors[i];
|
|
newData.datasets.push(dataset);
|
|
}
|
|
new Chart(ctx).StackedBar(newData, options);
|
|
|
|
}).fail(function () {
|
|
$('#' + container).addClass('general-chart-error');
|
|
});
|
|
console.log('URL for stacked column chart : ' + URL);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param URL
|
|
* @param container
|
|
* @param options
|
|
*/
|
|
function comboChart(URL, container, options) {
|
|
"use strict";
|
|
columnChart(URL, container, options);
|
|
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param URL
|
|
* @param container
|
|
* @param options
|
|
*/
|
|
function pieChart(URL, container, options) {
|
|
"use strict";
|
|
|
|
options = options || defaultPieOptions;
|
|
$.getJSON(URL).success(function (data) {
|
|
|
|
var ctx = document.getElementById(container).getContext("2d");
|
|
new Chart(ctx).Pie(data, options);
|
|
|
|
}).fail(function () {
|
|
$('#' + container).addClass('general-chart-error');
|
|
});
|
|
|
|
|
|
console.log('URL for pie chart : ' + URL);
|
|
|
|
}
|