tdesktop/Telegram/SourceFiles/api/api_peer_photo.h

119 lines
2.7 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 "mtproto/sender.h"
class ApiWrap;
class PeerData;
class UserData;
namespace Data {
struct FileOrigin;
} // namespace Data
namespace Main {
class Session;
} // namespace Main
namespace Api {
class PeerPhoto final {
public:
using UserPhotoId = PhotoId;
explicit PeerPhoto(not_null<ApiWrap*> api);
enum class EmojiListType {
Profile,
Group,
2023-10-27 19:40:39 +00:00
Background,
};
struct UserPhoto {
QImage image;
DocumentId markupDocumentId = 0;
std::vector<QColor> markupColors;
};
void upload(
not_null<PeerData*> peer,
UserPhoto &&photo,
Fn<void()> done = nullptr);
void uploadFallback(not_null<PeerData*> peer, UserPhoto &&photo);
void updateSelf(
not_null<PhotoData*> photo,
Data::FileOrigin origin,
Fn<void()> done = nullptr);
void suggest(not_null<PeerData*> peer, UserPhoto &&photo);
void clear(not_null<PhotoData*> photo);
void clearPersonal(not_null<UserData*> user);
void set(not_null<PeerData*> peer, not_null<PhotoData*> photo);
void requestUserPhotos(not_null<UserData*> user, UserPhotoId afterId);
void requestEmojiList(EmojiListType type);
using EmojiList = std::vector<DocumentId>;
[[nodiscard]] rpl::producer<EmojiList> emojiListValue(EmojiListType type);
2022-12-19 11:48:24 +00:00
// Non-personal photo in case a personal photo is set.
void registerNonPersonalPhoto(
not_null<UserData*> user,
not_null<PhotoData*> photo);
void unregisterNonPersonalPhoto(not_null<UserData*> user);
[[nodiscard]] PhotoData *nonPersonalPhoto(
not_null<UserData*> user) const;
private:
enum class UploadType {
Default,
Suggestion,
Fallback,
};
2023-10-27 19:40:39 +00:00
struct EmojiListData {
rpl::variable<EmojiList> list;
mtpRequestId requestId = 0;
};
void ready(
const FullMsgId &msgId,
std::optional<MTPInputFile> file,
std::optional<MTPVideoSize> videoSize);
void upload(
not_null<PeerData*> peer,
UserPhoto &&photo,
UploadType type,
Fn<void()> done);
2023-10-27 19:40:39 +00:00
[[nodiscard]] EmojiListData &emojiList(EmojiListType type);
[[nodiscard]] const EmojiListData &emojiList(EmojiListType type) const;
const not_null<Main::Session*> _session;
MTP::Sender _api;
struct UploadValue {
not_null<PeerData*> peer;
UploadType type = UploadType::Default;
Fn<void()> done;
};
base::flat_map<FullMsgId, UploadValue> _uploads;
base::flat_map<not_null<UserData*>, mtpRequestId> _userPhotosRequests;
2022-12-19 11:48:24 +00:00
base::flat_map<
not_null<UserData*>,
not_null<PhotoData*>> _nonPersonalPhotos;
2023-10-27 19:40:39 +00:00
EmojiListData _profileEmojiList;
EmojiListData _groupEmojiList;
EmojiListData _backgroundEmojiList;
};
} // namespace Api