mirror of
https://github.com/ohwgiles/laminar.git
synced 2024-10-27 20:34:20 +00:00
Update Chart.js to latest: 2.7.2
Adapt to new API. This removes a few workarounds and should contribute nicely to #44, #45 and #57
This commit is contained in:
parent
d29715c0ec
commit
e506142fa4
@ -71,15 +71,13 @@ file(DOWNLOAD https://cdnjs.cloudflare.com/ajax/libs/vue-router/2.7.0/vue-router
|
|||||||
js/vue-router.min.js EXPECTED_MD5 5d3e35710dbe02de78c39e3e439b8d4e)
|
js/vue-router.min.js EXPECTED_MD5 5d3e35710dbe02de78c39e3e439b8d4e)
|
||||||
file(DOWNLOAD https://raw.githubusercontent.com/drudru/ansi_up/v1.3.0/ansi_up.js
|
file(DOWNLOAD https://raw.githubusercontent.com/drudru/ansi_up/v1.3.0/ansi_up.js
|
||||||
js/ansi_up.js EXPECTED_MD5 158566dc1ff8f2804de972f7e841e2f6)
|
js/ansi_up.js EXPECTED_MD5 158566dc1ff8f2804de972f7e841e2f6)
|
||||||
file(DOWNLOAD https://cdnjs.cloudflare.com/ajax/libs/Chart.js/1.0.2/Chart.min.js
|
file(DOWNLOAD https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.7.2/Chart.min.js
|
||||||
js/Chart.min.js EXPECTED_MD5 0d3004601c1a855a3d203502549528a7)
|
js/Chart.min.js EXPECTED_MD5 f6c8efa65711e0cbbc99ba72997ecd0e)
|
||||||
file(DOWNLOAD https://raw.githubusercontent.com/tomsouthall/Chart.HorizontalBar.js/v1.04/Chart.HorizontalBar.js
|
|
||||||
js/Chart.HorizontalBar.js EXPECTED_MD5 95070a38e69bc56534e1b2086d985270)
|
|
||||||
file(DOWNLOAD https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css
|
file(DOWNLOAD https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css
|
||||||
css/bootstrap.min.css EXPECTED_MD5 5d5357cb3704e1f43a1f5bfed2aebf42)
|
css/bootstrap.min.css EXPECTED_MD5 5d5357cb3704e1f43a1f5bfed2aebf42)
|
||||||
# ...and compile them
|
# ...and compile them
|
||||||
generate_compressed_bins(${CMAKE_BINARY_DIR} js/vue-router.min.js js/vue.min.js
|
generate_compressed_bins(${CMAKE_BINARY_DIR} js/vue-router.min.js js/vue.min.js
|
||||||
js/ansi_up.js js/Chart.min.js js/Chart.HorizontalBar.js css/bootstrap.min.css)
|
js/ansi_up.js js/Chart.min.js css/bootstrap.min.css)
|
||||||
# (see resources.cpp where these are fetched)
|
# (see resources.cpp where these are fetched)
|
||||||
|
|
||||||
## Server
|
## Server
|
||||||
|
@ -37,13 +37,11 @@ Resources::Resources()
|
|||||||
INIT_RESOURCE("/favicon-152.png", favicon_152_png, CONTENT_TYPE_PNG);
|
INIT_RESOURCE("/favicon-152.png", favicon_152_png, CONTENT_TYPE_PNG);
|
||||||
INIT_RESOURCE("/icon.png", icon_png, CONTENT_TYPE_PNG);
|
INIT_RESOURCE("/icon.png", icon_png, CONTENT_TYPE_PNG);
|
||||||
INIT_RESOURCE("/js/app.js", js_app_js, CONTENT_TYPE_JS);
|
INIT_RESOURCE("/js/app.js", js_app_js, CONTENT_TYPE_JS);
|
||||||
INIT_RESOURCE("/js/Chart.HorizontalBar.js", js_Chart_HorizontalBar_js, CONTENT_TYPE_JS);
|
|
||||||
INIT_RESOURCE("/js/ansi_up.js", js_ansi_up_js, CONTENT_TYPE_JS);
|
INIT_RESOURCE("/js/ansi_up.js", js_ansi_up_js, CONTENT_TYPE_JS);
|
||||||
INIT_RESOURCE("/js/vue.min.js", js_vue_min_js, CONTENT_TYPE_JS);
|
INIT_RESOURCE("/js/vue.min.js", js_vue_min_js, CONTENT_TYPE_JS);
|
||||||
INIT_RESOURCE("/js/vue-router.min.js", js_vue_router_min_js, CONTENT_TYPE_JS);
|
INIT_RESOURCE("/js/vue-router.min.js", js_vue_router_min_js, CONTENT_TYPE_JS);
|
||||||
INIT_RESOURCE("/js/ansi_up.js", js_ansi_up_js, CONTENT_TYPE_JS);
|
INIT_RESOURCE("/js/ansi_up.js", js_ansi_up_js, CONTENT_TYPE_JS);
|
||||||
INIT_RESOURCE("/js/Chart.min.js", js_Chart_min_js, CONTENT_TYPE_JS);
|
INIT_RESOURCE("/js/Chart.min.js", js_Chart_min_js, CONTENT_TYPE_JS);
|
||||||
INIT_RESOURCE("/js/Chart.HorizontalBar.js", js_Chart_HorizontalBar_js, CONTENT_TYPE_JS);
|
|
||||||
INIT_RESOURCE("/css/bootstrap.min.css", css_bootstrap_min_css, CONTENT_TYPE_CSS);
|
INIT_RESOURCE("/css/bootstrap.min.css", css_bootstrap_min_css, CONTENT_TYPE_CSS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,7 +12,6 @@
|
|||||||
<script src="/js/vue-router.min.js"></script>
|
<script src="/js/vue-router.min.js"></script>
|
||||||
<script src="/js/ansi_up.js"></script>
|
<script src="/js/ansi_up.js"></script>
|
||||||
<script src="/js/Chart.min.js"></script>
|
<script src="/js/Chart.min.js"></script>
|
||||||
<script src="/js/Chart.HorizontalBar.js"></script>
|
|
||||||
<link href="/css/bootstrap.min.css" rel="stylesheet">
|
<link href="/css/bootstrap.min.css" rel="stylesheet">
|
||||||
<link href="/custom/style.css" rel="stylesheet">
|
<link href="/custom/style.css" rel="stylesheet">
|
||||||
<script src="/js/app.js" defer></script>
|
<script src="/js/app.js" defer></script>
|
||||||
|
@ -177,8 +177,8 @@ const Home = function() {
|
|||||||
var chtUtilization, chtBuildsPerDay, chtBuildsPerJob, chtTimePerJob;
|
var chtUtilization, chtBuildsPerDay, chtBuildsPerJob, chtTimePerJob;
|
||||||
|
|
||||||
var updateUtilization = function(busy) {
|
var updateUtilization = function(busy) {
|
||||||
chtUtilization.segments[0].value += busy ? 1 : -1;
|
chtUtilization.data.datasets[0].data[0] += busy ? 1 : -1;
|
||||||
chtUtilization.segments[1].value -= busy ? 1 : -1;
|
chtUtilization.data.datasets[0].data[1] -= busy ? 1 : -1;
|
||||||
chtUtilization.update();
|
chtUtilization.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -196,23 +196,20 @@ const Home = function() {
|
|||||||
this.$forceUpdate();
|
this.$forceUpdate();
|
||||||
|
|
||||||
// setup charts
|
// setup charts
|
||||||
chtUtilization = new Chart(document.getElementById("chartUtil").getContext("2d")).Pie(
|
chtUtilization = new Chart(document.getElementById("chartUtil"), {
|
||||||
[{
|
type: 'pie',
|
||||||
value: msg.executorsBusy,
|
data: {
|
||||||
color: "tan",
|
labels: ["Busy", "Idle"],
|
||||||
label: "Busy"
|
datasets: [{
|
||||||
},
|
data: [ msg.executorsBusy, msg.executorsTotal - msg.executorsBusy ],
|
||||||
{
|
backgroundColor: ["tan", "darkseagreen"]
|
||||||
value: msg.executorsTotal - msg.executorsBusy,
|
}]
|
||||||
color: "darkseagreen",
|
|
||||||
label: "Idle"
|
|
||||||
}
|
}
|
||||||
], {
|
});
|
||||||
animationEasing: 'easeInOutQuad'
|
chtBuildsPerDay = new Chart(document.getElementById("chartBpd"), {
|
||||||
}
|
type: 'line',
|
||||||
);
|
data: {
|
||||||
chtBuildsPerDay = new Chart(document.getElementById("chartBpd").getContext("2d")).Line({
|
labels: (()=>{
|
||||||
labels: function() {
|
|
||||||
res = [];
|
res = [];
|
||||||
var now = new Date();
|
var now = new Date();
|
||||||
for (var i = 6; i >= 0; --i) {
|
for (var i = 6; i >= 0; --i) {
|
||||||
@ -220,45 +217,42 @@ const Home = function() {
|
|||||||
res.push(["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"][then.getDay()]);
|
res.push(["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"][then.getDay()]);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}(),
|
})(),
|
||||||
datasets: [{
|
datasets: [{
|
||||||
label: "Successful Builds",
|
label: 'Successful Builds',
|
||||||
fillColor: "rgba(143,188,143,0.65)", //darkseagreen at 0.65
|
backgroundColor: "rgba(143,188,143,0.65)", //darkseagreen at 0.65
|
||||||
strokeColor: "forestgreen",
|
borderColor: "forestgreen",
|
||||||
data: msg.buildsPerDay.map(function(e) {
|
data: msg.buildsPerDay.map((e)=>{ return e.success || 0; })
|
||||||
return e.success || 0;
|
|
||||||
})
|
|
||||||
}, {
|
}, {
|
||||||
label: "Failed Bulids",
|
label: 'Failed Builds',
|
||||||
fillColor: "rgba(233,150,122,0.65)", //darksalmon at 0.65
|
backgroundColor: "rgba(233,150,122,0.65)", //darkseagreen at 0.65
|
||||||
strokeColor: "crimson",
|
borderColor: "crimson",
|
||||||
data: msg.buildsPerDay.map(function(e) {
|
data: msg.buildsPerDay.map((e)=>{ return e.failed || 0; })
|
||||||
return e.failed || 0;
|
|
||||||
})
|
|
||||||
}]
|
}]
|
||||||
}, {
|
}
|
||||||
showTooltips: false
|
|
||||||
});
|
});
|
||||||
chtBuildsPerJob = new Chart(document.getElementById("chartBpj").getContext("2d")).HorizontalBar({
|
chtBuildsPerJob = new Chart(document.getElementById("chartBpj"), {
|
||||||
|
type: 'horizontalBar',
|
||||||
|
data: {
|
||||||
labels: Object.keys(msg.buildsPerJob),
|
labels: Object.keys(msg.buildsPerJob),
|
||||||
datasets: [{
|
datasets: [{
|
||||||
fillColor: "lightsteelblue",
|
label: 'Most runs per job in last 24hrs',
|
||||||
data: Object.keys(msg.buildsPerJob).map(function(e) {
|
backgroundColor: "lightsteelblue",
|
||||||
return msg.buildsPerJob[e];
|
data: Object.keys(msg.buildsPerJob).map((e)=>{ return msg.buildsPerJob[e]; })
|
||||||
})
|
|
||||||
}]
|
}]
|
||||||
}, {});
|
}
|
||||||
chtTimePerJob = new Chart(document.getElementById("chartTpj").getContext("2d")).HorizontalBar({
|
});
|
||||||
|
chtTimePerJob = new Chart(document.getElementById("chartTpj"), {
|
||||||
|
type: 'horizontalBar',
|
||||||
|
data: {
|
||||||
labels: Object.keys(msg.timePerJob),
|
labels: Object.keys(msg.timePerJob),
|
||||||
datasets: [{
|
datasets: [{
|
||||||
fillColor: "lightsteelblue",
|
label: 'Longest average runtime this week',
|
||||||
data: Object.keys(msg.timePerJob).map(function(e) {
|
backgroundColor: "lightsteelblue",
|
||||||
return msg.timePerJob[e];
|
data: Object.keys(msg.timePerJob).map((e)=>{ return msg.timePerJob[e]; })
|
||||||
})
|
|
||||||
}]
|
}]
|
||||||
}, {});
|
}
|
||||||
|
});
|
||||||
|
|
||||||
},
|
},
|
||||||
job_queued: function(data) {
|
job_queued: function(data) {
|
||||||
state.jobsQueued.splice(0, 0, data);
|
state.jobsQueued.splice(0, 0, data);
|
||||||
@ -272,9 +266,9 @@ const Home = function() {
|
|||||||
},
|
},
|
||||||
job_completed: function(data) {
|
job_completed: function(data) {
|
||||||
if (data.result === "success")
|
if (data.result === "success")
|
||||||
chtBuildsPerDay.datasets[0].points[6].value++;
|
chtBuildsPerDay.data.datasets[0].data[6]++;
|
||||||
else
|
else
|
||||||
chtBuildsPerDay.datasets[1].points[6].value++;
|
chtBuildsPerDay.data.datasets[1].data[6]++;
|
||||||
chtBuildsPerDay.update();
|
chtBuildsPerDay.update();
|
||||||
|
|
||||||
for (var i = 0; i < state.jobsRunning.length; ++i) {
|
for (var i = 0; i < state.jobsRunning.length; ++i) {
|
||||||
@ -287,9 +281,9 @@ const Home = function() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
updateUtilization(false);
|
updateUtilization(false);
|
||||||
for (var j = 0; j < chtBuildsPerJob.datasets[0].bars.length; ++j) {
|
for (var j = 0; j < chtBuildsPerJob.data.datasets[0].data.length; ++j) {
|
||||||
if (chtBuildsPerJob.datasets[0].bars[j].label == job.name) {
|
if (chtBuildsPerJob.data.labels[j] == job.name) {
|
||||||
chtBuildsPerJob.datasets[0].bars[j].value++;
|
chtBuildsPerJob.data.datasets[0].data[j]++;
|
||||||
chtBuildsPerJob.update();
|
chtBuildsPerJob.update();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -426,27 +420,27 @@ var Job = function() {
|
|||||||
state.pages = msg.pages;
|
state.pages = msg.pages;
|
||||||
state.page = msg.page;
|
state.page = msg.page;
|
||||||
|
|
||||||
var chtBt = new Chart(document.getElementById("chartBt").getContext("2d")).Bar({
|
var chtBt = new Chart(document.getElementById("chartBt"), {
|
||||||
|
type: 'bar',
|
||||||
|
data: {
|
||||||
labels: msg.recent.map(function(e) {
|
labels: msg.recent.map(function(e) {
|
||||||
return '#' + e.number;
|
return '#' + e.number;
|
||||||
}).reverse(),
|
}).reverse(),
|
||||||
datasets: [{
|
datasets: [{
|
||||||
fillColor: "darkseagreen",
|
label: 'Build time',
|
||||||
strokeColor: "forestgreen",
|
backgroundColor: (new Array(msg.recent.length)).fill('darkseagreen'),
|
||||||
|
borderColor: (new Array(msg.recent.length)).fill('forestgreen'),
|
||||||
data: msg.recent.map(function(e) {
|
data: msg.recent.map(function(e) {
|
||||||
return e.completed - e.started;
|
return e.completed - e.started;
|
||||||
}).reverse()
|
}).reverse()
|
||||||
}]
|
}]
|
||||||
}, {
|
}
|
||||||
barValueSpacing: 1,
|
|
||||||
barStrokeWidth: 1,
|
|
||||||
barDatasetSpacing: 0
|
|
||||||
});
|
});
|
||||||
|
|
||||||
for (var i = 0, n = msg.recent.length; i < n; ++i) {
|
for (var i = 0, n = msg.recent.length; i < n; ++i) {
|
||||||
if (msg.recent[i].result != "success") {
|
if (msg.recent[i].result != "success") {
|
||||||
chtBt.datasets[0].bars[n - i - 1].fillColor = "darksalmon";
|
chtBt.data.datasets[0].backgroundColor[n - i - 1] = "darksalmon";
|
||||||
chtBt.datasets[0].bars[n - i - 1].strokeColor = "crimson";
|
chtBt.data.datasets[0].borderColor[n - i - 1] = "crimson";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
chtBt.update();
|
chtBt.update();
|
||||||
|
Loading…
Reference in New Issue
Block a user