diff options
author | Maxim Devaev <[email protected]> | 2021-09-20 06:14:13 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2021-09-20 07:14:38 +0300 |
commit | 701df3c76fff0679c6b1b05c067fe05c3b9f5e38 (patch) | |
tree | 34e2fd0ee62a3fdb90047e52af287353597c6ea5 /web/share/js/kvm/recorder.js | |
parent | f160fb561fa5bdcc7e35d35d16f66cc9150a0859 (diff) |
rewrited #65
Diffstat (limited to 'web/share/js/kvm/recorder.js')
-rw-r--r-- | web/share/js/kvm/recorder.js | 35 |
1 files changed, 33 insertions, 2 deletions
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; |