2018-08-13 19:22:58 +03:00
|
|
|
$(function() {
|
|
|
|
|
|
|
|
function KlipperGraphViewModel(parameters) {
|
|
|
|
var self = this;
|
2018-08-18 10:19:26 +03:00
|
|
|
|
|
|
|
self.header = OctoPrint.getRequestHeaders({
|
2018-08-13 19:22:58 +03:00
|
|
|
"content-type": "application/json",
|
|
|
|
"cache-control": "no-cache"
|
2018-08-18 10:19:26 +03:00
|
|
|
});
|
|
|
|
self.apiUrl = OctoPrint.getSimpleApiUrl("klipper");
|
2018-08-13 19:22:58 +03:00
|
|
|
|
|
|
|
self.availableLogFiles = ko.observableArray();
|
|
|
|
self.logFile = ko.observable();
|
|
|
|
self.status = ko.observable();
|
|
|
|
self.datasets = ko.observableArray();
|
2018-08-14 19:30:56 +03:00
|
|
|
self.datasetFill = ko.observable(false);
|
2018-08-13 19:22:58 +03:00
|
|
|
self.canvas;
|
|
|
|
self.canvasContext;
|
|
|
|
self.chart;
|
2018-08-14 19:30:56 +03:00
|
|
|
self.spinnerDialog;
|
2018-08-13 19:22:58 +03:00
|
|
|
|
|
|
|
self.onStartup = function() {
|
|
|
|
self.canvas = $("#klipper_graph_canvas")[0]
|
|
|
|
self.canvasContext = self.canvas.getContext("2d");
|
2018-08-14 19:30:56 +03:00
|
|
|
self.spinnerDialog = $("#klipper_graph_spinner");
|
2018-08-13 19:22:58 +03:00
|
|
|
|
|
|
|
Chart.defaults.global.elements.line.borderWidth=1;
|
|
|
|
Chart.defaults.global.elements.line.fill= false;
|
|
|
|
Chart.defaults.global.elements.point.radius= 0;
|
|
|
|
|
|
|
|
var myChart = new Chart(self.canvas, {
|
|
|
|
type: "line"
|
|
|
|
});
|
|
|
|
self.listLogFiles();
|
|
|
|
}
|
|
|
|
|
|
|
|
self.listLogFiles = function() {
|
|
|
|
var settings = {
|
2018-08-18 10:19:26 +03:00
|
|
|
"crossDomain": true,
|
2018-08-13 19:22:58 +03:00
|
|
|
"url": self.apiUrl,
|
|
|
|
"method": "POST",
|
|
|
|
"headers": self.header,
|
|
|
|
"processData": false,
|
|
|
|
"dataType": "json",
|
|
|
|
"data": JSON.stringify({command: "listLogFiles"})
|
|
|
|
}
|
|
|
|
|
|
|
|
$.ajax(settings).done(function (response) {
|
|
|
|
self.availableLogFiles.removeAll();
|
|
|
|
self.availableLogFiles(response["data"]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
self.saveGraphToPng = function() {
|
|
|
|
button = $('#download-btn');
|
|
|
|
var dataURL = self.canvas.toDataURL("image/png");//.replace("image/png", "image/octet-stream");
|
|
|
|
button.attr("href", dataURL);
|
|
|
|
}
|
|
|
|
|
2018-08-14 19:30:56 +03:00
|
|
|
self.showSpinner = function(showDialog) {
|
|
|
|
if (showDialog) {
|
|
|
|
self.spinnerDialog.modal({
|
|
|
|
show: true,
|
|
|
|
keyboard: false,
|
|
|
|
backdrop: "static"
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
self.spinnerDialog.modal("hide");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-13 19:22:58 +03:00
|
|
|
self.toggleDatasetFill = function() {
|
|
|
|
if(self.datasets) {
|
|
|
|
for (i=0; i < self.datasets().length; i++) {
|
|
|
|
self.datasets()[i].fill = self.datasetFill();
|
|
|
|
}
|
|
|
|
self.chart.update();
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
self.convertTime = function(val) {
|
|
|
|
return moment(val, "X");
|
|
|
|
}
|
|
|
|
|
|
|
|
self.loadData = function() {
|
|
|
|
var settings = {
|
|
|
|
"crossDomain": true,
|
|
|
|
"url": self.apiUrl,
|
|
|
|
"method": "POST",
|
|
|
|
"headers": self.header,
|
|
|
|
"processData": false,
|
|
|
|
"dataType": "json",
|
|
|
|
"data": JSON.stringify(
|
|
|
|
{
|
|
|
|
command: "getStats",
|
|
|
|
logFile: self.logFile()
|
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|
2018-08-14 19:30:56 +03:00
|
|
|
|
|
|
|
self.showSpinner(true);
|
|
|
|
|
2018-08-13 19:22:58 +03:00
|
|
|
$.ajax(settings).done(function (response) {
|
|
|
|
self.status("")
|
|
|
|
self.datasetFill(false);
|
2018-08-14 19:30:56 +03:00
|
|
|
|
|
|
|
self.showSpinner(false);
|
|
|
|
|
2018-08-13 19:22:58 +03:00
|
|
|
if("error" in response) {
|
|
|
|
self.status(response.error);
|
|
|
|
} else {
|
|
|
|
self.datasets.removeAll();
|
|
|
|
self.datasets.push(
|
|
|
|
{
|
|
|
|
label: "MCU Load",
|
|
|
|
backgroundColor: "rgba(199, 44, 59, 0.5)",
|
|
|
|
borderColor: "rgb(199, 44, 59)",
|
2018-08-18 10:19:26 +03:00
|
|
|
yAxisID: 'y-axis-1',
|
2018-08-13 19:22:58 +03:00
|
|
|
data: response.loads
|
|
|
|
});
|
|
|
|
|
|
|
|
self.datasets.push(
|
|
|
|
{
|
|
|
|
label: "Bandwith",
|
|
|
|
backgroundColor: "rgba(255, 130, 1, 0.5)",
|
|
|
|
borderColor: "rgb(255, 130, 1)",
|
2018-08-18 10:19:26 +03:00
|
|
|
yAxisID: 'y-axis-1',
|
2018-08-13 19:22:58 +03:00
|
|
|
data: response.bwdeltas
|
|
|
|
});
|
|
|
|
|
|
|
|
self.datasets.push(
|
|
|
|
{
|
|
|
|
label: "Host Buffer",
|
|
|
|
backgroundColor: "rgba(0, 145, 106, 0.5)",
|
|
|
|
borderColor: "rgb(0, 145, 106)",
|
2018-08-18 10:19:26 +03:00
|
|
|
yAxisID: 'y-axis-1',
|
2018-08-13 19:22:58 +03:00
|
|
|
data: response.buffers
|
|
|
|
});
|
|
|
|
|
|
|
|
self.datasets.push(
|
|
|
|
{
|
|
|
|
label: "Awake Time",
|
|
|
|
backgroundColor: "rgba(33, 64, 95, 0.5)",
|
|
|
|
borderColor: "rgb(33, 64, 95)",
|
2018-08-18 10:19:26 +03:00
|
|
|
yAxisID: 'y-axis-1',
|
2018-08-13 19:22:58 +03:00
|
|
|
data: response.awake
|
|
|
|
});
|
2018-08-18 10:19:26 +03:00
|
|
|
|
|
|
|
// self.datasets.push(
|
|
|
|
// {
|
|
|
|
// label: "Frequency",
|
|
|
|
// backgroundColor: "rgba(33, 64, 95, 0.5)",
|
|
|
|
// borderColor: "rgb(33, 64, 95)",
|
|
|
|
// yAxisID: 'y-axis-2',
|
|
|
|
// data: response.frequency
|
|
|
|
// });
|
|
|
|
|
2018-08-13 19:22:58 +03:00
|
|
|
self.chart = new Chart(self.canvas, {
|
|
|
|
type: "line",
|
|
|
|
data: {
|
|
|
|
labels: response.times,
|
|
|
|
datasets: self.datasets()
|
|
|
|
},
|
|
|
|
options: {
|
|
|
|
elements:{
|
|
|
|
line: {
|
|
|
|
tension: 0
|
|
|
|
}
|
|
|
|
},
|
|
|
|
scales: {
|
|
|
|
xAxes: [{
|
|
|
|
type: 'time',
|
|
|
|
time: {
|
|
|
|
parser: self.convertTime,
|
|
|
|
tooltipFormat: "HH:mm",
|
|
|
|
displayFormats: {
|
|
|
|
minute: "HH:mm",
|
|
|
|
second: "HH:mm",
|
|
|
|
millisecond: "HH:mm"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
scaleLabel: {
|
|
|
|
display: true,
|
|
|
|
labelString: 'Time'
|
|
|
|
}
|
|
|
|
}],
|
|
|
|
yAxes: [{
|
|
|
|
scaleLabel: {
|
|
|
|
display: true,
|
|
|
|
labelString: '%'
|
2018-08-18 10:19:26 +03:00
|
|
|
},
|
|
|
|
position: 'left',
|
|
|
|
id: 'y-axis-1'
|
|
|
|
}
|
|
|
|
// {
|
|
|
|
// scaleLabel: {
|
|
|
|
// display: true,
|
|
|
|
// labelString: 'MHz'
|
|
|
|
// },
|
|
|
|
// position: 'right',
|
|
|
|
// id: 'y-axis-2'
|
|
|
|
// }
|
|
|
|
]
|
2018-08-13 19:22:58 +03:00
|
|
|
},
|
|
|
|
legend: {
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OCTOPRINT_VIEWMODELS.push({
|
|
|
|
construct: KlipperGraphViewModel,
|
|
|
|
dependencies: [],
|
|
|
|
elements: ["#klipper_graph_dialog"]
|
|
|
|
});
|
|
|
|
});
|