2019-04-17 12:06:00 +02:00
|
|
|
#include "text_sensor.h"
|
|
|
|
#include "esphome/core/log.h"
|
|
|
|
|
|
|
|
namespace esphome {
|
|
|
|
namespace text_sensor {
|
|
|
|
|
2021-06-10 22:19:44 +02:00
|
|
|
static const char *const TAG = "text_sensor";
|
2019-04-17 12:06:00 +02:00
|
|
|
|
|
|
|
TextSensor::TextSensor() : TextSensor("") {}
|
2021-10-10 10:37:05 +02:00
|
|
|
TextSensor::TextSensor(const std::string &name) : EntityBase(name) {}
|
2019-04-17 12:06:00 +02:00
|
|
|
|
2021-06-10 13:04:40 +02:00
|
|
|
void TextSensor::publish_state(const std::string &state) {
|
2021-09-29 23:25:06 +02:00
|
|
|
this->raw_state = state;
|
|
|
|
this->raw_callback_.call(state);
|
|
|
|
|
|
|
|
ESP_LOGV(TAG, "'%s': Received new state %s", this->name_.c_str(), state.c_str());
|
|
|
|
|
|
|
|
if (this->filter_list_ == nullptr) {
|
|
|
|
this->internal_send_state_to_frontend(state);
|
|
|
|
} else {
|
|
|
|
this->filter_list_->input(state);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void TextSensor::add_filter(Filter *filter) {
|
|
|
|
// inefficient, but only happens once on every sensor setup and nobody's going to have massive amounts of
|
|
|
|
// filters
|
|
|
|
ESP_LOGVV(TAG, "TextSensor(%p)::add_filter(%p)", this, filter);
|
|
|
|
if (this->filter_list_ == nullptr) {
|
|
|
|
this->filter_list_ = filter;
|
|
|
|
} else {
|
|
|
|
Filter *last_filter = this->filter_list_;
|
|
|
|
while (last_filter->next_ != nullptr)
|
|
|
|
last_filter = last_filter->next_;
|
|
|
|
last_filter->initialize(this, filter);
|
|
|
|
}
|
|
|
|
filter->initialize(this, nullptr);
|
|
|
|
}
|
|
|
|
void TextSensor::add_filters(const std::vector<Filter *> &filters) {
|
|
|
|
for (Filter *filter : filters) {
|
|
|
|
this->add_filter(filter);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
void TextSensor::set_filters(const std::vector<Filter *> &filters) {
|
|
|
|
this->clear_filters();
|
|
|
|
this->add_filters(filters);
|
|
|
|
}
|
|
|
|
void TextSensor::clear_filters() {
|
|
|
|
if (this->filter_list_ != nullptr) {
|
|
|
|
ESP_LOGVV(TAG, "TextSensor(%p)::clear_filters()", this);
|
|
|
|
}
|
|
|
|
this->filter_list_ = nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
void TextSensor::add_on_state_callback(std::function<void(std::string)> callback) {
|
|
|
|
this->callback_.add(std::move(callback));
|
|
|
|
}
|
|
|
|
void TextSensor::add_on_raw_state_callback(std::function<void(std::string)> callback) {
|
|
|
|
this->raw_callback_.add(std::move(callback));
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string TextSensor::get_state() const { return this->state; }
|
|
|
|
std::string TextSensor::get_raw_state() const { return this->raw_state; }
|
|
|
|
void TextSensor::internal_send_state_to_frontend(const std::string &state) {
|
2021-12-13 03:21:09 +01:00
|
|
|
this->state = state;
|
2019-04-17 12:06:00 +02:00
|
|
|
this->has_state_ = true;
|
|
|
|
ESP_LOGD(TAG, "'%s': Sending state '%s'", this->name_.c_str(), state.c_str());
|
|
|
|
this->callback_.call(state);
|
|
|
|
}
|
2021-09-29 23:25:06 +02:00
|
|
|
|
2019-04-17 12:06:00 +02:00
|
|
|
std::string TextSensor::unique_id() { return ""; }
|
|
|
|
bool TextSensor::has_state() { return this->has_state_; }
|
|
|
|
|
|
|
|
} // namespace text_sensor
|
|
|
|
} // namespace esphome
|