172 lines
5.7 KiB
HTML
172 lines
5.7 KiB
HTML
<!doctype html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
|
|
<meta name="description" content="">
|
|
<title>Beer Gravity Monitor</title>
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.1/dist/css/bootstrap.min.css" integrity="sha384-zCbKRCUGaJDkqS1kPbPd7TveP5iyJE0EjAuZQTgFLD2ylzuqKfdKlfG/eSrtxUkn" crossorigin="anonymous">
|
|
<script src="https://code.jquery.com/jquery-3.6.0.min.js" integrity="sha256-/xUj+3OJU5yExlq6GSYGSHk7tPXikynS7ogEvDej/m4=" crossorigin="anonymous"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.1/dist/js/bootstrap.bundle.min.js" integrity="sha384-fQybjgWLrvvRgtW6bFlB7jaZrFsaBXjsOMm/tB9LTS58ONXgqbR9W8oWht/amnpF" crossorigin="anonymous"></script>
|
|
</head>
|
|
|
|
<body class="py-4">
|
|
|
|
<!-- START MENU -->
|
|
|
|
<nav class="navbar navbar-expand-sm navbar-dark bg-primary">
|
|
<a class="navbar-brand" href="/firmware.htm">Beer Gravity Monitor - Firmware upgrade</a>
|
|
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar" aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
|
|
<div class="collapse navbar-collapse" id="navbar">
|
|
<div class="spinner-border text-light" id="spinner" role="status"></div>
|
|
</div>
|
|
</nav>
|
|
|
|
<!-- START MAIN INDEX -->
|
|
|
|
<div class="container">
|
|
|
|
<hr class="my-4">
|
|
|
|
<div class="alert alert-success alert-dismissible fade hide show d-none" role="alert" id="alert">
|
|
<div id="alert-msg">...</div>
|
|
<button type="button" id="alert-btn" class="close" aria-label="Close">
|
|
<span aria-hidden="true">×</span>
|
|
</button>
|
|
</div>
|
|
|
|
<script type="text/javascript">
|
|
function showError( msg ) {
|
|
$('.alert').removeClass('alert-success').addClass('alert-danger').removeClass('d-none').addClass('show')
|
|
$('#alert-msg').text( msg );
|
|
}
|
|
|
|
function showSuccess( msg ) {
|
|
$('.alert').addClass('alert-success').removeClass('alert-danger').removeClass('d-none').addClass('show')
|
|
$('#alert-msg').text( msg );
|
|
}
|
|
|
|
$("#alert-btn").click(function(e){
|
|
$('.alert').addClass('d-none').removeClass('show')
|
|
});
|
|
</script>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col-md-12 themed-grid-col bg-light">Here you can upload a new firmware version, it will not check the version number so you can also downgrade the firmware here.
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<div class="col-md-8 themed-grid-col bg-light">Current version:</div>
|
|
<div class="col-md-4 themed-grid-col bg-light" id="app-ver">Loading...</div>
|
|
</div>
|
|
<div class="row mb-3">
|
|
<div class="col-md-8 themed-grid-col bg-light">Platform:</div>
|
|
<div class="col-md-4 themed-grid-col bg-light" id="platform">Loading...</div>
|
|
</div>
|
|
|
|
<div class="row mb-3">
|
|
<!--
|
|
<form action="/api/upload" method="post" enctype="multipart/form-data">
|
|
<div class="col-md-8 custom-file">
|
|
<input type="file" accept=".bin" class="custom-file-input" name="name" id="name">
|
|
<label class="custom-file-label" for="name">Choose file</label>
|
|
</div>
|
|
<button type="submit" class="btn btn-primary" id="upload-btn" value="upload">Flash firmware</button>
|
|
</form>
|
|
-->
|
|
<form id="uploadForm" enctype="multipart/form-data">
|
|
<div class="col-md-8 custom-file">
|
|
<input type="file" accept=".bin" class="custom-file-input" name="name" id="name">
|
|
<label class="custom-file-label" for="name">Choose file</label>
|
|
</div>
|
|
<button type="submit" class="btn btn-primary" id="upload-btn" value="upload">Flash firmware</button>
|
|
</form>
|
|
</div>
|
|
|
|
<div class="progress">
|
|
<div class="progress-bar" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
|
|
<hr class="my-4">
|
|
</div>
|
|
|
|
<script type="text/javascript">
|
|
window.onload = getStatus;
|
|
|
|
$(document).ready(function() {
|
|
$("#uploadForm").on('submit', function(e) {
|
|
e.preventDefault();
|
|
$.ajax( {
|
|
xhr: function() {
|
|
var xhr = new window.XMLHttpRequest();
|
|
xhr.upload.addEventListener("progress", function(evt) {
|
|
if (evt.lengthComputable) {
|
|
progressHandler(evt);
|
|
}
|
|
}, false);
|
|
return xhr;
|
|
},
|
|
type: 'POST',
|
|
url: '/api/upload',
|
|
data: new FormData(this),
|
|
contentType: false,
|
|
cache: false,
|
|
processData:false,
|
|
beforeSend: function() {
|
|
setProgress(0);
|
|
},
|
|
error:function() {
|
|
showError("Upload failed");
|
|
},
|
|
success: function(resp) {
|
|
showSuccess("Upload completed, device is restarting. Waiting 10 seconds to refresh browser.");
|
|
setTimeout(() => {
|
|
window.location = "/";
|
|
}, 10000);
|
|
}
|
|
});
|
|
});
|
|
});
|
|
|
|
function progressHandler(event) {
|
|
var percent = (event.loaded / event.total) * 100;
|
|
setProgress(Math.round(percent));
|
|
}
|
|
|
|
function setProgress(val) {
|
|
$('.progress-bar').css('width', val+'%').attr('aria-valuenow', val).text(val + "%");
|
|
}
|
|
|
|
function getStatus() {
|
|
var url = "/api/status";
|
|
//var url = "/test/status.json";
|
|
$('#spinner').show();
|
|
$.getJSON(url, function (cfg) {
|
|
console.log( cfg );
|
|
|
|
$("#app-ver").text(cfg["app-ver"]);
|
|
$("#platform").text(cfg["platform"]);
|
|
|
|
})
|
|
.fail(function () {
|
|
showError('Unable to get data from the device.');
|
|
})
|
|
.always(function() {
|
|
$('#spinner').hide();
|
|
});
|
|
}
|
|
|
|
function start() {
|
|
setInterval(getStatus, 3000);
|
|
}
|
|
</script>
|
|
|
|
<!-- START FOOTER -->
|
|
|
|
<div class="container-fluid themed-container bg-primary text-light">(C) Copyright 2021-22 Magnus Persson</div>
|
|
</body>
|
|
</html> |