Merge branch 'v1.5.0'

This commit is contained in:
Nicu Hodos 2025-02-06 13:24:50 +01:00
commit 348ae0bd7d
2 changed files with 41 additions and 1 deletions

View File

@ -1,7 +1,7 @@
{
"$schema": "https://raw.githubusercontent.com/platformio/platformio-core/develop/platformio/assets/schema/library.json",
"name": "ha-mqtt",
"version": "1.4.2",
"version": "1.5.0",
"description": "Home Assistant classes for integration with MQTT auto discovery",
"repository": {
"type": "git",

View File

@ -224,6 +224,20 @@ namespace Ha {
}
};
struct Light : Component, StatefulCommand {
Light(const char* name, const char* id, onMessage f = nullptr) : Component(id, name, "light"), StatefulCommand(this, f) {}
void updateState(bool state) {
State::updateState(state ? "ON" : "OFF");
}
void buildConfig(JsonDocument& jsonDoc) override {
Component::buildConfig(jsonDoc);
StatefulCommand::buildConfig(jsonDoc);
}
};
struct Number : Component, StatefulCommand {
unsigned int min = 1;
unsigned int max = 100;
@ -244,6 +258,27 @@ namespace Ha {
}
};
struct Text : Component, StatefulCommand {
unsigned int min = 1;
unsigned int max = 100;
const char* pattern = nullptr;
Text(const char* name, const char* id, onMessage f) : Component(id, name, "text"), StatefulCommand(this, f) {}
void updateState(unsigned int value) {
State::updateState(to_string(value).c_str());
}
void buildConfig(JsonDocument& jsonDoc) override {
Component::buildConfig(jsonDoc);
StatefulCommand::buildConfig(jsonDoc);
jsonDoc["min"] = min;
jsonDoc["max"] = max;
jsonDoc["platform"] = "text";
if (pattern) jsonDoc["pattern"] = pattern;
}
};
struct Sensor : Component, State {
const char* unitMeasure = nullptr;
const char* valueTemplate = nullptr;
@ -377,6 +412,11 @@ namespace Ha {
return *this;
}
Builder& withPattern(const char* value) {
cmp->pattern = value;
return *this;
}
Builder& withJsonAttributes(const char* value) {
cmp->jsonAttributesTemplate = value;
return *this;