mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-24 22:52:32 +02:00 
			
		
		
		
	fix state behavior
This commit is contained in:
		| @@ -31,7 +31,7 @@ class ALabel : public IModule { | |||||||
|  |  | ||||||
|   virtual bool handleToggle(GdkEventButton *const &ev); |   virtual bool handleToggle(GdkEventButton *const &ev); | ||||||
|   virtual bool handleScroll(GdkEventScroll *); |   virtual bool handleScroll(GdkEventScroll *); | ||||||
|   virtual std::string getState(uint8_t value, bool reverse = false); |   virtual std::string getState(uint8_t value, bool lesser = false, bool reverse = false); | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   std::vector<int> pid_; |   std::vector<int> pid_; | ||||||
|   | |||||||
| @@ -129,7 +129,7 @@ std::string waybar::ALabel::getIcon(uint16_t percentage, const std::string& alt, | |||||||
|   return ""; |   return ""; | ||||||
| } | } | ||||||
|  |  | ||||||
| std::string waybar::ALabel::getState(uint8_t value, bool reverse) { | std::string waybar::ALabel::getState(uint8_t value, bool lesser, bool reverse) { | ||||||
|   if (!config_["states"].isObject()) { |   if (!config_["states"].isObject()) { | ||||||
|     return ""; |     return ""; | ||||||
|   } |   } | ||||||
| @@ -148,7 +148,7 @@ std::string waybar::ALabel::getState(uint8_t value, bool reverse) { | |||||||
|   }); |   }); | ||||||
|   std::string valid_state; |   std::string valid_state; | ||||||
|   for (auto const& state : states) { |   for (auto const& state : states) { | ||||||
|     if (value <= state.second && valid_state.empty()) { |     if ((lesser ? value <= state.second : value >= state.second) && valid_state.empty()) { | ||||||
|       label_.get_style_context()->add_class(state.first); |       label_.get_style_context()->add_class(state.first); | ||||||
|       valid_state = state.first; |       valid_state = state.first; | ||||||
|     } else { |     } else { | ||||||
|   | |||||||
| @@ -130,7 +130,7 @@ auto waybar::modules::Battery::update() -> void { | |||||||
|   } |   } | ||||||
|   std::transform(status.begin(), status.end(), status.begin(), ::tolower); |   std::transform(status.begin(), status.end(), status.begin(), ::tolower); | ||||||
|   auto format = format_; |   auto format = format_; | ||||||
|   auto state = getState(capacity, true); |   auto state = getState(capacity, true, true); | ||||||
|   if (!old_status_.empty()) { |   if (!old_status_.empty()) { | ||||||
|     label_.get_style_context()->remove_class(old_status_); |     label_.get_style_context()->remove_class(old_status_); | ||||||
|   } |   } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 unresolvedsymbol
					unresolvedsymbol