[Option][GUI] Disable notifications from top bar
This commit is contained in:
		
							parent
							
								
									1d9d794bf8
								
							
						
					
					
						commit
						8bdb7e4141
					
				
					 10 changed files with 72 additions and 3 deletions
				
			
		
							
								
								
									
										
											BIN
										
									
								
								Telegram/Resources/icons/info/info_notifications_active.png
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								Telegram/Resources/icons/info/info_notifications_active.png
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.6 KiB | 
							
								
								
									
										
											BIN
										
									
								
								Telegram/Resources/icons/info/info_notifications_active@2x.png
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								Telegram/Resources/icons/info/info_notifications_active@2x.png
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								Telegram/Resources/icons/info/info_notifications_active@3x.png
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								Telegram/Resources/icons/info/info_notifications_active@3x.png
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.9 KiB | 
|  | @ -70,6 +70,7 @@ | |||
| 	"ktg_settings_filters_only_unmuted_counter": "Do not count muted chats", | ||||
| 	"ktg_settings_filters_hide_edit": "Hide Edit button", | ||||
| 	"ktg_settings_filters_hide_folder_names": "Compact folders", | ||||
| 	"ktg_settings_top_bar_mute": "Mute in profile top bar", | ||||
| 	"ktg_settings_messages": "Messages", | ||||
| 	"ktg_settings_filters_hide_all": "Hide \"All chats\" folder", | ||||
| 	"ktg_settings_tray_icon": "Tray icon", | ||||
|  |  | |||
|  | @ -162,8 +162,19 @@ infoTopBarMenu: IconButton(infoTopBarBack) { | |||
| 	iconPosition: point(18px, -1px); | ||||
| 	rippleAreaPosition: point(1px, 6px); | ||||
| } | ||||
| infoTopBarCall: IconButton(infoTopBarMenu) { | ||||
| 
 | ||||
| infoTopBarNotifications: IconButton(infoTopBarMenu) { | ||||
| 	width: 42px; | ||||
| 	icon: icon {{ "info/info_notifications", boxTitleCloseFg }}; | ||||
| 	iconOver: icon {{ "info/info_notifications", boxTitleCloseFgOver }}; | ||||
| 	iconPosition: point(5px, -1px); | ||||
| 	rippleAreaPosition: point(0px, 6px); | ||||
| } | ||||
| infoNotificationsActive: icon {{ | ||||
| 	"info/info_notifications_active", | ||||
| 	windowBgActive | ||||
| }}; | ||||
| infoTopBarCall: IconButton(infoTopBarNotifications) { | ||||
| 	icon: icon {{ "top_bar_call", boxTitleCloseFg }}; | ||||
| 	iconOver: icon {{ "top_bar_call", boxTitleCloseFgOver }}; | ||||
| 	iconPosition: point(5px, -1px); | ||||
|  | @ -257,6 +268,12 @@ infoLayerTopBarMenu: IconButton(infoLayerTopBarClose) { | |||
| 	iconOver: icon {{ "title_menu_dots", boxTitleCloseFgOver }}; | ||||
| 	iconPosition: point(16px, -1px); | ||||
| } | ||||
| infoLayerTopBarNotifications: IconButton(infoLayerTopBarMenu) { | ||||
| 	icon: icon {{ "info/info_notifications", boxTitleCloseFg }}; | ||||
| 	iconOver: icon {{ "info/info_notifications", boxTitleCloseFgOver }}; | ||||
| 	iconPosition: point(4px, -1px); | ||||
| 	rippleAreaPosition: point(0px, 9px); | ||||
| } | ||||
| infoLayerTopBarCall: IconButton(infoLayerTopBarMenu) { | ||||
| 	icon: icon {{ "top_bar_call", boxTitleCloseFg }}; | ||||
| 	iconOver: icon {{ "top_bar_call", boxTitleCloseFgOver }}; | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL | |||
| */ | ||||
| #include "info/info_wrap_widget.h" | ||||
| 
 | ||||
| #include "kotato/kotato_settings.h" | ||||
| #include "info/profile/info_profile_widget.h" | ||||
| #include "info/profile/info_profile_values.h" | ||||
| #include "info/media/info_media_widget.h" | ||||
|  | @ -35,6 +36,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL | |||
| #include "boxes/peer_list_box.h" | ||||
| #include "ui/boxes/confirm_box.h" | ||||
| #include "main/main_session.h" | ||||
| #include "menu/menu_mute.h" | ||||
| #include "mtproto/mtproto_config.h" | ||||
| #include "data/data_download_manager.h" | ||||
| #include "data/data_session.h" | ||||
|  | @ -407,6 +409,11 @@ void WrapWidget::setupTopBarMenuToggle() { | |||
| 			} | ||||
| 		}, _topBar->lifetime()); | ||||
| 	} | ||||
| 
 | ||||
