$(function() { function KlipperViewModel(parameters) { var self = this; // injection settingsViewModel self.settings = parameters[0]; // injection loginStateViewModel self.loginState = parameters[1]; // injection connectionViewModel self.connectionState = parameters[2]; self.shortStatus = ko.observable(); self.logMessages = ko.observableArray(); self.onGetStatus = function() { self.shortStatus("Update Status") OctoPrint.control.sendGcode("Status") } self.onRestartFirmware = function() { self.logMessage("Restarted Firmware"); self.shortStatus("Restarting Firmware"); OctoPrint.control.sendGcode("FIRMWARE_RESTART") }; self.onRestartHost = function() { self.logMessage("Restarted Host"); self.shortStatus("Restarting Host"); OctoPrint.control.sendGcode("RESTART") }; self.onBeforeBinding = function() { //self.connectionState.selectedPort("VIRTUAL"); } self.onAfterBinding = function() { self.connectionState.selectedPort(self.settings.settings.plugins.klipper.serialport()); console.log(self.connectionState.selectedPort()); self.shortStatus("Idle"); } self.onDataUpdaterPluginMessage = function(plugin, message) { //console.log(message); self.logMessage(message["time"], message["type"], message["message"]); } self.logMessage = function(timestamp, type, message) { self.logMessages.push({time: timestamp, type: type, msg: message}); } self.onClearLog = function() { self.logMessages.removeAll(); }; self.isActive = function() { return self.connectionState.isOperational() && self.loginState.isUser(); } // ------------ Settings ---------------- // self.moveItemDown = function(list, item) { var i = list().indexOf(item); if (i < list().length - 1) { var rawList = list(); list.splice(i, 2, rawList[i + 1], rawList[i]); } } self.moveItemUp = function(list, item) { var i = list().indexOf(item); if (i > 0) { var rawList = list(); list.splice(i-1, 2, rawList[i], rawList[i-1]); } } self.executeMacro = function(macro) { console.log(macro.name()); OctoPrint.control.sendGcode(macro.macro()); } self.addMacro = function() { self.settings.settings.plugins.klipper.macros.push({name: 'Macro', macro: ''}); } self.removeMacro = function(macro) { self.settings.settings.plugins.klipper.macros.remove(macro); } self.moveMacroUp = function(macro) { self.moveItemUp(self.settings.settings.plugins.klipper.macros, macro) } self.moveMacroDown = function(macro) { self.moveItemDown(self.settings.settings.plugins.klipper.macros, macro) } self.addProbePoint = function() { self.settings.settings.plugins.klipper.probePoints.push({x: 0, y:0, z:0}); } self.removeProbePoint = function(point) { self.settings.settings.plugins.klipper.probePoints.remove(point); } self.moveProbePointUp = function(macro) { self.moveItemUp(self.settings.settings.plugins.klipper.probePoints, macro) } self.moveProbePointDown = function(macro) { self.moveItemDown(self.settings.settings.plugins.klipper.probePoints, macro) } } /* var KlipperMacroCollection = function(name, gcode) { this.name = name; this.macros = ko.observableArray(macros); this.addMacro = function() { this.push({name: 'macro 2', macro: 'G1 X1 Y2 Z3'}); }.bind(this); }*/ // This is how our plugin registers itself with the application, by adding some configuration // information to the global variable OCTOPRINT_VIEWMODELS OCTOPRINT_VIEWMODELS.push({ // This is the constructor to call for instantiating the plugin construct: KlipperViewModel, // dependencies to inject into the plugin. dependencies: ["settingsViewModel", "loginStateViewModel", "connectionViewModel"], // elements this view model will be bound to. elements: ["#tab_plugin_klipper", "#sidebar_plugin_klipper", "#settings_plugin_klipper", "#navbar_plugin_klipper"] }); });