fix(editor):ask reload of file after SAVE_CONFIG
This commit is contained in:
parent
c635bc23f2
commit
c8a2486b7c
|
@ -378,6 +378,10 @@ class KlipperPlugin(
|
||||||
return None
|
return None
|
||||||
|
|
||||||
# -- GCODE Hook
|
# -- GCODE Hook
|
||||||
|
def process_sent_GCODE(self, comm_instance, phase, cmd, cmd_type, gcode, *args, **kwargs):
|
||||||
|
if cmd == "SAVE_CONFIG":
|
||||||
|
logger.log_info(self, "SAVE_CONFIG detected")
|
||||||
|
util.send_message(self, type = "reload", subtype = "config")
|
||||||
|
|
||||||
def on_parse_gcode(self, comm, line, *args, **kwargs):
|
def on_parse_gcode(self, comm, line, *args, **kwargs):
|
||||||
|
|
||||||
|
@ -642,6 +646,7 @@ def __plugin_load__():
|
||||||
"octoprint.server.http.routes": __plugin_implementation__.route_hook,
|
"octoprint.server.http.routes": __plugin_implementation__.route_hook,
|
||||||
"octoprint.access.permissions": __plugin_implementation__.get_additional_permissions,
|
"octoprint.access.permissions": __plugin_implementation__.get_additional_permissions,
|
||||||
"octoprint.comm.protocol.atcommand.sending": __plugin_implementation__.processAtCommand,
|
"octoprint.comm.protocol.atcommand.sending": __plugin_implementation__.processAtCommand,
|
||||||
|
"octoprint.comm.protocol.gcode.sent": __plugin_implementation__.process_sent_GCODE,
|
||||||
"octoprint.comm.protocol.gcode.received": __plugin_implementation__.on_parse_gcode,
|
"octoprint.comm.protocol.gcode.received": __plugin_implementation__.on_parse_gcode,
|
||||||
"octoprint.plugin.softwareupdate.check_config": __plugin_implementation__.get_update_information
|
"octoprint.plugin.softwareupdate.check_config": __plugin_implementation__.get_update_information
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,7 @@ $(function () {
|
||||||
self.CfgFilename = ko.observable("");
|
self.CfgFilename = ko.observable("");
|
||||||
self.CfgContent = ko.observable("");
|
self.CfgContent = ko.observable("");
|
||||||
self.loadedConfig = "";
|
self.loadedConfig = "";
|
||||||
|
self.CfgChangedExtern = false;
|
||||||
|
|
||||||
self.header = OctoPrint.getRequestHeaders({
|
self.header = OctoPrint.getRequestHeaders({
|
||||||
"content-type": "application/json",
|
"content-type": "application/json",
|
||||||
|
@ -39,6 +40,12 @@ $(function () {
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
self.onShown = function () {
|
||||||
|
self.checkExternChange();
|
||||||
|
editor.focus();
|
||||||
|
self.setEditorDivSize();
|
||||||
|
}
|
||||||
|
|
||||||
self.close_selection = function (index) {
|
self.close_selection = function (index) {
|
||||||
switch (index) {
|
switch (index) {
|
||||||
case 0:
|
case 0:
|
||||||
|
@ -101,6 +108,7 @@ $(function () {
|
||||||
|
|
||||||
if (editor) {
|
if (editor) {
|
||||||
editor.session.setValue(self.CfgContent());
|
editor.session.setValue(self.CfgContent());
|
||||||
|
self.CfgChangedExtern = false;
|
||||||
editor.setFontSize(self.settings.settings.plugins.klipper.configuration.fontsize());
|
editor.setFontSize(self.settings.settings.plugins.klipper.configuration.fontsize());
|
||||||
self.settings.settings.plugins.klipper.configuration.old_config(config.content);
|
self.settings.settings.plugins.klipper.configuration.old_config(config.content);
|
||||||
editor.clearSelection();
|
editor.clearSelection();
|
||||||
|
@ -114,6 +122,43 @@ $(function () {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
self.onDataUpdaterPluginMessage = function (plugin, data) {
|
||||||
|
if (plugin == "klipper" && data.type == "reload" && data.subtype == "config") {
|
||||||
|
self.klipperViewModel.consoleMessage("debug", "onDataUpdaterPluginMessage klipper reload baseconfig");
|
||||||
|
self.ConfigChangedAfterSave();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
self.ConfigChangedAfterSave = function () {
|
||||||
|
if (!self.klipperViewModel.hasRight("CONFIG")) return;
|
||||||
|
|
||||||
|
if (self.CfgFilename() == self.settings.settings.plugins.klipper.configuration.baseconfig()) {
|
||||||
|
self.CfgChangedExtern = true;
|
||||||
|
self.checkExternChange();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
self.checkExternChange = function() {
|
||||||
|
var baseconfig = self.settings.settings.plugins.klipper.configuration.baseconfig();
|
||||||
|
if (self.CfgChangedExtern && self.CfgFilename() == baseconfig) {
|
||||||
|
if (editordialog.is(":visible")) {
|
||||||
|
|
||||||
|
var perform = function () {
|
||||||
|
self.reloadFromFile();
|
||||||
|
}
|
||||||
|
|
||||||
|
var html = "<p>" + gettext("Reload Configfile after SAVE_CONFIG?") + "</p>";
|
||||||
|
|
||||||
|
showConfirmationDialog({
|
||||||
|
title: gettext("Externally changed config") + " " + baseconfig,
|
||||||
|
html: html,
|
||||||
|
proceed: gettext("Proceed"),
|
||||||
|
onproceed: perform,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
self.checkSyntax = function () {
|
self.checkSyntax = function () {
|
||||||
if (editor.session) {
|
if (editor.session) {
|
||||||
self.klipperViewModel.consoleMessage("debug", "checkSyntax started");
|
self.klipperViewModel.consoleMessage("debug", "checkSyntax started");
|
||||||
|
@ -214,8 +259,10 @@ $(function () {
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
self.klipperViewModel.showPopUp("success", gettext("Reload Config"), gettext("File reloaded."));
|
self.klipperViewModel.showPopUp("success", gettext("Reload Config"), gettext("File reloaded."));
|
||||||
|
self.CfgChangedExtern = false;
|
||||||
if (editor) {
|
if (editor) {
|
||||||
editor.session.setValue(response.response.config);
|
editor.session.setValue(response.response.config);
|
||||||
|
self.loadedConfig = response.response.config;
|
||||||
editor.clearSelection();
|
editor.clearSelection();
|
||||||
editor.focus();
|
editor.focus();
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,10 @@ $(function () {
|
||||||
|
|
||||||
self.markedForFileRemove = ko.observableArray([]);
|
self.markedForFileRemove = ko.observableArray([]);
|
||||||
|
|
||||||
|
$(document).on('shown.bs.modal','#klipper_editor', function () {
|
||||||
|
self.klipperEditorViewModel.onShown();
|
||||||
|
});
|
||||||
|
|
||||||
self.checkFontsize = function () {
|
self.checkFontsize = function () {
|
||||||
if (self.settings.settings.plugins.klipper.configuration.fontsize() > 20) {
|
if (self.settings.settings.plugins.klipper.configuration.fontsize() > 20) {
|
||||||
self.settings.settings.plugins.klipper.configuration.fontsize(20)
|
self.settings.settings.plugins.klipper.configuration.fontsize(20)
|
||||||
|
@ -312,21 +316,8 @@ $(function () {
|
||||||
if (plugin == "klipper" && data.type == "reload" && data.subtype == "configlist") {
|
if (plugin == "klipper" && data.type == "reload" && data.subtype == "configlist") {
|
||||||
self.klipperViewModel.consoleMessage("debug", "onDataUpdaterPluginMessage klipper reload configlist");
|
self.klipperViewModel.consoleMessage("debug", "onDataUpdaterPluginMessage klipper reload configlist");
|
||||||
self.listCfgFiles();
|
self.listCfgFiles();
|
||||||
} else if (plugin == "klipper" && data.type == "start" && data.subtype == "config") {
|
|
||||||
self.klipperViewModel.consoleMessage("debug", "onDataUpdaterPluginMessage klipper start config");
|
|
||||||
self.startConfig(data.title, data.payload);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
self.startConfig = function (file, content) {
|
|
||||||
if (!self.klipperViewModel.hasRight("CONFIG")) return;
|
|
||||||
filename = file || "";
|
|
||||||
var config = {
|
|
||||||
content: content,
|
|
||||||
file: filename,
|
|
||||||
};
|
|
||||||
self.klipperEditorViewModel.process(config).then();
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
OCTOPRINT_VIEWMODELS.push({
|
OCTOPRINT_VIEWMODELS.push({
|
||||||
|
|
Loading…
Reference in New Issue