let function1Name, function1Macro, function2Name, function2Macro, function3Name, function3Macro, function4Name, function4Macro, function5Name, function5Macro; getMacros(); let sendText = document.getElementById("sendText"); let sendButton = document.getElementById("sendButton"); let receiveText = document.getElementById("receiveText"); let connectButton = document.getElementById("connectButton"); let statusBar = document.getElementById("statusBar"); //Couple the elements to the Events connectButton.addEventListener("click", clickConnect) sendButton.addEventListener("click", clickSend) helpButton.addEventListener("click", clickHelp) statusButton.addEventListener("click", clickStatus) //When the connectButton is pressed async function clickConnect() { if (port) { //if already connected, disconnect disconnect(); } else { //otherwise connect await connect(); } } //Define outputstream, inputstream and port so they can be used throughout the sketch var outputStream, inputStream, port; navigator.serial.addEventListener('connect', e => { statusBar.innerText = `Connected to ${e.port}`; connectButton.innerText = "Disconnect" }); navigator.serial.addEventListener('disconnect', e => { statusBar.innerText = `Disconnected`; connectButton.innerText = "Connect" }); //Connect to the serial async function connect() { //Optional filter to only see relevant boards const filter = { usbVendorId: 0x2341 // Arduino SA }; //Try to connect to the Serial port try { port = await navigator.serial.requestPort(/*{ filters: [filter] }*/); // Continue connecting to |port|. // - Wait for the port to open. await port.open({ baudRate: 1200 }); statusBar.innerText = "Connected"; connectButton.innerText = "Disconnect" let decoder = new TextDecoderStream(); inputDone = port.readable.pipeTo(decoder.writable); inputStream = decoder.readable; const encoder = new TextEncoderStream(); outputDone = encoder.readable.pipeTo(port.writable); outputStream = encoder.writable; reader = inputStream.getReader(); readLoop(); } catch (e) { //If the pipeTo error appears; clarify the problem by giving suggestions. if (e == "TypeError: Cannot read property 'pipeTo' of undefined") { e += "\n Use Google Chrome and enable-experimental-web-platform-features" } connectButton.innerText = "Connect" statusBar.innerText = e; } } //Write to the Serial port async function writeToStream(line) { var enc = new TextEncoder(); // always utf-8 const writer = outputStream.getWriter(); writer.write(line); writer.releaseLock(); } //Disconnect from the Serial port async function disconnect() { if (reader) { await reader.cancel(); await inputDone.catch(() => { }); reader = null; inputDone = null; } if (outputStream) { await outputStream.getWriter().close(); await outputDone; outputStream = null; outputDone = null; } statusBar.innerText = "Disconnected"; connectButton.innerText = "Connect" //Close the port. await port.close(); port = null; } //When the send button is pressed function clickSend() { writeToStream(sendText.value); writeToStream("\r"); //and clear the input field, so it's clear it has been sent sendText.value = ""; } function morsekey_func1() { console.log("F1: " + function1Macro); writeToStream(function1Macro); //and clear the input field, so it's clear it has been sent sendText.value = ""; } function morsekey_func2() { console.log("F2: " + function2Macro); writeToStream(function2Macro); //and clear the input field, so it's clear it has been sent sendText.value = ""; } function morsekey_func3() { console.log("F3: " + function3Macro); writeToStream(function3Macro); //and clear the input field, so it's clear it has been sent sendText.value = ""; } function morsekey_func4() { console.log("F4: " + function4Macro); writeToStream(function4Macro); //and clear the input field, so it's clear it has been sent sendText.value = ""; } function morsekey_func5() { console.log("F5: " + function5Macro); writeToStream(function5Macro); //and clear the input field, so it's clear it has been sent sendText.value = ""; } //Read the incoming data async function readLoop() { while (true) { const { value, done } = await reader.read(); if (done === true){ break; } console.log(value); //When recieved something add it to the big textarea receiveText.value += value; //Scroll to the bottom of the text field receiveText.scrollTop = receiveText.scrollHeight; } } function closeModal() { var container = document.getElementById("modals-here") var backdrop = document.getElementById("modal-backdrop") var modal = document.getElementById("modal") modal.classList.remove("show") backdrop.classList.remove("show") getMacros(); setTimeout(function() { container.removeChild(backdrop) container.removeChild(modal) }, 200) } // Call url and store the returned json data as variables function getMacros() { fetch(base_url + 'index.php/qso/cwmacros_json') .then(response => response.json()) .then(data => { function1Name = data.function1_name; function1Macro = data.function1_macro; function2Name = data.function2_name; function2Macro = data.function2_macro; function3Name = data.function3_name; function3Macro = data.function3_macro; function4Name = data.function4_name; function4Macro = data.function4_macro; function5Name = data.function5_name; function5Macro = data.function5_macro; // Do something with the variables const morsekey_func1_Button = document.getElementById('morsekey_func1'); morsekey_func1_Button.textContent = 'F1 (' + function1Name + ')'; const morsekey_func2_Button = document.getElementById('morsekey_func2'); morsekey_func2_Button.textContent = 'F2 (' + function2Name + ')'; const morsekey_func3_Button = document.getElementById('morsekey_func3'); morsekey_func3_Button.textContent = 'F3 (' + function3Name + ')'; const morsekey_func4_Button = document.getElementById('morsekey_func4'); morsekey_func4_Button.textContent = 'F4 (' + function4Name + ')'; const morsekey_func5_Button = document.getElementById('morsekey_func5'); morsekey_func5_Button.textContent = 'F5 (' + function5Name + ')'; }); }