-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathshowChartByCredit.js
85 lines (78 loc) · 2.82 KB
/
showChartByCredit.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
var typeGrade = ['A', 'B+', 'B', 'C+', 'C', 'D+', 'D', 'F', 'W', 'P', 'N'];
var valueOfGrade = [4.0, 3.5, 3.0, 2.5, 2.0, 1.5, 1.0, 0.0, undefined, undefined];
var countGrade = {};
typeGrade.forEach(function(x) {
countGrade[x] = 0;
});
var cells = document.getElementsByClassName('tr');
for (var i = 0, size = cells.length; i < size; i++) {
var text = cells[i].innerHTML;
if(i % 4 === 2) {
const fixGradeFFormat = (str) => str.replace('(', '').replace(')', '')
countGrade[text] += parseInt(fixGradeFFormat(cells[i+1].innerHTML));
}
}
var sumOfMul = typeGrade.reduce((prev, curr, index) => {
if (valueOfGrade[index] !== undefined) return prev + countGrade[curr]*valueOfGrade[index];
else return prev;
}, 0);
var creditAll = typeGrade.reduce((prev, curr, index) => {
if (valueOfGrade[index] !== undefined) return prev + countGrade[curr];
else return prev;
}, 0);
var gpa = sumOfMul / creditAll;
var border = '===============================\n';
var chart = document.createElement('tr');
var canvas = document.createElement("canvas");
canvas.id = "myChart";
canvas.width = 400;
canvas.height = 400;
canvas.style = "width: 100%;"
var table = document.createElement('table');
table.border = 0; table.width = "100%"; table.cellspacing=0; table.className="table";
table.style="border: solid 1px black; width:100%;";
table.appendChild(canvas);
var td = document.createElement('td');
table.appendChild(td);
chart.appendChild(table);
var normalTables = document.getElementsByTagName('tbody')[5].getElementsByTagName('table');
normalTables[1].parentElement.appendChild(chart);
normalTables[0].style = "border-left: solid 1px black;";
document.getElementsByTagName('table')[5].style = "border-bottom: none;";
var js = document.createElement("script");
js.type = "text/javascript";
js.src = "https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.1.3/Chart.bundle.min.js";
document.body.appendChild(js);
js.onload = function() {
var canvas = document.getElementById("myChart");
var ctx = document.getElementById("myChart").getContext("2d");
var myChart = new Chart(ctx, {
type: 'bar',
data: {
labels: typeGrade,
datasets: [{
label: '# of Credit (by ZugarZeeker @Cleverse)',
backgroundColor: ['#14ACDE', '#06A199', '#32A42B','#B4CB01', '#FFE401', '#EA640B', '#D7031C', '#E2006C', '#A90C5D', '#7F378B'],
borderColor: 'black',
borderWidth: 1,
hoverBackgroundColor: "rgba(255,99,132,0.4)",
hoverBorderColor: "rgba(255,99,132,1)",
data: typeGrade.map(function(grade) {return countGrade[grade]})
}]
},
options: {
title: {
display: true,
position: 'bottom',
text: `cum. G.P.A. = ${gpa.toFixed(2)} credit = ${creditAll}`
},
scales: {
yAxes: [{
ticks: {
beginAtZero:true
}
}]
}
}
});
}