Added suggestion for upgrade to premium to top bar in dialogs.

This commit is contained in:
23rd 2025-04-05 20:33:28 +03:00 committed by John Preston
parent b280a26317
commit fbfe3fd5ed
2 changed files with 22 additions and 12 deletions

View file

@ -3867,6 +3867,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
"lng_dialogs_suggestions_birthday_about" = "Let your contacts know when youre celebrating."; "lng_dialogs_suggestions_birthday_about" = "Let your contacts know when youre celebrating.";
"lng_dialogs_suggestions_premium_annual_title" = "Telegram Premium with a {text} discount"; "lng_dialogs_suggestions_premium_annual_title" = "Telegram Premium with a {text} discount";
"lng_dialogs_suggestions_premium_annual_about" = "Sign up for the annual payment plan for Telegram Premium now to get the discount."; "lng_dialogs_suggestions_premium_annual_about" = "Sign up for the annual payment plan for Telegram Premium now to get the discount.";
"lng_dialogs_suggestions_premium_upgrade_title" = "Telegram Premium with a {text} discount";
"lng_dialogs_suggestions_premium_upgrade_about" = "Upgrade to the annual payment plan for Telegram Premium now to get the discount.";
"lng_about_random" = "Send a {emoji} emoji to any chat to try your luck."; "lng_about_random" = "Send a {emoji} emoji to any chat to try your luck.";
"lng_about_random_send" = "Send"; "lng_about_random_send" = "Send";

View file

@ -36,6 +36,7 @@ namespace {
constexpr auto kSugSetBirthday = "BIRTHDAY_SETUP"_cs; constexpr auto kSugSetBirthday = "BIRTHDAY_SETUP"_cs;
constexpr auto kSugPremiumAnnual = "PREMIUM_ANNUAL"_cs; constexpr auto kSugPremiumAnnual = "PREMIUM_ANNUAL"_cs;
constexpr auto kSugPremiumUpgrade = "PREMIUM_UPGRADE"_cs;
} // namespace } // namespace
@ -76,7 +77,8 @@ rpl::producer<Ui::SlideWrap<Ui::RpWidget>*> TopBarSuggestionValue(
const auto content = state->content; const auto content = state->content;
const auto wrap = state->wrap; const auto wrap = state->wrap;
using RightIcon = TopBarSuggestionContent::RightIcon; using RightIcon = TopBarSuggestionContent::RightIcon;
if (session->appConfig().suggestionCurrent(kSugSetBirthday.utf8()) const auto config = &session->appConfig();
if (config->suggestionCurrent(kSugSetBirthday.utf8())
&& !Data::IsBirthdayToday(session->user()->birthday())) { && !Data::IsBirthdayToday(session->user()->birthday())) {
content->setRightIcon(RightIcon::Close); content->setRightIcon(RightIcon::Close);
content->setClickedCallback([=] { content->setClickedCallback([=] {
@ -101,8 +103,7 @@ rpl::producer<Ui::SlideWrap<Ui::RpWidget>*> TopBarSuggestionValue(
}); });
}); });
content->setHideCallback([=] { content->setHideCallback([=] {
session->appConfig().dismissSuggestion( config->dismissSuggestion(kSugSetBirthday.utf8());
kSugSetBirthday.utf8());
repeat(repeat); repeat(repeat);
}); });
content->setContent( content->setContent(
@ -113,31 +114,38 @@ rpl::producer<Ui::SlideWrap<Ui::RpWidget>*> TopBarSuggestionValue(
tr::now, tr::now,
TextWithEntities::Simple)); TextWithEntities::Simple));
wrap->toggle(true, anim::type::normal); wrap->toggle(true, anim::type::normal);
} else if (session->premiumPossible() } else if (const auto isAnnual = config->suggestionCurrent(
kSugPremiumUpgrade.utf8());
session->premiumPossible()
&& !session->premium() && !session->premium()
&& session->appConfig().suggestionCurrent( && (isAnnual
kSugPremiumAnnual.utf8())) { || config->suggestionCurrent(kSugPremiumAnnual.utf8()))) {
content->setRightIcon(RightIcon::Arrow); content->setRightIcon(RightIcon::Arrow);
const auto api = &session->api().premium(); const auto api = &session->api().premium();
const auto set = [=](QString discount) { const auto set = [=](QString discount) {
constexpr auto kMinus = QChar(0x2212); constexpr auto kMinus = QChar(0x2212);
const auto &title = isAnnual
? tr::lng_dialogs_suggestions_premium_annual_title
: tr::lng_dialogs_suggestions_premium_upgrade_title;
const auto &description = isAnnual
? tr::lng_dialogs_suggestions_premium_annual_about
: tr::lng_dialogs_suggestions_premium_upgrade_about;
content->setContent( content->setContent(
tr::lng_dialogs_suggestions_premium_annual_title( title(
tr::now, tr::now,
lt_text, lt_text,
{ discount.replace(kMinus, QChar()) }, { discount.replace(kMinus, QChar()) },
Ui::Text::Bold), Ui::Text::Bold),
tr::lng_dialogs_suggestions_premium_annual_about( description(tr::now, TextWithEntities::Simple));
tr::now,
TextWithEntities::Simple));
content->setClickedCallback([=] { content->setClickedCallback([=] {
const auto controller = FindSessionController(parent); const auto controller = FindSessionController(parent);
if (!controller) { if (!controller) {
return; return;
} }
Settings::ShowPremium(controller, "dialogs_hint"); Settings::ShowPremium(controller, "dialogs_hint");
session->appConfig().dismissSuggestion( config->dismissSuggestion(isAnnual
kSugPremiumAnnual.utf8()); ? kSugPremiumAnnual.utf8()
: kSugPremiumUpgrade.utf8());
repeat(repeat); repeat(repeat);
}); });
wrap->toggle(true, anim::type::normal); wrap->toggle(true, anim::type::normal);