2017-08-28 23:10:51 +02:00
|
|
|
/*
|
|
|
|
* Author: ntoff
|
|
|
|
* License: AGPLv3
|
|
|
|
*/
|
|
|
|
$(function() {
|
|
|
|
|
2017-08-30 14:39:57 +02:00
|
|
|
function FanSliderPluginViewModel(parameters) {
|
2017-08-28 23:10:51 +02:00
|
|
|
var self = this;
|
|
|
|
|
2017-09-05 14:57:53 +02:00
|
|
|
self.settings = parameters[0];
|
|
|
|
self.control = parameters[1];
|
|
|
|
self.loginState = parameters[2];
|
2017-08-30 14:39:57 +02:00
|
|
|
|
2017-09-04 19:52:55 +02:00
|
|
|
fanSpeed = ko.observable(undefined);
|
|
|
|
|
2017-08-30 10:28:26 +02:00
|
|
|
//convert percentage into PWM
|
2017-09-05 14:57:53 +02:00
|
|
|
self.fanPWM = ko.pureComputed(function () {
|
2017-09-05 01:37:05 +02:00
|
|
|
self.speed = fanSpeed() * 255 / 100 //don't forget to limit this to 2 decimal places at some point.
|
2017-09-04 19:52:55 +02:00
|
|
|
return self.speed;
|
2017-08-28 23:10:51 +02:00
|
|
|
});
|
2017-08-30 14:39:57 +02:00
|
|
|
//send gcode to set fan speed
|
2017-08-28 23:10:51 +02:00
|
|
|
sendFanSpeed = function () {
|
2017-09-05 14:57:53 +02:00
|
|
|
self.control.sendCustomCommand({ command: "M106 S" + self.fanPWM() });
|
2017-11-06 08:23:25 +01:00
|
|
|
};
|
|
|
|
try {
|
|
|
|
//extra classes
|
|
|
|
$("#control > div.jog-panel").eq(0).addClass("controls");
|
|
|
|
$("#control > div.jog-panel").eq(1).addClass("tools");
|
|
|
|
$("#control > div.jog-panel").eq(2).addClass("general");
|
|
|
|
//If !TouchUI then remove standard buttons + add slider + new buttons
|
|
|
|
if ($("#touch body").length ==0 ) {
|
|
|
|
//add ID to buttons
|
|
|
|
$("#control > div.general").find("button").eq(0).attr("id", "motors-off");
|
|
|
|
$("#control > div.general").find("button").eq(1).attr("id", "fan-on");
|
|
|
|
$("#control > div.general").find("button").eq(2).attr("id", "fan-off");
|
|
|
|
//remove original fan on/off buttons
|
|
|
|
$("#fan-on").remove();
|
|
|
|
$("#fan-off").remove();
|
|
|
|
//add new fan controls
|
|
|
|
$("#control > div.jog-panel.general").find("button").eq(0).before("\
|
|
|
|
<input type=\"number\" style=\"width: 90px\" data-bind=\"slider: {min: 00, max: 100, step: 1, value: fanSpeed, tooltip: 'hide'}\">\
|
|
|
|
<button class=\"btn btn-block control-box\" data-bind=\"enable: isOperational() && loginState.isUser(), click: function() { sendFanSpeed() }\">" + gettext("Fan on") + ":<span data-bind=\"text: fanSpeed() + '%'\"></span></button>\
|
|
|
|
<button class=\"btn btn-block control-box\" data-bind=\"enable: isOperational() && loginState.isUser(), click: function() { $root.sendCustomCommand({ type: 'command', commands: ['M106 S0'] }) }\">" + gettext("Fan off") + "</button>\
|
|
|
|
");
|
|
|
|
} else { //if TouchUI is active we only add the speed input + fan on button in a new section.
|
|
|
|
console.log("Fan Speed Slider: NOTICE! TouchUI is active, adding simplified control.");
|
|
|
|
$("#control > div.jog-panel.general").after("\
|
|
|
|
<div id=\"control-fan-slider\" class=\"jog-panel filament\" data-bind=\"visible: loginState.isUser\">\
|
|
|
|
<div>\
|
|
|
|
<input type=\"number\" style=\"width: 150px\" data-bind=\"slider: {min: 00, max: 255, step: 1, value: fanSpeed, tooltip: 'hide'}\">\
|
|
|
|
<button class=\"btn btn-block control-box\" data-bind=\"enable: isOperational() && loginState.isUser(), click: function() { sendFanSpeed() }\">" + gettext("Fan Speed(%)") + "</button>\
|
|
|
|
</div>\
|
2017-08-30 10:28:26 +02:00
|
|
|
</div>\
|
2017-11-06 08:23:25 +01:00
|
|
|
");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch(error) {
|
|
|
|
console.log(error);
|
2017-08-30 10:28:26 +02:00
|
|
|
}
|
2017-08-30 14:39:57 +02:00
|
|
|
//retrieve settings
|
|
|
|
self.onBeforeBinding = function() {
|
2017-09-06 09:52:23 +02:00
|
|
|
fanSpeed(self.settings.settings.plugins.fanspeedslider.defaultFanSpeed());
|
2017-08-30 14:39:57 +02:00
|
|
|
}
|
2017-08-28 23:10:51 +02:00
|
|
|
}
|
2017-11-11 12:41:07 +01:00
|
|
|
|
|
|
|
OCTOPRINT_VIEWMODELS.push({
|
|
|
|
construct: FanSliderPluginViewModel,
|
|
|
|
additionalNames: [],
|
|
|
|
dependencies: ["settingsViewModel", "controlViewModel", "loginStateViewModel"],
|
|
|
|
optional: [],
|
|
|
|
elements: []
|
|
|
|
});
|
|
|
|
});
|