mirror of
https://github.com/telegramdesktop/tdesktop
synced 2025-02-20 15:17:41 +00:00
Update API scheme on layer 142: Premium reactions.
This commit is contained in:
parent
2f6f432583
commit
d87c9c72fb
@ -1322,7 +1322,7 @@ messageReactions#4f2b9479 flags:# min:flags.0?true can_see_list:flags.2?true res
|
||||
|
||||
messages.messageReactionsList#31bd492d flags:# count:int reactions:Vector<MessagePeerReaction> chats:Vector<Chat> users:Vector<User> next_offset:flags.0?string = messages.MessageReactionsList;
|
||||
|
||||
availableReaction#c077ec01 flags:# inactive:flags.0?true reaction:string title:string static_icon:Document appear_animation:Document select_animation:Document activate_animation:Document effect_animation:Document around_animation:flags.1?Document center_icon:flags.1?Document = AvailableReaction;
|
||||
availableReaction#c077ec01 flags:# inactive:flags.0?true premium:flags.2?true reaction:string title:string static_icon:Document appear_animation:Document select_animation:Document activate_animation:Document effect_animation:Document around_animation:flags.1?Document center_icon:flags.1?Document = AvailableReaction;
|
||||
|
||||
messages.availableReactionsNotModified#9f071957 = messages.AvailableReactions;
|
||||
messages.availableReactions#768e3aad hash:int reactions:Vector<AvailableReaction> = messages.AvailableReactions;
|
||||
|
@ -1016,7 +1016,7 @@ void Controller::fillManageSection() {
|
||||
EditAllowedReactionsBox,
|
||||
!_peer->isBroadcast(),
|
||||
session->data().reactions().list(
|
||||
Data::Reactions::Type::Active),
|
||||
Data::Reactions::Type::ActiveNonPremium),
|
||||
*Data::PeerAllowedReactions(_peer),
|
||||
done));
|
||||
},
|
||||
|
@ -8,6 +8,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||
#include "boxes/reactions_settings_box.h"
|
||||
|
||||
#include "base/unixtime.h"
|
||||
#include "data/data_user.h"
|
||||
#include "data/data_document.h"
|
||||
#include "data/data_document_media.h"
|
||||
#include "data/data_message_reactions.h"
|
||||
@ -25,6 +26,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||
#include "ui/chat/chat_theme.h"
|
||||
#include "ui/effects/scroll_content_shadow.h"
|
||||
#include "ui/layers/generic_box.h"
|
||||
#include "ui/toasts/common_toasts.h"
|
||||
#include "ui/widgets/buttons.h"
|
||||
#include "ui/widgets/labels.h"
|
||||
#include "ui/widgets/scroll_area.h"
|
||||
@ -424,6 +426,7 @@ void ReactionsSettingsBox(
|
||||
rpl::single<QString>(base::duplicate(r.title)),
|
||||
st::settingsButton);
|
||||
|
||||
const auto premium = r.premium;
|
||||
const auto iconSize = st::settingsReactionSize;
|
||||
AddReactionLottieIcon(
|
||||
button,
|
||||
@ -443,6 +446,12 @@ void ReactionsSettingsBox(
|
||||
&button->lifetime());
|
||||
|
||||
button->setClickedCallback([=, emoji = r.emoji] {
|
||||
if (premium && !controller->session().user()->isPremium()) {
|
||||
Ui::ShowMultilineToast({
|
||||
.text = { u"Premium reaction."_q },
|
||||
});
|
||||
return;
|
||||
}
|
||||
checkButton(button);
|
||||
state->selectedEmoji = emoji;
|
||||
});
|
||||
|
@ -73,6 +73,7 @@ void Reactions::refresh() {
|
||||
|
||||
const std::vector<Reaction> &Reactions::list(Type type) const {
|
||||
switch (type) {
|
||||
case Type::ActiveNonPremium: return _activeNonPremium;
|
||||
case Type::Active: return _active;
|
||||
case Type::All: return _available;
|
||||
}
|
||||
@ -301,6 +302,7 @@ void Reactions::updateFromData(const MTPDmessages_availableReactions &data) {
|
||||
_iconsCache.emplace(document, document->createMediaView());
|
||||
}
|
||||
};
|
||||
_activeNonPremium.clear();
|
||||
_active.clear();
|
||||
_available.clear();
|
||||
_active.reserve(list.size());
|
||||
@ -315,6 +317,9 @@ void Reactions::updateFromData(const MTPDmessages_availableReactions &data) {
|
||||
toCache(parsed->selectAnimation);
|
||||
toCache(parsed->centerIcon);
|
||||
toCache(parsed->aroundAnimation);
|
||||
if (!parsed->premium) {
|
||||
_activeNonPremium.push_back(*parsed);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -354,6 +359,7 @@ std::optional<Reaction> Reactions::parse(const MTPAvailableReaction &entry) {
|
||||
*data.varound_animation()).get()
|
||||
: nullptr),
|
||||
.active = !data.is_inactive(),
|
||||
.premium = data.is_premium(),
|
||||
})
|
||||
: std::nullopt;
|
||||
});
|
||||
|
@ -29,6 +29,7 @@ struct Reaction {
|
||||
DocumentData *centerIcon = nullptr;
|
||||
DocumentData *aroundAnimation = nullptr;
|
||||
bool active = false;
|
||||
bool premium = false;
|
||||
};
|
||||
|
||||
class Reactions final {
|
||||
@ -39,6 +40,7 @@ public:
|
||||
void refresh();
|
||||
|
||||
enum class Type {
|
||||
ActiveNonPremium,
|
||||
Active,
|
||||
All,
|
||||
};
|
||||
@ -101,6 +103,7 @@ private:
|
||||
|
||||
const not_null<Session*> _owner;
|
||||
|
||||
std::vector<Reaction> _activeNonPremium;
|
||||
std::vector<Reaction> _active;
|
||||
std::vector<Reaction> _available;
|
||||
QString _favorite;
|
||||
|
@ -425,6 +425,7 @@ not_null<UserData*> Session::processUser(const MTPUser &data) {
|
||||
| (data.is_scam() ? Flag::Scam : Flag())
|
||||
| (data.is_fake() ? Flag::Fake : Flag())
|
||||
| (data.is_bot_inline_geo() ? Flag::BotInlineGeo : Flag())
|
||||
| (data.is_premium() ? Flag::Premium : Flag())
|
||||
| (data.is_support() ? Flag::Support : Flag())
|
||||
| (!minimal
|
||||
? (data.is_contact() ? Flag::Contact : Flag())
|
||||
|
@ -381,7 +381,11 @@ HistoryInner::HistoryInner(
|
||||
_reactionsManager->chosen(
|
||||
) | rpl::start_with_next([=](ChosenReaction reaction) {
|
||||
const auto item = session().data().message(reaction.context);
|
||||
if (!item) {
|
||||
if (!item
|
||||
|| Window::ShowReactPremiumError(
|
||||
_controller,
|
||||
item,
|
||||
reaction.emoji)) {
|
||||
return;
|
||||
}
|
||||
item->toggleReaction(reaction.emoji);
|
||||
@ -1876,7 +1880,9 @@ void HistoryInner::toggleFavoriteReaction(not_null<Element*> view) const {
|
||||
return;
|
||||
}
|
||||
const auto item = view->data();
|
||||
if (item->chosenReaction() != favorite) {
|
||||
if (Window::ShowReactPremiumError(_controller, item, favorite)) {
|
||||
return;
|
||||
} else if (item->chosenReaction() != favorite) {
|
||||
if (const auto top = itemTop(view); top >= 0) {
|
||||
view->animateReaction({ .emoji = favorite });
|
||||
}
|
||||
|
@ -28,6 +28,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||
#include "apiwrap.h"
|
||||
#include "api/api_who_reacted.h"
|
||||
#include "layout/layout_selection.h"
|
||||
#include "window/section_widget.h"
|
||||
#include "window/window_adaptive.h"
|
||||
#include "window/window_session_controller.h"
|
||||
#include "window/window_peer_menu.h"
|
||||
@ -349,7 +350,11 @@ ListWidget::ListWidget(
|
||||
_reactionsManager->chosen(
|
||||
) | rpl::start_with_next([=](ChosenReaction reaction) {
|
||||
const auto item = session().data().message(reaction.context);
|
||||
if (!item) {
|
||||
if (!item
|
||||
|| Window::ShowReactPremiumError(
|
||||
_controller,
|
||||
item,
|
||||
reaction.emoji)) {
|
||||
return;
|
||||
}
|
||||
item->toggleReaction(reaction.emoji);
|
||||
@ -2119,7 +2124,9 @@ void ListWidget::toggleFavoriteReaction(not_null<Element*> view) const {
|
||||
return;
|
||||
}
|
||||
const auto item = view->data();
|
||||
if (item->chosenReaction() != favorite) {
|
||||
if (Window::ShowReactPremiumError(_controller, item, favorite)) {
|
||||
return;
|
||||
} else if (item->chosenReaction() != favorite) {
|
||||
if (const auto top = itemTop(view); top >= 0) {
|
||||
view->animateReaction({ .emoji = favorite });
|
||||
}
|
||||
|
@ -443,7 +443,8 @@ rpl::producer<int> FullReactionsCountValue(
|
||||
return rpl::single(rpl::empty) | rpl::then(
|
||||
reactions->updates()
|
||||
) | rpl::map([=] {
|
||||
return int(reactions->list(Data::Reactions::Type::Active).size());
|
||||
return int(reactions->list(
|
||||
Data::Reactions::Type::ActiveNonPremium).size());
|
||||
}) | rpl::distinct_until_changed();
|
||||
}
|
||||
|
||||
|
@ -17,6 +17,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||
#include "data/data_changes.h"
|
||||
#include "data/data_session.h"
|
||||
#include "data/data_cloud_themes.h"
|
||||
#include "data/data_message_reactions.h"
|
||||
#include "history/history_item.h"
|
||||
#include "main/main_session.h"
|
||||
#include "window/section_memento.h"
|
||||
#include "window/window_slide_animation.h"
|
||||
@ -338,4 +340,24 @@ bool ShowSendPremiumError(
|
||||
return true;
|
||||
}
|
||||
|
||||
bool ShowReactPremiumError(
|
||||
not_null<SessionController*> controller,
|
||||
not_null<HistoryItem*> item,
|
||||
const QString &emoji) {
|
||||
if (item->chosenReaction() == emoji
|
||||
|| controller->session().user()->isPremium()) {
|
||||
return false;
|
||||
}
|
||||
const auto &list = controller->session().data().reactions().list(
|
||||
Data::Reactions::Type::Active);
|
||||
const auto i = ranges::find(list, emoji, &Data::Reaction::emoji);
|
||||
if (i == end(list) || !i->premium) {
|
||||
return false;
|
||||
}
|
||||
Ui::ShowMultilineToast({
|
||||
.text = { u"Premium reaction."_q },
|
||||
});
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace Window
|
||||
|
@ -209,4 +209,9 @@ private:
|
||||
not_null<SessionController*> controller,
|
||||
not_null<DocumentData*> document);
|
||||
|
||||
[[nodiscard]] bool ShowReactPremiumError(
|
||||
not_null<SessionController*> controller,
|
||||
not_null<HistoryItem*> item,
|
||||
const QString &emoji);
|
||||
|
||||
} // namespace Window
|
||||
|
Loading…
Reference in New Issue
Block a user