diff options
Diffstat (limited to 'web/share/js')
-rw-r--r-- | web/share/js/kvm/gpio.js | 14 | ||||
-rw-r--r-- | web/share/js/kvm/recorder.js | 35 | ||||
-rw-r--r-- | web/share/js/kvm/session.js | 2 |
3 files changed, 37 insertions, 14 deletions
diff --git a/web/share/js/kvm/gpio.js b/web/share/js/kvm/gpio.js index bd9e5dd7..2319f2ac 100644 --- a/web/share/js/kvm/gpio.js +++ b/web/share/js/kvm/gpio.js @@ -27,7 +27,7 @@ import {tools, $, $$$} from "../tools.js"; import {wm} from "../wm.js"; -export function Gpio(__recordWsEvent) { +export function Gpio(__recorder) { var self = this; /************************************************************************/ @@ -167,13 +167,9 @@ export function Gpio(__recordWsEvent) { if (to === "0" && el.hasAttribute("data-confirm-off")) { confirm = el.getAttribute("data-confirm-off"); } - let event = { - "event_type": "gpio_switch", - "event": {"channel": channel, "state": to, "wait": 0}, - }; let act = () => { __sendPost(`/api/gpio/switch?channel=${channel}&state=${to}`); - __recordWsEvent(event); + __recorder.recordGpioSwitchEvent(channel, to); }; if (confirm) { wm.confirm(confirm).then(function(ok) { @@ -191,13 +187,9 @@ export function Gpio(__recordWsEvent) { var __pulseChannel = function(el) { let channel = el.getAttribute("data-channel"); let confirm = el.getAttribute("data-confirm"); - let event = { - "event_type": "gpio_pulse", - "event": {"channel": channel, "delay": 0, "wait": 0}, - }; let act = () => { __sendPost(`/api/gpio/pulse?channel=${channel}`); - __recordWsEvent(event); + __recorder.recordGpioPulseEvent(channel); }; if (confirm) { wm.confirm(confirm).then(function(ok) { if (ok) act(); }); diff --git a/web/share/js/kvm/recorder.js b/web/share/js/kvm/recorder.js index b1992eb7..f2ca6d5c 100644 --- a/web/share/js/kvm/recorder.js +++ b/web/share/js/kvm/recorder.js @@ -71,6 +71,14 @@ export function Recorder() { __recordEvent({"event_type": "print", "event": {"text": text}}); }; + self.recordGpioSwitchEvent = function(channel, to) { + __recordEvent({"event_type": "gpio_switch", "event": {"channel": channel, "state": to}}); + }; + + self.recordGpioPulseEvent = function(channel) { + __recordEvent({"event_type": "gpio_pulse", "event": {"channel": channel}}); + }; + var __recordEvent = function(event) { if (__recording) { let now = new Date().getTime(); @@ -163,8 +171,13 @@ export function Recorder() { __checkType(event.event.delta, "object", "Non-object mouse wheel delta"); __checkInt(event.event.delta.x, "Non-int mouse delta X"); __checkInt(event.event.delta.y, "Non-int mouse delta Y"); + } else if (event.event_type === "gpio_switch") { + __checkType(event.event.channel, "string", "Non-string GPIO channel"); + __checkType(event.event.state, "boolean", "Non-bool GPIO state"); + } else if (event.event_type === "gpio_pulse") { + __checkType(event.event.channel, "string", "Non-string GPIO channel"); } else { - throw "Unknown event type"; + throw `Unknown event type: ${event.event_type}`; } events.push(event); @@ -217,7 +230,25 @@ export function Recorder() { } }, event.event.text, "text/plain"); return; - } else if (["key", "mouse_button", "mouse_move", "mouse_wheel", "gpio_switch", "gpio_pulse"].includes(event.event_type)) { + } else if (["gpio_switch", "gpio_pulse"].includes(event.event_type)) { + let path = "/api/gpio"; + if (event.event_type === "gpio_switch") { + path += `/switch?channel=${event.event.channel}&state=${event.event.to}`; + } else { // gpio_pulse + path += `/pulse?channel=${event.event.channel}`; + } + let http = tools.makeRequest("POST", path, function() { + if (http.readyState === 4) { + if (http.status !== 200) { + wm.error("GPIO error:<br>", http.responseText); + __stopProcess(); + } else if (http.status === 200) { + __play_timer = setTimeout(() => __runEvents(index + 1, time), 0); + } + } + }); + return; + } else if (["key", "mouse_button", "mouse_move", "mouse_wheel"].includes(event.event_type)) { __ws.send(JSON.stringify(event)); } index += 1; diff --git a/web/share/js/kvm/session.js b/web/share/js/kvm/session.js index b183730a..3b2f18c1 100644 --- a/web/share/js/kvm/session.js +++ b/web/share/js/kvm/session.js @@ -49,7 +49,7 @@ export function Session() { var __hid = new Hid(__streamer.getResolution, __recorder); var __atx = new Atx(); var __msd = new Msd(); - var __gpio = new Gpio(__recorder.recordWsEvent); + var __gpio = new Gpio(__recorder); var __init__ = function() { __startSession(); |