committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 1177 additions and 1175 deletions
-
6.gitignore
-
1039html/website.html
-
263html/websiteMgmt.h
-
88src/main.cpp
-
954src/websiteMgmt.h
1039
html/website.html
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,263 +0,0 @@ |
|||||
static const char mgtWebsite[] PROGMEM = "<!DOCTYPE html>\ |
|
||||
<html lang=\"de\">\ |
|
||||
<head>\ |
|
||||
<title>ESPuino-Konfiguration</title>\ |
|
||||
<meta charset=\"utf-8\">\ |
|
||||
<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\ |
|
||||
<link rel=\"stylesheet\" href=\"https://ts-cs.de/css/bootstrap.min.css\">\ |
|
||||
<script src=\"https://ts-cs.de/js/jquery.min.js\"></script>\ |
|
||||
<script src=\"https://ts-cs.de/js/popper.min.js\"></script>\ |
|
||||
<script src=\"https://ts-cs.de/js/bootstrap.min.js\"></script>\ |
|
||||
</head>\ |
|
||||
<body>\ |
|
||||
<nav class=\"navbar navbar-expand-sm bg-primary navbar-dark\">\ |
|
||||
<button class=\"navbar-toggler\" type=\"button\" data-toggle=\"collapse\" data-target=\"#navbarSupportedContent\" aria-controls=\"navbarSupportedContent\" aria-expanded=\"false\" aria-label=\"Toggle navigation\">\ |
|
||||
<span class=\"navbar-toggler-icon\"></span>\ |
|
||||
</button>\ |
|
||||
<a class=\"navbar-brand\">\ |
|
||||
<img src=\"./tonuino_logo.png\" width=\"30\" height=\"30\" class=\"d-inline-block align-top\" alt=\"\" />\ |
|
||||
Tonuino\ |
|
||||
</a>\ |
|
||||
<div class=\"collapse navbar-collapse\" id=\"collapsibleNavbar\">\ |
|
||||
<ul class=\"navbar-nav mr-auto\">\ |
|
||||
<li class=\"nav-item\">\ |
|
||||
<a class=\"nav-link\" href=\"#wifiConfig\">WLAN</a>\ |
|
||||
</li>\ |
|
||||
<li class=\"nav-item\">\ |
|
||||
<a class=\"nav-link\" href=\"#rfidMusicTags\">RFID-Zuweisungen</a>\ |
|
||||
</li>\ |
|
||||
<li class=\"nav-item\">\ |
|
||||
<a class=\"nav-link\" href=\"#rfidModTags\">RFID-Modifikationen</a>\ |
|
||||
</li>\ |
|
||||
<li class=\"nav-item\">\ |
|
||||
<a class=\"nav-link\" href=\"#mqttConfig\">MQTT</a>\ |
|
||||
</li>\ |
|
||||
<li class=\"nav-item\">\ |
|
||||
<a class=\"nav-link\" href=\"#ftpConfig\">FTP</a>\ |
|
||||
</li>\ |
|
||||
<li class=\"nav-item\">\ |
|
||||
<a class=\"nav-link\" href=\"#generalConfig\">Allgemein</a>\ |
|
||||
</li>\ |
|
||||
</ul>\ |
|
||||
</div>\ |
|
||||
</nav>\ |
|
||||
<br />\ |
|
||||
<div class=\"container\" id=\"wifiConfig\">\ |
|
||||
<h2>WLAN-Konfiguration</h2>\ |
|
||||
<form action=\"#wifiConfig\" method=\"GET\">\ |
|
||||
<div class=\"form-group col-md-6\">\ |
|
||||
<label for=\"SSID\">WLAN-Name (SSID):</label>\ |
|
||||
<input type=\"text\" class=\"form-control\" id=\"SSID\" placeholder=\"SSID\" name=\"SSID\" required>\ |
|
||||
<div class=\"invalid-feedback\">\ |
|
||||
Bitte SSID des WLANs eintragen.\ |
|
||||
</div>\ |
|
||||
<label for=\"pwd\">Passwort:</label>\ |
|
||||
<input type=\"password\" class=\"form-control\" id=\"pwd\" placeholder=\"Passwort\" name=\"pwd\" required>\ |
|
||||
</div>\ |
|
||||
<button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |
|
||||
<button type=\"submit\" class=\"btn btn-primary\" onclick=\"wifiConfig()\">Absenden</button>\ |
|
||||
</form>\ |
|
||||
</div>\ |
|
||||
<div class=\"container my-5\" id=\"rfidMusicTags\">\ |
|
||||
<h2>RFID-Zuweisungen</h2>\ |
|
||||
<form action=\"#rfidMusicTags\" method=\"GET\">\ |
|
||||
<div class=\"form-group col-md-6\">\ |
|
||||
<label for=\"rfidIdMusic\">RFID-Chip-Nummer</label>\ |
|
||||
<input type=\"text\" class=\"form-control\" id=\"rfidIdMusic\" maxlength=\"12\" pattern=\"[0-9]{12}\" placeholder=\"012345678912\" name=\"rfidIdMusic\" required>\ |
|
||||
<label for=\"fileOrUrl\">Datei, Verzeichnis oder URL (URL nur für Webradio)</label>\ |
|
||||
<input type=\"text\" class=\"form-control\" id=\"fileOrUrl\" maxlength=\"255\" placeholder=\"z.B. /mp3/Hoerspiele/Yakari/Yakari_und_seine_Freunde.mp3\" name=\"fileOrUrl\" required>\ |
|
||||
<label for=\"playMode\">Abspielmodus</label>\ |
|
||||
<select class=\"form-control\" id=\"playMode\" name=\"playMode\">\ |
|
||||
<option value=\"1\">Einzelner Titel</option>\ |
|
||||
<option value=\"2\">Einzelner Titel (Endlosschleife)</option>\ |
|
||||
<option value=\"3\">Hörbuch</option>\ |
|
||||
<option value=\"4\">Hörbuch (Endlosschleife)</option>\ |
|
||||
<option value=\"5\">Alle Titel eines Verzeichnis (sortiert)</option>\ |
|
||||
<option value=\"6\">Alle Titel eines Verzeichnis (zufällig)</option>\ |
|
||||
<option value=\"7\">Alle Titel eines Verzeichnis (sortiert, Endlosschleife)</option>\ |
|
||||
<option value=\"8\">Alle Titel eines Verzeichnis (zufällig, Endlosschleife)</option>\ |
|
||||
<option value=\"9\">Webradio</option>\ |
|
||||
</select>\ |
|
||||
</div>\ |
|
||||
<button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |
|
||||
<button type=\"submit\" class=\"btn btn-primary\" onclick=\"rfidAssign()\">Absenden</button>\ |
|
||||
</form>\ |
|
||||
</div>\ |
|
||||
<div class=\"container my-5\" id=\"rfidModTags\">\ |
|
||||
<h2>RFID-Modifkationen</h2>\ |
|
||||
<form class=\"needs-validation\" action=\"#rfidModTags\" method=\"GET\" novalidate>\ |
|
||||
<div class=\"form-group col-md-6\">\ |
|
||||
<label for=\"rfidIdMod\">RFID-Chip-Nummer</label>\ |
|
||||
<input type=\"text\" class=\"form-control\" id=\"rfidIdMod\" maxlength=\"12\" pattern=\"[0-9]{12}\" placeholder=\"012345678912\" name=\"rfidIdMod\" required>\ |
|
||||
<div class=\"invalid-feedback\">\ |
|
||||
Bitte eine 12-stellige Zahl eingeben.\ |
|
||||
</div>\ |
|
||||
<label for=\"modId\">Abspielmodus</label>\ |
|
||||
<select class=\"form-control\" id=\"modId\" name=\"modId\">\ |
|
||||
<option value=\"100\">Tastensperre</option>\ |
|
||||
<option value=\"101\">Schlafen nach 15 Minuten</option>\ |
|
||||
<option value=\"102\">Schlafen nach 30 Minuten</option>\ |
|
||||
<option value=\"103\">Schlafen nach 1 Stunde</option>\ |
|
||||
<option value=\"104\">Schlafen nach 2 Stunden</option>\ |
|
||||
<option value=\"105\">Schlafen nach Ende des Titels</option>\ |
|
||||
<option value=\"106\">Schlafen nach Ende der Playlist</option>\ |
|
||||
<option value=\"110\">Wiederhole Playlist (endlos)</option>\ |
|
||||
<option value=\"111\">Wiederhole Titel (endlos)</option>\ |
|
||||
<option value=\"112\">Dimme LEDs (Nachtmodus)</option>\ |
|
||||
</select>\ |
|
||||
</div>\ |
|
||||
<button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |
|
||||
<button type=\"submit\" class=\"btn btn-primary\" onclick=\"rfidMods()\">Absenden</button>\ |
|
||||
</form>\ |
|
||||
</div>\ |
|
||||
<div class=\"container my-5\" id=\"mqttConfig\">\ |
|
||||
<h2>MQTT-Konfiguration</h2>\ |
|
||||
<form class=\"needs-validation\" action=\"#mqttConfig\" method=\"GET\" novalidate>\ |
|
||||
<div class=\"form-check col-md-6\">\ |
|
||||
<input class=\"form-check-input\" type=\"checkbox\" value=\"1\" id=\"mqttEnable\" name=\"mqttEnable\" %MQTT_ENABLE%>\ |
|
||||
<label class=\"form-check-label\" for=\"mqttEnable\">\ |
|
||||
MQTT aktivieren\ |
|
||||
</label>\ |
|
||||
</div>\ |
|
||||
<div class=\"form-group my-2 col-md-6\">\ |
|
||||
<label for=\"mqttServer\">MQTT-Server (IP-Adresse)</label>\ |
|
||||
<input type=\"text\" class=\"form-control\" id=\"mqttServer\" pattern=\"^((\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.){3}(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$\" minlength=\"7\" maxlength=\"15\" placeholder=\"z.B. 192.168.2.89\" name=\"mqttServer\" value=\"%MQTT_SERVER%\">\ |
|
||||
<div class=\"invalid-feedback\">\ |
|
||||
Bitte eine gültige IPv4-Adresse eingeben, z.B. 192.168.2.89.\ |
|
||||
</div>\ |
|
||||
</div>\ |
|
||||
<button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |
|
||||
<button type=\"submit\" class=\"btn btn-primary\" onclick=\"mqttSettings()\">Absenden</button>\ |
|
||||
</form>\ |
|
||||
</div>\ |
|
||||
<div class=\"container\" id=\"ftpConfig\">\ |
|
||||
<h2>FTP-Konfiguration</h2>\ |
|
||||
<form action=\"#ftpConfig\" method=\"GET\">\ |
|
||||
<div class=\"form-group col-md-6\">\ |
|
||||
<label for=\"ftpUser\">FTP-Benutzername:</label>\ |
|
||||
<input type=\"text\" class=\"form-control\" id=\"ftpUser\" maxlength=\"32\" placeholder=\"Benutzername\" name=\"ftpUser\" value=\"%FTP_USER%\" required>\ |
|
||||
<label for=\"pwd\">Passwort:</label>\ |
|
||||
<input type=\"password\" class=\"form-control\" id=\"ftpPwd\" maxlength=\"32\" placeholder=\"Passwort\" name=\"ftpPwd\" value=\"%FTP_PWD%\" required>\ |
|
||||
</div>\ |
|
||||
<button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |
|
||||
<button type=\"submit\" class=\"btn btn-primary\" onClick=\"ftpSettings()\">Absenden</button>\ |
|
||||
</form>\ |
|
||||
</div>\ |
|
||||
<div class=\"container my-5\" id=\"generalConfig\">\ |
|
||||
<h2>Allgemeine Konfiguration</h2>\ |
|
||||
<form action=\"#generalConfig\" method=\"GET\">\ |
|
||||
<div class=\"form-group col-md-6\">\ |
|
||||
<label for=\"initialVolume\">Lautstärke nach dem Einschalten</label>\ |
|
||||
<input type=\"number\" min=\"1\" max=\"21\" class=\"form-control\" id=\"initialVolume\" name=\"initialVolume\" value=\"%INIT_VOLUME%\" required>\ |
|
||||
<label for=\"maxVolume\">Maximale Lautstärke</label>\ |
|
||||
<input type=\"number\" min=\"1\" max=\"21\" class=\"form-control\" id=\"maxVolume\" name=\"maxVolume\" value=\"%MAX_VOLUME%\" required>\ |
|
||||
</div>\ |
|
||||
<div class=\"form-group col-md-6\">\ |
|
||||
<label for=\"initBrightness\">Neopixel-Helligkeit nach dem Einschalten</label>\ |
|
||||
<input type=\"number\" min=\"0\" max=\"255\" class=\"form-control\" id=\"initBrightness\" name=\"initBrightness\" value=\"%INIT_LED_BRIGHTBESS%\" required>\ |
|
||||
<label for=\"nightBrightness\">Neopixel-Helligkeit im Nachtmodus</label>\ |
|
||||
<input type=\"number\" min=\"0\" max=\"255\" class=\"form-control\" id=\"nightBrightness\" name=\"nightBrightness\" value=\"%NIGHT_LED_BRIGHTBESS%\" required>\ |
|
||||
</div>\ |
|
||||
<div class=\"form-group col-md-6\">\ |
|
||||
<label for=\"inactivityTime\">Deep-Sleep nach Inaktivität (Minuten)</label>\ |
|
||||
<input type=\"number\" min=\"1\" max=\"1440\" class=\"form-control\" id=\"inactivityTime\" name=\"inactivityTime\" value=\"%MAX_INACTIVITY%\" required>\ |
|
||||
</div>\ |
|
||||
<button type=\"reset\" class=\"btn btn-secondary\">Reset</button>\ |
|
||||
<button type=\"submit\" class=\"btn btn-primary\" onClick=\"genSettings()\">Absenden</button>\ |
|
||||
</form>\ |
|
||||
<script>\ |
|
||||
(function() {\ |
|
||||
'use strict';\ |
|
||||
window.addEventListener('load', function() {\ |
|
||||
// Fetch all the forms we want to apply custom Bootstrap validation styles to\ |
|
||||
var forms = document.getElementsByClassName('needs-validation');\ |
|
||||
// Loop over them and prevent submission\ |
|
||||
var validation = Array.prototype.filter.call(forms, function(form) {\ |
|
||||
form.addEventListener('submit', function(event) {\ |
|
||||
if (form.checkValidity() === false) {\ |
|
||||
event.preventDefault();\ |
|
||||
event.stopPropagation();\ |
|
||||
}\ |
|
||||
form.classList.add('was-validated');\ |
|
||||
}, false);\ |
|
||||
});\ |
|
||||
}, false);\ |
|
||||
});\ |
|
||||
\ |
|
||||
let socket = new WebSocket(\"ws://%IPv4%:81/ws\");\ |
|
||||
\ |
|
||||
function genSettings() {\ |
|
||||
\ |
|
||||
var myObj = {\ |
|
||||
\"general\": {\ |
|
||||
iVol: document.getElementById('initialVolume').value,\ |
|
||||
mVol: document.getElementById('maxVolume').value,\ |
|
||||
iBright: document.getElementById('initBrightness').value,\ |
|
||||
nBright: document.getElementById('nightBrightness').value,\ |
|
||||
iTime: document.getElementById('inactivityTime').value\ |
|
||||
}\ |
|
||||
};\ |
|
||||
var myJSON = JSON.stringify(myObj);\ |
|
||||
socket.send(myJSON);\ |
|
||||
}\ |
|
||||
\ |
|
||||
function ftpSettings() {\ |
|
||||
var myObj = {\ |
|
||||
\"ftp\": {\ |
|
||||
ftpUser: document.getElementById('ftpUser').value,\ |
|
||||
ftpPwd: document.getElementById('ftpPwd').value\ |
|
||||
}\ |
|
||||
};\ |
|
||||
var myJSON = JSON.stringify(myObj);\ |
|
||||
socket.send(myJSON);\ |
|
||||
}\ |
|
||||
\ |
|
||||
function mqttSettings() {\ |
|
||||
var myObj = {\ |
|
||||
\"mqtt\": {\ |
|
||||
enable: document.getElementById('mqttEnable').value,\ |
|
||||
server: document.getElementById('mqttServer').value\ |
|
||||
}\ |
|
||||
};\ |
|
||||
var myJSON = JSON.stringify(myObj);\ |
|
||||
socket.send(myJSON);\ |
|
||||
}\ |
|
||||
\ |
|
||||
function rfidMods() {\ |
|
||||
var myObj = {\ |
|
||||
\"rfidMod\": {\ |
|
||||
rfidId: document.getElementById('rfidIdMod').value,\ |
|
||||
modId: document.getElementById('modId').value\ |
|
||||
}\ |
|
||||
};\ |
|
||||
var myJSON = JSON.stringify(myObj);\ |
|
||||
socket.send(myJSON);\ |
|
||||
}\ |
|
||||
\ |
|
||||
function rfidAssign() {\ |
|
||||
var myObj = {\ |
|
||||
\"rfidAssign\": {\ |
|
||||
rfidId: document.getElementById('rfidIdMusic').value,\ |
|
||||
fileOrUrl: document.getElementById('fileOrUrl').value,\ |
|
||||
playmode: document.getElementById('playMode').value\ |
|
||||
}\ |
|
||||
};\ |
|
||||
var myJSON = JSON.stringify(myObj);\ |
|
||||
socket.send(myJSON);\ |
|
||||
}\ |
|
||||
\ |
|
||||
function wifiConfig() {\ |
|
||||
var myObj = {\ |
|
||||
\"wifiConfig\": {\ |
|
||||
ssid: document.getElementById('SSID').value,\ |
|
||||
pwd: document.getElementById('pwd').value\ |
|
||||
}\ |
|
||||
};\ |
|
||||
var myJSON = JSON.stringify(myObj);\ |
|
||||
socket.send(myJSON);\ |
|
||||
}\ |
|
||||
</script>\ |
|
||||
</div>\ |
|
||||
</body>\ |
|
||||
</html>\ |
|
||||
"; |
|
954
src/websiteMgmt.h
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
Write
Preview
Loading…
Cancel
Save
Reference in new issue