tdesktop/Telegram/SourceFiles/data/stickers/data_custom_emoji.h

138 lines
3.5 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 "data/stickers/data_stickers_set.h"
#include "ui/text/custom_emoji_instance.h"
2022-06-28 15:13:20 +02:00
#include "base/timer.h"
#include "base/weak_ptr.h"
struct StickerSetIdentifier;
namespace Main {
class Session;
} // namespace Main
namespace Data {
class Session;
class CustomEmojiLoader;
struct CustomEmojiId {
uint64 selfId = 0;
uint64 id = 0;
};
2022-06-28 15:13:20 +02:00
class CustomEmojiManager final : public base::has_weak_ptr {
public:
2022-06-28 15:13:20 +02:00
enum class SizeTag {
Normal,
Large,
2022-07-25 16:54:37 +02:00
Isolated,
kCount,
2022-06-28 15:13:20 +02:00
};
CustomEmojiManager(not_null<Session*> owner);
~CustomEmojiManager();
[[nodiscard]] std::unique_ptr<Ui::Text::CustomEmoji> create(
QStringView data,
2022-07-25 10:30:38 +02:00
Fn<void()> update,
SizeTag tag = SizeTag::Normal);
[[nodiscard]] std::unique_ptr<Ui::Text::CustomEmoji> create(
DocumentId documentId,
Fn<void()> update,
SizeTag tag = SizeTag::Normal);
[[nodiscard]] std::unique_ptr<Ui::Text::CustomEmoji> create(
not_null<DocumentData*> document,
Fn<void()> update,
SizeTag tag = SizeTag::Normal);
bool resolved(QStringView data, Fn<void()> callback);
bool resolved(DocumentId documentId, Fn<void()> callback);
[[nodiscard]] std::unique_ptr<Ui::CustomEmoji::Loader> createLoader(
not_null<DocumentData*> document,
SizeTag tag);
[[nodiscard]] std::unique_ptr<Ui::CustomEmoji::Loader> createLoader(
DocumentId documentId,
SizeTag tag);
[[nodiscard]] QString lookupSetName(uint64 setId);
[[nodiscard]] Main::Session &session() const;
[[nodiscard]] Session &owner() const;
private:
2022-07-25 16:54:37 +02:00
static constexpr auto kSizeCount = int(SizeTag::kCount);
2022-06-28 15:13:20 +02:00
struct RepaintBunch {
crl::time when = 0;
std::vector<base::weak_ptr<Ui::CustomEmoji::Instance>> instances;
};
2022-07-05 21:36:25 +02:00
void request();
void requestFinished();
2022-06-28 15:13:20 +02:00
void repaintLater(
not_null<Ui::CustomEmoji::Instance*> instance,
Ui::CustomEmoji::RepaintRequest request);
void scheduleRepaintTimer();
void invokeRepaints();
void requestSetFor(not_null<DocumentData*> document);
[[nodiscard]] Ui::CustomEmoji::Preview prepareNonExactPreview(
DocumentId documentId,
SizeTag tag) const;
2022-07-25 10:30:38 +02:00
template <typename LoaderFactory>
[[nodiscard]] std::unique_ptr<Ui::Text::CustomEmoji> create(
DocumentId documentId,
Fn<void()> update,
SizeTag tag,
LoaderFactory factory);
[[nodiscard]] static int SizeIndex(SizeTag tag);
const not_null<Session*> _owner;
2022-07-25 16:54:37 +02:00
std::array<
base::flat_map<
DocumentId,
2022-07-25 16:54:37 +02:00
std::unique_ptr<Ui::CustomEmoji::Instance>>,
kSizeCount> _instances;
std::array<
base::flat_map<
DocumentId,
2022-07-25 16:54:37 +02:00
std::vector<base::weak_ptr<CustomEmojiLoader>>>,
kSizeCount> _loaders;
base::flat_map<DocumentId, std::vector<Fn<void()>>> _resolvers;
base::flat_set<DocumentId> _pendingForRequest;
2022-07-05 21:36:25 +02:00
mtpRequestId _requestId = 0;
2022-06-28 15:13:20 +02:00
base::flat_map<crl::time, RepaintBunch> _repaints;
crl::time _repaintNext = 0;
base::Timer _repaintTimer;
bool _repaintTimerScheduled = false;
bool _requestSetsScheduled = false;
2022-06-28 15:13:20 +02:00
};
[[nodiscard]] int FrameSizeFromTag(CustomEmojiManager::SizeTag tag);
[[nodiscard]] QString SerializeCustomEmojiId(const CustomEmojiId &id);
[[nodiscard]] QString SerializeCustomEmojiId(
not_null<DocumentData*> document);
[[nodiscard]] CustomEmojiId ParseCustomEmojiData(QStringView data);
[[nodiscard]] bool AllowEmojiWithoutPremium(not_null<PeerData*> peer);
2022-07-05 21:36:25 +02:00
void InsertCustomEmoji(
not_null<Ui::InputField*> field,
not_null<DocumentData*> document);
} // namespace Data