Waybar/src/modules/sway/mode.cpp

50 lines
1.1 KiB
C++
Raw Normal View History

2018-10-30 12:39:30 +00:00
#include "modules/sway/mode.hpp"
2019-04-19 09:09:06 +00:00
namespace waybar::modules::sway {
Mode::Mode(const std::string& id, const Bar& bar, const Json::Value& config)
2019-04-18 15:52:00 +00:00
: ALabel(config, "{}"), bar_(bar) {
2018-12-18 16:30:54 +00:00
label_.set_name("mode");
if (!id.empty()) {
label_.get_style_context()->add_class(id);
}
2018-10-30 12:39:30 +00:00
ipc_.subscribe("[ \"mode\" ]");
2019-04-19 09:09:06 +00:00
ipc_.signal_event.connect(sigc::mem_fun(*this, &Mode::onEvent));
2018-10-30 12:39:30 +00:00
// Launch worker
worker();
2018-12-18 16:30:54 +00:00
dp.emit();
2018-10-30 12:39:30 +00:00
}
2019-04-19 09:09:06 +00:00
void Mode::onEvent(const struct Ipc::ipc_response res) {
auto parsed = parser_.parse(res.payload);
if (parsed["change"] != "default") {
mode_ = parsed["change"].asString();
} else {
mode_.clear();
}
dp.emit();
}
void Mode::worker() {
2018-10-30 12:39:30 +00:00
thread_ = [this] {
try {
2019-04-19 09:09:06 +00:00
ipc_.handleEvent();
2018-10-30 12:39:30 +00:00
} catch (const std::exception& e) {
std::cerr << "Mode: " << e.what() << std::endl;
2018-10-30 12:39:30 +00:00
}
};
}
2019-04-19 09:09:06 +00:00
auto Mode::update() -> void {
2018-10-30 12:39:30 +00:00
if (mode_.empty()) {
2018-12-18 16:30:54 +00:00
event_box_.hide();
2018-10-30 12:39:30 +00:00
} else {
2018-11-21 19:49:09 +00:00
label_.set_markup(fmt::format(format_, mode_));
2019-02-22 10:35:26 +00:00
if (tooltipEnabled()) {
label_.set_tooltip_text(mode_);
}
2018-12-18 16:30:54 +00:00
event_box_.show();
2018-10-30 12:39:30 +00:00
}
2019-04-19 09:09:06 +00:00
}
} // namespace waybar::modules::sway