137 lines
5.0 KiB
HTML
137 lines
5.0 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">
|
|
</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">v1.2.75</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>
|