mirror of https://github.com/procxx/kepka.git
Add megagroup stickerset to StickersListWidget.
This commit is contained in:
parent
d44b303fb3
commit
cb5b6d0cb8
|
@ -887,6 +887,9 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||||
"lng_faved_stickers" = "Favorite stickers";
|
"lng_faved_stickers" = "Favorite stickers";
|
||||||
"lng_faved_stickers_add" = "Add to Favorites";
|
"lng_faved_stickers_add" = "Add to Favorites";
|
||||||
"lng_faved_stickers_remove" = "Remove from Favorites";
|
"lng_faved_stickers_remove" = "Remove from Favorites";
|
||||||
|
"lng_group_stickers" = "Group stickers";
|
||||||
|
"lng_group_stickers_description" = "You can choose sticker set which will be available for every member while in the group chat.";
|
||||||
|
"lng_group_stickers_add" = "Choose sticker set";
|
||||||
|
|
||||||
"lng_switch_stickers" = "Stickers";
|
"lng_switch_stickers" = "Stickers";
|
||||||
"lng_switch_emoji" = "Emoji";
|
"lng_switch_emoji" = "Emoji";
|
||||||
|
|
|
@ -313,6 +313,7 @@ void ApiWrap::gotChatFull(PeerData *peer, const MTPmessages_ChatFull &result, mt
|
||||||
|
|
||||||
auto canViewAdmins = channel->canViewAdmins();
|
auto canViewAdmins = channel->canViewAdmins();
|
||||||
auto canViewMembers = channel->canViewMembers();
|
auto canViewMembers = channel->canViewMembers();
|
||||||
|
auto canEditStickers = channel->canEditStickers();
|
||||||
|
|
||||||
channel->flagsFull = f.vflags.v;
|
channel->flagsFull = f.vflags.v;
|
||||||
if (auto photo = App::feedPhoto(f.vchat_photo)) {
|
if (auto photo = App::feedPhoto(f.vchat_photo)) {
|
||||||
|
@ -382,11 +383,25 @@ void ApiWrap::gotChatFull(PeerData *peer, const MTPmessages_ChatFull &result, mt
|
||||||
} else {
|
} else {
|
||||||
channel->mgInfo->pinnedMsgId = 0;
|
channel->mgInfo->pinnedMsgId = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto stickersChanged = (canEditStickers != channel->canEditStickers());
|
||||||
|
auto stickerSet = (f.has_stickerset() ? &f.vstickerset.c_stickerSet() : nullptr);
|
||||||
|
auto newSetId = (stickerSet ? stickerSet->vid.v : 0);
|
||||||
|
auto oldSetId = (channel->mgInfo->stickerSet.type() == mtpc_inputStickerSetID) ? channel->mgInfo->stickerSet.c_inputStickerSetID().vid.v : 0;
|
||||||
|
if (oldSetId != newSetId) {
|
||||||
|
channel->mgInfo->stickerSet = stickerSet ? MTP_inputStickerSetID(stickerSet->vid, stickerSet->vaccess_hash) : MTP_inputStickerSetEmpty();
|
||||||
|
stickersChanged = true;
|
||||||
|
}
|
||||||
|
if (stickersChanged) {
|
||||||
|
Notify::peerUpdatedDelayed(channel, Notify::PeerUpdate::Flag::ChannelStickersChanged);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
channel->fullUpdated();
|
channel->fullUpdated();
|
||||||
|
|
||||||
if (canViewAdmins != channel->canViewAdmins()
|
if (canViewAdmins != channel->canViewAdmins()
|
||||||
|| canViewMembers != channel->canViewMembers()) Notify::peerUpdatedDelayed(channel, Notify::PeerUpdate::Flag::ChannelRightsChanged);
|
|| canViewMembers != channel->canViewMembers()) {
|
||||||
|
Notify::peerUpdatedDelayed(channel, Notify::PeerUpdate::Flag::ChannelRightsChanged);
|
||||||
|
}
|
||||||
|
|
||||||
notifySettingReceived(MTP_inputNotifyPeer(peer->input), f.vnotify_settings);
|
notifySettingReceived(MTP_inputNotifyPeer(peer->input), f.vnotify_settings);
|
||||||
}
|
}
|
||||||
|
@ -1260,101 +1275,7 @@ PeerData *ApiWrap::notifySettingReceived(MTPInputNotifyPeer notifyPeer, const MT
|
||||||
|
|
||||||
void ApiWrap::gotStickerSet(uint64 setId, const MTPmessages_StickerSet &result) {
|
void ApiWrap::gotStickerSet(uint64 setId, const MTPmessages_StickerSet &result) {
|
||||||
_stickerSetRequests.remove(setId);
|
_stickerSetRequests.remove(setId);
|
||||||
|
Stickers::FeedSetFull(result);
|
||||||
if (result.type() != mtpc_messages_stickerSet) return;
|
|
||||||
auto &d(result.c_messages_stickerSet());
|
|
||||||
|
|
||||||
if (d.vset.type() != mtpc_stickerSet) return;
|
|
||||||
auto &s(d.vset.c_stickerSet());
|
|
||||||
|
|
||||||
auto &sets = Global::RefStickerSets();
|
|
||||||
auto it = sets.find(setId);
|
|
||||||
if (it == sets.cend()) return;
|
|
||||||
|
|
||||||
it->access = s.vaccess_hash.v;
|
|
||||||
it->hash = s.vhash.v;
|
|
||||||
it->shortName = qs(s.vshort_name);
|
|
||||||
it->title = stickerSetTitle(s);
|
|
||||||
auto clientFlags = it->flags & (MTPDstickerSet_ClientFlag::f_featured | MTPDstickerSet_ClientFlag::f_unread | MTPDstickerSet_ClientFlag::f_not_loaded | MTPDstickerSet_ClientFlag::f_special);
|
|
||||||
it->flags = s.vflags.v | clientFlags;
|
|
||||||
it->flags &= ~MTPDstickerSet_ClientFlag::f_not_loaded;
|
|
||||||
|
|
||||||
auto &d_docs = d.vdocuments.v;
|
|
||||||
auto custom = sets.find(Stickers::CustomSetId);
|
|
||||||
|
|
||||||
StickerPack pack;
|
|
||||||
pack.reserve(d_docs.size());
|
|
||||||
for (int32 i = 0, l = d_docs.size(); i != l; ++i) {
|
|
||||||
DocumentData *doc = App::feedDocument(d_docs.at(i));
|
|
||||||
if (!doc || !doc->sticker()) continue;
|
|
||||||
|
|
||||||
pack.push_back(doc);
|
|
||||||
if (custom != sets.cend()) {
|
|
||||||
int32 index = custom->stickers.indexOf(doc);
|
|
||||||
if (index >= 0) {
|
|
||||||
custom->stickers.removeAt(index);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (custom != sets.cend() && custom->stickers.isEmpty()) {
|
|
||||||
sets.erase(custom);
|
|
||||||
custom = sets.end();
|
|
||||||
}
|
|
||||||
|
|
||||||
auto writeRecent = false;
|
|
||||||
auto &recent = cGetRecentStickers();
|
|
||||||
for (auto i = recent.begin(); i != recent.cend();) {
|
|
||||||
if (it->stickers.indexOf(i->first) >= 0 && pack.indexOf(i->first) < 0) {
|
|
||||||
i = recent.erase(i);
|
|
||||||
writeRecent = true;
|
|
||||||
} else {
|
|
||||||
++i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pack.isEmpty()) {
|
|
||||||
int removeIndex = Global::StickerSetsOrder().indexOf(setId);
|
|
||||||
if (removeIndex >= 0) Global::RefStickerSetsOrder().removeAt(removeIndex);
|
|
||||||
sets.erase(it);
|
|
||||||
} else {
|
|
||||||
it->stickers = pack;
|
|
||||||
it->emoji.clear();
|
|
||||||
auto &v = d.vpacks.v;
|
|
||||||
for (auto i = 0, l = v.size(); i != l; ++i) {
|
|
||||||
if (v[i].type() != mtpc_stickerPack) continue;
|
|
||||||
|
|
||||||
auto &pack = v[i].c_stickerPack();
|
|
||||||
if (auto emoji = Ui::Emoji::Find(qs(pack.vemoticon))) {
|
|
||||||
emoji = emoji->original();
|
|
||||||
auto &stickers = pack.vdocuments.v;
|
|
||||||
|
|
||||||
StickerPack p;
|
|
||||||
p.reserve(stickers.size());
|
|
||||||
for (auto j = 0, c = stickers.size(); j != c; ++j) {
|
|
||||||
auto doc = App::document(stickers[j].v);
|
|
||||||
if (!doc || !doc->sticker()) continue;
|
|
||||||
|
|
||||||
p.push_back(doc);
|
|
||||||
}
|
|
||||||
it->emoji.insert(emoji, p);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (writeRecent) {
|
|
||||||
Local::writeUserSettings();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (it->flags & MTPDstickerSet::Flag::f_installed) {
|
|
||||||
if (!(it->flags & MTPDstickerSet::Flag::f_archived)) {
|
|
||||||
Local::writeInstalledStickers();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (it->flags & MTPDstickerSet_ClientFlag::f_featured) {
|
|
||||||
Local::writeFeaturedStickers();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (App::main()) emit App::main()->stickersUpdated();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ApiWrap::requestWebPageDelayed(WebPageData *page) {
|
void ApiWrap::requestWebPageDelayed(WebPageData *page) {
|
||||||
|
|
|
@ -312,7 +312,7 @@ void Application::startApplication() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::createMessenger() {
|
void Application::createMessenger() {
|
||||||
t_assert(!App::quitting());
|
Expects(!App::quitting());
|
||||||
_messengerInstance = std::make_unique<Messenger>();
|
_messengerInstance = std::make_unique<Messenger>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -208,6 +208,11 @@ stickerIconMove: 400;
|
||||||
stickerPreviewDuration: 150;
|
stickerPreviewDuration: 150;
|
||||||
stickerPreviewMin: 0.1;
|
stickerPreviewMin: 0.1;
|
||||||
|
|
||||||
|
stickerGroupCategorySize: 28px;
|
||||||
|
stickerGroupCategoryAbout: defaultTextStyle;
|
||||||
|
stickerGroupCategoryAddMargin: margins(0px, 10px, 0px, 5px);
|
||||||
|
stickerGroupCategoryAdd: stickersTrendingAdd;
|
||||||
|
|
||||||
stickersToastMaxWidth: 340px;
|
stickersToastMaxWidth: 340px;
|
||||||
stickersToastPadding: margins(16px, 13px, 16px, 12px);
|
stickersToastPadding: margins(16px, 13px, 16px, 12px);
|
||||||
|
|
||||||
|
|
|
@ -651,6 +651,132 @@ std::vector<gsl::not_null<EmojiPtr>> GetEmojiListFromSet(gsl::not_null<DocumentD
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Set *FeedSet(const MTPDstickerSet &set) {
|
||||||
|
auto &sets = Global::RefStickerSets();
|
||||||
|
auto it = sets.find(set.vid.v);
|
||||||
|
auto title = stickerSetTitle(set);
|
||||||
|
auto flags = MTPDstickerSet::Flags(0);
|
||||||
|
if (it == sets.cend()) {
|
||||||
|
it = sets.insert(set.vid.v, Stickers::Set(set.vid.v, set.vaccess_hash.v, title, qs(set.vshort_name), set.vcount.v, set.vhash.v, set.vflags.v | MTPDstickerSet_ClientFlag::f_not_loaded));
|
||||||
|
} else {
|
||||||
|
it->access = set.vaccess_hash.v;
|
||||||
|
it->title = title;
|
||||||
|
it->shortName = qs(set.vshort_name);
|
||||||
|
flags = it->flags;
|
||||||
|
auto clientFlags = it->flags & (MTPDstickerSet_ClientFlag::f_featured | MTPDstickerSet_ClientFlag::f_unread | MTPDstickerSet_ClientFlag::f_not_loaded | MTPDstickerSet_ClientFlag::f_special);
|
||||||
|
it->flags = set.vflags.v | clientFlags;
|
||||||
|
if (it->count != set.vcount.v || it->hash != set.vhash.v || it->emoji.isEmpty()) {
|
||||||
|
it->count = set.vcount.v;
|
||||||
|
it->hash = set.vhash.v;
|
||||||
|
it->flags |= MTPDstickerSet_ClientFlag::f_not_loaded; // need to request this set
|
||||||
|
}
|
||||||
|
}
|
||||||
|
auto changedFlags = (flags ^ it->flags);
|
||||||
|
if (changedFlags & MTPDstickerSet::Flag::f_archived) {
|
||||||
|
auto index = Global::ArchivedStickerSetsOrder().indexOf(it->id);
|
||||||
|
if (it->flags & MTPDstickerSet::Flag::f_archived) {
|
||||||
|
if (index < 0) {
|
||||||
|
Global::RefArchivedStickerSetsOrder().push_front(it->id);
|
||||||
|
}
|
||||||
|
} else if (index >= 0) {
|
||||||
|
Global::RefArchivedStickerSetsOrder().removeAt(index);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return &it.value();
|
||||||
|
}
|
||||||
|
|
||||||
|
Set *FeedSetFull(const MTPmessages_StickerSet &data) {
|
||||||
|
Expects(data.type() == mtpc_messages_stickerSet);
|
||||||
|
Expects(data.c_messages_stickerSet().vset.type() == mtpc_stickerSet);
|
||||||
|
auto &d = data.c_messages_stickerSet();
|
||||||
|
auto set = FeedSet(d.vset.c_stickerSet());
|
||||||
|
|
||||||
|
set->flags &= ~MTPDstickerSet_ClientFlag::f_not_loaded;
|
||||||
|
|
||||||
|
auto &sets = Global::RefStickerSets();
|
||||||
|
auto &d_docs = d.vdocuments.v;
|
||||||
|
auto custom = sets.find(Stickers::CustomSetId);
|
||||||
|
|
||||||
|
auto pack = StickerPack();
|
||||||
|
pack.reserve(d_docs.size());
|
||||||
|
for (auto i = 0, l = d_docs.size(); i != l; ++i) {
|
||||||
|
auto doc = App::feedDocument(d_docs.at(i));
|
||||||
|
if (!doc || !doc->sticker()) continue;
|
||||||
|
|
||||||
|
pack.push_back(doc);
|
||||||
|
if (custom != sets.cend()) {
|
||||||
|
auto index = custom->stickers.indexOf(doc);
|
||||||
|
if (index >= 0) {
|
||||||
|
custom->stickers.removeAt(index);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (custom != sets.cend() && custom->stickers.isEmpty()) {
|
||||||
|
sets.erase(custom);
|
||||||
|
custom = sets.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
auto writeRecent = false;
|
||||||
|
auto &recent = cGetRecentStickers();
|
||||||
|
for (auto i = recent.begin(); i != recent.cend();) {
|
||||||
|
if (set->stickers.indexOf(i->first) >= 0 && pack.indexOf(i->first) < 0) {
|
||||||
|
i = recent.erase(i);
|
||||||
|
writeRecent = true;
|
||||||
|
} else {
|
||||||
|
++i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pack.isEmpty()) {
|
||||||
|
int removeIndex = Global::StickerSetsOrder().indexOf(set->id);
|
||||||
|
if (removeIndex >= 0) Global::RefStickerSetsOrder().removeAt(removeIndex);
|
||||||
|
sets.remove(set->id);
|
||||||
|
set = nullptr;
|
||||||
|
} else {
|
||||||
|
set->stickers = pack;
|
||||||
|
set->emoji.clear();
|
||||||
|
auto &v = d.vpacks.v;
|
||||||
|
for (auto i = 0, l = v.size(); i != l; ++i) {
|
||||||
|
if (v[i].type() != mtpc_stickerPack) continue;
|
||||||
|
|
||||||
|
auto &pack = v[i].c_stickerPack();
|
||||||
|
if (auto emoji = Ui::Emoji::Find(qs(pack.vemoticon))) {
|
||||||
|
emoji = emoji->original();
|
||||||
|
auto &stickers = pack.vdocuments.v;
|
||||||
|
|
||||||
|
StickerPack p;
|
||||||
|
p.reserve(stickers.size());
|
||||||
|
for (auto j = 0, c = stickers.size(); j != c; ++j) {
|
||||||
|
auto doc = App::document(stickers[j].v);
|
||||||
|
if (!doc || !doc->sticker()) continue;
|
||||||
|
|
||||||
|
p.push_back(doc);
|
||||||
|
}
|
||||||
|
set->emoji.insert(emoji, p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (writeRecent) {
|
||||||
|
Local::writeUserSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (set) {
|
||||||
|
if (set->flags & MTPDstickerSet::Flag::f_installed) {
|
||||||
|
if (!(set->flags & MTPDstickerSet::Flag::f_archived)) {
|
||||||
|
Local::writeInstalledStickers();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (set->flags & MTPDstickerSet_ClientFlag::f_featured) {
|
||||||
|
Local::writeFeaturedStickers();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (App::main()) emit App::main()->stickersUpdated();
|
||||||
|
|
||||||
|
return set;
|
||||||
|
}
|
||||||
|
|
||||||
namespace internal {
|
namespace internal {
|
||||||
|
|
||||||
FeaturedReader::FeaturedReader(QObject *parent) : QObject(parent)
|
FeaturedReader::FeaturedReader(QObject *parent) : QObject(parent)
|
||||||
|
|
|
@ -42,6 +42,9 @@ void GifsReceived(const QVector<MTPDocument> &items, int32 hash);
|
||||||
StickerPack GetListByEmoji(gsl::not_null<EmojiPtr> emoji);
|
StickerPack GetListByEmoji(gsl::not_null<EmojiPtr> emoji);
|
||||||
std::vector<gsl::not_null<EmojiPtr>> GetEmojiListFromSet(gsl::not_null<DocumentData*> document);
|
std::vector<gsl::not_null<EmojiPtr>> GetEmojiListFromSet(gsl::not_null<DocumentData*> document);
|
||||||
|
|
||||||
|
Set *FeedSet(const MTPDstickerSet &data);
|
||||||
|
Set *FeedSetFull(const MTPmessages_StickerSet &data);
|
||||||
|
|
||||||
namespace internal {
|
namespace internal {
|
||||||
|
|
||||||
class FeaturedReader : public QObject, private MTP::Sender {
|
class FeaturedReader : public QObject, private MTP::Sender {
|
||||||
|
|
|
@ -33,6 +33,9 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||||
#include "boxes/sticker_set_box.h"
|
#include "boxes/sticker_set_box.h"
|
||||||
#include "boxes/stickers_box.h"
|
#include "boxes/stickers_box.h"
|
||||||
#include "boxes/confirm_box.h"
|
#include "boxes/confirm_box.h"
|
||||||
|
#include "auth_session.h"
|
||||||
|
#include "observer_peer.h"
|
||||||
|
#include "apiwrap.h"
|
||||||
|
|
||||||
namespace ChatHelpers {
|
namespace ChatHelpers {
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -49,6 +52,7 @@ struct StickerIcon {
|
||||||
}
|
}
|
||||||
uint64 setId = 0;
|
uint64 setId = 0;
|
||||||
DocumentData *sticker = nullptr;
|
DocumentData *sticker = nullptr;
|
||||||
|
ChannelData *megagroup = nullptr;
|
||||||
int pixw = 0;
|
int pixw = 0;
|
||||||
int pixh = 0;
|
int pixh = 0;
|
||||||
|
|
||||||
|
@ -207,6 +211,8 @@ void StickersListWidget::Footer::paintEvent(QPaintEvent *e) {
|
||||||
auto pix = icon.sticker->thumb->pix(icon.pixw, icon.pixh);
|
auto pix = icon.sticker->thumb->pix(icon.pixw, icon.pixh);
|
||||||
|
|
||||||
p.drawPixmapLeft(x + (st::emojiCategory.width - icon.pixw) / 2, _iconsTop + (st::emojiCategory.height - icon.pixh) / 2, width(), pix);
|
p.drawPixmapLeft(x + (st::emojiCategory.width - icon.pixw) / 2, _iconsTop + (st::emojiCategory.height - icon.pixh) / 2, width(), pix);
|
||||||
|
} else if (icon.megagroup) {
|
||||||
|
icon.megagroup->paintUserpicLeft(p, x + (st::emojiCategory.width - st::stickerGroupCategorySize) / 2, _iconsTop + (st::emojiCategory.height - st::stickerGroupCategorySize) / 2, width(), st::stickerGroupCategorySize);
|
||||||
} else {
|
} else {
|
||||||
auto getSpecialSetIcon = [](uint64 setId) {
|
auto getSpecialSetIcon = [](uint64 setId) {
|
||||||
if (setId == Stickers::FeaturedSetId) {
|
if (setId == Stickers::FeaturedSetId) {
|
||||||
|
@ -432,7 +438,8 @@ StickersListWidget::StickersListWidget(QWidget *parent, gsl::not_null<Window::Co
|
||||||
, _section(Section::Stickers)
|
, _section(Section::Stickers)
|
||||||
, _addText(lang(lng_stickers_featured_add).toUpper())
|
, _addText(lang(lng_stickers_featured_add).toUpper())
|
||||||
, _addWidth(st::stickersTrendingAdd.font->width(_addText))
|
, _addWidth(st::stickersTrendingAdd.font->width(_addText))
|
||||||
, _settings(this, lang(lng_stickers_you_have)) {
|
, _settings(this, lang(lng_stickers_you_have))
|
||||||
|
, _megagroupSetAbout(st::emojiPanWidth - st::emojiScroll.width - st::emojiPanHeaderLeft) {
|
||||||
resize(st::emojiPanWidth - st::emojiScroll.width - st::buttonRadius, countHeight());
|
resize(st::emojiPanWidth - st::emojiScroll.width - st::buttonRadius, countHeight());
|
||||||
|
|
||||||
setMouseTracking(true);
|
setMouseTracking(true);
|
||||||
|
@ -447,6 +454,11 @@ StickersListWidget::StickersListWidget(QWidget *parent, gsl::not_null<Window::Co
|
||||||
update();
|
update();
|
||||||
readVisibleSets();
|
readVisibleSets();
|
||||||
});
|
});
|
||||||
|
subscribe(Notify::PeerUpdated(), Notify::PeerUpdatedHandler(Notify::PeerUpdate::Flag::ChannelStickersChanged, [this](const Notify::PeerUpdate &update) {
|
||||||
|
if (update.peer == _megagroupSet) {
|
||||||
|
refreshStickers();
|
||||||
|
}
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
object_ptr<TabbedSelector::InnerFooter> StickersListWidget::createFooter() {
|
object_ptr<TabbedSelector::InnerFooter> StickersListWidget::createFooter() {
|
||||||
|
@ -504,9 +516,14 @@ bool StickersListWidget::enumerateSections(Callback callback) const {
|
||||||
auto &set = _mySets[i];
|
auto &set = _mySets[i];
|
||||||
info.section = i;
|
info.section = i;
|
||||||
info.count = set.pack.size();
|
info.count = set.pack.size();
|
||||||
info.rowsCount = (info.count / kStickersPanelPerRow) + ((info.count % kStickersPanelPerRow) ? 1 : 0);
|
|
||||||
info.rowsTop = info.top + (setHasTitle(set) ? st::emojiPanHeader : st::stickerPanPadding);
|
info.rowsTop = info.top + (setHasTitle(set) ? st::emojiPanHeader : st::stickerPanPadding);
|
||||||
info.rowsBottom = info.rowsTop + info.rowsCount * st::stickerPanSize.height();
|
if (set.id == Stickers::MegagroupEmptySetId) {
|
||||||
|
info.rowsCount = 0;
|
||||||
|
info.rowsBottom = info.rowsTop + _megagroupSetButtonRect.y() + _megagroupSetButtonRect.height() + st::stickerGroupCategoryAddMargin.bottom();
|
||||||
|
} else {
|
||||||
|
info.rowsCount = (info.count / kStickersPanelPerRow) + ((info.count % kStickersPanelPerRow) ? 1 : 0);
|
||||||
|
info.rowsBottom = info.rowsTop + info.rowsCount * st::stickerPanSize.height();
|
||||||
|
}
|
||||||
if (!callback(info)) {
|
if (!callback(info)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -744,6 +761,10 @@ void StickersListWidget::paintStickers(Painter &p, QRect clip) {
|
||||||
p.drawTextLeft(st::emojiPanHeaderLeft - st::buttonRadius, info.top + st::emojiPanHeaderTop, width(), titleText, titleWidth);
|
p.drawTextLeft(st::emojiPanHeaderLeft - st::buttonRadius, info.top + st::emojiPanHeaderTop, width(), titleText, titleWidth);
|
||||||
}
|
}
|
||||||
if (clip.top() + clip.height() > info.rowsTop) {
|
if (clip.top() + clip.height() > info.rowsTop) {
|
||||||
|
if (set.id == Stickers::MegagroupEmptySetId) {
|
||||||
|
auto buttonSelected = (base::get_if<OverGroupAdd>(&_selected) != nullptr);
|
||||||
|
paintMegagroupEmptySet(p, info.rowsTop, buttonSelected, ms);
|
||||||
|
}
|
||||||
auto special = (set.flags & MTPDstickerSet::Flag::f_official) != 0;
|
auto special = (set.flags & MTPDstickerSet::Flag::f_official) != 0;
|
||||||
auto fromRow = floorclamp(clip.y() - info.rowsTop, st::stickerPanSize.height(), 0, info.rowsCount);
|
auto fromRow = floorclamp(clip.y() - info.rowsTop, st::stickerPanSize.height(), 0, info.rowsCount);
|
||||||
auto toRow = ceilclamp(clip.y() + clip.height() - info.rowsTop, st::stickerPanSize.height(), 0, info.rowsCount);
|
auto toRow = ceilclamp(clip.y() + clip.height() - info.rowsTop, st::stickerPanSize.height(), 0, info.rowsCount);
|
||||||
|
@ -762,6 +783,29 @@ void StickersListWidget::paintStickers(Painter &p, QRect clip) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int StickersListWidget::megagroupSetInfoLeft() const {
|
||||||
|
return st::emojiPanHeaderLeft - st::buttonRadius;
|
||||||
|
}
|
||||||
|
|
||||||
|
void StickersListWidget::paintMegagroupEmptySet(Painter &p, int y, bool buttonSelected, TimeMs ms) {
|
||||||
|
auto infoLeft = megagroupSetInfoLeft();
|
||||||
|
_megagroupSetAbout.drawLeft(p, infoLeft, y, width() - infoLeft, width());
|
||||||
|
|
||||||
|
auto &textBg = buttonSelected ? st::stickerGroupCategoryAdd.textBgOver : st::stickerGroupCategoryAdd.textBg;
|
||||||
|
|
||||||
|
auto button = _megagroupSetButtonRect.translated(0, y);
|
||||||
|
App::roundRect(p, myrtlrect(button), textBg, ImageRoundRadius::Small);
|
||||||
|
if (_megagroupSetButtonRipple) {
|
||||||
|
_megagroupSetButtonRipple->paint(p, button.x(), button.y(), width(), ms);
|
||||||
|
if (_megagroupSetButtonRipple->empty()) {
|
||||||
|
_megagroupSetButtonRipple.reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p.setFont(st::stickerGroupCategoryAdd.font);
|
||||||
|
p.setPen(buttonSelected ? st::stickerGroupCategoryAdd.textFgOver : st::stickerGroupCategoryAdd.textFg);
|
||||||
|
p.drawTextLeft(button.x() - (st::stickerGroupCategoryAdd.width / 2), button.y() + st::stickerGroupCategoryAdd.textTop, width(), _megagroupSetButtonText, _megagroupSetButtonTextWidth);
|
||||||
|
}
|
||||||
|
|
||||||
void StickersListWidget::paintSticker(Painter &p, Set &set, int y, int index, bool selected, bool deleteSelected) {
|
void StickersListWidget::paintSticker(Painter &p, Set &set, int y, int index, bool selected, bool deleteSelected) {
|
||||||
auto sticker = set.pack[index];
|
auto sticker = set.pack[index];
|
||||||
if (!sticker->sticker()) return;
|
if (!sticker->sticker()) return;
|
||||||
|
@ -825,8 +869,16 @@ bool StickersListWidget::hasRemoveButton(int index) const {
|
||||||
if (index < 0 || index >= _mySets.size()) {
|
if (index < 0 || index >= _mySets.size()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
auto flags = _mySets[index].flags;
|
auto &set = _mySets[index];
|
||||||
return !(flags & MTPDstickerSet_ClientFlag::f_special);
|
auto flags = set.flags;
|
||||||
|
if (!(flags & MTPDstickerSet_ClientFlag::f_special)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (set.megagroupSet) {
|
||||||
|
t_assert(_megagroupSet != nullptr);
|
||||||
|
return (set.id == Stickers::MegagroupEmptySetId) ? (index + 1 != _mySets.size()) : _megagroupSet->canEditStickers();
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
QRect StickersListWidget::removeButtonRect(int index) const {
|
QRect StickersListWidget::removeButtonRect(int index) const {
|
||||||
|
@ -857,6 +909,10 @@ void StickersListWidget::setPressed(OverState newPressed) {
|
||||||
if (set.ripple) {
|
if (set.ripple) {
|
||||||
set.ripple->lastStop();
|
set.ripple->lastStop();
|
||||||
}
|
}
|
||||||
|
} else if (base::get_if<OverGroupAdd>(&_pressed)) {
|
||||||
|
if (_megagroupSetButtonRipple) {
|
||||||
|
_megagroupSetButtonRipple->lastStop();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
_pressed = newPressed;
|
_pressed = newPressed;
|
||||||
if (auto button = base::get_if<OverButton>(&_pressed)) {
|
if (auto button = base::get_if<OverButton>(&_pressed)) {
|
||||||
|
@ -867,9 +923,32 @@ void StickersListWidget::setPressed(OverState newPressed) {
|
||||||
set.ripple = createButtonRipple(button->section);
|
set.ripple = createButtonRipple(button->section);
|
||||||
}
|
}
|
||||||
set.ripple->add(mapFromGlobal(QCursor::pos()) - buttonRippleTopLeft(button->section));
|
set.ripple->add(mapFromGlobal(QCursor::pos()) - buttonRippleTopLeft(button->section));
|
||||||
|
} else if (base::get_if<OverGroupAdd>(&_pressed)) {
|
||||||
|
if (!_megagroupSetButtonRipple) {
|
||||||
|
auto maskSize = _megagroupSetButtonRect.size();
|
||||||
|
auto mask = Ui::RippleAnimation::roundRectMask(maskSize, st::buttonRadius);
|
||||||
|
_megagroupSetButtonRipple = std::make_unique<Ui::RippleAnimation>(st::stickerGroupCategoryAdd.ripple, std::move(mask), [this] {
|
||||||
|
rtlupdate(megagroupSetButtonRectFinal());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
_megagroupSetButtonRipple->add(mapFromGlobal(QCursor::pos()) - myrtlrect(megagroupSetButtonRectFinal()).topLeft());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QRect StickersListWidget::megagroupSetButtonRectFinal() const {
|
||||||
|
auto result = QRect();
|
||||||
|
if (_section == Section::Stickers) {
|
||||||
|
enumerateSections([this, &result](const SectionInfo &info) {
|
||||||
|
if (_mySets[info.section].id == Stickers::MegagroupEmptySetId) {
|
||||||
|
result = _megagroupSetButtonRect.translated(0, info.rowsTop);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
QSharedPointer<Ui::RippleAnimation> StickersListWidget::createButtonRipple(int section) {
|
QSharedPointer<Ui::RippleAnimation> StickersListWidget::createButtonRipple(int section) {
|
||||||
if (_section == Section::Featured) {
|
if (_section == Section::Featured) {
|
||||||
auto maskSize = QSize(_addWidth - st::stickersTrendingAdd.width, st::stickersTrendingAdd.height);
|
auto maskSize = QSize(_addWidth - st::stickersTrendingAdd.width, st::stickersTrendingAdd.height);
|
||||||
|
@ -937,6 +1016,8 @@ void StickersListWidget::mouseReleaseEvent(QMouseEvent *e) {
|
||||||
} else {
|
} else {
|
||||||
removeSet(sets[button->section].id);
|
removeSet(sets[button->section].id);
|
||||||
}
|
}
|
||||||
|
} else if (base::get_if<OverGroupAdd>(&pressed)) {
|
||||||
|
Ui::show(Box<InformBox>("TODO"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1047,6 +1128,7 @@ void StickersListWidget::refreshStickers() {
|
||||||
|
|
||||||
refreshRecentStickers(false);
|
refreshRecentStickers(false);
|
||||||
refreshFavedStickers();
|
refreshFavedStickers();
|
||||||
|
refreshMegagroupStickers();
|
||||||
for_const (auto setId, Global::StickerSetsOrder()) {
|
for_const (auto setId, Global::StickerSetsOrder()) {
|
||||||
appendSet(_mySets, setId, AppendSkip::Archived);
|
appendSet(_mySets, setId, AppendSkip::Archived);
|
||||||
}
|
}
|
||||||
|
@ -1203,6 +1285,32 @@ void StickersListWidget::refreshFavedStickers() {
|
||||||
_mySets.push_back(Set(Stickers::FavedSetId, MTPDstickerSet::Flag::f_official | MTPDstickerSet_ClientFlag::f_special, lang(lng_faved_stickers), it->stickers.size() * 2, it->stickers));
|
_mySets.push_back(Set(Stickers::FavedSetId, MTPDstickerSet::Flag::f_official | MTPDstickerSet_ClientFlag::f_special, lang(lng_faved_stickers), it->stickers.size() * 2, it->stickers));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StickersListWidget::refreshMegagroupStickers() {
|
||||||
|
if (!_megagroupSet) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (_megagroupSet->mgInfo->stickerSet.type() == mtpc_inputStickerSetEmpty) {
|
||||||
|
if (_megagroupSet->canEditStickers()) {
|
||||||
|
_mySets.push_back(Set(Stickers::MegagroupEmptySetId, qFlags(MTPDstickerSet_ClientFlag::f_special), lang(lng_group_stickers), 0));
|
||||||
|
_mySets.back().megagroupSet = true;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (_megagroupSet->mgInfo->stickerSet.type() == mtpc_inputStickerSetID) {
|
||||||
|
auto &set = _megagroupSet->mgInfo->stickerSet.c_inputStickerSetID();
|
||||||
|
appendSet(_mySets, set.vid.v);
|
||||||
|
if (_mySets.back().id == set.vid.v) {
|
||||||
|
_mySets.back().megagroupSet = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
request(MTPmessages_GetStickerSet(_megagroupSet->mgInfo->stickerSet)).done([this](const MTPmessages_StickerSet &result) {
|
||||||
|
if (auto set = Stickers::FeedSetFull(result)) {
|
||||||
|
refreshStickers();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
void StickersListWidget::fillIcons(QList<StickerIcon> &icons) {
|
void StickersListWidget::fillIcons(QList<StickerIcon> &icons) {
|
||||||
icons.clear();
|
icons.clear();
|
||||||
icons.reserve(_mySets.size() + 1);
|
icons.reserve(_mySets.size() + 1);
|
||||||
|
@ -1220,6 +1328,11 @@ void StickersListWidget::fillIcons(QList<StickerIcon> &icons) {
|
||||||
icons.push_back(StickerIcon(Stickers::FavedSetId));
|
icons.push_back(StickerIcon(Stickers::FavedSetId));
|
||||||
}
|
}
|
||||||
for (auto l = _mySets.size(); i != l; ++i) {
|
for (auto l = _mySets.size(); i != l; ++i) {
|
||||||
|
if (_mySets[i].megagroupSet) {
|
||||||
|
icons.push_back(StickerIcon(Stickers::MegagroupEmptySetId));
|
||||||
|
icons.back().megagroup = _megagroupSet;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
auto s = _mySets[i].pack[0];
|
auto s = _mySets[i].pack[0];
|
||||||
auto availw = st::emojiCategory.width - 2 * st::stickerIconPadding, availh = st::emojiCategory.height - 2 * st::stickerIconPadding;
|
auto availw = st::emojiCategory.width - 2 * st::stickerIconPadding, availh = st::emojiCategory.height - 2 * st::stickerIconPadding;
|
||||||
auto thumbw = s->thumb->width(), thumbh = s->thumb->height(), pixw = 1, pixh = 1;
|
auto thumbw = s->thumb->width(), thumbh = s->thumb->height(), pixw = 1, pixh = 1;
|
||||||
|
@ -1288,26 +1401,32 @@ void StickersListWidget::updateSelected() {
|
||||||
if (p.y() >= info.top && p.y() < info.rowsTop) {
|
if (p.y() >= info.top && p.y() < info.rowsTop) {
|
||||||
if (hasRemoveButton(section) && myrtlrect(removeButtonRect(section)).contains(p.x(), p.y())) {
|
if (hasRemoveButton(section) && myrtlrect(removeButtonRect(section)).contains(p.x(), p.y())) {
|
||||||
newSelected = OverButton { section };
|
newSelected = OverButton { section };
|
||||||
} else {
|
} else if (!(sets[section].flags & MTPDstickerSet_ClientFlag::f_special)) {
|
||||||
newSelected = OverSet { section };
|
newSelected = OverSet { section };
|
||||||
}
|
}
|
||||||
} else if (p.y() >= info.rowsTop && p.y() < info.rowsBottom && sx >= 0) {
|
} else if (p.y() >= info.rowsTop && p.y() < info.rowsBottom && sx >= 0) {
|
||||||
auto yOffset = p.y() - info.rowsTop;
|
auto yOffset = p.y() - info.rowsTop;
|
||||||
auto &set = sets[section];
|
auto &set = sets[section];
|
||||||
auto special = ((set.flags & MTPDstickerSet::Flag::f_official) != 0);
|
if (set.id == Stickers::MegagroupEmptySetId) {
|
||||||
auto rowIndex = qFloor(yOffset / st::stickerPanSize.height());
|
if (_megagroupSetButtonRect.contains(stickersLeft() + sx, yOffset)) {
|
||||||
auto columnIndex = qFloor(sx / st::stickerPanSize.width());
|
newSelected = OverGroupAdd {};
|
||||||
auto index = rowIndex * kStickersPanelPerRow + columnIndex;
|
}
|
||||||
if (index >= 0 && index < set.pack.size()) {
|
} else {
|
||||||
auto overDelete = false;
|
auto special = ((set.flags & MTPDstickerSet::Flag::f_official) != 0);
|
||||||
if (stickerHasDeleteButton(set, index)) {
|
auto rowIndex = qFloor(yOffset / st::stickerPanSize.height());
|
||||||
auto inx = sx - (columnIndex * st::stickerPanSize.width());
|
auto columnIndex = qFloor(sx / st::stickerPanSize.width());
|
||||||
auto iny = yOffset - (rowIndex * st::stickerPanSize.height());
|
auto index = rowIndex * kStickersPanelPerRow + columnIndex;
|
||||||
if (inx >= st::stickerPanSize.width() - st::stickerPanDelete.width() && iny < st::stickerPanDelete.height()) {
|
if (index >= 0 && index < set.pack.size()) {
|
||||||
overDelete = true;
|
auto overDelete = false;
|
||||||
}
|
if (stickerHasDeleteButton(set, index)) {
|
||||||
|
auto inx = sx - (columnIndex * st::stickerPanSize.width());
|
||||||
|
auto iny = yOffset - (rowIndex * st::stickerPanSize.height());
|
||||||
|
if (inx >= st::stickerPanSize.width() - st::stickerPanDelete.width() && iny < st::stickerPanDelete.height()) {
|
||||||
|
overDelete = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
newSelected = OverSticker { section, index, overDelete };
|
||||||
}
|
}
|
||||||
newSelected = OverSticker { section, index, overDelete };
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1419,6 +1538,31 @@ void StickersListWidget::showStickerSet(uint64 setId) {
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StickersListWidget::refreshMegagroupSetGeometry() {
|
||||||
|
auto left = megagroupSetInfoLeft();
|
||||||
|
auto availableWidth = (width() - left);
|
||||||
|
auto top = _megagroupSetAbout.countHeight(availableWidth) + st::stickerGroupCategoryAddMargin.top();
|
||||||
|
_megagroupSetButtonTextWidth = st::stickerGroupCategoryAdd.font->width(_megagroupSetButtonText);
|
||||||
|
auto buttonWidth = _megagroupSetButtonTextWidth - st::stickerGroupCategoryAdd.width;
|
||||||
|
_megagroupSetButtonRect = QRect(left, top, buttonWidth, st::stickerGroupCategoryAdd.height);
|
||||||
|
}
|
||||||
|
|
||||||
|
void StickersListWidget::showMegagroupSet(ChannelData *megagroup) {
|
||||||
|
Expects(!megagroup || megagroup->isMegagroup());
|
||||||
|
if (_megagroupSet != megagroup) {
|
||||||
|
_megagroupSet = megagroup;
|
||||||
|
|
||||||
|
if (_megagroupSetAbout.isEmpty()) {
|
||||||
|
_megagroupSetAbout.setText(st::stickerGroupCategoryAbout, lang(lng_group_stickers_description));
|
||||||
|
_megagroupSetButtonText = lang(lng_group_stickers_add).toUpper();
|
||||||
|
refreshMegagroupSetGeometry();
|
||||||
|
}
|
||||||
|
_megagroupSetButtonRipple.reset();
|
||||||
|
|
||||||
|
refreshStickers();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void StickersListWidget::displaySet(quint64 setId) {
|
void StickersListWidget::displaySet(quint64 setId) {
|
||||||
auto &sets = Global::StickerSets();
|
auto &sets = Global::StickerSets();
|
||||||
auto it = sets.constFind(setId);
|
auto it = sets.constFind(setId);
|
||||||
|
|
|
@ -47,6 +47,7 @@ public:
|
||||||
object_ptr<TabbedSelector::InnerFooter> createFooter() override;
|
object_ptr<TabbedSelector::InnerFooter> createFooter() override;
|
||||||
|
|
||||||
void showStickerSet(uint64 setId);
|
void showStickerSet(uint64 setId);
|
||||||
|
void showMegagroupSet(ChannelData *megagroup);
|
||||||
|
|
||||||
void refreshStickers();
|
void refreshStickers();
|
||||||
|
|
||||||
|
@ -104,6 +105,8 @@ private:
|
||||||
struct OverButton {
|
struct OverButton {
|
||||||
int section;
|
int section;
|
||||||
};
|
};
|
||||||
|
struct OverGroupAdd {
|
||||||
|
};
|
||||||
friend inline bool operator==(OverSticker a, OverSticker b) {
|
friend inline bool operator==(OverSticker a, OverSticker b) {
|
||||||
return (a.section == b.section) && (a.index == b.index) && (a.overDelete == b.overDelete);
|
return (a.section == b.section) && (a.index == b.index) && (a.overDelete == b.overDelete);
|
||||||
}
|
}
|
||||||
|
@ -113,7 +116,10 @@ private:
|
||||||
friend inline bool operator==(OverButton a, OverButton b) {
|
friend inline bool operator==(OverButton a, OverButton b) {
|
||||||
return (a.section == b.section);
|
return (a.section == b.section);
|
||||||
}
|
}
|
||||||
using OverState = base::optional_variant<OverSticker, OverSet, OverButton>;
|
friend inline bool operator==(OverGroupAdd a, OverGroupAdd b) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
using OverState = base::optional_variant<OverSticker, OverSet, OverButton, OverGroupAdd>;
|
||||||
|
|
||||||
struct SectionInfo {
|
struct SectionInfo {
|
||||||
int section = 0;
|
int section = 0;
|
||||||
|
@ -128,6 +134,7 @@ private:
|
||||||
Set(uint64 id, MTPDstickerSet::Flags flags, const QString &title, int32 hoversSize, const StickerPack &pack = StickerPack()) : id(id), flags(flags), title(title), pack(pack) {
|
Set(uint64 id, MTPDstickerSet::Flags flags, const QString &title, int32 hoversSize, const StickerPack &pack = StickerPack()) : id(id), flags(flags), title(title), pack(pack) {
|
||||||
}
|
}
|
||||||
uint64 id;
|
uint64 id;
|
||||||
|
bool megagroupSet = false;
|
||||||
MTPDstickerSet::Flags flags;
|
MTPDstickerSet::Flags flags;
|
||||||
QString title;
|
QString title;
|
||||||
StickerPack pack;
|
StickerPack pack;
|
||||||
|
@ -148,6 +155,7 @@ private:
|
||||||
bool stickerHasDeleteButton(const Set &set, int index) const;
|
bool stickerHasDeleteButton(const Set &set, int index) const;
|
||||||
void refreshRecentStickers(bool resize = true);
|
void refreshRecentStickers(bool resize = true);
|
||||||
void refreshFavedStickers();
|
void refreshFavedStickers();
|
||||||
|
void refreshMegagroupStickers();
|
||||||
|
|
||||||
void updateSelected();
|
void updateSelected();
|
||||||
void setSelected(OverState newSelected);
|
void setSelected(OverState newSelected);
|
||||||
|
@ -173,6 +181,7 @@ private:
|
||||||
|
|
||||||
void paintFeaturedStickers(Painter &p, QRect clip);
|
void paintFeaturedStickers(Painter &p, QRect clip);
|
||||||
void paintStickers(Painter &p, QRect clip);
|
void paintStickers(Painter &p, QRect clip);
|
||||||
|
void paintMegagroupEmptySet(Painter &p, int y, bool buttonSelected, TimeMs ms);
|
||||||
void paintSticker(Painter &p, Set &set, int y, int index, bool selected, bool deleteSelected);
|
void paintSticker(Painter &p, Set &set, int y, int index, bool selected, bool deleteSelected);
|
||||||
|
|
||||||
int stickersRight() const;
|
int stickersRight() const;
|
||||||
|
@ -180,12 +189,16 @@ private:
|
||||||
QRect featuredAddRect(int index) const;
|
QRect featuredAddRect(int index) const;
|
||||||
bool hasRemoveButton(int index) const;
|
bool hasRemoveButton(int index) const;
|
||||||
QRect removeButtonRect(int index) const;
|
QRect removeButtonRect(int index) const;
|
||||||
|
int megagroupSetInfoLeft() const;
|
||||||
|
void refreshMegagroupSetGeometry();
|
||||||
|
QRect megagroupSetButtonRectFinal() const;
|
||||||
|
|
||||||
enum class AppendSkip {
|
enum class AppendSkip {
|
||||||
|
None,
|
||||||
Archived,
|
Archived,
|
||||||
Installed,
|
Installed,
|
||||||
};
|
};
|
||||||
void appendSet(Sets &to, uint64 setId, AppendSkip skip);
|
void appendSet(Sets &to, uint64 setId, AppendSkip skip = AppendSkip::None);
|
||||||
|
|
||||||
void selectEmoji(EmojiPtr emoji);
|
void selectEmoji(EmojiPtr emoji);
|
||||||
int stickersLeft() const;
|
int stickersLeft() const;
|
||||||
|
@ -194,6 +207,7 @@ private:
|
||||||
void removeRecentSticker(int section, int index);
|
void removeRecentSticker(int section, int index);
|
||||||
void removeFavedSticker(int section, int index);
|
void removeFavedSticker(int section, int index);
|
||||||
|
|
||||||
|
ChannelData *_megagroupSet = nullptr;
|
||||||
Sets _mySets;
|
Sets _mySets;
|
||||||
Sets _featuredSets;
|
Sets _featuredSets;
|
||||||
OrderedSet<uint64> _installedLocallySets;
|
OrderedSet<uint64> _installedLocallySets;
|
||||||
|
@ -210,6 +224,12 @@ private:
|
||||||
OverState _pressed = nullptr;
|
OverState _pressed = nullptr;
|
||||||
QPoint _lastMousePosition;
|
QPoint _lastMousePosition;
|
||||||
|
|
||||||
|
Text _megagroupSetAbout;
|
||||||
|
QString _megagroupSetButtonText;
|
||||||
|
int _megagroupSetButtonTextWidth = 0;
|
||||||
|
QRect _megagroupSetButtonRect;
|
||||||
|
std::unique_ptr<Ui::RippleAnimation> _megagroupSetButtonRipple;
|
||||||
|
|
||||||
QString _addText;
|
QString _addText;
|
||||||
int _addWidth;
|
int _addWidth;
|
||||||
|
|
||||||
|
|
|
@ -519,6 +519,10 @@ void TabbedSelector::stickersInstalled(uint64 setId) {
|
||||||
stickers()->showStickerSet(setId);
|
stickers()->showStickerSet(setId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TabbedSelector::showMegagroupSet(ChannelData *megagroup) {
|
||||||
|
stickers()->showMegagroupSet(megagroup);
|
||||||
|
}
|
||||||
|
|
||||||
void TabbedSelector::setCurrentPeer(PeerData *peer) {
|
void TabbedSelector::setCurrentPeer(PeerData *peer) {
|
||||||
gifs()->setInlineQueryPeer(peer);
|
gifs()->setInlineQueryPeer(peer);
|
||||||
_currentPeer = peer;
|
_currentPeer = peer;
|
||||||
|
|
|
@ -61,6 +61,7 @@ public:
|
||||||
void setRoundRadius(int radius);
|
void setRoundRadius(int radius);
|
||||||
void refreshStickers();
|
void refreshStickers();
|
||||||
void stickersInstalled(uint64 setId);
|
void stickersInstalled(uint64 setId);
|
||||||
|
void showMegagroupSet(ChannelData *megagroup);
|
||||||
void setCurrentPeer(PeerData *peer);
|
void setCurrentPeer(PeerData *peer);
|
||||||
|
|
||||||
void hideFinished();
|
void hideFinished();
|
||||||
|
|
|
@ -535,45 +535,6 @@ DefineVar(Sandbox, ProxyData, PreLaunchProxy);
|
||||||
|
|
||||||
} // namespace Sandbox
|
} // namespace Sandbox
|
||||||
|
|
||||||
namespace Stickers {
|
|
||||||
|
|
||||||
Set *FeedSet(const MTPDstickerSet &set) {
|
|
||||||
MTPDstickerSet::Flags flags = 0;
|
|
||||||
|
|
||||||
auto &sets = Global::RefStickerSets();
|
|
||||||
auto it = sets.find(set.vid.v);
|
|
||||||
auto title = stickerSetTitle(set);
|
|
||||||
if (it == sets.cend()) {
|
|
||||||
it = sets.insert(set.vid.v, Stickers::Set(set.vid.v, set.vaccess_hash.v, title, qs(set.vshort_name), set.vcount.v, set.vhash.v, set.vflags.v | MTPDstickerSet_ClientFlag::f_not_loaded));
|
|
||||||
} else {
|
|
||||||
it->access = set.vaccess_hash.v;
|
|
||||||
it->title = title;
|
|
||||||
it->shortName = qs(set.vshort_name);
|
|
||||||
flags = it->flags;
|
|
||||||
auto clientFlags = it->flags & (MTPDstickerSet_ClientFlag::f_featured | MTPDstickerSet_ClientFlag::f_unread | MTPDstickerSet_ClientFlag::f_not_loaded | MTPDstickerSet_ClientFlag::f_special);
|
|
||||||
it->flags = set.vflags.v | clientFlags;
|
|
||||||
if (it->count != set.vcount.v || it->hash != set.vhash.v || it->emoji.isEmpty()) {
|
|
||||||
it->count = set.vcount.v;
|
|
||||||
it->hash = set.vhash.v;
|
|
||||||
it->flags |= MTPDstickerSet_ClientFlag::f_not_loaded; // need to request this set
|
|
||||||
}
|
|
||||||
}
|
|
||||||
auto changedFlags = (flags ^ it->flags);
|
|
||||||
if (changedFlags & MTPDstickerSet::Flag::f_archived) {
|
|
||||||
auto index = Global::ArchivedStickerSetsOrder().indexOf(it->id);
|
|
||||||
if (it->flags & MTPDstickerSet::Flag::f_archived) {
|
|
||||||
if (index < 0) {
|
|
||||||
Global::RefArchivedStickerSetsOrder().push_front(it->id);
|
|
||||||
}
|
|
||||||
} else if (index >= 0) {
|
|
||||||
Global::RefArchivedStickerSetsOrder().removeAt(index);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return &it.value();
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace Stickers
|
|
||||||
|
|
||||||
namespace Global {
|
namespace Global {
|
||||||
namespace internal {
|
namespace internal {
|
||||||
|
|
||||||
|
|
|
@ -251,6 +251,7 @@ constexpr auto NoneSetId = 0xFFFFFFFFFFFFFFFDULL; // for emoji/stickers panel, s
|
||||||
constexpr auto CloudRecentSetId = 0xFFFFFFFFFFFFFFFCULL; // for cloud-stored recent stickers
|
constexpr auto CloudRecentSetId = 0xFFFFFFFFFFFFFFFCULL; // for cloud-stored recent stickers
|
||||||
constexpr auto FeaturedSetId = 0xFFFFFFFFFFFFFFFBULL; // for emoji/stickers panel, should not appear in Sets
|
constexpr auto FeaturedSetId = 0xFFFFFFFFFFFFFFFBULL; // for emoji/stickers panel, should not appear in Sets
|
||||||
constexpr auto FavedSetId = 0xFFFFFFFFFFFFFFFAULL; // for cloud-stored faved stickers
|
constexpr auto FavedSetId = 0xFFFFFFFFFFFFFFFAULL; // for cloud-stored faved stickers
|
||||||
|
constexpr auto MegagroupEmptySetId = 0xFFFFFFFFFFFFFFEFULL; // for setting up megagroup sticker set
|
||||||
struct Set {
|
struct Set {
|
||||||
Set(uint64 id, uint64 access, const QString &title, const QString &shortName, int32 count, int32 hash, MTPDstickerSet::Flags flags)
|
Set(uint64 id, uint64 access, const QString &title, const QString &shortName, int32 count, int32 hash, MTPDstickerSet::Flags flags)
|
||||||
: id(id)
|
: id(id)
|
||||||
|
@ -278,8 +279,6 @@ inline MTPInputStickerSet inputSetId(const Set &set) {
|
||||||
return MTP_inputStickerSetShortName(MTP_string(set.shortName));
|
return MTP_inputStickerSetShortName(MTP_string(set.shortName));
|
||||||
}
|
}
|
||||||
|
|
||||||
Set *FeedSet(const MTPDstickerSet &set);
|
|
||||||
|
|
||||||
} // namespace Stickers
|
} // namespace Stickers
|
||||||
|
|
||||||
namespace Global {
|
namespace Global {
|
||||||
|
|
|
@ -1772,6 +1772,8 @@ void HistoryWidget::showHistory(const PeerId &peerId, MsgId showAtMsgId, bool re
|
||||||
applyDraft(false);
|
applyDraft(false);
|
||||||
_send->finishAnimation();
|
_send->finishAnimation();
|
||||||
|
|
||||||
|
_tabbedSelector->showMegagroupSet(_peer->asMegagroup());
|
||||||
|
|
||||||
updateControlsGeometry();
|
updateControlsGeometry();
|
||||||
if (!_previewCancelled) {
|
if (!_previewCancelled) {
|
||||||
onPreviewParse();
|
onPreviewParse();
|
||||||
|
@ -1786,6 +1788,7 @@ void HistoryWidget::showHistory(const PeerId &peerId, MsgId showAtMsgId, bool re
|
||||||
unreadCountChanged(_history); // set _historyDown badge.
|
unreadCountChanged(_history); // set _historyDown badge.
|
||||||
} else {
|
} else {
|
||||||
clearFieldText();
|
clearFieldText();
|
||||||
|
_tabbedSelector->showMegagroupSet(nullptr);
|
||||||
doneShow();
|
doneShow();
|
||||||
}
|
}
|
||||||
updateForwarding();
|
updateForwarding();
|
||||||
|
|
|
@ -33,7 +33,7 @@ struct PeerUpdate {
|
||||||
}
|
}
|
||||||
PeerData *peer;
|
PeerData *peer;
|
||||||
|
|
||||||
enum class Flag {
|
enum class Flag : uint32 {
|
||||||
None = 0x00000000U,
|
None = 0x00000000U,
|
||||||
|
|
||||||
// Common flags
|
// Common flags
|
||||||
|
@ -50,7 +50,7 @@ struct PeerUpdate {
|
||||||
InviteLinkChanged = 0x00000100U,
|
InviteLinkChanged = 0x00000100U,
|
||||||
MembersChanged = 0x00000200U,
|
MembersChanged = 0x00000200U,
|
||||||
AdminsChanged = 0x00000400U,
|
AdminsChanged = 0x00000400U,
|
||||||
BannedUsersChanged = 0x00000800U,
|
BannedUsersChanged = 0x00000800U,
|
||||||
|
|
||||||
// For users
|
// For users
|
||||||
UserCanShareContact = 0x00010000U,
|
UserCanShareContact = 0x00010000U,
|
||||||
|
@ -69,6 +69,7 @@ struct PeerUpdate {
|
||||||
// For channels
|
// For channels
|
||||||
ChannelAmIn = 0x00010000U,
|
ChannelAmIn = 0x00010000U,
|
||||||
ChannelRightsChanged = 0x00020000U,
|
ChannelRightsChanged = 0x00020000U,
|
||||||
|
ChannelStickersChanged = 0x00040000U,
|
||||||
};
|
};
|
||||||
Q_DECLARE_FLAGS(Flags, Flag);
|
Q_DECLARE_FLAGS(Flags, Flag);
|
||||||
Flags flags = 0;
|
Flags flags = 0;
|
||||||
|
|
|
@ -750,6 +750,7 @@ struct MegagroupInfo {
|
||||||
int botStatus = 0; // -1 - no bots, 0 - unknown, 1 - one bot, that sees all history, 2 - other
|
int botStatus = 0; // -1 - no bots, 0 - unknown, 1 - one bot, that sees all history, 2 - other
|
||||||
MsgId pinnedMsgId = 0;
|
MsgId pinnedMsgId = 0;
|
||||||
bool joinedMessageFound = false;
|
bool joinedMessageFound = false;
|
||||||
|
MTPInputStickerSet stickerSet = MTP_inputStickerSetEmpty();
|
||||||
|
|
||||||
enum LastParticipantsStatus {
|
enum LastParticipantsStatus {
|
||||||
LastParticipantsUpToDate = 0x00,
|
LastParticipantsUpToDate = 0x00,
|
||||||
|
@ -760,6 +761,7 @@ struct MegagroupInfo {
|
||||||
int lastParticipantsCount = 0;
|
int lastParticipantsCount = 0;
|
||||||
|
|
||||||
ChatData *migrateFromPtr = nullptr;
|
ChatData *migrateFromPtr = nullptr;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class ChannelData : public PeerData {
|
class ChannelData : public PeerData {
|
||||||
|
@ -922,6 +924,9 @@ public:
|
||||||
bool canEditUsername() const {
|
bool canEditUsername() const {
|
||||||
return amCreator() && (flagsFull & MTPDchannelFull::Flag::f_can_set_username);
|
return amCreator() && (flagsFull & MTPDchannelFull::Flag::f_can_set_username);
|
||||||
}
|
}
|
||||||
|
bool canEditStickers() const {
|
||||||
|
return (flagsFull & MTPDchannelFull::Flag::f_can_set_stickers);
|
||||||
|
}
|
||||||
bool canDelete() const {
|
bool canDelete() const {
|
||||||
constexpr auto kDeleteChannelMembersLimit = 1000;
|
constexpr auto kDeleteChannelMembersLimit = 1000;
|
||||||
return amCreator() && (membersCount() <= kDeleteChannelMembersLimit);
|
return amCreator() && (membersCount() <= kDeleteChannelMembersLimit);
|
||||||
|
|
Loading…
Reference in New Issue