mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-26 14:32:28 +01:00 
			
		
		
		
	Add formatting and states handling
This commit is contained in:
		| @@ -5,6 +5,7 @@ | |||||||
| #include <gtkmm/image.h> | #include <gtkmm/image.h> | ||||||
| #include <gtkmm/label.h> | #include <gtkmm/label.h> | ||||||
|  |  | ||||||
|  | #include <map> | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <vector> | #include <vector> | ||||||
|  |  | ||||||
| @@ -25,6 +26,7 @@ class Workspace { | |||||||
|   auto update() -> void; |   auto update() -> void; | ||||||
|  |  | ||||||
|   auto id() const -> uint32_t { return id_; } |   auto id() const -> uint32_t { return id_; } | ||||||
|  |   auto is_active() const -> bool { return state_ & static_cast<uint32_t>(State::ACTIVE); } | ||||||
|   // wlr stuff |   // wlr stuff | ||||||
|   auto handle_name(const std::string &name) -> void { name_ = name; } |   auto handle_name(const std::string &name) -> void { name_ = name; } | ||||||
|   auto handle_coordinates(const std::vector<uint32_t> &coordinates) -> void { |   auto handle_coordinates(const std::vector<uint32_t> &coordinates) -> void { | ||||||
| @@ -33,9 +35,14 @@ class Workspace { | |||||||
|   auto handle_state(const std::vector<uint32_t> &state) -> void; |   auto handle_state(const std::vector<uint32_t> &state) -> void; | ||||||
|   auto handle_remove() -> void; |   auto handle_remove() -> void; | ||||||
|  |  | ||||||
|  |   auto handle_done() -> void; | ||||||
|  |   auto handle_clicked() -> void; | ||||||
|  |  | ||||||
|   enum class State { ACTIVE = 1 << 0 }; |   enum class State { ACTIVE = 1 << 0 }; | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|  |   auto get_icon() -> std::string; | ||||||
|  |  | ||||||
|   static uint32_t    workspace_global_id; |   static uint32_t    workspace_global_id; | ||||||
|   const Bar &        bar_; |   const Bar &        bar_; | ||||||
|   const Json::Value &config_; |   const Json::Value &config_; | ||||||
| @@ -48,6 +55,9 @@ class Workspace { | |||||||
|   uint32_t                                  id_; |   uint32_t                                  id_; | ||||||
|   std::string                               name_; |   std::string                               name_; | ||||||
|   std::vector<uint32_t>                     coordinates_; |   std::vector<uint32_t>                     coordinates_; | ||||||
|  |   static std::map<std::string, std::string> icons_map_; | ||||||
|  |   std::string                               format_; | ||||||
|  |   bool                                      with_icon_ = false; | ||||||
|  |  | ||||||
|   Gtk::Button button_; |   Gtk::Button button_; | ||||||
|   Gtk::Box    content_; |   Gtk::Box    content_; | ||||||
| @@ -62,6 +72,7 @@ class WorkspaceGroup { | |||||||
|   auto update() -> void; |   auto update() -> void; | ||||||
|  |  | ||||||
|   auto id() const -> uint32_t { return id_; } |   auto id() const -> uint32_t { return id_; } | ||||||
|  |   auto is_visible() const -> bool { return output_ != nullptr; } | ||||||
|   auto remove_workspace(uint32_t id_) -> void; |   auto remove_workspace(uint32_t id_) -> void; | ||||||
|  |  | ||||||
|   // wlr stuff |   // wlr stuff | ||||||
| @@ -71,6 +82,8 @@ class WorkspaceGroup { | |||||||
|   auto handle_output_leave() -> void; |   auto handle_output_leave() -> void; | ||||||
|  |  | ||||||
|   auto add_button(Gtk::Button &button) -> void; |   auto add_button(Gtk::Button &button) -> void; | ||||||
|  |   auto handle_done() -> void; | ||||||
|  |   auto commit() -> void; | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   static uint32_t    group_global_id; |   static uint32_t    group_global_id; | ||||||
| @@ -102,6 +115,7 @@ class WorkspaceManager : public AModule { | |||||||
|   auto handle_finished() -> void; |   auto handle_finished() -> void; | ||||||
|  |  | ||||||
|   auto add_button(Gtk::Button &button) -> void { box_.pack_start(button, false, false); } |   auto add_button(Gtk::Button &button) -> void { box_.pack_start(button, false, false); } | ||||||
|  |   auto commit() -> void; | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   const waybar::Bar &                          bar_; |   const waybar::Bar &                          bar_; | ||||||
|   | |||||||
| @@ -11,6 +11,7 @@ namespace waybar::modules::wlr { | |||||||
|  |  | ||||||
| uint32_t                           Workspace::workspace_global_id = 0; | uint32_t                           Workspace::workspace_global_id = 0; | ||||||
| uint32_t                           WorkspaceGroup::group_global_id = 0; | uint32_t                           WorkspaceGroup::group_global_id = 0; | ||||||
|  | std::map<std::string, std::string> Workspace::icons_map_; | ||||||
|  |  | ||||||
| WorkspaceManager::WorkspaceManager(const std::string &id, const waybar::Bar &bar, | WorkspaceManager::WorkspaceManager(const std::string &id, const waybar::Bar &bar, | ||||||
|                                    const Json::Value &config) |                                    const Json::Value &config) | ||||||
| @@ -53,6 +54,9 @@ auto WorkspaceManager::handle_finished() -> void { | |||||||
| } | } | ||||||
|  |  | ||||||
| auto WorkspaceManager::handle_done() -> void { | auto WorkspaceManager::handle_done() -> void { | ||||||
|  |   for (auto &group : groups_) { | ||||||
|  |     group->handle_done(); | ||||||
|  |   } | ||||||
|   dp.emit(); |   dp.emit(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -83,6 +87,7 @@ auto WorkspaceManager::remove_workspace_group(uint32_t id) -> void { | |||||||
|  |  | ||||||
|   groups_.erase(it); |   groups_.erase(it); | ||||||
| } | } | ||||||
|  | auto WorkspaceManager::commit() -> void { zwlr_workspace_manager_v1_commit(workspace_manager_); } | ||||||
|  |  | ||||||
| WorkspaceGroup::WorkspaceGroup(const Bar &bar, const Json::Value &config, WorkspaceManager &manager, | WorkspaceGroup::WorkspaceGroup(const Bar &bar, const Json::Value &config, WorkspaceManager &manager, | ||||||
|                                zwlr_workspace_group_handle_v1 *workspace_group_handle) |                                zwlr_workspace_group_handle_v1 *workspace_group_handle) | ||||||
| @@ -145,6 +150,14 @@ auto WorkspaceGroup::remove_workspace(uint32_t id) -> void { | |||||||
|  |  | ||||||
|   workspaces_.erase(it); |   workspaces_.erase(it); | ||||||
| } | } | ||||||
|  | auto WorkspaceGroup::handle_done() -> void { | ||||||
|  |   if (is_visible()) { | ||||||
|  |     for (auto &workspace : workspaces_) { | ||||||
|  |       workspace->handle_done(); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | auto WorkspaceGroup::commit() -> void { workspace_manager_.commit(); } | ||||||
|  |  | ||||||
| Workspace::Workspace(const Bar &bar, const Json::Value &config, WorkspaceGroup &workspace_group, | Workspace::Workspace(const Bar &bar, const Json::Value &config, WorkspaceGroup &workspace_group, | ||||||
|                      zwlr_workspace_handle_v1 *workspace) |                      zwlr_workspace_handle_v1 *workspace) | ||||||
| @@ -152,17 +165,30 @@ Workspace::Workspace(const Bar &bar, const Json::Value &config, WorkspaceGroup & | |||||||
|       config_(config), |       config_(config), | ||||||
|       workspace_group_(workspace_group), |       workspace_group_(workspace_group), | ||||||
|       workspace_handle_(workspace), |       workspace_handle_(workspace), | ||||||
|       id_(++workspace_global_id), |       id_(++workspace_global_id) { | ||||||
|       content_{bar.vertical ? Gtk::ORIENTATION_VERTICAL : Gtk::ORIENTATION_HORIZONTAL, 0} { |  | ||||||
|   add_workspace_listener(workspace, this); |   add_workspace_listener(workspace, this); | ||||||
|  |  | ||||||
|  |   auto config_format = config["format"]; | ||||||
|  |  | ||||||
|  |   format_ = config_format.isString() ? config_format.asString() : "{name}"; | ||||||
|  |   with_icon_ = format_.find("{icon}") != std::string::npos; | ||||||
|  |  | ||||||
|  |   if (with_icon_ && icons_map_.empty()) { | ||||||
|  |     auto format_icons = config["format-icons"]; | ||||||
|  |     for (auto &name : format_icons.getMemberNames()) { | ||||||
|  |       icons_map_.emplace(name, format_icons[name].asString()); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   button_.signal_clicked().connect(sigc::mem_fun(this, &Workspace::handle_clicked)); | ||||||
|  |  | ||||||
|   workspace_group.add_button(button_); |   workspace_group.add_button(button_); | ||||||
|   button_.set_relief(Gtk::RELIEF_NONE); |   button_.set_relief(Gtk::RELIEF_NONE); | ||||||
|   label_.set_label(fmt::format("{name}", fmt::arg("name", "1"))); |   content_.set_center_widget(label_); | ||||||
|   label_.show(); |  | ||||||
|   content_.add(label_); |  | ||||||
|   content_.show(); |  | ||||||
|   button_.add(content_); |   button_.add(content_); | ||||||
|   button_.show(); |   button_.show(); | ||||||
|  |   label_.show(); | ||||||
|  |   content_.show(); | ||||||
| } | } | ||||||
|  |  | ||||||
| Workspace::~Workspace() { | Workspace::~Workspace() { | ||||||
| @@ -175,8 +201,8 @@ Workspace::~Workspace() { | |||||||
| } | } | ||||||
|  |  | ||||||
| auto Workspace::update() -> void { | auto Workspace::update() -> void { | ||||||
|   label_.set_label(fmt::format("{name}", fmt::arg("name", name_))); |   label_.set_markup(fmt::format( | ||||||
|   label_.show(); |       format_, fmt::arg("name", name_), fmt::arg("icon", with_icon_ ? get_icon() : ""))); | ||||||
| } | } | ||||||
|  |  | ||||||
| auto Workspace::handle_state(const std::vector<uint32_t> &state) -> void { | auto Workspace::handle_state(const std::vector<uint32_t> &state) -> void { | ||||||
| @@ -195,4 +221,38 @@ auto Workspace::handle_remove() -> void { | |||||||
|   workspace_handle_ = nullptr; |   workspace_handle_ = nullptr; | ||||||
|   workspace_group_.remove_workspace(id_); |   workspace_group_.remove_workspace(id_); | ||||||
| } | } | ||||||
|  | auto Workspace::handle_done() -> void { | ||||||
|  |   spdlog::debug("Workspace {} changed to state {}", id_, state_); | ||||||
|  |   auto style_context = button_.get_style_context(); | ||||||
|  |   if (is_active()) { | ||||||
|  |     style_context->add_class("focused"); | ||||||
|  |   } else { | ||||||
|  |     style_context->remove_class("focused"); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | auto Workspace::get_icon() -> std::string { | ||||||
|  |   if (is_active()) { | ||||||
|  |     auto focused_icon_it = icons_map_.find("focused"); | ||||||
|  |     if (focused_icon_it != icons_map_.end()) { | ||||||
|  |       return focused_icon_it->second; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   auto named_icon_it = icons_map_.find(name_); | ||||||
|  |   if (named_icon_it != icons_map_.end()) { | ||||||
|  |     return named_icon_it->second; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   auto default_icon_it = icons_map_.find("default"); | ||||||
|  |   if (default_icon_it != icons_map_.end()) { | ||||||
|  |     return default_icon_it->second; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return name_; | ||||||
|  | } | ||||||
|  | auto Workspace::handle_clicked() -> void { | ||||||
|  |   spdlog::debug("Workspace {} clicked", (void*)workspace_handle_); | ||||||
|  |   zwlr_workspace_handle_v1_activate(workspace_handle_); | ||||||
|  |   workspace_group_.commit(); | ||||||
|  | } | ||||||
| }  // namespace waybar::modules::wlr | }  // namespace waybar::modules::wlr | ||||||
		Reference in New Issue
	
	Block a user
	 dmitry
					dmitry