2
0
mirror of https://github.com/telegramdesktop/tdesktop synced 2025-08-25 11:47:29 +00:00
tdesktop/Telegram/SourceFiles/data/data_emoji_statuses.h

179 lines
4.6 KiB
C
Raw Normal View History

/*
This file is part of Telegram Desktop,
the official desktop application for the Telegram messaging service.
For license and copyright information please follow this link:
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
*/
#pragma once
#include "base/timer.h"
namespace Main {
class Session;
} // namespace Main
2023-01-20 20:44:08 +04:00
namespace Ui {
struct EmojiGroup;
} // namespace Ui
namespace Data {
class DocumentMedia;
class Session;
2025-01-09 18:38:40 +04:00
struct UniqueGift;
2025-01-09 11:24:54 +04:00
struct EmojiStatusCollectible {
CollectibleId id = 0;
DocumentId documentId = 0;
QString title;
QString slug;
DocumentId patternDocumentId = 0;
QColor centerColor;
QColor edgeColor;
QColor patternColor;
QColor textColor;
explicit operator bool() const {
return id != 0;
}
};
struct EmojiStatusData {
EmojiStatusId id;
TimeId until = 0;
};
class EmojiStatuses final {
public:
explicit EmojiStatuses(not_null<Session*> owner);
~EmojiStatuses();
[[nodiscard]] Session &owner() const {
return *_owner;
}
[[nodiscard]] Main::Session &session() const;
void refreshRecent();
void refreshRecentDelayed();
void refreshDefault();
void refreshColored();
2023-12-21 22:06:10 -04:00
void refreshChannelDefault();
void refreshChannelColored();
void refreshCollectibles();
enum class Type {
Recent,
Default,
Colored,
2023-12-21 22:06:10 -04:00
ChannelDefault,
ChannelColored,
2025-01-09 11:24:54 +04:00
Collectibles,
};
2025-01-09 11:24:54 +04:00
[[nodiscard]] const std::vector<EmojiStatusId> &list(Type type) const;
[[nodiscard]] EmojiStatusData parse(const MTPEmojiStatus &status);
[[nodiscard]] rpl::producer<> recentUpdates() const;
[[nodiscard]] rpl::producer<> defaultUpdates() const;
2023-12-21 22:06:10 -04:00
[[nodiscard]] rpl::producer<> channelDefaultUpdates() const;
2025-01-09 11:24:54 +04:00
[[nodiscard]] rpl::producer<> collectiblesUpdates() const;
2025-01-09 11:24:54 +04:00
void set(EmojiStatusId id, TimeId until = 0);
void set(not_null<PeerData*> peer, EmojiStatusId id, TimeId until = 0);
2025-01-09 18:38:40 +04:00
[[nodiscard]] EmojiStatusId fromUniqueGift(const Data::UniqueGift &gift);
[[nodiscard]] EmojiStatusCollectible *collectibleInfo(CollectibleId id);
2023-12-16 22:43:35 +00:00
void registerAutomaticClear(not_null<PeerData*> peer, TimeId until);
2022-09-01 09:58:04 +04:00
2023-01-20 20:44:08 +04:00
using Groups = std::vector<Ui::EmojiGroup>;
[[nodiscard]] rpl::producer<Groups> emojiGroupsValue() const;
[[nodiscard]] rpl::producer<Groups> statusGroupsValue() const;
2024-04-30 22:30:39 +04:00
[[nodiscard]] rpl::producer<Groups> stickerGroupsValue() const;
[[nodiscard]] rpl::producer<Groups> profilePhotoGroupsValue() const;
2023-01-20 20:44:08 +04:00
void requestEmojiGroups();
void requestStatusGroups();
2024-04-30 22:30:39 +04:00
void requestStickerGroups();
void requestProfilePhotoGroups();
2023-01-20 20:44:08 +04:00
private:
2023-01-20 20:44:08 +04:00
struct GroupsType {
rpl::variable<Groups> data;
mtpRequestId requestId = 0;
int32 hash = 0;
};
void requestRecent();
void requestDefault();
void requestColored();
2023-12-21 22:06:10 -04:00
void requestChannelDefault();
void requestChannelColored();
void requestCollectibles();
void updateRecent(const MTPDaccount_emojiStatuses &data);
void updateDefault(const MTPDaccount_emojiStatuses &data);
void updateColored(const MTPDmessages_stickerSet &data);
2023-12-21 22:06:10 -04:00
void updateChannelDefault(const MTPDaccount_emojiStatuses &data);
void updateChannelColored(const MTPDmessages_stickerSet &data);
void updateCollectibles(const MTPDaccount_emojiStatuses &data);
2022-09-30 13:37:34 +04:00
void processClearingIn(TimeId wait);
2022-09-01 09:58:04 +04:00
void processClearing();
2025-01-09 11:24:54 +04:00
[[nodiscard]] std::vector<EmojiStatusId> parse(
const MTPDaccount_emojiStatuses &data);
2023-01-20 20:44:08 +04:00
template <typename Request>
void requestGroups(not_null<GroupsType*> type, Request &&request);
const not_null<Session*> _owner;
2025-01-09 11:24:54 +04:00
std::vector<EmojiStatusId> _recent;
std::vector<EmojiStatusId> _default;
std::vector<EmojiStatusId> _colored;
std::vector<EmojiStatusId> _channelDefault;
std::vector<EmojiStatusId> _channelColored;
std::vector<EmojiStatusId> _collectibles;
rpl::event_stream<> _recentUpdated;
rpl::event_stream<> _defaultUpdated;
rpl::event_stream<> _coloredUpdated;
2023-12-21 22:06:10 -04:00
rpl::event_stream<> _channelDefaultUpdated;
rpl::event_stream<> _channelColoredUpdated;
2025-01-09 11:24:54 +04:00
rpl::event_stream<> _collectiblesUpdated;
base::flat_map<
CollectibleId,
std::shared_ptr<EmojiStatusCollectible>> _collectibleData;
mtpRequestId _recentRequestId = 0;
bool _recentRequestScheduled = false;
uint64 _recentHash = 0;
mtpRequestId _defaultRequestId = 0;
uint64 _defaultHash = 0;
mtpRequestId _coloredRequestId = 0;
2023-12-21 22:06:10 -04:00
mtpRequestId _channelDefaultRequestId = 0;
uint64 _channelDefaultHash = 0;
mtpRequestId _channelColoredRequestId = 0;
2025-01-09 11:24:54 +04:00
mtpRequestId _collectiblesRequestId = 0;
uint64 _collectiblesHash = 0;
2025-01-09 11:24:54 +04:00
2023-12-21 22:06:10 -04:00
base::flat_map<not_null<PeerData*>, mtpRequestId> _sentRequests;
2023-12-16 22:43:35 +00:00
base::flat_map<not_null<PeerData*>, TimeId> _clearing;
2022-09-01 09:58:04 +04:00
base::Timer _clearingTimer;
2023-01-20 20:44:08 +04:00
GroupsType _emojiGroups;
GroupsType _statusGroups;
2024-04-30 22:30:39 +04:00
GroupsType _stickerGroups;
GroupsType _profilePhotoGroups;
2023-01-20 20:44:08 +04:00
rpl::lifetime _lifetime;
};
} // namespace Data