summaryrefslogtreecommitdiff
path: root/web/share/js/kvm/gpio.js
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2024-10-19 08:59:52 +0300
committerMaxim Devaev <[email protected]>2024-10-19 08:59:52 +0300
commit90d8e745e39b5e49fcb1d50c1efa95148593496b (patch)
treef098894e16275d8fe80b8cb16bb615ff3a106e5e /web/share/js/kvm/gpio.js
parent3852d0a4568c3726d0182f3b00a9a3e8bb7e8af9 (diff)
gpio diff events mode
Diffstat (limited to 'web/share/js/kvm/gpio.js')
-rw-r--r--web/share/js/kvm/gpio.js60
1 files changed, 36 insertions, 24 deletions
diff --git a/web/share/js/kvm/gpio.js b/web/share/js/kvm/gpio.js
index fea1af32..9e237a54 100644
--- a/web/share/js/kvm/gpio.js
+++ b/web/share/js/kvm/gpio.js
@@ -32,17 +32,41 @@ export function Gpio(__recorder) {
/************************************************************************/
- var __state = null;
+ var __has_model = false;
/************************************************************************/
self.setState = function(state) {
if (state) {
+ if (state.model) {
+ __applyModel(state.model);
+ __has_model = true;
+ }
+ if (__has_model && state.state) {
+ __applyState(state.state);
+ }
+ } else {
+ for (let el of $$("__gpio-led")) {
+ __setLedState(el, false);
+ }
+ for (let selector of ["__gpio-switch", "__gpio-button"]) {
+ for (let el of $$(selector)) {
+ tools.el.setEnabled(el, false);
+ }
+ }
+ __has_model = false;
+ }
+ };
+
+ var __applyState = function(state) {
+ if (state.inputs) {
for (let ch in state.inputs) {
for (let el of $$(`__gpio-led-${ch}`)) {
__setLedState(el, state.inputs[ch].state);
}
}
+ }
+ if (state.outputs) {
for (let ch in state.outputs) {
for (let type of ["switch", "button"]) {
for (let el of $$(`__gpio-${type}-${ch}`)) {
@@ -53,20 +77,10 @@ export function Gpio(__recorder) {
el.checked = state.outputs[ch].state;
}
}
- } else {
- for (let el of $$("__gpio-led")) {
- __setLedState(el, false);
- }
- for (let selector of ["__gpio-switch", "__gpio-button"]) {
- for (let el of $$(selector)) {
- tools.el.setEnabled(el, false);
- }
- }
}
- __state = state;
};
- self.setModel = function(model) {
+ var __applyModel = function(model) {
tools.feature.setEnabled($("gpio-dropdown"), model.view.table.length);
if (model.view.table.length) {
let title = [];
@@ -81,23 +95,23 @@ export function Gpio(__recorder) {
$("gpio-menu-button").innerHTML = title.join(" ");
}
- let content = "<table class=\"kv\">";
+ let html = "<table class=\"kv\">";
for (let row of model.view.table) {
if (row === null) {
- content += "</table><hr><table class=\"kv\">";
+ html += "</table><hr><table class=\"kv\">";
} else {
- content += "<tr>";
+ html += "<tr>";
for (let item of row) {
if (item.type === "output") {
item.scheme = model.scheme.outputs[item.channel];
}
- content += `<td align="center">${__createItem(item)}</td>`;
+ html += `<td align="center">${__createItem(item)}</td>`;
}
- content += "</tr>";
+ html += "</tr>";
}
}
- content += "</table>";
- $("gpio-menu").innerHTML = content;
+ html += "</table>";
+ $("gpio-menu").innerHTML = html;
for (let ch in model.scheme.outputs) {
for (let el of $$(`__gpio-switch-${ch}`)) {
@@ -111,8 +125,6 @@ export function Gpio(__recorder) {
tools.feature.setEnabled($("v3-usb-breaker"), ("__v3_usb_breaker__" in model.scheme.outputs));
tools.feature.setEnabled($("v4-locator"), ("__v4_locator__" in model.scheme.outputs));
tools.feature.setEnabled($("system-tool-wol"), ("__wol__" in model.scheme.outputs));
-
- self.setState(__state);
};
var __createItem = function(item) {
@@ -167,9 +179,9 @@ export function Gpio(__recorder) {
}
};
- var __setLedState = function(el, state) {
+ var __setLedState = function(el, on) {
let color = el.getAttribute("data-color");
- if (state) {
+ if (on) {
el.classList.add(`led-${color}`);
el.classList.remove("led-gray");
} else {
@@ -221,7 +233,7 @@ export function Gpio(__recorder) {
var __sendPost = function(url, params) {
tools.httpPost(url, params, function(http) {
if (http.status === 409) {
- wm.error("Performing another operation for this GPIO channel.<br>Please try again later");
+ wm.error("Performing another operation for this GPIO channel.<br>Please try again later.");
} else if (http.status !== 200) {
wm.error("GPIO error", http.responseText);
}