| 	if (section.type() == Section::Type::Profile | ||||
| 		&& ::Kotato::JsonSettings::GetBool("profile_top_mute")) { | ||||
| 		addProfileNotificationsButton(); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void WrapWidget::checkBeforeClose(Fn<void()> close) { | ||||
|  | @ -476,6 +483,45 @@ void WrapWidget::addProfileCallsButton() { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| void WrapWidget::addProfileNotificationsButton() { | ||||
| 	Expects(_topBar != nullptr); | ||||
| 
 | ||||
| 	const auto peer = key().peer(); | ||||
| 	if (!peer || peer->isSelf()) { | ||||
| 		return; | ||||
| 	} | ||||
| 	const auto topic = key().topic(); | ||||
| 	const auto topicRootId = topic ? topic->rootId() : MsgId(); | ||||
| 	const auto makeThread = [=] { | ||||
| 		return topicRootId | ||||
| 			? static_cast<Data::Thread*>(peer->forumTopicFor(topicRootId)) | ||||
| 			: reinterpret_cast<Data::Thread*>(peer->owner().history(peer).get()); | ||||
| 	}; | ||||
| 	auto notifications = _topBar->addButton( | ||||
| 		base::make_unique_q<Ui::IconButton>( | ||||
| 			_topBar, | ||||
| 			(wrap() == Wrap::Layer | ||||
| 				? st::infoLayerTopBarNotifications | ||||
| 				: st::infoTopBarNotifications))); | ||||
| 	MuteMenu::SetupMuteMenu( | ||||
| 		notifications, | ||||
| 		notifications->clicks() | rpl::to_empty, | ||||
| 		makeThread, | ||||
| 		_controller->uiShow()); | ||||
| 	Profile::NotificationsEnabledValue( | ||||
| 		peer | ||||
| 	) | rpl::start_with_next([notifications](bool enabled) { | ||||
| 		const auto iconOverride = enabled | ||||
| 			? &st::infoNotificationsActive | ||||
| 			: nullptr; | ||||
| 		const auto rippleOverride = enabled | ||||
| 			? &st::lightButtonBgOver | ||||
| 			: nullptr; | ||||
| 		notifications->setIconOverride(iconOverride, iconOverride); | ||||
| 		notifications->setRippleColorOverride(rippleOverride); | ||||
| 	}, notifications->lifetime()); | ||||
| } | ||||
| 
 | ||||
| void WrapWidget::showTopBarMenu(bool check) { | ||||
| 	if (_topBarMenu) { | ||||
| 		_topBarMenu->hideMenu(true); | ||||
|  |  | |||
|  | @ -204,6 +204,7 @@ private: | |||
| 
 | ||||
| 	void addTopBarMenuButton(); | ||||
| 	void addProfileCallsButton(); | ||||
| 	void addProfileNotificationsButton(); | ||||
| 	void showTopBarMenu(bool check); | ||||
| 
 | ||||
| 	rpl::variable<Wrap> _wrap; | ||||
|  |  | |||
|  | @ -1273,7 +1273,7 @@ object_ptr<Ui::RpWidget> DetailsFiller::setupInfo() { | |||
| 			addTranslateToMenu(about.text, AboutWithIdValue(_peer)); | ||||
| 		} | ||||
| 	} | ||||
| 	if (!_peer->isSelf()) { | ||||
| 	if (!_peer->isSelf() && !::Kotato::JsonSettings::GetBool("profile_top_mute")) { | ||||
| 		// No notifications toggle for Self => no separator.
 | ||||
| 		result->add(object_ptr<Ui::SlideWrap<>>( | ||||
| 			result, | ||||
|  | @ -1799,7 +1799,7 @@ object_ptr<Ui::RpWidget> DetailsFiller::fill() { | |||
| 	add(object_ptr<Ui::BoxContentDivider>(_wrap)); | ||||
| 	add(CreateSkipWidget(_wrap)); | ||||
| 	add(setupInfo()); | ||||
| 	if (!_peer->isSelf()) { | ||||
| 	if (!_peer->isSelf() && !::Kotato::JsonSettings::GetBool("profile_top_mute")) { | ||||
| 		add(setupMuteToggle()); | ||||
| 	} | ||||
| 	setupMainButtons(); | ||||
|  |  | |||
|  | @ -323,6 +323,9 @@ const std::map<QString, Definition, std::greater<QString>> DefinitionMap { | |||
| 	{ "folders/hide_all_chats", { | ||||
| 		.type = SettingType::BoolSetting, | ||||
| 		.defaultValue = false, }}, | ||||
| 	{ "profile_top_mute", { | ||||
| 		.type = SettingType::BoolSetting, | ||||
| 		.defaultValue = false, }}, | ||||
| 	{ "folders/local", { | ||||
| 		.scope = SettingScope::Account, | ||||
| 		.type = SettingType::QJsonArraySetting, }}, | ||||
|  |  | |||
|  | @ -160,6 +160,7 @@ void SetupKotatoChats( | |||
| 		updateRecentStickersLimitHeight); | ||||
| 	updateRecentStickersLimitLabel(::Kotato::JsonSettings::GetInt("recent_stickers_limit")); | ||||
| 
 | ||||
| 	SettingsMenuJsonSwitch(ktg_settings_top_bar_mute, profile_top_mute); | ||||
| 	SettingsMenuJsonSwitch(ktg_settings_disable_up_edit, disable_up_edit); | ||||
| 	SettingsMenuJsonSwitch(ktg_settings_always_show_scheduled, always_show_scheduled); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue