diff --git a/Telegram/Resources/langs/rewrites/en.json b/Telegram/Resources/langs/rewrites/en.json index b72e24466..0cc94dd72 100644 --- a/Telegram/Resources/langs/rewrites/en.json +++ b/Telegram/Resources/langs/rewrites/en.json @@ -28,6 +28,7 @@ "ktg_mac_menu_show": "Show Kotatogram", "ktg_settings_kotato": "Kotatogram Settings", "ktg_settings_chats": "Chats", + "ktg_settings_emoji_outline": "Big emoji outline", "ktg_fonts_title": "Fonts", "ktg_settings_fonts": "Change application fonts", "ktg_fonts_reset": "Reset", diff --git a/Telegram/SourceFiles/chat_helpers/stickers_emoji_image_loader.cpp b/Telegram/SourceFiles/chat_helpers/stickers_emoji_image_loader.cpp index 08a12fc7d..a44f627d6 100644 --- a/Telegram/SourceFiles/chat_helpers/stickers_emoji_image_loader.cpp +++ b/Telegram/SourceFiles/chat_helpers/stickers_emoji_image_loader.cpp @@ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL */ #include "chat_helpers/stickers_emoji_image_loader.h" +#include "kotato/kotato_settings.h" #include "styles/style_chat.h" namespace Stickers { @@ -33,7 +34,9 @@ QImage EmojiImageLoader::prepare(EmojiPtr emoji) const { auto tinted = QImage( QSize(st::largeEmojiSize, st::largeEmojiSize) * factor, QImage::Format_ARGB32_Premultiplied); - tinted.fill(Qt::white); + tinted.fill(::Kotato::JsonSettings::GetBool("big_emoji_outline") + ? Qt::white + : QColor(0, 0, 0, 0)); if (loaded) { QPainter p(&tinted); p.setCompositionMode(QPainter::CompositionMode_DestinationIn); diff --git a/Telegram/SourceFiles/chat_helpers/stickers_emoji_pack.cpp b/Telegram/SourceFiles/chat_helpers/stickers_emoji_pack.cpp index d663f4290..da43e84b7 100644 --- a/Telegram/SourceFiles/chat_helpers/stickers_emoji_pack.cpp +++ b/Telegram/SourceFiles/chat_helpers/stickers_emoji_pack.cpp @@ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL */ #include "chat_helpers/stickers_emoji_pack.h" +#include "kotato/kotato_settings.h" #include "chat_helpers/stickers_emoji_image_loader.h" #include "history/history_item.h" #include "lottie/lottie_common.h" @@ -106,6 +107,13 @@ EmojiPack::EmojiPack(not_null session) refreshAll(); }, _lifetime); + ::Kotato::JsonSettings::Events( + "big_emoji_outline" + ) | rpl::start_with_next([=] { + _images.clear(); + refreshAll(); + }, _lifetime); + Ui::Emoji::Updated( ) | rpl::start_with_next([=] { _images.clear(); diff --git a/Telegram/SourceFiles/history/history_widget.cpp b/Telegram/SourceFiles/history/history_widget.cpp index bec05d182..6824312c4 100644 --- a/Telegram/SourceFiles/history/history_widget.cpp +++ b/Telegram/SourceFiles/history/history_widget.cpp @@ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL */ #include "history/history_widget.h" +#include "kotato/kotato_settings.h" #include "api/api_editing.h" #include "api/api_bot.h" #include "api/api_chat_participants.h" @@ -529,6 +530,14 @@ HistoryWidget::HistoryWidget( }); }, lifetime()); + ::Kotato::JsonSettings::Events( + "big_emoji_outline" + ) | rpl::start_with_next([=] { + crl::on_main(this, [=] { + updateHistoryGeometry(); + }); + }, lifetime()); + session().data().animationPlayInlineRequest( ) | rpl::start_with_next([=](not_null item) { if (const auto view = item->mainView()) { diff --git a/Telegram/SourceFiles/kotato/kotato_settings.cpp b/Telegram/SourceFiles/kotato/kotato_settings.cpp index 65b94308e..d26e61946 100644 --- a/Telegram/SourceFiles/kotato/kotato_settings.cpp +++ b/Telegram/SourceFiles/kotato/kotato_settings.cpp @@ -244,6 +244,9 @@ const std::map> DefinitionMap { { "fonts/use_original_metrics", { .type = SettingType::BoolSetting, .defaultValue = false, }}, + { "big_emoji_outline", { + .type = SettingType::BoolSetting, + .defaultValue = true, }}, }; using OldOptionKey = QString; diff --git a/Telegram/SourceFiles/kotato/kotato_settings_menu.cpp b/Telegram/SourceFiles/kotato/kotato_settings_menu.cpp index e986d2bab..cb6edc07c 100644 --- a/Telegram/SourceFiles/kotato/kotato_settings_menu.cpp +++ b/Telegram/SourceFiles/kotato/kotato_settings_menu.cpp @@ -85,6 +85,8 @@ void SetupKotatoChats( void SetupKotatoMessages(not_null container) { AddSubsectionTitle(container, rktr("ktg_settings_messages")); + SettingsMenuJsonSwitch(ktg_settings_emoji_outline, big_emoji_outline); + AddSkip(container); }