diff --git a/octoprint_fanspeedslider/static/js/fanslider.js b/octoprint_fanspeedslider/static/js/fanslider.js
index 2e6b755..d6e0eff 100644
--- a/octoprint_fanspeedslider/static/js/fanslider.js
+++ b/octoprint_fanspeedslider/static/js/fanslider.js
@@ -2,7 +2,7 @@
* Author: ntoff
* License: AGPLv3
*/
-$(function() {
+$(function () {
function FanSliderPluginViewModel(parameters) {
'use strict';
@@ -19,38 +19,46 @@ $(function() {
self.control.maxFanSpeed = new ko.observable(100);
self.control.notifyDelay = new ko.observable(3000); //time in milliseconds
- self.showNotify = function(self,options) {
+ self.showNotify = function (self, options) {
options.hide = true;
options.title = "Fan Speed Control";
- options.delay = self.control.notifyDelay();
+ options.delay = self.control.notifyDelay();
options.type = "info";
if (options.delay != "0") {
new PNotify(options);
}
};
- //send gcode to set fan speed
- self.control.sendFanSpeed = ko.pureComputed(function () {
+ self.control.fanSpeedToPwm = ko.pureComputed(function () {
self.speed = self.control.fanSpeed() * 255 / 100 //don't forget to limit this to 2 decimal places at some point.
+ return self.speed;
+ });
+
+ self.control.checkSliderValue = ko.pureComputed(function () {
if (self.control.fanSpeed() < self.control.minFanSpeed() && self.control.fanSpeed() != "0") {
- console.log("Fan Speed Control Plugin: " + self.control.fanSpeed() + "% is less than the minimum speed ("+self.control.minFanSpeed()+"%), increasing.");
+ console.log("Fan Speed Control Plugin: " + self.control.fanSpeed() + "% is less than the minimum speed (" + self.control.minFanSpeed() + "%), increasing.");
self.control.fanSpeed(self.control.minFanSpeed());
var options = {
text: 'Fan speed increased to meet minimum requirement.',
}
- self.showNotify(self,options);
+ self.showNotify(self, options);
}
else if (self.control.fanSpeed() > self.control.maxFanSpeed()) {
- console.log("Fan Speed Control Plugin: " + self.control.fanSpeed() + "% is more than the maximum speed ("+self.control.maxFanSpeed()+"%), decreasing.");
- self.control.fanSpeed(self.control.maxFanSpeed());
- var options = {
- text: 'Fan speed decreased to meet maximum requirement.',
- }
- self.showNotify(self,options);
+ console.log("Fan Speed Control Plugin: " + self.control.fanSpeed() + "% is more than the maximum speed (" + self.control.maxFanSpeed() + "%), decreasing.");
+ self.control.fanSpeed(self.control.maxFanSpeed());
+ var options = {
+ text: 'Fan speed decreased to meet maximum requirement.',
+ }
+ self.showNotify(self, options);
}
- self.control.sendCustomCommand({ command: "M106 S" + self.speed });
});
+ //send gcode to set fan speed
+ self.control.sendFanSpeed = function () {
+ self.control.checkSliderValue();
+ self.control.sendCustomCommand({ command: "M106 S" + self.control.fanSpeedToPwm() });
+ };
+
//ph34r
try {
//for some reason touchui uses "jog general" for the fan controls? Oh well, makes my job easier
@@ -58,7 +66,7 @@ $(function() {
$("#control-jog-general").find("button").eq(1).attr("id", "fan-on");
$("#control-jog-general").find("button").eq(2).attr("id", "fan-off");
//If not TouchUI then remove standard buttons + add slider + new buttons
- if ($("#touch body").length ==0 ) {
+ if ($("#touch body").length == 0) {
//remove original fan on/off buttons
$("#fan-on").remove();
$("#fan-off").remove();
@@ -68,7 +76,7 @@ $(function() {
\
\
");
- } else {
+ } else {
//replace touch UI's fan on button with one that sends whatever speed is set in this plugin
$("#fan-on").remove();
$("#control-jog-general").find("button").eq(0).after("\
@@ -85,22 +93,22 @@ $(function() {
");
}
}
- catch(error) {
+ catch (error) {
console.log(error);
}
- self.updateSettings = function() {
+ self.updateSettings = function () {
try {
- self.control.minFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.minSpeed()));
- self.control.maxFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.maxSpeed()));
- self.control.notifyDelay(parseInt(self.settings.settings.plugins.fanspeedslider.notifyDelay()));
+ self.control.minFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.minSpeed()));
+ self.control.maxFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.maxSpeed()));
+ self.control.notifyDelay(parseInt(self.settings.settings.plugins.fanspeedslider.notifyDelay()));
}
- catch(error) {
+ catch (error) {
console.log(error);
}
}
- self.onBeforeBinding = function() {
+ self.onBeforeBinding = function () {
self.control.defaultFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.defaultFanSpeed()));
self.updateSettings();
//if the default fan speed is above or below max/min then set to either max or min
@@ -116,10 +124,10 @@ $(function() {
}
//update settings in case user changes them, otherwise a refresh of the UI is required
- self.onSettingsHidden = function() {
+ self.onSettingsHidden = function () {
self.updateSettings();
}
- }
+ }
OCTOPRINT_VIEWMODELS.push({
construct: FanSliderPluginViewModel,