status indicator sets window icon
	
		
			
	
		
	
	
		
	
		
			Some checks are pending
		
		
	
	
		
			
				
	
				ContinuousDelivery / linux-ubuntu (push) Waiting to run
				
			
		
			
				
	
				ContinuousDelivery / android (map[ndk_abi:arm64-v8a vcpkg_toolkit:arm64-android]) (push) Waiting to run
				
			
		
			
				
	
				ContinuousDelivery / android (map[ndk_abi:armeabi-v7a vcpkg_toolkit:arm-neon-android]) (push) Waiting to run
				
			
		
			
				
	
				ContinuousDelivery / android (map[ndk_abi:x86_64 vcpkg_toolkit:x64-android]) (push) Waiting to run
				
			
		
			
				
	
				ContinuousDelivery / windows (push) Waiting to run
				
			
		
			
				
	
				ContinuousDelivery / windows-asan (push) Waiting to run
				
			
		
			
				
	
				ContinuousDelivery / release (push) Blocked by required conditions
				
			
		
			
				
	
				ContinuousIntegration / linux (push) Waiting to run
				
			
		
			
				
	
				ContinuousIntegration / android (map[ndk_abi:arm64-v8a vcpkg_toolkit:arm64-android]) (push) Waiting to run
				
			
		
			
				
	
				ContinuousIntegration / android (map[ndk_abi:armeabi-v7a vcpkg_toolkit:arm-neon-android]) (push) Waiting to run
				
			
		
			
				
	
				ContinuousIntegration / android (map[ndk_abi:x86_64 vcpkg_toolkit:x64-android]) (push) Waiting to run
				
			
		
			
				
	
				ContinuousIntegration / macos (push) Waiting to run
				
			
		
			
				
	
				ContinuousIntegration / windows (push) Waiting to run
				
			
		
		
	
	
				
					
				
			
		
			Some checks are pending
		
		
	
	ContinuousDelivery / linux-ubuntu (push) Waiting to run
				
			ContinuousDelivery / android (map[ndk_abi:arm64-v8a vcpkg_toolkit:arm64-android]) (push) Waiting to run
				
			ContinuousDelivery / android (map[ndk_abi:armeabi-v7a vcpkg_toolkit:arm-neon-android]) (push) Waiting to run
				
			ContinuousDelivery / android (map[ndk_abi:x86_64 vcpkg_toolkit:x64-android]) (push) Waiting to run
				
			ContinuousDelivery / windows (push) Waiting to run
				
			ContinuousDelivery / windows-asan (push) Waiting to run
				
			ContinuousDelivery / release (push) Blocked by required conditions
				
			ContinuousIntegration / linux (push) Waiting to run
				
			ContinuousIntegration / android (map[ndk_abi:arm64-v8a vcpkg_toolkit:arm64-android]) (push) Waiting to run
				
			ContinuousIntegration / android (map[ndk_abi:armeabi-v7a vcpkg_toolkit:arm-neon-android]) (push) Waiting to run
				
			ContinuousIntegration / android (map[ndk_abi:x86_64 vcpkg_toolkit:x64-android]) (push) Waiting to run
				
			ContinuousIntegration / macos (push) Waiting to run
				
			ContinuousIntegration / windows (push) Waiting to run
				
			This commit is contained in:
		| @@ -105,6 +105,9 @@ target_sources(tomato PUBLIC | |||||||
| 	./tox_friend_faux_offline_messaging.hpp | 	./tox_friend_faux_offline_messaging.hpp | ||||||
| 	./tox_friend_faux_offline_messaging.cpp | 	./tox_friend_faux_offline_messaging.cpp | ||||||
|  |  | ||||||
|  | 	./status_indicator.hpp | ||||||
|  | 	./status_indicator.cpp | ||||||
|  |  | ||||||
| 	./chat_gui4.hpp | 	./chat_gui4.hpp | ||||||
| 	./chat_gui4.cpp | 	./chat_gui4.cpp | ||||||
|  |  | ||||||
|   | |||||||
| @@ -43,6 +43,7 @@ MainScreen::MainScreen(SimpleConfigModel&& conf_, SDL_Renderer* renderer_, Theme | |||||||
| 	contact_tc(tal, sdlrtu), | 	contact_tc(tal, sdlrtu), | ||||||
| 	mil(), | 	mil(), | ||||||
| 	msg_tc(mil, sdlrtu), | 	msg_tc(mil, sdlrtu), | ||||||
|  | 	si(rmm, cr, SDL_GetRenderWindow(renderer_)), | ||||||
| 	cg(conf, os, rmm, cr, sdlrtu, contact_tc, msg_tc, theme), | 	cg(conf, os, rmm, cr, sdlrtu, contact_tc, msg_tc, theme), | ||||||
| 	sw(conf), | 	sw(conf), | ||||||
| 	osui(os), | 	osui(os), | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ | |||||||
| #include "./tox_avatar_loader.hpp" | #include "./tox_avatar_loader.hpp" | ||||||
| #include "./message_image_loader.hpp" | #include "./message_image_loader.hpp" | ||||||
|  |  | ||||||
|  | #include "./status_indicator.hpp" | ||||||
| #include "./chat_gui4.hpp" | #include "./chat_gui4.hpp" | ||||||
| #include "./chat_gui/settings_window.hpp" | #include "./chat_gui/settings_window.hpp" | ||||||
| #include "./object_store_ui.hpp" | #include "./object_store_ui.hpp" | ||||||
| @@ -91,6 +92,7 @@ struct MainScreen final : public Screen { | |||||||
| 	MessageImageLoader mil; | 	MessageImageLoader mil; | ||||||
| 	TextureCache<void*, Message3Handle, MessageImageLoader> msg_tc; | 	TextureCache<void*, Message3Handle, MessageImageLoader> msg_tc; | ||||||
|  |  | ||||||
|  | 	StatusIndicator si; | ||||||
| 	ChatGui4 cg; | 	ChatGui4 cg; | ||||||
| 	SettingsWindow sw; | 	SettingsWindow sw; | ||||||
| 	ObjectStoreUI osui; | 	ObjectStoreUI osui; | ||||||
|   | |||||||
							
								
								
									
										69
									
								
								src/status_indicator.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/status_indicator.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | #include "./status_indicator.hpp" | ||||||
|  |  | ||||||
|  | #include <solanaceae/contact/components.hpp> | ||||||
|  | #include <solanaceae/message3/components.hpp> | ||||||
|  |  | ||||||
|  | #include "./icon_generator.hpp" | ||||||
|  |  | ||||||
|  | #include <memory> | ||||||
|  |  | ||||||
|  | void StatusIndicator::updateState(State state) { | ||||||
|  | 	if (_state == state) { | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	_state = state; | ||||||
|  |  | ||||||
|  | 	std::unique_ptr<SDL_Surface, decltype(&SDL_DestroySurface)> surf{nullptr, &SDL_DestroySurface}; | ||||||
|  |  | ||||||
|  | 	switch (state) { | ||||||
|  | 		case State::base: | ||||||
|  | 			surf = {IconGenerator::base(), &SDL_DestroySurface}; | ||||||
|  | 			break; | ||||||
|  | 		case State::unread: | ||||||
|  | 			surf = {IconGenerator::colorIndicator(1.f, .5f, 0.f, 1.f), &SDL_DestroySurface}; | ||||||
|  | 			break; | ||||||
|  | 		case State::none: | ||||||
|  | 			break; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	SDL_SetWindowIcon(_main_window, surf.get()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | StatusIndicator::StatusIndicator( | ||||||
|  | 	RegistryMessageModelI& rmm, | ||||||
|  | 	Contact3Registry& cr, | ||||||
|  | 	SDL_Window* main_window | ||||||
|  | ) : | ||||||
|  | 	_rmm(rmm), | ||||||
|  | 	_cr(cr), | ||||||
|  | 	_main_window(main_window) | ||||||
|  | { | ||||||
|  | 	// start off with base icon | ||||||
|  | 	updateState(State::base); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void StatusIndicator::render(float delta) { | ||||||
|  | 	_cooldown -= delta; | ||||||
|  | 	if (_cooldown <= 0.f) { | ||||||
|  | 		_cooldown = 1.f; // once a second | ||||||
|  |  | ||||||
|  | 		bool has_unread = false; | ||||||
|  | 		for (const auto& c : _cr.view<Contact::Components::TagBig>()) { | ||||||
|  | 			// maybe cache mm? | ||||||
|  | 			if (const auto* mm = _rmm.get(c); mm != nullptr) { | ||||||
|  | 				if (const auto* unread_storage = mm->storage<Message::Components::TagUnread>(); unread_storage != nullptr && !unread_storage->empty()) { | ||||||
|  | 					has_unread = true; | ||||||
|  | 					break; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if (has_unread) { | ||||||
|  | 			updateState(State::unread); | ||||||
|  | 		} else { | ||||||
|  | 			updateState(State::base); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
							
								
								
									
										36
									
								
								src/status_indicator.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								src/status_indicator.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include <solanaceae/message3/registry_message_model.hpp> | ||||||
|  |  | ||||||
|  | #include <SDL3/SDL.h> | ||||||
|  |  | ||||||
|  | // service that sets window and tray icon depending on program state | ||||||
|  |  | ||||||
|  | class StatusIndicator { | ||||||
|  | 	RegistryMessageModelI& _rmm; | ||||||
|  | 	Contact3Registry& _cr; | ||||||
|  |  | ||||||
|  | 	SDL_Window* _main_window; | ||||||
|  | 	// systray ptr here | ||||||
|  |  | ||||||
|  | 	float _cooldown {1.f}; | ||||||
|  |  | ||||||
|  | 	enum class State { | ||||||
|  | 		base, | ||||||
|  | 		unread, | ||||||
|  | 		none, // only used for initialization | ||||||
|  | 	} _state = State::none; | ||||||
|  |  | ||||||
|  | 	void updateState(State state); | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		StatusIndicator( | ||||||
|  | 			RegistryMessageModelI& rmm, | ||||||
|  | 			Contact3Registry& cr, | ||||||
|  | 			SDL_Window* main_window | ||||||
|  | 		); | ||||||
|  |  | ||||||
|  | 		// does not actually render, just on the render thread | ||||||
|  | 		void render(float delta); | ||||||
|  | }; | ||||||
|  |  | ||||||
		Reference in New Issue
	
	Block a user