mirror of
https://github.com/AyuGram/AyuGramDesktop.git
synced 2025-06-05 22:54:01 +02:00
Added suggestion for restore premium to top bar in dialogs.
This commit is contained in:
parent
fbfe3fd5ed
commit
2c3cb3f5ce
2 changed files with 39 additions and 21 deletions
|
@ -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";
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Add table
Reference in a new issue