forked from AdoptOpenJDK/openjdk-dashboard
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrelease.js
118 lines (113 loc) · 3.69 KB
/
release.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
function graph(version) {
var url = 'https://api.adoptopenjdk.net/v2/info/releases/' + version;
fetch(url)
.then(
function(response) {
if (response.status !== 200) {
console.log('Looks like there was a problem. Status Code: ' +
response.status);
return;
}
// Examine the text in the response
response.json().then(function(data) {
var labels = [];
var downloads = [];
for (var release in data) {
labels.push(data[release].release_name)
downloads.push(data[release].download_count)
}
var ctx = document.getElementById("graph");
Chart.defaults.global.defaultFontSize = 15;
var myChart = new Chart(ctx, {
type: 'bar',
data: {
labels: labels,
datasets: [{
label: '# of ' + version + ' Downloads',
data: downloads,
backgroundColor: 'rgba(54, 162, 235, 0.2)',
borderColor: 'rgba(54, 162, 235, 1)',
borderWidth: 1
}]
},
options: {
"hover": {
"animationDuration": 0
},
"animation": {
"duration": 1,
"onComplete": function() {
var chartInstance = this.chart,
ctx = chartInstance.ctx;
ctx.font = Chart.helpers.fontString(Chart.defaults.global.defaultFontSize, Chart.defaults.global.defaultFontStyle, Chart.defaults.global.defaultFontFamily);
ctx.textAlign = 'center';
ctx.textBaseline = 'bottom';
this.data.datasets.forEach(function(dataset, i) {
var meta = chartInstance.controller.getDatasetMeta(i);
meta.data.forEach(function(bar, index) {
var data = dataset.data[index];
ctx.fillText(Comma(data), bar._model.x, bar._model.y - 5);
});
});
}
},
onClick: graphClickEvent,
tooltips: {
"enabled": false
},
scales: {
yAxes: [{
ticks: {
beginAtZero: true
}
}],
xAxes: [{
stacked: false,
beginAtZero: true,
ticks: {
maxRotation: 15,
minRotation: 0,
stepSize: 1,
min: 0,
autoSkip: false
}
}],
}
}
});
});
}
)
.catch(function(err) {
console.log('Fetch Error :-S', err);
});
function graphClickEvent(event, array) {
if (array[0]) {
tag = encodeURIComponent(array[0]._model.label)
window.open('./version.html?version=' + version + '&tag=' + tag ,'_blank');
}
}
}
function Comma(Num) { //function to add commas to textboxes
Num += '';
Num = Num.replace(',', '');
Num = Num.replace(',', '');
Num = Num.replace(',', '');
Num = Num.replace(',', '');
Num = Num.replace(',', '');
Num = Num.replace(',', '');
x = Num.split('.');
x1 = x[0];
x2 = x.length > 1 ? '.' + x[1] : '';
var rgx = /(\d+)(\d{3})/;
while (rgx.test(x1))
x1 = x1.replace(rgx, '$1' + ',' + '$2');
return x1 + x2;
}
var url_string = window.location.href;
var url = new URL(url_string);
var version = url.searchParams.get("version");
if (!version) {
alert('please specify a version e.g "?version=openjdk8|openjdk11"')
}
graph(version)