148 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!-- head --><!DOCTYPE html>
 | |
| <html lang="en">
 | |
| <head>
 | |
|     <meta charset="UTF-8">
 | |
|     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | |
|     <title>FilaMan - Filament Management Tool</title>
 | |
|     <link rel="icon" type="image/png" href="/favicon.ico">
 | |
|     <link rel="stylesheet" href="style.css">
 | |
|     <script>
 | |
|         fetch('/api/version')
 | |
|             .then(response => response.json())
 | |
|             .then(data => {
 | |
|                 const versionSpan = document.querySelector('.version');
 | |
|                 if (versionSpan) {
 | |
|                     versionSpan.textContent = 'v' + data.version;
 | |
|                 }
 | |
|             })
 | |
|             .catch(error => console.error('Error fetching version:', error));
 | |
|     </script>
 | |
| </head>
 | |
| <body>
 | |
|     <div class="navbar">
 | |
|         <div style="display: flex; align-items: center; gap: 2rem;">
 | |
|             <img src="/logo.png" alt="FilaMan Logo" class="logo">
 | |
|             <div class="logo-text">
 | |
|                 <h1>FilaMan<span class="version"></span></h1>
 | |
|                 <h4>Filament Management Tool</h4>
 | |
|             </div>
 | |
|         </div>
 | |
|         <nav style="display: flex; gap: 1rem;">
 | |
|             <a href="/">Start</a>
 | |
|             <a href="/waage">Scale</a>
 | |
|             <a href="/spoolman">Spoolman/Bambu</a>
 | |
|             <a href="/about">About</a>
 | |
|             <a href="/upgrade">Upgrade</a>
 | |
|         </nav>
 | |
|         <div class="status-container">
 | |
|             <div class="status-item">
 | |
|                 <span class="status-dot" id="bambuDot"></span>B
 | |
|             </div>
 | |
|             <div class="status-item">
 | |
|                 <span class="status-dot" id="spoolmanDot"></span>S
 | |
|             </div>
 | |
|             <div class="ram-status" id="ramStatus"></div>
 | |
|         </div>
 | |
|     </div>
 | |
| 
 | |
| <!-- head -->
 | |
| 
 | |
|     <div class="content">
 | |
|         <h1>Scale Configuration Page</h1>
 | |
|         
 | |
|         <div class="card">
 | |
|             <div class="card-body">
 | |
|                 <h5 class="card-title">Sacle Calibration</h5>
 | |
|                 <button id="calibrateBtn" class="btn btn-primary">Calibrate Scale</button>
 | |
|                 <button id="tareBtn" class="btn btn-secondary">Tare Scale</button>
 | |
|                 <div id="statusMessage" class="mt-3"></div>
 | |
|             </div>
 | |
|         </div>
 | |
| 
 | |
|         <!-- Neue Kalibrierungskarte -->
 | |
|         <div id="calibrationCard" class="card mt-3" style="display: none;">
 | |
|             <div class="card-body">
 | |
|                 <h5 class="card-title">Calibration done</h5>
 | |
|                 <p>Please follow these steps:</p>
 | |
|                 <ol>
 | |
|                     <li>Make sure the scale is empty</li>
 | |
|                     <li>Have a 500g calibration weight ready</li>
 | |
|                     <li>Click on "Start Calibration"</li>
 | |
|                     <li>Follow the further instructions</li>
 | |
|                 </ol>
 | |
|                 <ol>
 | |
|                     <li>Step 1: Empty the scale</li>
 | |
|                     <li>Step 2: Place the 500g weight on the scale</li>
 | |
|                     <li>Step 3: Remove weight from Scale</li>
 | |
|                 </ol>
 | |
|                 <button id="startCalibrationBtn" class="btn btn-danger">Start Calibration</button>
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
| 
 | |
|     <script>
 | |
|         let ws = null;
 | |
|         const statusMessage = document.getElementById('statusMessage');
 | |
| 
 | |
|         function connectWebSocket() {
 | |
|             ws = new WebSocket(`ws://${window.location.hostname}/ws`);
 | |
|             
 | |
|             ws.onopen = () => {
 | |
|                 console.log('WebSocket verbunden');
 | |
|                 statusMessage.innerHTML = 'Scale connected';
 | |
|                 enableButtons(true);
 | |
|             };
 | |
| 
 | |
|             ws.onclose = () => {
 | |
|                 console.log('WebSocket getrennt');
 | |
|                 statusMessage.innerHTML = 'Scale connection lost';
 | |
|                 enableButtons(false);
 | |
|                 setTimeout(connectWebSocket, 2000);
 | |
|             };
 | |
| 
 | |
|             ws.onmessage = (event) => {
 | |
|                 const data = JSON.parse(event.data);
 | |
|                 if (data.type === 'scale') {
 | |
|                     if (data.payload === 'success') {
 | |
|                         statusMessage.innerHTML = 'Well done';
 | |
|                         statusMessage.className = 'alert alert-success';
 | |
|                     } else if (data.payload === 'error') {
 | |
|                         statusMessage.innerHTML = 'Error while action';
 | |
|                         statusMessage.className = 'alert alert-danger';
 | |
|                     }
 | |
|                 }
 | |
|             };
 | |
|         }
 | |
| 
 | |
|         function enableButtons(enabled) {
 | |
|             document.getElementById('calibrateBtn').disabled = !enabled;
 | |
|             document.getElementById('tareBtn').disabled = !enabled;
 | |
|         }
 | |
| 
 | |
|         document.getElementById('calibrateBtn').addEventListener('click', () => {
 | |
|             // Kalibrierungskarte anzeigen
 | |
|             document.getElementById('calibrationCard').style.display = 'block';
 | |
|         });
 | |
| 
 | |
|         document.getElementById('startCalibrationBtn').addEventListener('click', () => {
 | |
|             ws.send(JSON.stringify({
 | |
|                 type: 'scale',
 | |
|                 payload: 'calibrate'
 | |
|             }));
 | |
|             // Optional: Kalibrierungskarte nach dem Start ausblenden
 | |
|             document.getElementById('calibrationCard').style.display = 'none';
 | |
|         });
 | |
| 
 | |
|         document.getElementById('tareBtn').addEventListener('click', () => {
 | |
|             ws.send(JSON.stringify({
 | |
|                 type: 'scale',
 | |
|                 payload: 'tare'
 | |
|             }));
 | |
|         });
 | |
| 
 | |
|         // WebSocket-Verbindung beim Laden der Seite initiieren
 | |
|         connectWebSocket();
 | |
|     </script>
 | |
| </body>
 | |
| </html>
 |