mirror of https://github.com/arendst/Tasmota.git
parent
b9f6bf402a
commit
c39e2da6b5
|
@ -1,6 +1,7 @@
|
||||||
/* 6.4.1.16 20190211
|
/* 6.4.1.16 20190211
|
||||||
* Initial support for online template change using command Template or GUI Configure Other (#5177)
|
* Initial support for online template change using command Template or GUI Configure Other (#5177)
|
||||||
* Add parameter CFG_HOLDER to status 1 message (#5206)
|
* Add parameter CFG_HOLDER to status 1 message (#5206)
|
||||||
|
* Update GUI
|
||||||
*
|
*
|
||||||
* 6.4.1.15 20190208
|
* 6.4.1.15 20190208
|
||||||
* Change image name BE_MINIMAL to FIRMWARE_MINIMAL (#5106)
|
* Change image name BE_MINIMAL to FIRMWARE_MINIMAL (#5106)
|
||||||
|
|
|
@ -189,7 +189,10 @@ const char HTTP_HEAD_STYLE[] PROGMEM =
|
||||||
|
|
||||||
"<style>"
|
"<style>"
|
||||||
"div,fieldset,input,select{padding:5px;font-size:1em;}"
|
"div,fieldset,input,select{padding:5px;font-size:1em;}"
|
||||||
|
"fieldset{background-color:#f2f2f2;}"
|
||||||
|
"p{margin-block-start:0.5em;margin-block-end:0.5em;}"
|
||||||
"input{width:100%;box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;}"
|
"input{width:100%;box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;}"
|
||||||
|
"input[type=checkbox],input[type=radio]{width:1em;margin-right:6px;vertical-align:-1px;}"
|
||||||
"select{width:100%;}"
|
"select{width:100%;}"
|
||||||
"textarea{resize:none;width:98%;height:318px;padding:5px;overflow:auto;}"
|
"textarea{resize:none;width:98%;height:318px;padding:5px;overflow:auto;}"
|
||||||
"body{text-align:center;font-family:verdana;}"
|
"body{text-align:center;font-family:verdana;}"
|
||||||
|
@ -226,82 +229,108 @@ const char HTTP_MSG_SLIDER2[] PROGMEM =
|
||||||
"<div><input type='range' min='1' max='100' value='%d' onchange='lb(value)'></div>";
|
"<div><input type='range' min='1' max='100' value='%d' onchange='lb(value)'></div>";
|
||||||
const char HTTP_MSG_RSTRT[] PROGMEM =
|
const char HTTP_MSG_RSTRT[] PROGMEM =
|
||||||
"<br/><div style='text-align:center;'>" D_DEVICE_WILL_RESTART "</div><br/>";
|
"<br/><div style='text-align:center;'>" D_DEVICE_WILL_RESTART "</div><br/>";
|
||||||
|
|
||||||
const char HTTP_BTN_MENU1[] PROGMEM =
|
const char HTTP_BTN_MENU1[] PROGMEM =
|
||||||
#ifndef FIRMWARE_MINIMAL
|
|
||||||
"<br/><form action='cn' method='get'><button>" D_CONFIGURATION "</button></form>"
|
|
||||||
"<br/><form action='in' method='get'><button>" D_INFORMATION "</button></form>"
|
|
||||||
#endif
|
|
||||||
"<br/><form action='up' method='get'><button>" D_FIRMWARE_UPGRADE "</button></form>"
|
|
||||||
"<br/><form action='cs' method='get'><button>" D_CONSOLE "</button></form>";
|
|
||||||
const char HTTP_BTN_RSTRT[] PROGMEM =
|
|
||||||
"<br/><form action='.' method='get' onsubmit='return confirm(\"" D_CONFIRM_RESTART "\");'><button name='rstrt' class='button bred'>" D_RESTART "</button></form>";
|
|
||||||
const char HTTP_BTN_MENU_MODULE[] PROGMEM =
|
|
||||||
"<br/><form action='md' method='get'><button>" D_CONFIGURE_MODULE "</button></form>"
|
|
||||||
"<br/><form action='wi' method='get'><button>" D_CONFIGURE_WIFI "</button></form>";
|
|
||||||
const char HTTP_BTN_MENU4[] PROGMEM =
|
|
||||||
"<br/><form action='lg' method='get'><button>" D_CONFIGURE_LOGGING "</button></form>"
|
|
||||||
"<br/><form action='co' method='get'><button>" D_CONFIGURE_OTHER "</button></form>"
|
|
||||||
"<br/>"
|
"<br/>"
|
||||||
"<br/><form action='rt' method='get' onsubmit='return confirm(\"" D_CONFIRM_RESET_CONFIGURATION "\");'><button class='button bred'>" D_RESET_CONFIGURATION "</button></form>"
|
#ifndef FIRMWARE_MINIMAL
|
||||||
"<br/><form action='dl' method='get'><button>" D_BACKUP_CONFIGURATION "</button></form>"
|
"<form action='cn' method='get'><button>" D_CONFIGURATION "</button></form>"
|
||||||
"<br/><form action='rs' method='get'><button>" D_RESTORE_CONFIGURATION "</button></form>";
|
"<p><form action='in' method='get'><button>" D_INFORMATION "</button></form></p>"
|
||||||
|
#endif
|
||||||
|
"<form action='up' method='get'><button>" D_FIRMWARE_UPGRADE "</button></form>"
|
||||||
|
"<p><form action='cs' method='get'><button>" D_CONSOLE "</button></form></p>";
|
||||||
|
const char HTTP_BTN_RSTRT[] PROGMEM =
|
||||||
|
"<form action='.' method='get' onsubmit='return confirm(\"" D_CONFIRM_RESTART "\");'><button name='rstrt' class='button bred'>" D_RESTART "</button></form>";
|
||||||
|
|
||||||
|
const char HTTP_BTN_MENU_MODULE[] PROGMEM =
|
||||||
|
"<p><form action='md' method='get'><button>" D_CONFIGURE_MODULE "</button></form></p>"
|
||||||
|
"<p><form action='wi' method='get'><button>" D_CONFIGURE_WIFI "</button></form></p>";
|
||||||
|
const char HTTP_BTN_MENU4[] PROGMEM =
|
||||||
|
"<p><form action='lg' method='get'><button>" D_CONFIGURE_LOGGING "</button></form></p>"
|
||||||
|
"<p><form action='co' method='get'><button>" D_CONFIGURE_OTHER "</button></form></p>"
|
||||||
|
"<br/>"
|
||||||
|
"<form action='rt' method='get' onsubmit='return confirm(\"" D_CONFIRM_RESET_CONFIGURATION "\");'><button class='button bred'>" D_RESET_CONFIGURATION "</button></form>"
|
||||||
|
"<p><form action='dl' method='get'><button>" D_BACKUP_CONFIGURATION "</button></form></p>"
|
||||||
|
"<p><form action='rs' method='get'><button>" D_RESTORE_CONFIGURATION "</button></form></p>";
|
||||||
const char HTTP_BTN_MAIN[] PROGMEM =
|
const char HTTP_BTN_MAIN[] PROGMEM =
|
||||||
"<br/><br/><form action='.' method='get'><button>" D_MAIN_MENU "</button></form>";
|
"<br/>"
|
||||||
|
"<form action='.' method='get'><button>" D_MAIN_MENU "</button></form>";
|
||||||
|
|
||||||
const char HTTP_FORM_LOGIN[] PROGMEM =
|
const char HTTP_FORM_LOGIN[] PROGMEM =
|
||||||
"<form method='post' action='/'>"
|
"<form method='post' action='/'>"
|
||||||
"<br/><b>" D_USER "</b><br/><input name='USER1' placeholder='" D_USER "'><br/>"
|
"<br/><b>" D_USER "</b><br/><input name='USER1' placeholder='" D_USER "'><br/>"
|
||||||
"<br/><b>" D_PASSWORD "</b><br/><input name='PASS1' type='password' placeholder='" D_PASSWORD "'><br/>"
|
"<br/><b>" D_PASSWORD "</b><br/><input name='PASS1' type='password' placeholder='" D_PASSWORD "'><br/>"
|
||||||
"<br/>"
|
"<br/>"
|
||||||
"<br/><button>" D_OK "</button></form>";
|
"<br/><button>" D_OK "</button></form>";
|
||||||
|
|
||||||
const char HTTP_BTN_CONF[] PROGMEM =
|
const char HTTP_BTN_CONF[] PROGMEM =
|
||||||
"<br/><br/><form action='cn' method='get'><button>" D_CONFIGURATION "</button></form>";
|
"<br/>"
|
||||||
|
"<form action='cn' method='get'><button>" D_CONFIGURATION "</button></form>";
|
||||||
|
|
||||||
const char HTTP_FORM_MODULE[] PROGMEM =
|
const char HTTP_FORM_MODULE[] PROGMEM =
|
||||||
"<fieldset><legend><b> " D_MODULE_PARAMETERS " </b></legend><form method='get' action='md'>"
|
"<fieldset><legend><b> " D_MODULE_PARAMETERS " </b></legend><form method='get' action='md'>"
|
||||||
"<br/><b>" D_MODULE_TYPE "</b> ({mt)<br/><select id='g99' name='g99'></select><br/>";
|
"<p></p><b>" D_MODULE_TYPE "</b> ({mt)<br/><select id='g99' name='g99'></select><br/>";
|
||||||
|
|
||||||
const char HTTP_FORM_MODULE_PULLUP[] PROGMEM =
|
const char HTTP_FORM_MODULE_PULLUP[] PROGMEM =
|
||||||
"<br/><input style='width:10%;' id='b1' name='b1' type='checkbox'{r1><b>" D_PULLUP_ENABLE "</b><br/>";
|
"<br/><input id='b1' name='b1' type='checkbox'{r1><b>" D_PULLUP_ENABLE "</b><br/>";
|
||||||
|
|
||||||
const char HTTP_LNK_ITEM[] PROGMEM =
|
const char HTTP_LNK_ITEM[] PROGMEM =
|
||||||
"<div><a href='#p' onclick='c(this)'>{v}</a> ({w}) <span class='q'>{i} {r}%</span></div>";
|
"<div><a href='#p' onclick='c(this)'>{v}</a> ({w}) <span class='q'>{i} {r}%</span></div>";
|
||||||
const char HTTP_LNK_SCAN[] PROGMEM =
|
const char HTTP_LNK_SCAN[] PROGMEM =
|
||||||
"<div><a href='/wi?scan='>" D_SCAN_FOR_WIFI_NETWORKS "</a></div><br/>";
|
"<div><a href='/wi?scan='>" D_SCAN_FOR_WIFI_NETWORKS "</a></div><br/>";
|
||||||
const char HTTP_FORM_WIFI[] PROGMEM =
|
const char HTTP_FORM_WIFI[] PROGMEM =
|
||||||
"<fieldset><legend><b> " D_WIFI_PARAMETERS " </b></legend><form method='get' action='wi'>"
|
"<fieldset><legend><b> " D_WIFI_PARAMETERS " </b></legend>"
|
||||||
"<br/><b>" D_AP1_SSID "</b> (" STA_SSID1 ")<br/><input id='s1' name='s1' placeholder='" STA_SSID1 "' value='{s1'><br/>"
|
"<form method='get' action='wi'>"
|
||||||
"<br/><b>" D_AP1_PASSWORD "</b><br/><input id='p1' name='p1' type='password' placeholder='" D_AP1_PASSWORD "' value='" D_ASTERIX "'><br/>"
|
"<p><b>" D_AP1_SSID "</b> (" STA_SSID1 ")<br/><input id='s1' name='s1' placeholder='" STA_SSID1 "' value='{s1'></p>"
|
||||||
"<br/><b>" D_AP2_SSID "</b> (" STA_SSID2 ")<br/><input id='s2' name='s2' placeholder='" STA_SSID2 "' value='{s2'><br/>"
|
"<p><b>" D_AP1_PASSWORD "</b><br/><input id='p1' name='p1' type='password' placeholder='" D_AP1_PASSWORD "' value='" D_ASTERIX "'></p>"
|
||||||
"<br/><b>" D_AP2_PASSWORD "</b><br/><input id='p2' name='p2' type='password' placeholder='" D_AP2_PASSWORD "' value='" D_ASTERIX "'><br/>"
|
"<p><b>" D_AP2_SSID "</b> (" STA_SSID2 ")<br/><input id='s2' name='s2' placeholder='" STA_SSID2 "' value='{s2'></p>"
|
||||||
"<br/><b>" D_HOSTNAME "</b> (" WIFI_HOSTNAME ")<br/><input id='h' name='h' placeholder='" WIFI_HOSTNAME" ' value='{h1'><br/>";
|
"<p><b>" D_AP2_PASSWORD "</b><br/><input id='p2' name='p2' type='password' placeholder='" D_AP2_PASSWORD "' value='" D_ASTERIX "'></p>"
|
||||||
|
"<p><b>" D_HOSTNAME "</b> (" WIFI_HOSTNAME ")<br/><input id='h' name='h' placeholder='" WIFI_HOSTNAME" ' value='{h1'></p>";
|
||||||
|
|
||||||
const char HTTP_FORM_LOG1[] PROGMEM =
|
const char HTTP_FORM_LOG1[] PROGMEM =
|
||||||
"<fieldset><legend><b> " D_LOGGING_PARAMETERS " </b></legend><form method='get' action='lg'>";
|
"<fieldset><legend><b> " D_LOGGING_PARAMETERS " </b>"
|
||||||
|
"</legend><form method='get' action='lg'>";
|
||||||
const char HTTP_FORM_LOG2[] PROGMEM =
|
const char HTTP_FORM_LOG2[] PROGMEM =
|
||||||
"<br/><b>{b0</b> ({b1)<br/><select id='{b2' name='{b2'>"
|
"<p><b>{b0</b> ({b1)<br/><select id='{b2' name='{b2'>"
|
||||||
"<option{a0value='0'>0 " D_NONE "</option>"
|
"<option{a0value='0'>0 " D_NONE "</option>"
|
||||||
"<option{a1value='1'>1 " D_ERROR "</option>"
|
"<option{a1value='1'>1 " D_ERROR "</option>"
|
||||||
"<option{a2value='2'>2 " D_INFO "</option>"
|
"<option{a2value='2'>2 " D_INFO "</option>"
|
||||||
"<option{a3value='3'>3 " D_DEBUG "</option>"
|
"<option{a3value='3'>3 " D_DEBUG "</option>"
|
||||||
"<option{a4value='4'>4 " D_MORE_DEBUG "</option>"
|
"<option{a4value='4'>4 " D_MORE_DEBUG "</option>"
|
||||||
"</select><br/>";
|
"</select></p>";
|
||||||
const char HTTP_FORM_LOG3[] PROGMEM =
|
const char HTTP_FORM_LOG3[] PROGMEM =
|
||||||
"<br/><b>" D_SYSLOG_HOST "</b> (" SYS_LOG_HOST ")<br/><input id='lh' name='lh' placeholder='" SYS_LOG_HOST "' value='{l2'><br/>"
|
"<p><b>" D_SYSLOG_HOST "</b> (" SYS_LOG_HOST ")<br/><input id='lh' name='lh' placeholder='" SYS_LOG_HOST "' value='{l2'></p>"
|
||||||
"<br/><b>" D_SYSLOG_PORT "</b> (" STR(SYS_LOG_PORT) ")<br/><input id='lp' name='lp' placeholder='" STR(SYS_LOG_PORT) "' value='{l3'><br/>"
|
"<p><b>" D_SYSLOG_PORT "</b> (" STR(SYS_LOG_PORT) ")<br/><input id='lp' name='lp' placeholder='" STR(SYS_LOG_PORT) "' value='{l3'></p>"
|
||||||
"<br/><b>" D_TELEMETRY_PERIOD "</b> (" STR(TELE_PERIOD) ")<br/><input id='lt' name='lt' placeholder='" STR(TELE_PERIOD) "' value='{l4'><br/>";
|
"<p><b>" D_TELEMETRY_PERIOD "</b> (" STR(TELE_PERIOD) ")<br/><input id='lt' name='lt' placeholder='" STR(TELE_PERIOD) "' value='{l4'></p>";
|
||||||
|
|
||||||
const char HTTP_FORM_OTHER[] PROGMEM =
|
const char HTTP_FORM_OTHER[] PROGMEM =
|
||||||
"<fieldset><legend><b> " D_OTHER_PARAMETERS " </b></legend><form method='get' action='co'>"
|
"<fieldset><legend><b> " D_OTHER_PARAMETERS " </b></legend>"
|
||||||
"<br/><b>" D_TEMPLATE "</b><br/><input id='t1' name='t1' placeholder='" D_TEMPLATE "' value='{t1'><br/>"
|
"<form method='get' action='co'>"
|
||||||
"<br/><b>" D_WEB_ADMIN_PASSWORD "</b><br/><input id='p1' name='p1' type='password' placeholder='" D_WEB_ADMIN_PASSWORD "' value='" D_ASTERIX "'><br/>"
|
"<p></p>"
|
||||||
"<br/><input style='width:10%;' id='b1' name='b1' type='checkbox'{r1><b>" D_MQTT_ENABLE "</b><br/>";
|
"<fieldset><legend><b> " D_TEMPLATE " </b></legend>"
|
||||||
|
"<p><input id='t1' name='t1' placeholder='" D_TEMPLATE "' value='{t1'></p>"
|
||||||
|
"<p><input id='t2' name='t2' type='checkbox'><b>" D_ACTIVATE "</b></p>"
|
||||||
|
"</fieldset>"
|
||||||
|
"<br/>"
|
||||||
|
"<b>" D_WEB_ADMIN_PASSWORD "</b><br/><input id='p1' name='p1' type='password' placeholder='" D_WEB_ADMIN_PASSWORD "' value='" D_ASTERIX "'><br/>"
|
||||||
|
"<br>"
|
||||||
|
"<input id='b1' name='b1' type='checkbox'{r1><b>" D_MQTT_ENABLE "</b><br/>"
|
||||||
|
"<br/>";
|
||||||
const char HTTP_FORM_OTHER2[] PROGMEM =
|
const char HTTP_FORM_OTHER2[] PROGMEM =
|
||||||
"<br/><b>" D_FRIENDLY_NAME " {1</b> ({2)<br/><input id='a{1' name='a{1' placeholder='{2' value='{3'><br/>";
|
"<b>" D_FRIENDLY_NAME " {1</b> ({2)<br/><input id='a{1' name='a{1' placeholder='{2' value='{3'><p></p>";
|
||||||
#ifdef USE_EMULATION
|
#ifdef USE_EMULATION
|
||||||
const char HTTP_FORM_OTHER3a[] PROGMEM =
|
const char HTTP_FORM_OTHER3a[] PROGMEM =
|
||||||
"<br/><fieldset><legend><b> " D_EMULATION " </b></legend>";
|
"<p></p>" // Keep close to Friendlynames so do not use <br/>
|
||||||
|
"<fieldset><legend><b> " D_EMULATION " </b></legend><p>";
|
||||||
const char HTTP_FORM_OTHER3b[] PROGMEM =
|
const char HTTP_FORM_OTHER3b[] PROGMEM =
|
||||||
"<br/><input style='width:10%;' id='r{1' name='b2' type='radio' value='{1'{2><b>{3</b>{4"; // Different id only used for labels
|
"<input id='r{1' name='b2' type='radio' value='{1'{2><b>{3</b>{4<br/>"; // Different id only used for labels
|
||||||
|
const char HTTP_FORM_OTHER3c[] PROGMEM =
|
||||||
|
"</p></fieldset>";
|
||||||
#endif // USE_EMULATION
|
#endif // USE_EMULATION
|
||||||
|
|
||||||
const char HTTP_FORM_END[] PROGMEM =
|
const char HTTP_FORM_END[] PROGMEM =
|
||||||
"<br/><button name='save' type='submit' class='button bgrn'>" D_SAVE "</button></form></fieldset>";
|
"<br/>"
|
||||||
|
"<button name='save' type='submit' class='button bgrn'>" D_SAVE "</button>"
|
||||||
|
"</form></fieldset>";
|
||||||
|
|
||||||
const char HTTP_FORM_RST[] PROGMEM =
|
const char HTTP_FORM_RST[] PROGMEM =
|
||||||
"<div id='f1' name='f1' style='display:block;'>"
|
"<div id='f1' name='f1' style='display:block;'>"
|
||||||
"<fieldset><legend><b> " D_RESTORE_CONFIGURATION " </b></legend>";
|
"<fieldset><legend><b> " D_RESTORE_CONFIGURATION " </b></legend>";
|
||||||
|
@ -1177,6 +1206,7 @@ void HandleOtherConfiguration(void)
|
||||||
page.replace(F("{2"), (i) ? stemp : FRIENDLY_NAME);
|
page.replace(F("{2"), (i) ? stemp : FRIENDLY_NAME);
|
||||||
page.replace(F("{3"), Settings.friendlyname[i]);
|
page.replace(F("{3"), Settings.friendlyname[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_EMULATION
|
#ifdef USE_EMULATION
|
||||||
page += FPSTR(HTTP_FORM_OTHER3a);
|
page += FPSTR(HTTP_FORM_OTHER3a);
|
||||||
for (uint8_t i = 0; i < EMUL_MAX; i++) {
|
for (uint8_t i = 0; i < EMUL_MAX; i++) {
|
||||||
|
@ -1186,9 +1216,9 @@ void HandleOtherConfiguration(void)
|
||||||
page.replace(F("{3"), (i == EMUL_NONE) ? F(D_NONE) : (i == EMUL_WEMO) ? F(D_BELKIN_WEMO) : F(D_HUE_BRIDGE));
|
page.replace(F("{3"), (i == EMUL_NONE) ? F(D_NONE) : (i == EMUL_WEMO) ? F(D_BELKIN_WEMO) : F(D_HUE_BRIDGE));
|
||||||
page.replace(F("{4"), (i == EMUL_NONE) ? F("") : (i == EMUL_WEMO) ? F(" " D_SINGLE_DEVICE) : F(" " D_MULTI_DEVICE));
|
page.replace(F("{4"), (i == EMUL_NONE) ? F("") : (i == EMUL_WEMO) ? F(" " D_SINGLE_DEVICE) : F(" " D_MULTI_DEVICE));
|
||||||
}
|
}
|
||||||
page += F("<br/>");
|
page += FPSTR(HTTP_FORM_OTHER3c);
|
||||||
page += F("<br/></fieldset>");
|
|
||||||
#endif // USE_EMULATION
|
#endif // USE_EMULATION
|
||||||
|
|
||||||
page += FPSTR(HTTP_FORM_END);
|
page += FPSTR(HTTP_FORM_END);
|
||||||
page += FPSTR(HTTP_BTN_CONF);
|
page += FPSTR(HTTP_BTN_CONF);
|
||||||
ShowPage(page);
|
ShowPage(page);
|
||||||
|
@ -1221,6 +1251,12 @@ void OtherSaveSettings(void)
|
||||||
char svalue[128];
|
char svalue[128];
|
||||||
snprintf_P(svalue, sizeof(svalue), PSTR(D_CMND_TEMPLATE " %s"), tmp);
|
snprintf_P(svalue, sizeof(svalue), PSTR(D_CMND_TEMPLATE " %s"), tmp);
|
||||||
ExecuteWebCommand(svalue, SRC_WEBGUI);
|
ExecuteWebCommand(svalue, SRC_WEBGUI);
|
||||||
|
|
||||||
|
if (WebServer->hasArg("t2")) {
|
||||||
|
snprintf_P(svalue, sizeof(svalue), PSTR(D_CMND_MODULE " 0"));
|
||||||
|
ExecuteWebCommand(svalue, SRC_WEBGUI);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -868,17 +868,18 @@ bool MqttCommand(void)
|
||||||
const char S_CONFIGURE_MQTT[] PROGMEM = D_CONFIGURE_MQTT;
|
const char S_CONFIGURE_MQTT[] PROGMEM = D_CONFIGURE_MQTT;
|
||||||
|
|
||||||
const char HTTP_BTN_MENU_MQTT[] PROGMEM =
|
const char HTTP_BTN_MENU_MQTT[] PROGMEM =
|
||||||
"<br/><form action='" WEB_HANDLE_MQTT "' method='get'><button>" D_CONFIGURE_MQTT "</button></form>";
|
"<p><form action='" WEB_HANDLE_MQTT "' method='get'><button>" D_CONFIGURE_MQTT "</button></form></p>";
|
||||||
|
|
||||||
const char HTTP_FORM_MQTT[] PROGMEM =
|
const char HTTP_FORM_MQTT[] PROGMEM =
|
||||||
"<fieldset><legend><b> " D_MQTT_PARAMETERS " </b></legend><form method='get' action='" WEB_HANDLE_MQTT "'>"
|
"<fieldset><legend><b> " D_MQTT_PARAMETERS " </b></legend>"
|
||||||
"<br/><b>" D_HOST "</b> (" MQTT_HOST ")<br/><input id='mh' name='mh' placeholder='" MQTT_HOST" ' value='{m1'><br/>"
|
"<form method='get' action='" WEB_HANDLE_MQTT "'>"
|
||||||
"<br/><b>" D_PORT "</b> (" STR(MQTT_PORT) ")<br/><input id='ml' name='ml' placeholder='" STR(MQTT_PORT) "' value='{m2'><br/>"
|
"<p><b>" D_HOST "</b> (" MQTT_HOST ")<br/><input id='mh' name='mh' placeholder='" MQTT_HOST" ' value='{m1'></p>"
|
||||||
"<br/><b>" D_CLIENT "</b> ({m0)<br/><input id='mc' name='mc' placeholder='" MQTT_CLIENT_ID "' value='{m3'><br/>"
|
"<p><b>" D_PORT "</b> (" STR(MQTT_PORT) ")<br/><input id='ml' name='ml' placeholder='" STR(MQTT_PORT) "' value='{m2'></p>"
|
||||||
"<br/><b>" D_USER "</b> (" MQTT_USER ")<br/><input id='mu' name='mu' placeholder='" MQTT_USER "' value='{m4'><br/>"
|
"<p><b>" D_CLIENT "</b> ({m0)<br/><input id='mc' name='mc' placeholder='" MQTT_CLIENT_ID "' value='{m3'></p>"
|
||||||
"<br/><b>" D_PASSWORD "</b><br/><input id='mp' name='mp' type='password' placeholder='" D_PASSWORD "' value='" D_ASTERIX "'><br/>"
|
"<p><b>" D_USER "</b> (" MQTT_USER ")<br/><input id='mu' name='mu' placeholder='" MQTT_USER "' value='{m4'></p>"
|
||||||
"<br/><b>" D_TOPIC "</b> = %topic% (" MQTT_TOPIC ")<br/><input id='mt' name='mt' placeholder='" MQTT_TOPIC" ' value='{m6'><br/>"
|
"<p><b>" D_PASSWORD "</b><br/><input id='mp' name='mp' type='password' placeholder='" D_PASSWORD "' value='" D_ASTERIX "'></p>"
|
||||||
"<br/><b>" D_FULL_TOPIC "</b> (" MQTT_FULLTOPIC ")<br/><input id='mf' name='mf' placeholder='" MQTT_FULLTOPIC" ' value='{m7'><br/>";
|
"<p><b>" D_TOPIC "</b> = %topic% (" MQTT_TOPIC ")<br/><input id='mt' name='mt' placeholder='" MQTT_TOPIC" ' value='{m6'></p>"
|
||||||
|
"<p><b>" D_FULL_TOPIC "</b> (" MQTT_FULLTOPIC ")<br/><input id='mf' name='mf' placeholder='" MQTT_FULLTOPIC" ' value='{m7'></p>";
|
||||||
|
|
||||||
void HandleMqttConfiguration(void)
|
void HandleMqttConfiguration(void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -431,11 +431,13 @@ void DomoticzSensorPowerEnergy(int power, char *energy)
|
||||||
const char S_CONFIGURE_DOMOTICZ[] PROGMEM = D_CONFIGURE_DOMOTICZ;
|
const char S_CONFIGURE_DOMOTICZ[] PROGMEM = D_CONFIGURE_DOMOTICZ;
|
||||||
|
|
||||||
const char HTTP_BTN_MENU_DOMOTICZ[] PROGMEM =
|
const char HTTP_BTN_MENU_DOMOTICZ[] PROGMEM =
|
||||||
"<br/><form action='" WEB_HANDLE_DOMOTICZ "' method='get'><button>" D_CONFIGURE_DOMOTICZ "</button></form>";
|
"<p><form action='" WEB_HANDLE_DOMOTICZ "' method='get'><button>" D_CONFIGURE_DOMOTICZ "</button></form></p>";
|
||||||
|
|
||||||
const char HTTP_FORM_DOMOTICZ[] PROGMEM =
|
const char HTTP_FORM_DOMOTICZ[] PROGMEM =
|
||||||
"<fieldset><legend><b> " D_DOMOTICZ_PARAMETERS " </b></legend><form method='post' action='" WEB_HANDLE_DOMOTICZ "'>"
|
"<fieldset><legend><b> " D_DOMOTICZ_PARAMETERS " </b></legend>"
|
||||||
"<br/><table>";
|
"<form method='post' action='" WEB_HANDLE_DOMOTICZ "'>"
|
||||||
|
"<br/>"
|
||||||
|
"<table>";
|
||||||
const char HTTP_FORM_DOMOTICZ_RELAY[] PROGMEM =
|
const char HTTP_FORM_DOMOTICZ_RELAY[] PROGMEM =
|
||||||
"<tr><td style='width:260px'><b>" D_DOMOTICZ_IDX " {1</b></td><td style='width:70px'><input id='r{1' name='r{1' placeholder='0' value='{2'></td></tr>"
|
"<tr><td style='width:260px'><b>" D_DOMOTICZ_IDX " {1</b></td><td style='width:70px'><input id='r{1' name='r{1' placeholder='0' value='{2'></td></tr>"
|
||||||
"<tr><td style='width:260px'><b>" D_DOMOTICZ_KEY_IDX " {1</b></td><td style='width:70px'><input id='k{1' name='k{1' placeholder='0' value='{3'></td></tr>";
|
"<tr><td style='width:260px'><b>" D_DOMOTICZ_KEY_IDX " {1</b></td><td style='width:70px'><input id='k{1' name='k{1' placeholder='0' value='{3'></td></tr>";
|
||||||
|
|
|
@ -517,7 +517,7 @@ bool TimerCommand(void)
|
||||||
const char S_CONFIGURE_TIMER[] PROGMEM = D_CONFIGURE_TIMER;
|
const char S_CONFIGURE_TIMER[] PROGMEM = D_CONFIGURE_TIMER;
|
||||||
|
|
||||||
const char HTTP_BTN_MENU_TIMER[] PROGMEM =
|
const char HTTP_BTN_MENU_TIMER[] PROGMEM =
|
||||||
"<br/><form action='" WEB_HANDLE_TIMER "' method='get'><button>" D_CONFIGURE_TIMER "</button></form>";
|
"<p><form action='" WEB_HANDLE_TIMER "' method='get'><button>" D_CONFIGURE_TIMER "</button></form></p>";
|
||||||
|
|
||||||
const char HTTP_TIMER_SCRIPT[] PROGMEM =
|
const char HTTP_TIMER_SCRIPT[] PROGMEM =
|
||||||
"var pt=[],ct=99;"
|
"var pt=[],ct=99;"
|
||||||
|
@ -637,36 +637,34 @@ const char HTTP_TIMER_SCRIPT[] PROGMEM =
|
||||||
"o=qs('#mw');for(i=0;i<=15;i++){ce((i<10)?('0'+i):i,o);}" // Create window minutes select options
|
"o=qs('#mw');for(i=0;i<=15;i++){ce((i<10)?('0'+i):i,o);}" // Create window minutes select options
|
||||||
"o=qs('#d1');for(i=0;i<}1;i++){ce(i+1,o);}" // Create outputs
|
"o=qs('#d1');for(i=0;i<}1;i++){ce(i+1,o);}" // Create outputs
|
||||||
"var a='" D_DAY3LIST "';"
|
"var a='" D_DAY3LIST "';"
|
||||||
"s='';for(i=0;i<7;i++){s+=\"<input style='width:5%;' id='w\"+i+\"' name='w\"+i+\"' type='checkbox'><b>\"+a.substring(i*3,(i*3)+3)+\"</b>\"}"
|
"s='';for(i=0;i<7;i++){s+=\"<input id='w\"+i+\"' name='w\"+i+\"' type='checkbox'><b>\"+a.substring(i*3,(i*3)+3)+\"</b> \"}"
|
||||||
"eb('ds').innerHTML=s;" // Create weekdays
|
"eb('ds').innerHTML=s;" // Create weekdays
|
||||||
"eb('dP').click();" // Get the element with id='dP' and click on it
|
"eb('dP').click();" // Get the element with id='dP' and click on it
|
||||||
"}";
|
"}";
|
||||||
const char HTTP_TIMER_STYLE[] PROGMEM =
|
const char HTTP_TIMER_STYLE[] PROGMEM =
|
||||||
".tl{float:left;border-radius:0;border:1px solid #fff;padding:1px;width:6.25%;}"
|
".tl{float:left;border-radius:0;border:1px solid #fff;padding:1px;width:6.25%;}"
|
||||||
#ifdef USE_SUNRISE
|
|
||||||
"input[type='radio']{width:13px;height:24px;margin-top:-1px;margin-right:8px;vertical-align:middle;}"
|
|
||||||
#endif
|
|
||||||
"</style>";
|
"</style>";
|
||||||
const char HTTP_FORM_TIMER[] PROGMEM =
|
const char HTTP_FORM_TIMER[] PROGMEM =
|
||||||
"<fieldset style='min-width:470px;text-align:center;'>"
|
"<fieldset style='min-width:470px;text-align:center;'>"
|
||||||
"<legend style='text-align:left;'><b> " D_TIMER_PARAMETERS " </b></legend>"
|
"<legend style='text-align:left;'><b> " D_TIMER_PARAMETERS " </b></legend>"
|
||||||
"<form method='post' action='" WEB_HANDLE_TIMER "' onsubmit='return st();'>"
|
"<form method='post' action='" WEB_HANDLE_TIMER "' onsubmit='return st();'>"
|
||||||
"<br/><input style='width:5%;' id='e0' name='e0' type='checkbox'{e0><b>" D_TIMER_ENABLE "</b><br/><br/><hr/>"
|
"<br/><input id='e0' name='e0' type='checkbox'{e0><b>" D_TIMER_ENABLE "</b><br/><br/><hr/>"
|
||||||
"<input id='t0' name='t0' value='";
|
"<input id='t0' name='t0' value='";
|
||||||
const char HTTP_FORM_TIMER1[] PROGMEM =
|
const char HTTP_FORM_TIMER1[] PROGMEM =
|
||||||
"' hidden><div id='bt' name='bt'></div><br/><br/><br/>"
|
"' hidden><div id='bt' name='bt'></div><br/><br/><br/>"
|
||||||
"<div id='oa' name='oa'></div><br/>"
|
"<div id='oa' name='oa'></div><br/>"
|
||||||
"<div>"
|
"<div>"
|
||||||
"<input style='width:5%;' id='a0' name='a0' type='checkbox'><b>" D_TIMER_ARM "</b> "
|
"<input id='a0' name='a0' type='checkbox'><b>" D_TIMER_ARM "</b> "
|
||||||
"<input style='width:5%;' id='r0' name='r0' type='checkbox'><b>" D_TIMER_REPEAT "</b>"
|
"<input id='r0' name='r0' type='checkbox'><b>" D_TIMER_REPEAT "</b>"
|
||||||
"</div><br/>"
|
"</div><br/>"
|
||||||
"<div>"
|
"<div>"
|
||||||
#ifdef USE_SUNRISE
|
#ifdef USE_SUNRISE
|
||||||
"<fieldset style='width:299px;margin:auto;text-align:left;border:0;'>"
|
"<fieldset style='width:299px;margin:auto;text-align:left;border:0;'>" // 299 used in page.replace(F("299")
|
||||||
"<input id='b0' name='rd' type='radio' value='0' onclick='gt();'><b>" D_TIMER_TIME "</b><br/>"
|
"<input id='b0' name='rd' type='radio' value='0' onclick='gt();'><b>" D_TIMER_TIME "</b><br/>"
|
||||||
"<input id='b1' name='rd' type='radio' value='1' onclick='gt();'><b>" D_SUNRISE "</b> (}8)<br/>"
|
"<input id='b1' name='rd' type='radio' value='1' onclick='gt();'><b>" D_SUNRISE "</b> (}8)<br/>"
|
||||||
"<input id='b2' name='rd' type='radio' value='2' onclick='gt();'><b>" D_SUNSET "</b> (}9)<br/>"
|
"<input id='b2' name='rd' type='radio' value='2' onclick='gt();'><b>" D_SUNSET "</b> (}9)<br/>"
|
||||||
"</fieldset>"
|
"</fieldset>"
|
||||||
|
"<p></p>"
|
||||||
"<span><select style='width:46px;' id='dr' name='dr'></select></span>"
|
"<span><select style='width:46px;' id='dr' name='dr'></select></span>"
|
||||||
" "
|
" "
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -752,20 +752,21 @@ void KnxSensor(uint8_t sensor_type, float value)
|
||||||
const char S_CONFIGURE_KNX[] PROGMEM = D_CONFIGURE_KNX;
|
const char S_CONFIGURE_KNX[] PROGMEM = D_CONFIGURE_KNX;
|
||||||
|
|
||||||
const char HTTP_BTN_MENU_KNX[] PROGMEM =
|
const char HTTP_BTN_MENU_KNX[] PROGMEM =
|
||||||
"<br/><form action='kn' method='get'><button>" D_CONFIGURE_KNX "</button></form>";
|
"<p><form action='kn' method='get'><button>" D_CONFIGURE_KNX "</button></form></p>";
|
||||||
|
|
||||||
const char HTTP_FORM_KNX[] PROGMEM =
|
const char HTTP_FORM_KNX[] PROGMEM =
|
||||||
"<fieldset><legend style='text-align:left;'><b> " D_KNX_PARAMETERS " </b></legend><form method='post' action='kn'>"
|
"<fieldset><legend style='text-align:left;'><b> " D_KNX_PARAMETERS " </b>"
|
||||||
|
"</legend><form method='post' action='kn'>"
|
||||||
"<br/><center>"
|
"<br/><center>"
|
||||||
"<b>" D_KNX_PHYSICAL_ADDRESS " </b>"
|
"<b>" D_KNX_PHYSICAL_ADDRESS " </b>"
|
||||||
"<input style='width:12%;' type='number' name='area' min='0' max='15' value='{kna'> . "
|
"<input style='width:12%;' type='number' name='area' min='0' max='15' value='{kna'> . "
|
||||||
"<input style='width:12%;' type='number' name='line' min='0' max='15' value='{knl'> . "
|
"<input style='width:12%;' type='number' name='line' min='0' max='15' value='{knl'> . "
|
||||||
"<input style='width:12%;' type='number' name='member' min='0' max='255' value='{knm'>"
|
"<input style='width:12%;' type='number' name='member' min='0' max='255' value='{knm'>"
|
||||||
"<br/><br/>" D_KNX_PHYSICAL_ADDRESS_NOTE "<br/><br/>"
|
"<br/><br/>" D_KNX_PHYSICAL_ADDRESS_NOTE "<br/><br/>"
|
||||||
"<input style='width:10%;' id='b1' name='b1' type='checkbox'";
|
"<input id='b1' name='b1' type='checkbox'";
|
||||||
|
|
||||||
const char HTTP_FORM_KNX1[] PROGMEM =
|
const char HTTP_FORM_KNX1[] PROGMEM =
|
||||||
"><b>" D_KNX_ENABLE " </b><input style='width:10%;' id='b2' name='b2' type='checkbox'";
|
"><b>" D_KNX_ENABLE "</b> <input id='b2' name='b2' type='checkbox'";
|
||||||
|
|
||||||
const char HTTP_FORM_KNX2[] PROGMEM =
|
const char HTTP_FORM_KNX2[] PROGMEM =
|
||||||
"><b>" D_KNX_ENHANCEMENT "</b><br/></center><br/>"
|
"><b>" D_KNX_ENHANCEMENT "</b><br/></center><br/>"
|
||||||
|
|
|
@ -377,19 +377,19 @@ const char HTTP_BTN_MENU_MAIN_HX711[] PROGMEM =
|
||||||
"<br/><form action='" WEB_HANDLE_HX711 "' method='get'><button name='reset'>" D_RESET_HX711 "</button></form>";
|
"<br/><form action='" WEB_HANDLE_HX711 "' method='get'><button name='reset'>" D_RESET_HX711 "</button></form>";
|
||||||
|
|
||||||
const char HTTP_BTN_MENU_HX711[] PROGMEM =
|
const char HTTP_BTN_MENU_HX711[] PROGMEM =
|
||||||
"<br/><form action='" WEB_HANDLE_HX711 "' method='get'><button>" D_CONFIGURE_HX711 "</button></form>";
|
"<p><form action='" WEB_HANDLE_HX711 "' method='get'><button>" D_CONFIGURE_HX711 "</button></form></p>";
|
||||||
|
|
||||||
const char HTTP_FORM_HX711[] PROGMEM =
|
const char HTTP_FORM_HX711[] PROGMEM =
|
||||||
"<fieldset><legend><b> " D_CALIBRATION " </b></legend>"
|
"<fieldset><legend><b> " D_CALIBRATION " </b></legend>"
|
||||||
"<form method='post' action='" WEB_HANDLE_HX711 "'>"
|
"<form method='post' action='" WEB_HANDLE_HX711 "'>"
|
||||||
"<br/><b>" D_REFERENCE_WEIGHT "</b> (" D_UNIT_KILOGRAM ")<br/><input type='number' step='0.001' id='p1' name='p1' placeholder='0' value='{1'><br/>"
|
"<p><b>" D_REFERENCE_WEIGHT "</b> (" D_UNIT_KILOGRAM ")<br/><input type='number' step='0.001' id='p1' name='p1' placeholder='0' value='{1'></p>"
|
||||||
"<br/><button name='calibrate' type='submit'>" D_CALIBRATE "</button><br/>"
|
"<br/><button name='calibrate' type='submit'>" D_CALIBRATE "</button>"
|
||||||
"</form>"
|
"</form>"
|
||||||
"</fieldset><br/><br/>"
|
"</fieldset><br/><br/>"
|
||||||
|
|
||||||
"<fieldset><legend><b> " D_HX711_PARAMETERS " </b></legend>"
|
"<fieldset><legend><b> " D_HX711_PARAMETERS " </b></legend>"
|
||||||
"<form method='post' action='" WEB_HANDLE_HX711 "'>"
|
"<form method='post' action='" WEB_HANDLE_HX711 "'>"
|
||||||
"<br/><b>" D_ITEM_WEIGHT "</b> (" D_UNIT_KILOGRAM ")<br/><input type='number' max='6.5535' step='0.0001' id='p2' name='p2' placeholder='0.0' value='{2'><br/>";
|
"<p><b>" D_ITEM_WEIGHT "</b> (" D_UNIT_KILOGRAM ")<br/><input type='number' max='6.5535' step='0.0001' id='p2' name='p2' placeholder='0.0' value='{2'></p>";
|
||||||
|
|
||||||
void HandleHxAction(void)
|
void HandleHxAction(void)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue