mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 13:36:15 +00: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);
 | |
| 
 | |
| }
 |