Fixed replacement of some placeholder. Added a timezone string to the config.

This commit is contained in:
Kai Lauterbach 2023-05-02 08:03:14 +02:00
parent 3dc7ebf263
commit 3cbdf20e79
7 changed files with 36 additions and 30 deletions

View file

@ -3,7 +3,9 @@
#define SERIAL_BAUD_RATE 115200 #define SERIAL_BAUD_RATE 115200
#define light_name "Dimmable Hue Light" //default light name #define LOCAL_TIMEZONE_STRING "CET-1CEST-2,M3.5.0/02:00:00,M10.5.0/03:00:00" // Berlin, Germany - https://sites.google.com/a/usapiens.com/opnode/time-zones
#define light_name "Dimmable Hue Light (DEV)" // default light name
#define LIGHTS_COUNT 4 // do not modify because luminie p30 only has 4 channel, never set above 80 #define LIGHTS_COUNT 4 // do not modify because luminie p30 only has 4 channel, never set above 80

View file

@ -45,19 +45,19 @@ String getConfigHTML()
"</div>" "</div>"
"<div class=\"pure-control-group\">" "<div class=\"pure-control-group\">"
"<label for=\"ip\">IP</label>" "<label for=\"ip\">IP</label>"
"<input id=\"ip\" name=\"ip\" type=\"text\" value=\"{{WIFI_IP}}\">" "<input id=\"ip\" name=\"ip\" type=\"text\" value=\"{{WIFI_CFG_IP}}\">"
"</div>" "</div>"
"<div class=\"pure-control-group\">" "<div class=\"pure-control-group\">"
"<label for=\"gwip\">Gateway IP</label>" "<label for=\"gwip\">Gateway IP</label>"
"<input id=\"gwip\" name=\"gwip\" type=\"text\" value=\"{{WIFI_GW}}\">" "<input id=\"gwip\" name=\"gwip\" type=\"text\" value=\"{{WIFI_CFG_GW}}\">"
"</div>" "</div>"
"<div class=\"pure-control-group\">" "<div class=\"pure-control-group\">"
"<label for=\"ip\">Netmask</label>" "<label for=\"ip\">Netmask</label>"
"<input id=\"netmask\" name=\"netmas\" type=\"text\" value=\"{{WIFI_NM}}\">" "<input id=\"netmask\" name=\"netmas\" type=\"text\" value=\"{{WIFI_CFG_NM}}\">"
"</div>" "</div>"
"<div class=\"pure-control-group\">" "<div class=\"pure-control-group\">"
"<label for=\"ip\">DNS</label>" "<label for=\"ip\">DNS</label>"
"<input id=\"netmask\" name=\"dns\" type=\"text\" value=\"{{WIFI_DNS}}\">" "<input id=\"netmask\" name=\"dns\" type=\"text\" value=\"{{WIFI_CFG_DNS}}\">"
"</div>" "</div>"
"<div class=\"pure-controls\">" "<div class=\"pure-controls\">"
"<button type=\"submit\" class=\"pure-button pure-button-primary\">Save</button>" "<button type=\"submit\" class=\"pure-button pure-button-primary\">Save</button>"

View file

@ -41,19 +41,19 @@
</div> </div>
<div class="pure-control-group"> <div class="pure-control-group">
<label for="ip">IP</label> <label for="ip">IP</label>
<input id="ip" name="ip" type="text" value="{{WIFI_IP}}"> <input id="ip" name="ip" type="text" value="{{WIFI_CFG_IP}}">
</div> </div>
<div class="pure-control-group"> <div class="pure-control-group">
<label for="gwip">Gateway IP</label> <label for="gwip">Gateway IP</label>
<input id="gwip" name="gwip" type="text" value="{{WIFI_GW}}"> <input id="gwip" name="gwip" type="text" value="{{WIFI_CFG_GW}}">
</div> </div>
<div class="pure-control-group"> <div class="pure-control-group">
<label for="ip">Netmask</label> <label for="ip">Netmask</label>
<input id="netmask" name="netmas" type="text" value="{{WIFI_NM}}"> <input id="netmask" name="netmas" type="text" value="{{WIFI_CFG_NM}}">
</div> </div>
<div class="pure-control-group"> <div class="pure-control-group">
<label for="ip">DNS</label> <label for="ip">DNS</label>
<input id="netmask" name="dns" type="text" value="{{WIFI_DNS}}"> <input id="netmask" name="dns" type="text" value="{{WIFI_CFG_DNS}}">
</div> </div>
<div class="pure-controls"> <div class="pure-controls">
<button type="submit" class="pure-button pure-button-primary">Save</button> <button type="submit" class="pure-button pure-button-primary">Save</button>

View file

@ -80,12 +80,16 @@ uint32_t last_lightengine_activity = 0;
//********************************// //********************************//
void apply_scene(uint8_t new_scene, uint8_t light) { void apply_scene(uint8_t new_scene, uint8_t light)
if (new_scene == SCENE_RELEAX) { {
if (new_scene == SCENE_RELEAX)
{
bri[light] = 144; bri[light] = 144;
} else if (new_scene == SCENE_BRIGHT) { } else if (new_scene == SCENE_BRIGHT)
{
bri[light] = 254; bri[light] = 254;
} else if (new_scene == SCENE_NIGHTLY) { } else if (new_scene == SCENE_NIGHTLY)
{
bri[0] = 25; bri[0] = 25;
bri[1] = 0; bri[1] = 0;
bri[2] = 0; bri[2] = 0;
@ -619,6 +623,8 @@ void init_webserver()
http_content.replace("{{LIGHT_NAME}}", (String)light_name); http_content.replace("{{LIGHT_NAME}}", (String)light_name);
http_content.replace("{{LIGHT_COUNT}}", (String)LIGHTS_COUNT);
int tc_val = EEPROM.read(EEPROM_TIMING_CONTROL_ENABLED_ADDRESS); int tc_val = EEPROM.read(EEPROM_TIMING_CONTROL_ENABLED_ADDRESS);
if (tc_val == TIMING_CONTROL_ENABLED) if (tc_val == TIMING_CONTROL_ENABLED)
{ {
@ -700,7 +706,7 @@ void init_webserver()
String config_content = getConfigHTML(); String config_content = getConfigHTML();
// Wifi settings // Wifi settings
config_content.replace("{{WIFI_SSIF}}", WiFi.SSID()); config_content.replace("{{WIFI_SSID}}", WiFi.SSID());
// Network settings // Network settings
uint8_t dip = EEPROM.read(EEPROM_DYNAMIC_IP_ADDRESS); uint8_t dip = EEPROM.read(EEPROM_DYNAMIC_IP_ADDRESS);
@ -714,16 +720,15 @@ void init_webserver()
} }
// ip config // ip config
if (dip == 0) config_content.replace("{{WIFI_CFG_IP}}", WiFi.localIP().toString());
{ config_content.replace("{{WIFI_CFG_GW}}", WiFi.gatewayIP().toString());
config_content.replace("{{WIFI_IP}}", WiFi.localIP().toString()); config_content.replace("{{WIFI_CFG_NM}}", WiFi.subnetMask().toString());
config_content.replace("{{WIFI_GW}}", WiFi.gatewayIP().toString()); config_content.replace("{{WIFI_CFG_DNS}}", WiFi.dnsIP().toString());
config_content.replace("{{WIFI_NM}}", WiFi.subnetMask().toString());
config_content.replace("{{WIFI_DNS}}", WiFi.dnsIP().toString());
}
http_content.replace("{{CONFIG_PAGE}}", config_content); http_content.replace("{{CONFIG_PAGE}}", config_content);
http_content.replace("{{IP_ADDRESS}}", WiFi.localIP().toString());
// set the pwm values // set the pwm values
http_content.replace("{{PWM_MIN}}", (String)PWM_MIN); http_content.replace("{{PWM_MIN}}", (String)PWM_MIN);
http_content.replace("{{PWM_MAX}}", (String)PWM_MAX); http_content.replace("{{PWM_MAX}}", (String)PWM_MAX);

View file

@ -36,7 +36,7 @@ String getIndexHTML()
"<strong>Timing control</strong>" "<strong>Timing control</strong>"
"</label>" "</label>"
"<a id=\"tc_on\" class=\"pure-button {{TC_LINK_PRIMARY_ON}}\" href=\"#\">ON</a>" "<a id=\"tc_on\" class=\"pure-button {{TC_LINK_PRIMARY_ON}}\" href=\"#\">ON</a>"
"<a id=\"tc_off\" class=\"pure-button {{TC_LINK_PRIMARY_OFF\" href=\"#\">OFF</a>" "<a id=\"tc_off\" class=\"pure-button {{TC_LINK_PRIMARY_OFF}}\" href=\"#\">OFF</a>"
"</div>" "</div>"
"<script>" "<script>"
"var links = document.querySelectorAll('[id^=\"tc_on\"]');" "var links = document.querySelectorAll('[id^=\"tc_on\"]');"
@ -94,7 +94,6 @@ String getIndexHTML()
"<tr>" "<tr>"
"<td>" "<td>"
"{{LIGHTS_CONTROL}}" "{{LIGHTS_CONTROL}}"
""
"</td>" "</td>"
"<td>" "<td>"
"<div id=\"plot_chart\"></div>" "<div id=\"plot_chart\"></div>"
@ -228,7 +227,7 @@ String getIndexHTML()
"" ""
"function updateLightState() {" "function updateLightState() {"
"console.log('----> setting bri and power switch <----');" "console.log('----> setting bri and power switch <----');"
"for (let i = 1; i <= {{LIGHT_NUM}}; i++) {" "for (let i = 1; i <= {{LIGHT_COUNT}}; i++) {"
"const lightURL = `http://{{IP_ADDRESS}}/state?light=${i}`;" "const lightURL = `http://{{IP_ADDRESS}}/state?light=${i}`;"
"fetch(lightURL).then(response => response.json()).then(data => {" "fetch(lightURL).then(response => response.json()).then(data => {"
"const briSlider = document.getElementById(`bri${i - 1}`);" "const briSlider = document.getElementById(`bri${i - 1}`);"
@ -253,7 +252,7 @@ String getIndexHTML()
"" ""
"function updatePWMValues() {" "function updatePWMValues() {"
"console.log('----> setting pwm data <----');" "console.log('----> setting pwm data <----');"
"for (let i = 0; i < {{LIGHT_NUM}}; i++) {" "for (let i = 0; i < {{LIGHT_COUNT}}; i++) {"
"const lightID = i + 1;" "const lightID = i + 1;"
"const pwmElement = document.getElementById(`light${i}_pwm`);" "const pwmElement = document.getElementById(`light${i}_pwm`);"
"const pwmElementTxt = document.getElementById(`light${i}_pwm_txt`);" "const pwmElementTxt = document.getElementById(`light${i}_pwm_txt`);"

View file

@ -32,7 +32,7 @@
<strong>Timing control</strong> <strong>Timing control</strong>
</label> </label>
<a id="tc_on" class="pure-button {{TC_LINK_PRIMARY_ON}}" href="#">ON</a> <a id="tc_on" class="pure-button {{TC_LINK_PRIMARY_ON}}" href="#">ON</a>
<a id="tc_off" class="pure-button {{TC_LINK_PRIMARY_OFF" href="#">OFF</a> <a id="tc_off" class="pure-button {{TC_LINK_PRIMARY_OFF}}" href="#">OFF</a>
</div> </div>
<script> <script>
var links = document.querySelectorAll('[id^="tc_on"]'); var links = document.querySelectorAll('[id^="tc_on"]');
@ -224,7 +224,7 @@
function updateLightState() { function updateLightState() {
console.log('----> setting bri and power switch <----'); console.log('----> setting bri and power switch <----');
for (let i = 1; i <= {{LIGHT_NUM}}; i++) { for (let i = 1; i <= {{LIGHT_COUNT}}; i++) {
const lightURL = `http://{{IP_ADDRESS}}/state?light=${i}`; const lightURL = `http://{{IP_ADDRESS}}/state?light=${i}`;
fetch(lightURL).then(response => response.json()).then(data => { fetch(lightURL).then(response => response.json()).then(data => {
const briSlider = document.getElementById(`bri${i - 1}`); const briSlider = document.getElementById(`bri${i - 1}`);
@ -249,7 +249,7 @@
function updatePWMValues() { function updatePWMValues() {
console.log('----> setting pwm data <----'); console.log('----> setting pwm data <----');
for (let i = 0; i < {{LIGHT_NUM}}; i++) { for (let i = 0; i < {{LIGHT_COUNT}}; i++) {
const lightID = i + 1; const lightID = i + 1;
const pwmElement = document.getElementById(`light${i}_pwm`); const pwmElement = document.getElementById(`light${i}_pwm`);
const pwmElementTxt = document.getElementById(`light${i}_pwm_txt`); const pwmElementTxt = document.getElementById(`light${i}_pwm_txt`);

View file

@ -87,7 +87,7 @@ void tc_init()
tc_last_check = millis(); tc_last_check = millis();
// Set the timezone to Europe/Berlin // Set the timezone to Europe/Berlin
setenv("TZ", "CET-1CEST,M3.5.0,M10.5.0/3", 1); setenv("TZ", LOCAL_TIMEZONE_STRING, 1);
tzset(); tzset();
timeClient.begin(); timeClient.begin();