Browse Source

Merge branch 'zero-export' into patch-2

pull/1638/head
DanielR92 8 months ago
committed by GitHub
parent
commit
1e43f0c854
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 18
      src/plugins/zeroExport/powermeter.h
  2. 29
      src/web/html/setup.html

18
src/plugins/zeroExport/powermeter.h

@ -103,8 +103,8 @@ class powermeter {
863.25 MHz - geht (ohne Tibber Probleme) => 3 & 4 Balken 863.25 MHz - geht (ohne Tibber Probleme) => 3 & 4 Balken
*/ */
case zeroExportPowermeterType_t::Tibber: case zeroExportPowermeterType_t::Tibber:
if(mCfg->groups[group].pm_refresh < 3) mCfg->groups[group].pm_refresh = 3;
result = getPowermeterWattsTibber(*mLog, group, &power); result = getPowermeterWattsTibber(*mLog, group, &power);
mPreviousTsp += 2000; // Zusätzliche Pause
break; break;
#endif #endif
#if defined(ZEROEXPORT_POWERMETER_SHRDZM) #if defined(ZEROEXPORT_POWERMETER_SHRDZM)
@ -114,15 +114,16 @@ class powermeter {
#endif #endif
} }
if (result) { //if (mMqtt->isConnected()) mMqtt->publish(String("zero/state/groups/" + String(group) + "/result").c_str(), String(ret).c_str(), false);
if (result)
{
bufferWrite(power, group); bufferWrite(power, group);
// MQTT - Powermeter // MQTT - Powermeter
// if (mCfg->debug) {
if (mMqtt->isConnected()) { if (mMqtt->isConnected()) {
mMqtt->publish(String("zero/state/groups/" + String(group) + "/powermeter/P").c_str(), String(ah::round1(power)).c_str(), false); mMqtt->publish(String("zero/state/groups/" + String(group) + "/powermeter/P").c_str(), String(ah::round1(power)).c_str(), false);
} }
// }
} }
} }
} }
@ -181,7 +182,7 @@ class powermeter {
} }
/** onMqttMessage /** onMqttMessage
* * This function is needed for all mqtt connections between ahoy and other devices.
*/ */
void onMqttMessage(JsonObject obj) { void onMqttMessage(JsonObject obj) {
String topic = String(obj["topic"]); String topic = String(obj["topic"]);
@ -492,20 +493,19 @@ class powermeter {
{{0x01, 0x00, 0x02, 0x08, 0x00, 0xff}, &smlOBISWh, &_powerMeterExport}}; {{0x01, 0x00, 0x02, 0x08, 0x00, 0xff}, &smlOBISWh, &_powerMeterExport}};
bool getPowermeterWattsTibber(JsonObject logObj, uint8_t group, float *power) { bool getPowermeterWattsTibber(JsonObject logObj, uint8_t group, float *power) {
mPreviousTsp = mPreviousTsp + 2000; // Zusätzliche Pause
bool result = false; bool result = false;
logObj["mod"] = "getPowermeterWattsTibber"; logObj["mod"] = "getPowermeterWattsTibber";
String auth = mCfg->groups[group].pm_pass; String auth = mCfg->groups[group].pm_pass;
String url = String("http://") + mCfg->groups[group].pm_url + String("/") + String(mCfg->groups[group].pm_jsonPath); String url = String("http://") + mCfg->groups[group].pm_src + String("/") + String(mCfg->groups[group].pm_jsonPath);
setHeader(&http); setHeader(&http);
http.begin(url); http.begin(url);
http.addHeader("Authorization", "Basic " + auth); http.addHeader("Authorization", "Basic " + auth);
if (http.GET() == HTTP_CODE_OK && http.getSize() > 0) { if (http.GET() == HTTP_CODE_OK && http.getSize() > 0)
{
String myString = http.getString(); String myString = http.getString();
double readVal = 0; double readVal = 0;
unsigned char c; unsigned char c;

29
src/web/html/setup.html

@ -1509,8 +1509,8 @@
} }
// add addEventListener // add addEventListener
const selectElement = document.querySelector("#pm_type"); const se_pm_type = document.querySelector("#pm_type");
selectElement.addEventListener("change", (event) => { pm_type_dropdown() }); se_pm_type.addEventListener("change", (event) => { pm_type_dropdown() });
// run event one time // run event one time
pm_type_dropdown(); pm_type_dropdown();
@ -1566,6 +1566,31 @@
} }
} }
// add addEventListener
const se_battCfg = document.querySelector("#battCfg");
se_battCfg.addEventListener("change", (event) => { battCfg_dropdown() });
// run event one time
battCfg_dropdown();
function battCfg_dropdown()
{
var e = document.getElementsByName("battCfg")[0];
var value = e.options[e.selectedIndex].text;
var divsToHide = document.getElementById("divBattery");
// Formular for Powermeter-DropDown
// show all DIVs and remove only what is not necessary
// 1 = pm_refresh, 2 = pm_target, 3 = pm_src, 4 = pm_jsonPath, 5 = pm_user, 6 = pm_pass
for(var i = 0; i < divsToHide.childElementCount; i++) divsToHide.childNodes[i].style.display = '';
if(value == "---") for(var i = 1; i < divsToHide.childElementCount; i++) divsToHide.childNodes[i].style.display = 'none';
else if(value == "Inverter U dc") {
divsToHide.childNodes[1].style.display = 'none';
}
}
function pm_type_dropdown() function pm_type_dropdown()
{ {
var e = document.getElementsByName("pm_type")[0]; var e = document.getElementsByName("pm_type")[0];

Loading…
Cancel
Save