Added suggestion for restore premium to top bar in dialogs.

This commit is contained in:
23rd 2025-04-05 21:54:04 +03:00 committed by John Preston
parent fbfe3fd5ed
commit 2c3cb3f5ce
2 changed files with 39 additions and 21 deletions

View file

@ -3869,6 +3869,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
"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_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_dialogs_suggestions_premium_upgrade_about" = "Upgrade to the annual payment plan for Telegram Premium now to get the discount.";
"lng_dialogs_suggestions_premium_restore_title" = "Get Premium back with up to {text} off";
"lng_dialogs_suggestions_premium_restore_about" = "Your Telegram Premium has recently expired. Tap here to extend it.";
"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

@ -37,6 +37,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; constexpr auto kSugPremiumUpgrade = "PREMIUM_UPGRADE"_cs;
constexpr auto kSugPremiumRestore = "PREMIUM_RESTORE"_cs;
} // namespace } // namespace
@ -78,6 +79,7 @@ rpl::producer<Ui::SlideWrap<Ui::RpWidget>*> TopBarSuggestionValue(
const auto wrap = state->wrap; const auto wrap = state->wrap;
using RightIcon = TopBarSuggestionContent::RightIcon; using RightIcon = TopBarSuggestionContent::RightIcon;
const auto config = &session->appConfig(); const auto config = &session->appConfig();
auto hide = false;
if (config->suggestionCurrent(kSugSetBirthday.utf8()) if (config->suggestionCurrent(kSugSetBirthday.utf8())
&& !Data::IsBirthdayToday(session->user()->birthday())) { && !Data::IsBirthdayToday(session->user()->birthday())) {
content->setRightIcon(RightIcon::Close); content->setRightIcon(RightIcon::Close);
@ -114,21 +116,25 @@ 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 (const auto isAnnual = config->suggestionCurrent( } else if (session->premiumPossible() && !session->premium()) {
kSugPremiumUpgrade.utf8()); const auto isPremiumAnnual = config->suggestionCurrent(
session->premiumPossible() kSugPremiumAnnual.utf8());
&& !session->premium() const auto isPremiumRestore = !isPremiumAnnual
&& (isAnnual && config->suggestionCurrent(kSugPremiumRestore.utf8());
|| config->suggestionCurrent(kSugPremiumAnnual.utf8()))) { const auto isPremiumUpgrade = !isPremiumAnnual
content->setRightIcon(RightIcon::Arrow); && !isPremiumRestore
const auto api = &session->api().premium(); && config->suggestionCurrent(kSugPremiumUpgrade.utf8());
const auto set = [=](QString discount) { const auto set = [=](QString discount) {
constexpr auto kMinus = QChar(0x2212); constexpr auto kMinus = QChar(0x2212);
const auto &title = isAnnual const auto &title = isPremiumAnnual
? tr::lng_dialogs_suggestions_premium_annual_title ? tr::lng_dialogs_suggestions_premium_annual_title
: isPremiumRestore
? tr::lng_dialogs_suggestions_premium_restore_title
: tr::lng_dialogs_suggestions_premium_upgrade_title; : tr::lng_dialogs_suggestions_premium_upgrade_title;
const auto &description = isAnnual const auto &description = isPremiumAnnual
? tr::lng_dialogs_suggestions_premium_annual_about ? tr::lng_dialogs_suggestions_premium_annual_about
: isPremiumRestore
? tr::lng_dialogs_suggestions_premium_restore_about
: tr::lng_dialogs_suggestions_premium_upgrade_about; : tr::lng_dialogs_suggestions_premium_upgrade_about;
content->setContent( content->setContent(
title( title(
@ -143,25 +149,35 @@ rpl::producer<Ui::SlideWrap<Ui::RpWidget>*> TopBarSuggestionValue(
return; return;
} }
Settings::ShowPremium(controller, "dialogs_hint"); Settings::ShowPremium(controller, "dialogs_hint");
config->dismissSuggestion(isAnnual config->dismissSuggestion(isPremiumAnnual
? kSugPremiumAnnual.utf8() ? kSugPremiumAnnual.utf8()
: isPremiumRestore
? kSugPremiumRestore.utf8()
: kSugPremiumUpgrade.utf8()); : kSugPremiumUpgrade.utf8());
repeat(repeat); repeat(repeat);
}); });
wrap->toggle(true, anim::type::normal); wrap->toggle(true, anim::type::normal);
}; };
api->statusTextValue( if (isPremiumAnnual || isPremiumRestore || isPremiumUpgrade) {
) | rpl::start_with_next([=] { content->setRightIcon(RightIcon::Arrow);
for (const auto &option : api->subscriptionOptions()) { const auto api = &session->api().premium();
if (option.months == 12) { api->statusTextValue() | rpl::start_with_next([=] {
set(option.discount); for (const auto &o : api->subscriptionOptions()) {
state->premiumLifetime.destroy(); if (o.months == 12) {
return; set(o.discount);
state->premiumLifetime.destroy();
return;
}
} }
} }, state->premiumLifetime);
}, state->premiumLifetime); api->reload();
api->reload(); } else {
hide = true;
}
} else { } else {
hide = true;
}
if (hide) {
wrap->toggle(false, anim::type::normal); wrap->toggle(false, anim::type::normal);
base::call_delayed(st::slideWrapDuration * 2, wrap, [=] { base::call_delayed(st::slideWrapDuration * 2, wrap, [=] {
state->content = nullptr; state->content = nullptr;