2018-01-23 17:01:58 +03:00
|
|
|
# coding=utf-8
|
|
|
|
from __future__ import absolute_import
|
2018-01-23 21:30:55 +03:00
|
|
|
import datetime
|
2018-01-23 17:01:58 +03:00
|
|
|
import logging
|
|
|
|
import octoprint.plugin
|
|
|
|
import octoprint.plugin.core
|
|
|
|
|
|
|
|
class KlipperPlugin(
|
|
|
|
octoprint.plugin.StartupPlugin,
|
|
|
|
octoprint.plugin.TemplatePlugin,
|
|
|
|
octoprint.plugin.SettingsPlugin,
|
2018-01-24 19:15:48 +03:00
|
|
|
octoprint.plugin.AssetPlugin,
|
|
|
|
octoprint.plugin.WizardPlugin):
|
2018-01-23 17:01:58 +03:00
|
|
|
|
|
|
|
def on_after_startup(self):
|
2018-01-23 21:14:28 +03:00
|
|
|
pass
|
|
|
|
#self._logger.info("startup hook ---------- {value} ----------".format(value=self._settings.get(["replace_connection_panel"])) )
|
|
|
|
#self._settings.set(["appearance"]["components"]["order"]["sidebar"]["test"])
|
|
|
|
|
2018-01-23 17:01:58 +03:00
|
|
|
def get_settings_defaults(self):
|
|
|
|
return dict(
|
|
|
|
serialport="/tmp/printer",
|
|
|
|
replace_connection_panel=True,
|
2018-01-23 21:14:28 +03:00
|
|
|
macros=[{'name':"Echo", 'macro':"ECHO"}],
|
2018-01-23 23:31:43 +03:00
|
|
|
probeHeight=0,
|
2018-01-24 19:15:48 +03:00
|
|
|
probeLift=5,
|
2018-01-24 22:54:13 +03:00
|
|
|
probeSpeedXy=1500,
|
2018-01-24 21:05:28 +03:00
|
|
|
probeSpeedZ=500,
|
2018-01-23 23:31:43 +03:00
|
|
|
probePoints=[{'x':0, 'y':0}])
|
2018-01-23 17:01:58 +03:00
|
|
|
|
|
|
|
def get_template_configs(self):
|
|
|
|
return [
|
2018-01-23 21:45:55 +03:00
|
|
|
dict(type="navbar", custom_bindings=True),
|
2018-01-23 17:01:58 +03:00
|
|
|
dict(type="settings", custom_bindings=True),
|
2018-01-24 19:15:48 +03:00
|
|
|
dict(type="generic", name="Assisted Bed Leveling", template="klipper_leveling_dialog.jinja2", custom_bindings=True),
|
|
|
|
dict(type="generic", name="PID Tuning", template="klipper_pid_tuning_dialog.jinja2", custom_bindings=True),
|
|
|
|
dict(type="tab", name="Klipper", template="klipper_tab_main.jinja2", suffix="_main", custom_bindings=True),
|
2018-01-23 17:01:58 +03:00
|
|
|
dict(type="sidebar",
|
|
|
|
custom_bindings=True,
|
|
|
|
replaces= "connection" if self._settings.get(["replace_connection_panel"]) else "")
|
|
|
|
]
|
|
|
|
|
|
|
|
def get_assets(self):
|
|
|
|
return dict(
|
2018-01-24 19:15:48 +03:00
|
|
|
js=["js/klipper.js",
|
|
|
|
"js/klipper_settings.js",
|
|
|
|
"js/klipper_leveling.js",
|
|
|
|
"js/klipper_pid_tuning.js"],
|
2018-01-23 17:01:58 +03:00
|
|
|
css=["css/klipper.css"],
|
|
|
|
less=["css/klipper.less"]
|
|
|
|
)
|
2018-01-23 20:33:22 +03:00
|
|
|
|
|
|
|
parsingReturn = False
|
|
|
|
message = ""
|
|
|
|
|
|
|
|
def logInfo(self, message):
|
2018-01-23 21:30:55 +03:00
|
|
|
self._plugin_manager.send_plugin_message(
|
|
|
|
self._identifier,
|
|
|
|
dict(
|
|
|
|
time=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
|
|
|
|
type="info", message=message)
|
|
|
|
)
|
2018-01-23 20:33:22 +03:00
|
|
|
|
|
|
|
def logError(self, error):
|
2018-01-23 21:30:55 +03:00
|
|
|
self._plugin_manager.send_plugin_message(
|
|
|
|
self._identifier,
|
|
|
|
dict(
|
|
|
|
time=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
|
|
|
|
type="error",
|
|
|
|
message=error)
|
|
|
|
)
|
2018-01-23 20:33:22 +03:00
|
|
|
|
2018-01-23 17:01:58 +03:00
|
|
|
def on_parse_gcode(self, comm, line, *args, **kwargs):
|
2018-01-23 21:14:28 +03:00
|
|
|
if "//" in line:
|
|
|
|
self.parsingReturn = True
|
|
|
|
self.message = self.message + line.strip('/')
|
2018-01-23 20:33:22 +03:00
|
|
|
else:
|
2018-01-23 21:14:28 +03:00
|
|
|
if self.parsingReturn:
|
2018-01-23 20:33:22 +03:00
|
|
|
self.parsingReturn = False
|
|
|
|
self.logInfo(self.message)
|
|
|
|
self.message = ""
|
2018-01-23 21:14:28 +03:00
|
|
|
if "!!" in line:
|
|
|
|
self.logError(line.strip('!'))
|
2018-01-23 17:01:58 +03:00
|
|
|
return line
|
|
|
|
|
|
|
|
def on_printer_action(self, comm, line, action, *args, **kwargs):
|
|
|
|
#if not action == "custom":
|
|
|
|
# return
|
2018-01-23 20:33:22 +03:00
|
|
|
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)
|
2018-01-24 19:15:48 +03:00
|
|
|
|
|
|
|
def is_wizard_required(self):
|
|
|
|
return True;
|
2018-01-23 17:01:58 +03:00
|
|
|
|
|
|
|
__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()
|
|
|
|
|