293 lines
9.8 KiB
JavaScript
293 lines
9.8 KiB
JavaScript
$(function() {
|
|
function mystromswitchViewModel(parameters) {
|
|
var self = this;
|
|
|
|
self.loginState = parameters[0];
|
|
self.settings = parameters[1];
|
|
self.printer = parameters[2];
|
|
|
|
|
|
self.mystromswitchEnabled = ko.observable();
|
|
|
|
self.testButtonChangeStatus = function (stat) {
|
|
$("#tester_mystromswitch_gcode").prop("disabled", stat);
|
|
$("#tester_mystromswitch_api").prop("disabled", stat);
|
|
$("#tester_mystromswitch_api_custom").prop("disabled", stat);
|
|
}
|
|
|
|
self.eventChangeCheckToRadio = function (id, listOff) {
|
|
$(id).on("change", function () {
|
|
if ($(this).prop("checked") == true)
|
|
{
|
|
listOff.forEach(function(element) {
|
|
if (id != element.id)
|
|
{
|
|
if ($(element.id).prop("checked") == true)
|
|
{
|
|
$(element.id).unbind("change");
|
|
$(element.id).trigger("click");
|
|
self.eventChangeCheckToRadio(element.id, listOff);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
})
|
|
}
|
|
|
|
$("#tester_mystromswitch_gcode").on("click", function () {
|
|
self.settings.saveData();
|
|
$(this).children("i").show();
|
|
setTimeout(function (current) {
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: JSON.stringify({
|
|
command: "shutdown",
|
|
mode: 1,
|
|
eventView : true
|
|
}),
|
|
contentType: "application/json; charset=UTF-8"
|
|
}).done(function() {
|
|
current.children("i").hide();
|
|
});
|
|
|
|
}, 1000, $(this));
|
|
|
|
});
|
|
$("#tester_mystromswitch_api").on("click", function () {
|
|
self.settings.saveData();
|
|
$(this).children("i").show();
|
|
setTimeout(function (current) {
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: JSON.stringify({
|
|
command: "shutdown",
|
|
mode: 2,
|
|
eventView : true
|
|
}),
|
|
contentType: "application/json; charset=UTF-8"
|
|
}).done(function() {
|
|
current.children("i").hide();
|
|
});
|
|
}, 1000, $(this));
|
|
|
|
});
|
|
|
|
$("#tester_mystromswitch_api_custom").on("click", function () {
|
|
self.settings.saveData();
|
|
$(this).children("i").show();
|
|
setTimeout(function (current) {
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: JSON.stringify({
|
|
command: "shutdown",
|
|
mode: 3,
|
|
eventView : true
|
|
}),
|
|
contentType: "application/json; charset=UTF-8"
|
|
}).done(function() {
|
|
current.children("i").hide();
|
|
});
|
|
}, 1000, $(this));
|
|
|
|
});
|
|
self.listOffMode = [
|
|
{"id" : "#mystromswitch_mode_shutdown_gcode"},
|
|
{"id" : "#mystromswitch_mode_shutdown_api"},
|
|
{"id" : "#mystromswitch_mode_shutdown_api_custom"},
|
|
]
|
|
self.listOffHTTPMethode = [
|
|
{"id" : "#mystromswitch_api_custom_GET"},
|
|
{"id" : "#mystromswitch_api_custom_POST"},
|
|
{"id" : "#mystromswitch_api_custom_PUT"}
|
|
]
|
|
self.eventChangeCheckToRadio("#mystromswitch_mode_shutdown_gcode", self.listOffMode);
|
|
self.eventChangeCheckToRadio("#mystromswitch_mode_shutdown_api", self.listOffMode);
|
|
self.eventChangeCheckToRadio("#mystromswitch_mode_shutdown_api_custom", self.listOffMode);
|
|
|
|
self.eventChangeCheckToRadio("#mystromswitch_api_custom_GET", self.listOffHTTPMethode);
|
|
self.eventChangeCheckToRadio("#mystromswitch_api_custom_POST", self.listOffHTTPMethode);
|
|
self.eventChangeCheckToRadio("#mystromswitch_api_custom_PUT", self.listOffHTTPMethode);
|
|
|
|
// Hack to remove automatically added Cancel button
|
|
// See https://github.com/sciactive/pnotify/issues/141
|
|
//PNotify.prototype.options.confirm.buttons = [];
|
|
//another way use, add custom style class for hide cancel button
|
|
self.timeoutPopupText = gettext('Shutting down printer in ');
|
|
self.timeoutPopupOptions = {
|
|
title: gettext('Shutdown Printer'),
|
|
type: 'notice',
|
|
icon: true,
|
|
hide: false,
|
|
confirm: {
|
|
confirm: true,
|
|
buttons: [{
|
|
text: 'Abort Shutdown Printer',
|
|
addClass: 'btn-block btn-danger',
|
|
promptTrigger: true,
|
|
click: function(notice, value){
|
|
notice.remove();
|
|
notice.get().trigger("pnotify.cancel", [notice, value]);
|
|
}
|
|
}, {
|
|
addClass: 'mystromswitchHideCancelBtnConfirm',
|
|
promptTrigger: true,
|
|
click: function(notice, value){
|
|
notice.remove();
|
|
|
|
}
|
|
}]
|
|
},
|
|
buttons: {
|
|
closer: false,
|
|
sticker: false,
|
|
},
|
|
history: {
|
|
history: false
|
|
}
|
|
};
|
|
|
|
//for touch ui
|
|
self.touchUIMoveElement = function (self, counter) {
|
|
var hash = window.location.hash;
|
|
if (hash != "" && hash != "#printer" && hash != "#touch")
|
|
{
|
|
return;
|
|
}
|
|
if (counter < 10) {
|
|
if (document.getElementById("touch") != null && document.getElementById("printer") != null && document.getElementById("printer") != null && document.getElementById("touch").querySelector("#printer").querySelector("#files_wrapper")) {
|
|
var newParent = document.getElementById("files_wrapper").parentNode;
|
|
newParent.insertBefore(document.getElementById('sidebar_plugin_mystromswitch_wrapper'), document.getElementById("files_wrapper"));
|
|
} else {
|
|
setTimeout(self.touchUIMoveElement, 1000, self, ++counter);
|
|
}
|
|
}
|
|
}
|
|
//add octoprint event for check finish
|
|
self.onStartupComplete = function () {
|
|
//self.touchUIMoveElement(self, 0);
|
|
if (self.printer.isPrinting())
|
|
{
|
|
self.testButtonChangeStatus(true);
|
|
} else {
|
|
self.testButtonChangeStatus(false);
|
|
}
|
|
|
|
|
|
};
|
|
|
|
self.onUserLoggedIn = function() {
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: JSON.stringify({
|
|
command: "update",
|
|
eventView : false
|
|
}),
|
|
contentType: "application/json; charset=UTF-8"
|
|
})
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
data: JSON.stringify({
|
|
command: "status"
|
|
}),
|
|
context:self,
|
|
contentType: "application/json; charset=UTF-8"
|
|
}).done(function(data, textStatus, jqXHR ){
|
|
this.mystromswitchEnabled(data == "True" ? true : false);
|
|
})
|
|
}
|
|
|
|
self.onUserLoggedOut = function() {
|
|
}
|
|
|
|
self.onEventPrinterStateChanged = function(payload) {
|
|
if (payload.state_id == "PRINTING" || payload.state_id == "PAUSED"){
|
|
self.testButtonChangeStatus(true);
|
|
} else {
|
|
self.testButtonChangeStatus(false);
|
|
}
|
|
}
|
|
|
|
self.onmystromswitchEvent = function() {
|
|
if (self.mystromswitchEnabled()) {
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: JSON.stringify({
|
|
command: "enable",
|
|
eventView : false
|
|
}),
|
|
contentType: "application/json; charset=UTF-8"
|
|
})
|
|
} else {
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: JSON.stringify({
|
|
command: "disable",
|
|
eventView : false
|
|
}),
|
|
contentType: "application/json; charset=UTF-8"
|
|
})
|
|
}
|
|
}
|
|
|
|
self.mystromswitchEnabled.subscribe(self.onmystromswitchEvent, self);
|
|
|
|
self.onDataUpdaterPluginMessage = function(plugin, data) {
|
|
if (plugin != "mystromswitch" && plugin != "octoprint_mystromswitch") {
|
|
return;
|
|
}
|
|
|
|
self.mystromswitchEnabled(data.mystromswitchEnabled);
|
|
if (data.type == "timeout") {
|
|
if ((data.timeout_value != null) && (data.timeout_value > 0)) {
|
|
self.timeoutPopupOptions.text = self.timeoutPopupText + data.timeout_value;
|
|
if (typeof self.timeoutPopup != "undefined") {
|
|
self.timeoutPopup.update(self.timeoutPopupOptions);
|
|
} else {
|
|
self.timeoutPopup = new PNotify(self.timeoutPopupOptions);
|
|
self.timeoutPopup.get().on('pnotify.cancel', function() {self.abortShutdown(true);});
|
|
}
|
|
} else {
|
|
if (typeof self.timeoutPopup != "undefined") {
|
|
self.timeoutPopup.remove();
|
|
self.timeoutPopup = undefined;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
self.abortShutdown = function(abortShutdownValue) {
|
|
self.timeoutPopup.remove();
|
|
self.timeoutPopup = undefined;
|
|
$.ajax({
|
|
url: API_BASEURL + "plugin/mystromswitch",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: JSON.stringify({
|
|
command: "abort",
|
|
eventView : true
|
|
}),
|
|
contentType: "application/json; charset=UTF-8"
|
|
})
|
|
}
|
|
}
|
|
|
|
OCTOPRINT_VIEWMODELS.push([
|
|
mystromswitchViewModel,
|
|
["loginStateViewModel", "settingsViewModel", "printerStateViewModel"],
|
|
$(".sidebar_plugin_mystromswitch").get(0)
|
|
]);
|
|
});
|