Add reconnect m
This commit is contained in:
		| @@ -369,7 +369,7 @@ | ||||
|     } | ||||
|  | ||||
|     setStatus(msg, level = 'info') { | ||||
|       console.log(msg); | ||||
|       console.error(msg); | ||||
|       uiStatusSpan.textContent = msg; | ||||
|       uiStatusSpan.className = 'status status-' + level; | ||||
|     } | ||||
| @@ -596,24 +596,33 @@ | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     async autoReconnectTimeout() { | ||||
|         this.reconnectTimeoutId = null; | ||||
|         if (!uiAutoReconnectCheckbox.checked) { | ||||
|           this.setStatus('Auto-reconnect stopped.', 'info'); | ||||
|           return; | ||||
|         } | ||||
|         if (this.currentPort && !this.currentPort.isConnected) { | ||||
|           try { | ||||
|             await this.currentPort.connect(); | ||||
|             this.setStatus('Reconnected successfully', 'info'); | ||||
|           } catch (error) { | ||||
|             this.setStatus(`Reconnect failed: ${error.message}`, 'error'); | ||||
|             // Try again after a delay | ||||
|             this.tryAutoReconnect(); | ||||
|           } finally { | ||||
|             this.updateUIConnectionState(); | ||||
|           } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     tryAutoReconnect() { | ||||
|       this.updateUIConnectionState(); | ||||
|       if (!uiAutoReconnectCheckbox.checked) return; | ||||
|       if (this.reconnectTimeoutId !== null) return; // already trying | ||||
|       this.setStatus('Attempting to auto-reconnect...', 'info'); | ||||
|       this.reconnectTimeoutId = setTimeout(async () => { | ||||
|         this.reconnectTimeoutId = null; | ||||
|         if (!uiAutoReconnectCheckbox.checked) { | ||||
|           this.setStatus('Auto-reconnect stopped.', 'info'); | ||||
|           return; | ||||
|         } | ||||
|         if (this.currentPort) { | ||||
|           try { | ||||
|             await this.currentPort.connect(); | ||||
|           } finally { | ||||
|             this.updateUIConnectionState(); | ||||
|           } | ||||
|         } | ||||
|         await this.autoReconnectTimeout(); | ||||
|       }, 1000); | ||||
|     } | ||||
|  | ||||
| @@ -762,14 +771,15 @@ | ||||
|       // save <iso_date_time>,<received_line> | ||||
|       let csvContent = 'data:text/csv;charset=utf-8,'; | ||||
|       for (const entry of this.receivedData) { | ||||
|         let line = new Date(entry.time).toISOString() + ',"' + entry.text.replace(/[\r\n]+$/, '') + '"'; | ||||
|         let sanitizedText = entry.text.replace(/"/g, '""').replace(/[\r\n]+$/, ''); | ||||
|         let line = new Date(entry.time).toISOString() + ',"' + sanitizedText + '"'; | ||||
|         csvContent += line + '\n'; | ||||
|       } | ||||
|  | ||||
|       const encodedUri = encodeURI(csvContent); | ||||
|       const link = document.createElement('a'); | ||||
|       link.setAttribute('href', encodedUri); | ||||
|       const filename = new Date().toISOString() + '_tinyusb_received_serial_data.csv'; | ||||
|       const filename = new Date().toISOString().replace(/:/g, '-') + '_tinyusb_received_serial_data.csv'; | ||||
|       link.setAttribute('download', filename); | ||||
|       document.body.appendChild(link); | ||||
|       link.click(); | ||||
|   | ||||
| @@ -35,7 +35,7 @@ | ||||
|       </label> | ||||
|       <label for="auto_reconnect_checkbox" class="controls"> | ||||
|         <input type="checkbox" id="auto_reconnect_checkbox" /> | ||||
|         Auto Reconnect | ||||
|         Auto Reconnect WebUSB | ||||
|       </label> | ||||
|       <button id="forget_device_btn" class="controls btn danger">Forget Device</button> | ||||
|       <button id="forget_all_devices_btn" class="controls btn danger">Forget All Devices</button> | ||||
|   | ||||
| @@ -116,7 +116,7 @@ class SerialPort { | ||||
|     if (!this._port.writable) { | ||||
|       throw new Error('Port is not writable'); | ||||
|     } | ||||
|     this._writer = port.writeable.getWriter(); | ||||
|     this._writer = this._port.writable.getWriter(); | ||||
|     if (!this._writer) { | ||||
|       throw new Error('Failed to get writer from port'); | ||||
|     } | ||||
| @@ -141,6 +141,13 @@ class WebUsbSerialPort { | ||||
|     this._readLoopPromise = null; | ||||
|     this._initialized = false; | ||||
|     this._keepReading = true; | ||||
|  | ||||
|     this._vendorId = device.vendorId; | ||||
|     this._productId = device.productId; | ||||
|   } | ||||
|  | ||||
|   _isSameWebUsbSerialPort(webUsbSerialPort) { | ||||
|     return this._vendorId === webUsbSerialPort._vendorId && this._productId === webUsbSerialPort._productId; | ||||
|   } | ||||
|  | ||||
|   /// Connect and start reading loop | ||||
| @@ -152,14 +159,9 @@ class WebUsbSerialPort { | ||||
|         console.error('Error disconnecting previous device:', error); | ||||
|       } | ||||
|  | ||||
|       if (this._readLoopPromise) { | ||||
|         try { | ||||
|           await this._readLoopPromise; | ||||
|         } catch (error) { | ||||
|           console.error('Error in read loop:', error); | ||||
|         } | ||||
|       } | ||||
|       this._readLoopPromise = null; | ||||
|       const webUsbSerialPorts = await serial.getWebUsbSerialPorts(); | ||||
|       const webUsbSerialPort = webUsbSerialPorts.find(serialPort => this._isSameWebUsbSerialPort(serialPort)); | ||||
|       this._device = webUsbSerialPort ? webUsbSerialPort._device : this._device; | ||||
|     } | ||||
|     this._initialized = true; | ||||
|  | ||||
|   | ||||
| @@ -221,6 +221,12 @@ body.dark-mode { | ||||
|   color: #d4d4d4; | ||||
| } | ||||
|  | ||||
| body.dark-mode input[type="checkbox"] { | ||||
|   border-color: #888; | ||||
|   accent-color: #2e2e2e; | ||||
|   opacity: 0.8; | ||||
| } | ||||
|  | ||||
| body.dark-mode .btn-theme { | ||||
|   background-color: #b0b0b0; | ||||
|   color: #000; | ||||
| @@ -251,6 +257,7 @@ body.dark-mode .input:focus { | ||||
|  | ||||
| body.dark-mode .scrollbox { | ||||
|   background-color: #252526; | ||||
|   scrollbar-color: #555 #2e2e2e; | ||||
|   border: 1px solid #444; | ||||
| } | ||||
|  | ||||
| @@ -287,7 +294,3 @@ body.dark-mode option { | ||||
|   background-color: #3c3c3c; | ||||
|   color: #f0f0f0; | ||||
| } | ||||
|  | ||||
| body.dark-mode .scrollbox { | ||||
|   scrollbar-color: #555 #2e2e2e; | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 raldone01
					raldone01