separate stuff into their own functions

move percent to pwm function and checking the slider value is within range into their own functions
This commit is contained in:
ntoff 2017-11-12 06:33:51 +10:00
parent 9ff32751f8
commit 70d3e0803b

View File

@ -2,7 +2,7 @@
* Author: ntoff * Author: ntoff
* License: AGPLv3 * License: AGPLv3
*/ */
$(function() { $(function () {
function FanSliderPluginViewModel(parameters) { function FanSliderPluginViewModel(parameters) {
'use strict'; 'use strict';
@ -19,7 +19,7 @@ $(function() {
self.control.maxFanSpeed = new ko.observable(100); self.control.maxFanSpeed = new ko.observable(100);
self.control.notifyDelay = new ko.observable(3000); //time in milliseconds self.control.notifyDelay = new ko.observable(3000); //time in milliseconds
self.showNotify = function(self,options) { self.showNotify = function (self, options) {
options.hide = true; options.hide = true;
options.title = "Fan Speed Control"; options.title = "Fan Speed Control";
options.delay = self.control.notifyDelay(); options.delay = self.control.notifyDelay();
@ -29,28 +29,36 @@ $(function() {
} }
}; };
//send gcode to set fan speed self.control.fanSpeedToPwm = ko.pureComputed(function () {
self.control.sendFanSpeed = ko.pureComputed(function () {
self.speed = self.control.fanSpeed() * 255 / 100 //don't forget to limit this to 2 decimal places at some point. 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") { 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()); self.control.fanSpeed(self.control.minFanSpeed());
var options = { var options = {
text: 'Fan speed increased to meet minimum requirement.', text: 'Fan speed increased to meet minimum requirement.',
} }
self.showNotify(self,options); self.showNotify(self, options);
} }
else if (self.control.fanSpeed() > self.control.maxFanSpeed()) { 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."); 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()); self.control.fanSpeed(self.control.maxFanSpeed());
var options = { var options = {
text: 'Fan speed decreased to meet maximum requirement.', text: 'Fan speed decreased to meet maximum requirement.',
} }
self.showNotify(self,options); 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 //ph34r
try { try {
//for some reason touchui uses "jog general" for the fan controls? Oh well, makes my job easier //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(1).attr("id", "fan-on");
$("#control-jog-general").find("button").eq(2).attr("id", "fan-off"); $("#control-jog-general").find("button").eq(2).attr("id", "fan-off");
//If not TouchUI then remove standard buttons + add slider + new buttons //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 //remove original fan on/off buttons
$("#fan-on").remove(); $("#fan-on").remove();
$("#fan-off").remove(); $("#fan-off").remove();
@ -85,22 +93,22 @@ $(function() {
"); ");
} }
} }
catch(error) { catch (error) {
console.log(error); console.log(error);
} }
self.updateSettings = function() { self.updateSettings = function () {
try { try {
self.control.minFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.minSpeed())); self.control.minFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.minSpeed()));
self.control.maxFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.maxSpeed())); self.control.maxFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.maxSpeed()));
self.control.notifyDelay(parseInt(self.settings.settings.plugins.fanspeedslider.notifyDelay())); self.control.notifyDelay(parseInt(self.settings.settings.plugins.fanspeedslider.notifyDelay()));
} }
catch(error) { catch (error) {
console.log(error); console.log(error);
} }
} }
self.onBeforeBinding = function() { self.onBeforeBinding = function () {
self.control.defaultFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.defaultFanSpeed())); self.control.defaultFanSpeed(parseInt(self.settings.settings.plugins.fanspeedslider.defaultFanSpeed()));
self.updateSettings(); self.updateSettings();
//if the default fan speed is above or below max/min then set to either max or min //if the default fan speed is above or below max/min then set to either max or min
@ -116,7 +124,7 @@ $(function() {
} }
//update settings in case user changes them, otherwise a refresh of the UI is required //update settings in case user changes them, otherwise a refresh of the UI is required
self.onSettingsHidden = function() { self.onSettingsHidden = function () {
self.updateSettings(); self.updateSettings();
} }
} }