# coding=utf-8 from __future__ import absolute_import import logging import octoprint.plugin import octoprint.plugin.core class KlipperPlugin( octoprint.plugin.StartupPlugin, octoprint.plugin.TemplatePlugin, octoprint.plugin.SettingsPlugin, octoprint.plugin.AssetPlugin): def on_after_startup(self): #self._settings.set(["appearance"]["components"]["order"]["sidebar"]["test"]); self._logger.info("startup hook ---------- {value} ----------".format(value=self._settings.get(["replace_connection_panel"])) ) def get_settings_defaults(self): return dict( serialport="/tmp/printer", replace_connection_panel=True, macros=[], probePoints=[]) def get_template_configs(self): return [ dict(type="navbar", custom_bindings=False), dict(type="settings", custom_bindings=True), dict(type="sidebar", custom_bindings=True, replaces= "connection" if self._settings.get(["replace_connection_panel"]) else "") ] def get_assets(self): return dict( js=["js/klipper.js"], css=["css/klipper.css"], less=["css/klipper.less"] ) parsingReturn = False message = "" def logInfo(self, message): self._plugin_manager.send_plugin_message(self._identifier, dict(type="info", message=message)) def logError(self, error): self._plugin_manager.send_plugin_message(self._identifier, dict(type="error", message=error)) def on_parse_gcode(self, comm, line, *args, **kwargs): if "!!" in line: self.logError(line.strip('!')) else: if "//" in line: self.parsingReturn = True self.message = self.message + line.strip('/') else: if self.parsingReturn: self.parsingReturn = False self.logInfo(self.message) self.message = "" return line def on_printer_action(self, comm, line, action, *args, **kwargs): #if not action == "custom": # return self._plugin_manager.send_plugin_message(self._identifier, dict(message=line)) self._plugin_manager.send_plugin_message(self._identifier, dict(message=action)) #self._logger.info("action recieved:".action) __plugin_name__ = "Klipper" def __plugin_load__(): global __plugin_implementation__ global __plugin_hooks__ __plugin_implementation__ = KlipperPlugin() __plugin_hooks__ = { "octoprint.comm.protocol.gcode.received": __plugin_implementation__.on_parse_gcode, "octoprint.comm.protocol.action": __plugin_implementation__.on_printer_action } #__plugin_name__ = "Klipper" #__plugin_implementation__ = KlipperPlugin()