Remove some calls to Auth().

This commit is contained in:
John Preston 2019-07-24 13:13:51 +02:00
parent 9cf4cf6dca
commit 06982fdf04
39 changed files with 573 additions and 444 deletions

View File

@ -3270,7 +3270,7 @@ void ApiWrap::toggleSavedGif(
)).done([=](const MTPBool &result) { )).done([=](const MTPBool &result) {
if (mtpIsTrue(result)) { if (mtpIsTrue(result)) {
if (saved) { if (saved) {
App::addSavedGif(document); session().data().addSavedGif(document);
} }
} }
}).fail([=](const RPCError &error) { }).fail([=](const RPCError &error) {

View File

@ -115,33 +115,6 @@ namespace App {
return nullptr; return nullptr;
} }
void addSavedGif(DocumentData *doc) {
auto &saved = Auth().data().savedGifsRef();
int32 index = saved.indexOf(doc);
if (index) {
if (index > 0) saved.remove(index);
saved.push_front(doc);
if (saved.size() > Global::SavedGifsLimit()) saved.pop_back();
Local::writeSavedGifs();
Auth().data().notifySavedGifsUpdated();
Auth().data().setLastSavedGifsUpdate(0);
Auth().api().updateStickers();
}
}
void checkSavedGif(HistoryItem *item) {
if (!item->Has<HistoryMessageForwarded>() && (item->out() || item->history()->peer == Auth().user())) {
if (const auto media = item->media()) {
if (const auto document = media->document()) {
if (document->isGifv()) {
addSavedGif(document);
}
}
}
}
}
QString peerName(const PeerData *peer, bool forDialogs) { QString peerName(const PeerData *peer, bool forDialogs) {
return peer ? ((forDialogs && peer->isUser() && !peer->asUser()->nameOrPhone.isEmpty()) ? peer->asUser()->nameOrPhone : peer->name) : tr::lng_deleted(tr::now); return peer ? ((forDialogs && peer->isUser() && !peer->asUser()->nameOrPhone.isEmpty()) ? peer->asUser()->nameOrPhone : peer->name) : tr::lng_deleted(tr::now);
} }

View File

@ -65,8 +65,6 @@ namespace App {
QString formatPhone(QString phone); QString formatPhone(QString phone);
void addSavedGif(DocumentData *doc);
void checkSavedGif(HistoryItem *item);
[[nodiscard]] QString peerName(const PeerData *peer, bool forDialogs = false); [[nodiscard]] QString peerName(const PeerData *peer, bool forDialogs = false);
void hoveredItem(HistoryView::Element *item); void hoveredItem(HistoryView::Element *item);

View File

@ -154,7 +154,10 @@ void ShowAddParticipantsError(
class RevokePublicLinkBox::Inner : public TWidget, private MTP::Sender { class RevokePublicLinkBox::Inner : public TWidget, private MTP::Sender {
public: public:
Inner(QWidget *parent, Fn<void()> revokeCallback); Inner(
QWidget *parent,
not_null<AuthSession*> session,
Fn<void()> revokeCallback);
protected: protected:
void mouseMoveEvent(QMouseEvent *e) override; void mouseMoveEvent(QMouseEvent *e) override;
@ -173,6 +176,8 @@ private:
void paintChat(Painter &p, const ChatRow &row, bool selected) const; void paintChat(Painter &p, const ChatRow &row, bool selected) const;
void updateSelected(); void updateSelected();
const not_null<AuthSession*> _session;
PeerData *_selected = nullptr; PeerData *_selected = nullptr;
PeerData *_pressed = nullptr; PeerData *_pressed = nullptr;
@ -188,8 +193,20 @@ private:
}; };
AddContactBox::AddContactBox(QWidget*, QString fname, QString lname, QString phone) AddContactBox::AddContactBox(
: _first(this, st::defaultInputField, tr::lng_signup_firstname(), fname) QWidget*,
not_null<AuthSession*> session)
: AddContactBox(nullptr, session, QString(), QString(), QString()) {
}
AddContactBox::AddContactBox(
QWidget*,
not_null<AuthSession*> session,
QString fname,
QString lname,
QString phone)
: _session(session)
, _first(this, st::defaultInputField, tr::lng_signup_firstname(), fname)
, _last(this, st::defaultInputField, tr::lng_signup_lastname(), lname) , _last(this, st::defaultInputField, tr::lng_signup_lastname(), lname)
, _phone(this, st::defaultInputField, tr::lng_contact_phone(), phone) , _phone(this, st::defaultInputField, tr::lng_contact_phone(), phone)
, _invertOrder(langFirstNameGoesSecond()) { , _invertOrder(langFirstNameGoesSecond()) {
@ -198,28 +215,15 @@ AddContactBox::AddContactBox(QWidget*, QString fname, QString lname, QString pho
} }
} }
AddContactBox::AddContactBox(QWidget*, UserData *user)
: _user(user)
, _first(this, st::defaultInputField, tr::lng_signup_firstname(), user->firstName)
, _last(this, st::defaultInputField, tr::lng_signup_lastname(), user->lastName)
, _phone(this, st::defaultInputField, tr::lng_contact_phone(), user->phone())
, _invertOrder(langFirstNameGoesSecond()) {
_phone->setDisabled(true);
}
void AddContactBox::prepare() { void AddContactBox::prepare() {
if (_invertOrder) { if (_invertOrder) {
setTabOrder(_last, _first); setTabOrder(_last, _first);
} }
if (_user) { const auto readyToAdd = !_phone->getLastText().isEmpty()
setTitle(tr::lng_edit_contact_title()); && (!_first->getLastText().isEmpty() || !_last->getLastText().isEmpty());
} else { setTitle(readyToAdd
const auto readyToAdd = !_phone->getLastText().isEmpty() ? tr::lng_confirm_contact_data()
&& (!_first->getLastText().isEmpty() || !_last->getLastText().isEmpty()); : tr::lng_enter_contact_data());
setTitle(readyToAdd
? tr::lng_confirm_contact_data()
: tr::lng_enter_contact_data());
}
updateButtons(); updateButtons();
connect(_first, &Ui::InputField::submitted, [=] { submit(); }); connect(_first, &Ui::InputField::submitted, [=] { submit(); });
@ -307,7 +311,7 @@ void AddContactBox::save() {
_first->showError(); _first->showError();
} }
return; return;
} else if (!_user && !IsValidPhone(phone)) { } else if (!IsValidPhone(phone)) {
_phone->setFocus(); _phone->setFocus();
_phone->showError(); _phone->showError();
return; return;
@ -317,49 +321,31 @@ void AddContactBox::save() {
lastName = QString(); lastName = QString();
} }
_sentName = firstName; _sentName = firstName;
if (_user) { _contactId = rand_value<uint64>();
_contactId = rand_value<uint64>(); _addRequest = _session->api().request(MTPcontacts_ImportContacts(
QVector<MTPInputContact> v(1, MTP_inputPhoneContact(MTP_long(_contactId), MTP_string(_user->phone()), MTP_string(firstName), MTP_string(lastName))); MTP_vector<MTPInputContact>(
_addRequest = MTP::send(MTPcontacts_ImportContacts(MTP_vector<MTPInputContact>(v)), rpcDone(&AddContactBox::onSaveUserDone), rpcFail(&AddContactBox::onSaveUserFail)); 1,
} else { MTP_inputPhoneContact(
_contactId = rand_value<uint64>(); MTP_long(_contactId),
QVector<MTPInputContact> v(1, MTP_inputPhoneContact(MTP_long(_contactId), MTP_string(phone), MTP_string(firstName), MTP_string(lastName))); MTP_string(phone),
_addRequest = MTP::send(MTPcontacts_ImportContacts(MTP_vector<MTPInputContact>(v)), rpcDone(&AddContactBox::onImportDone)); MTP_string(firstName),
} MTP_string(lastName)))
)).done(crl::guard(this, [=](const MTPcontacts_ImportedContacts &res) {
})).send();
} }
bool AddContactBox::onSaveUserFail(const RPCError &error) { void AddContactBox::importDone(const MTPcontacts_ImportedContacts &result) {
if (MTP::isDefaultHandledError(error)) return false;
_addRequest = 0;
const auto &err = error.type();
const auto firstName = _first->getLastText().trimmed();
const auto lastName = _last->getLastText().trimmed();
if (err == "CHAT_TITLE_NOT_MODIFIED") {
_user->setName(firstName, lastName, _user->nameOrPhone, _user->username);
closeBox();
return true;
} else if (err == "NO_CHAT_TITLE") {
_first->setFocus();
_first->showError();
return true;
}
_first->setFocus();
return true;
}
void AddContactBox::onImportDone(const MTPcontacts_ImportedContacts &res) {
if (!isBoxShown() || !App::main()) return; if (!isBoxShown() || !App::main()) return;
const auto &d = res.c_contacts_importedContacts(); const auto &d = result.c_contacts_importedContacts();
Auth().data().processUsers(d.vusers()); _session->data().processUsers(d.vusers());
const auto &v = d.vimported().v; const auto &v = d.vimported().v;
const auto user = [&]() -> UserData* { const auto user = [&]() -> UserData* {
if (!v.isEmpty()) { if (!v.isEmpty()) {
auto &c = v.front().c_importedContact(); auto &c = v.front().c_importedContact();
if (c.vclient_id().v == _contactId) { if (c.vclient_id().v == _contactId) {
return Auth().data().userLoaded(c.vuser_id().v); return _session->data().userLoaded(c.vuser_id().v);
} }
} }
return nullptr; return nullptr;
@ -377,12 +363,6 @@ void AddContactBox::onImportDone(const MTPcontacts_ImportedContacts &res) {
} }
} }
void AddContactBox::onSaveUserDone(const MTPcontacts_ImportedContacts &res) {
auto &d = res.c_contacts_importedContacts();
Auth().data().processUsers(d.vusers());
closeBox();
}
void AddContactBox::retry() { void AddContactBox::retry() {
_addRequest = 0; _addRequest = 0;
_contactId = 0; _contactId = 0;
@ -402,19 +382,19 @@ void AddContactBox::updateButtons() {
if (_retrying) { if (_retrying) {
addButton(tr::lng_try_other_contact(), [=] { retry(); }); addButton(tr::lng_try_other_contact(), [=] { retry(); });
} else { } else {
addButton( addButton(tr::lng_add_contact(), [=] { save(); });
_user ? tr::lng_settings_save() : tr::lng_add_contact(),
[=] { save(); });
addButton(tr::lng_cancel(), [=] { closeBox(); }); addButton(tr::lng_cancel(), [=] { closeBox(); });
} }
} }
GroupInfoBox::GroupInfoBox( GroupInfoBox::GroupInfoBox(
QWidget*, QWidget*,
not_null<AuthSession*> session,
Type type, Type type,
const QString &title, const QString &title,
Fn<void(not_null<ChannelData*>)> channelDone) Fn<void(not_null<ChannelData*>)> channelDone)
: _type(type) : _session(session)
, _type(type)
, _initialTitle(title) , _initialTitle(title)
, _channelDone(std::move(channelDone)) { , _channelDone(std::move(channelDone)) {
} }
@ -537,7 +517,7 @@ void GroupInfoBox::createGroup(
auto image = _photo->takeResultImage(); auto image = _photo->takeResultImage();
Ui::hideLayer(); Ui::hideLayer();
Auth().api().applyUpdates(result); _session->api().applyUpdates(result);
auto success = base::make_optional(&result) auto success = base::make_optional(&result)
| [](auto updates) -> std::optional<const QVector<MTPChat>*> { | [](auto updates) -> std::optional<const QVector<MTPChat>*> {
@ -557,8 +537,8 @@ void GroupInfoBox::createGroup(
? base::make_optional(chats) ? base::make_optional(chats)
: std::nullopt; : std::nullopt;
} }
| [](auto chats) { | [&](auto chats) {
return Auth().data().chat(chats->front().c_chat().vid().v); return _session->data().chat(chats->front().c_chat().vid().v);
} }
| [&](not_null<ChatData*> chat) { | [&](not_null<ChatData*> chat) {
if (!image.isNull()) { if (!image.isNull()) {
@ -646,7 +626,7 @@ void GroupInfoBox::createChannel(const QString &title, const QString &descriptio
MTPInputGeoPoint(), // geo_point MTPInputGeoPoint(), // geo_point
MTPstring() // address MTPstring() // address
)).done([=](const MTPUpdates &result) { )).done([=](const MTPUpdates &result) {
Auth().api().applyUpdates(result); _session->api().applyUpdates(result);
const auto success = base::make_optional(&result) const auto success = base::make_optional(&result)
| [](auto updates) -> std::optional<const QVector<MTPChat>*> { | [](auto updates) -> std::optional<const QVector<MTPChat>*> {
@ -664,8 +644,8 @@ void GroupInfoBox::createChannel(const QString &title, const QString &descriptio
? base::make_optional(chats) ? base::make_optional(chats)
: std::nullopt; : std::nullopt;
} }
| [](auto chats) { | [&](auto chats) {
return Auth().data().channel(chats->front().c_channel().vid().v); return _session->data().channel(chats->front().c_channel().vid().v);
} }
| [&](not_null<ChannelData*> channel) { | [&](not_null<ChannelData*> channel) {
auto image = _photo->takeResultImage(); auto image = _photo->takeResultImage();
@ -729,10 +709,14 @@ void GroupInfoBox::updateMaxHeight() {
setDimensions(st::boxWideWidth, newHeight); setDimensions(st::boxWideWidth, newHeight);
} }
SetupChannelBox::SetupChannelBox(QWidget*, ChannelData *channel, bool existing) SetupChannelBox::SetupChannelBox(
QWidget*,
not_null<ChannelData*> channel,
bool existing)
: _channel(channel) : _channel(channel)
, _existing(existing) , _existing(existing)
, _privacyGroup(std::make_shared<Ui::RadioenumGroup<Privacy>>(Privacy::Public)) , _privacyGroup(
std::make_shared<Ui::RadioenumGroup<Privacy>>(Privacy::Public))
, _public( , _public(
this, this,
_privacyGroup, _privacyGroup,
@ -749,7 +733,12 @@ SetupChannelBox::SetupChannelBox(QWidget*, ChannelData *channel, bool existing)
? tr::lng_create_private_group_title ? tr::lng_create_private_group_title
: tr::lng_create_private_channel_title)(tr::now), : tr::lng_create_private_channel_title)(tr::now),
st::defaultBoxCheckbox) st::defaultBoxCheckbox)
, _aboutPublicWidth(st::boxWideWidth - st::boxPadding.left() - st::boxButtonPadding.right() - st::newGroupPadding.left() - st::defaultRadio.diameter - st::defaultBoxCheckbox.textPosition.x()) , _aboutPublicWidth(st::boxWideWidth
- st::boxPadding.left()
- st::boxButtonPadding.right()
- st::newGroupPadding.left()
- st::defaultRadio.diameter
- st::defaultBoxCheckbox.textPosition.x())
, _aboutPublic( , _aboutPublic(
st::defaultTextStyle, st::defaultTextStyle,
(channel->isMegagroup() (channel->isMegagroup()
@ -1003,11 +992,16 @@ void SetupChannelBox::privacyChanged(Privacy value) {
if (value == Privacy::Public) { if (value == Privacy::Public) {
if (_tooMuchUsernames) { if (_tooMuchUsernames) {
_privacyGroup->setValue(Privacy::Private); _privacyGroup->setValue(Privacy::Private);
Ui::show(Box<RevokePublicLinkBox>(crl::guard(this, [this] { const auto callback = crl::guard(this, [=] {
_tooMuchUsernames = false; _tooMuchUsernames = false;
_privacyGroup->setValue(Privacy::Public); _privacyGroup->setValue(Privacy::Public);
check(); check();
})), LayerOption::KeepOther); });
Ui::show(
Box<RevokePublicLinkBox>(
&_channel->session(),
callback),
LayerOption::KeepOther);
return; return;
} }
_link->show(); _link->show();
@ -1096,23 +1090,30 @@ bool SetupChannelBox::onCheckFail(const RPCError &error) {
} }
void SetupChannelBox::showRevokePublicLinkBoxForEdit() { void SetupChannelBox::showRevokePublicLinkBoxForEdit() {
closeBox(); const auto channel = _channel;
Ui::show(Box<RevokePublicLinkBox>([channel = _channel, existing = _existing]() { const auto existing = _existing;
const auto callback = [=] {
Ui::show( Ui::show(
Box<SetupChannelBox>(channel, existing), Box<SetupChannelBox>(channel, existing),
LayerOption::KeepOther); LayerOption::KeepOther);
}), LayerOption::KeepOther); };
closeBox();
Ui::show(
Box<RevokePublicLinkBox>(
&channel->session(),
callback),
LayerOption::KeepOther);
} }
bool SetupChannelBox::onFirstCheckFail(const RPCError &error) { bool SetupChannelBox::onFirstCheckFail(const RPCError &error) {
if (MTP::isDefaultHandledError(error)) return false; if (MTP::isDefaultHandledError(error)) return false;
_checkRequestId = 0; _checkRequestId = 0;
QString err(error.type()); const auto &type = error.type();
if (err == qstr("CHANNEL_PUBLIC_GROUP_NA")) { if (type == qstr("CHANNEL_PUBLIC_GROUP_NA")) {
Ui::hideLayer(); Ui::hideLayer();
return true; return true;
} else if (err == qstr("CHANNELS_ADMIN_PUBLIC_TOO_MUCH")) { } else if (type == qstr("CHANNELS_ADMIN_PUBLIC_TOO_MUCH")) {
if (_existing) { if (_existing) {
showRevokePublicLinkBoxForEdit(); showRevokePublicLinkBoxForEdit();
} else { } else {
@ -1248,7 +1249,12 @@ bool EditNameBox::saveSelfFail(const RPCError &error) {
return true; return true;
} }
RevokePublicLinkBox::Inner::Inner(QWidget *parent, Fn<void()> revokeCallback) : TWidget(parent) RevokePublicLinkBox::Inner::Inner(
QWidget *parent,
not_null<AuthSession*> session,
Fn<void()> revokeCallback)
: TWidget(parent)
, _session(session)
, _rowHeight(st::contactsPadding.top() + st::contactsPhotoSize + st::contactsPadding.bottom()) , _rowHeight(st::contactsPadding.top() + st::contactsPhotoSize + st::contactsPadding.bottom())
, _revokeWidth(st::normalFont->width(tr::lng_channels_too_much_public_revoke(tr::now))) , _revokeWidth(st::normalFont->width(tr::lng_channels_too_much_public_revoke(tr::now)))
, _revokeCallback(std::move(revokeCallback)) { , _revokeCallback(std::move(revokeCallback)) {
@ -1263,7 +1269,7 @@ RevokePublicLinkBox::Inner::Inner(QWidget *parent, Fn<void()> revokeCallback) :
return data.vchats().v; return data.vchats().v;
}); });
for (const auto &chat : chats) { for (const auto &chat : chats) {
if (const auto peer = Auth().data().processChat(chat)) { if (const auto peer = _session->data().processChat(chat)) {
if (!peer->isChannel() || peer->userName().isEmpty()) { if (!peer->isChannel() || peer->userName().isEmpty()) {
continue; continue;
} }
@ -1289,8 +1295,10 @@ RevokePublicLinkBox::Inner::Inner(QWidget *parent, Fn<void()> revokeCallback) :
RevokePublicLinkBox::RevokePublicLinkBox( RevokePublicLinkBox::RevokePublicLinkBox(
QWidget*, QWidget*,
not_null<AuthSession*> session,
Fn<void()> revokeCallback) Fn<void()> revokeCallback)
: _aboutRevoke( : _session(session)
, _aboutRevoke(
this, this,
tr::lng_channels_too_much_public_about(tr::now), tr::lng_channels_too_much_public_about(tr::now),
st::aboutRevokePublicLabel) st::aboutRevokePublicLabel)
@ -1299,7 +1307,7 @@ RevokePublicLinkBox::RevokePublicLinkBox(
void RevokePublicLinkBox::prepare() { void RevokePublicLinkBox::prepare() {
_innerTop = st::boxPadding.top() + _aboutRevoke->height() + st::boxPadding.top(); _innerTop = st::boxPadding.top() + _aboutRevoke->height() + st::boxPadding.top();
_inner = setInnerWidget(object_ptr<Inner>(this, [=] { _inner = setInnerWidget(object_ptr<Inner>(this, _session, [=] {
const auto callback = _revokeCallback; const auto callback = _revokeCallback;
closeBox(); closeBox();
if (callback) { if (callback) {
@ -1309,7 +1317,7 @@ void RevokePublicLinkBox::prepare() {
addButton(tr::lng_cancel(), [=] { closeBox(); }); addButton(tr::lng_cancel(), [=] { closeBox(); });
subscribe(Auth().downloaderTaskFinished(), [=] { update(); }); subscribe(_session->downloaderTaskFinished(), [=] { update(); });
_inner->resizeToWidth(st::boxWideWidth); _inner->resizeToWidth(st::boxWideWidth);
setDimensions(st::boxWideWidth, _innerTop + _inner->height()); setDimensions(st::boxWideWidth, _innerTop + _inner->height());
@ -1323,7 +1331,7 @@ void RevokePublicLinkBox::Inner::updateSelected() {
auto point = mapFromGlobal(QCursor::pos()); auto point = mapFromGlobal(QCursor::pos());
PeerData *selected = nullptr; PeerData *selected = nullptr;
auto top = _rowsTop; auto top = _rowsTop;
for_const (auto &row, _rows) { for (const auto &row : _rows) {
auto revokeLink = rtlrect(width() - st::contactsPadding.right() - st::contactsCheckPosition.x() - _revokeWidth, top + st::contactsPadding.top() + (st::contactsPhotoSize - st::normalFont->height) / 2, _revokeWidth, st::normalFont->height, width()); auto revokeLink = rtlrect(width() - st::contactsPadding.right() - st::contactsCheckPosition.x() - _revokeWidth, top + st::contactsPadding.top() + (st::contactsPhotoSize - st::normalFont->height) / 2, _revokeWidth, st::normalFont->height, width());
if (revokeLink.contains(point)) { if (revokeLink.contains(point)) {
selected = row.peer; selected = row.peer;

View File

@ -13,6 +13,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
class ConfirmBox; class ConfirmBox;
class PeerListBox; class PeerListBox;
class AuthSession;
constexpr auto kMaxBioLength = 70; constexpr auto kMaxBioLength = 70;
@ -43,10 +44,15 @@ void ShowAddParticipantsError(
not_null<PeerData*> chat, not_null<PeerData*> chat,
const std::vector<not_null<UserData*>> &users); const std::vector<not_null<UserData*>> &users);
class AddContactBox : public BoxContent, public RPCSender { class AddContactBox : public BoxContent {
public: public:
AddContactBox(QWidget*, QString fname = QString(), QString lname = QString(), QString phone = QString()); AddContactBox(QWidget*, not_null<AuthSession*> session);
AddContactBox(QWidget*, UserData *user); AddContactBox(
QWidget*,
not_null<AuthSession*> session,
QString fname,
QString lname,
QString phone);
protected: protected:
void prepare() override; void prepare() override;
@ -61,12 +67,9 @@ private:
void retry(); void retry();
void save(); void save();
void updateButtons(); void updateButtons();
void onImportDone(const MTPcontacts_ImportedContacts &res); void importDone(const MTPcontacts_ImportedContacts &result);
void onSaveUserDone(const MTPcontacts_ImportedContacts &res); const not_null<AuthSession*> _session;
bool onSaveUserFail(const RPCError &e);
UserData *_user = nullptr;
object_ptr<Ui::InputField> _first; object_ptr<Ui::InputField> _first;
object_ptr<Ui::InputField> _last; object_ptr<Ui::InputField> _last;
@ -91,6 +94,7 @@ public:
}; };
GroupInfoBox( GroupInfoBox(
QWidget*, QWidget*,
not_null<AuthSession*> session,
Type type, Type type,
const QString &title = QString(), const QString &title = QString(),
Fn<void(not_null<ChannelData*>)> channelDone = nullptr); Fn<void(not_null<ChannelData*>)> channelDone = nullptr);
@ -110,6 +114,8 @@ private:
void descriptionResized(); void descriptionResized();
void updateMaxHeight(); void updateMaxHeight();
const not_null<AuthSession*> _session;
Type _type = Type::Group; Type _type = Type::Group;
QString _initialTitle; QString _initialTitle;
Fn<void(not_null<ChannelData*>)> _channelDone; Fn<void(not_null<ChannelData*>)> _channelDone;
@ -126,7 +132,10 @@ private:
class SetupChannelBox : public BoxContent, public RPCSender { class SetupChannelBox : public BoxContent, public RPCSender {
public: public:
SetupChannelBox(QWidget*, ChannelData *channel, bool existing = false); SetupChannelBox(
QWidget*,
not_null<ChannelData*> channel,
bool existing = false);
void setInnerFocus() override; void setInnerFocus() override;
@ -162,7 +171,8 @@ private:
void showRevokePublicLinkBoxForEdit(); void showRevokePublicLinkBoxForEdit();
ChannelData *_channel = nullptr; const not_null<ChannelData*> _channel;
bool _existing = false; bool _existing = false;
std::shared_ptr<Ui::RadioenumGroup<Privacy>> _privacyGroup; std::shared_ptr<Ui::RadioenumGroup<Privacy>> _privacyGroup;
@ -215,7 +225,10 @@ private:
class RevokePublicLinkBox : public BoxContent, public RPCSender { class RevokePublicLinkBox : public BoxContent, public RPCSender {
public: public:
RevokePublicLinkBox(QWidget*, Fn<void()> revokeCallback); RevokePublicLinkBox(
QWidget*,
not_null<AuthSession*> session,
Fn<void()> revokeCallback);
protected: protected:
void prepare() override; void prepare() override;
@ -223,6 +236,8 @@ protected:
void resizeEvent(QResizeEvent *e) override; void resizeEvent(QResizeEvent *e) override;
private: private:
const not_null<AuthSession*> _session;
object_ptr<Ui::FlatLabel> _aboutRevoke; object_ptr<Ui::FlatLabel> _aboutRevoke;
class Inner; class Inner;

View File

@ -245,6 +245,7 @@ object_ptr<Ui::RpWidget> SetupCreateGroup(
const auto guarded = crl::guard(parent, callback); const auto guarded = crl::guard(parent, callback);
Ui::show( Ui::show(
Box<GroupInfoBox>( Box<GroupInfoBox>(
&channel->session(),
GroupInfoBox::Type::Megagroup, GroupInfoBox::Type::Megagroup,
channel->name + " Chat", channel->name + " Chat",
guarded), guarded),

View File

@ -464,7 +464,9 @@ void Controller::askUsernameRevoke() {
checkUsernameAvailability(); checkUsernameAvailability();
}); });
Ui::show( Ui::show(
Box<RevokePublicLinkBox>(std::move(revokeCallback)), Box<RevokePublicLinkBox>(
&_peer->session(),
std::move(revokeCallback)),
LayerOption::KeepOther); LayerOption::KeepOther);
} }

View File

@ -217,7 +217,7 @@ StickersListWidget::Footer::Footer(not_null<StickersListWidget*> parent)
_iconsLeft = _iconsRight = st::emojiCategorySkip + st::stickerIconWidth; _iconsLeft = _iconsRight = st::emojiCategorySkip + st::stickerIconWidth;
subscribe(Auth().downloaderTaskFinished(), [this] { subscribe(_pan->session().downloaderTaskFinished(), [=] {
update(); update();
}); });
} }
@ -689,7 +689,7 @@ void StickersListWidget::Footer::paintSearchIcon(Painter &p) const {
} }
void StickersListWidget::Footer::paintFeaturedStickerSetsBadge(Painter &p, int iconLeft) const { void StickersListWidget::Footer::paintFeaturedStickerSetsBadge(Painter &p, int iconLeft) const {
if (auto unread = Auth().data().featuredStickerSetsUnreadCount()) { if (const auto unread = _pan->session().data().featuredStickerSetsUnreadCount()) {
Dialogs::Layout::UnreadBadgeStyle unreadSt; Dialogs::Layout::UnreadBadgeStyle unreadSt;
unreadSt.sizeId = Dialogs::Layout::UnreadBadgeInStickersPanel; unreadSt.sizeId = Dialogs::Layout::UnreadBadgeInStickersPanel;
unreadSt.size = st::stickersSettingsUnreadSize; unreadSt.size = st::stickersSettingsUnreadSize;
@ -837,7 +837,7 @@ StickersListWidget::StickersListWidget(
Ui::show(Box<StickersBox>(StickersBox::Section::Installed)); Ui::show(Box<StickersBox>(StickersBox::Section::Installed));
}); });
subscribe(Auth().downloaderTaskFinished(), [=] { subscribe(session().downloaderTaskFinished(), [=] {
if (isVisible()) { if (isVisible()) {
update(); update();
readVisibleFeatured(getVisibleTop(), getVisibleBottom()); readVisibleFeatured(getVisibleTop(), getVisibleBottom());
@ -850,6 +850,10 @@ StickersListWidget::StickersListWidget(
})); }));
} }
AuthSession &StickersListWidget::session() const {
return controller()->session();
}
rpl::producer<not_null<DocumentData*>> StickersListWidget::chosen() const { rpl::producer<not_null<DocumentData*>> StickersListWidget::chosen() const {
return _chosen.events(); return _chosen.events();
} }
@ -923,7 +927,7 @@ void StickersListWidget::readVisibleFeatured(
} }
} }
if (loaded == count) { if (loaded == count) {
Auth().api().readFeaturedSetDelayed(set.id); session().api().readFeaturedSetDelayed(set.id);
} }
} }
} }
@ -1178,7 +1182,7 @@ void StickersListWidget::fillLocalSearchRows(const QString &query) {
return true; return true;
}; };
const auto &sets = Auth().data().stickerSets(); const auto &sets = session().data().stickerSets();
for (const auto &[setId, titleWords] : _searchIndex) { for (const auto &[setId, titleWords] : _searchIndex) {
if (allSearchWordsInTitle(titleWords)) { if (allSearchWordsInTitle(titleWords)) {
if (const auto it = sets.find(setId); it != sets.end()) { if (const auto it = sets.find(setId); it != sets.end()) {
@ -1190,7 +1194,7 @@ void StickersListWidget::fillLocalSearchRows(const QString &query) {
void StickersListWidget::fillCloudSearchRows( void StickersListWidget::fillCloudSearchRows(
const std::vector<uint64> &cloudSets) { const std::vector<uint64> &cloudSets) {
const auto &sets = Auth().data().stickerSets(); const auto &sets = session().data().stickerSets();
for (const auto setId : cloudSets) { for (const auto setId : cloudSets) {
if (const auto it = sets.find(setId); it != sets.end()) { if (const auto it = sets.find(setId); it != sets.end()) {
addSearchRow(&*it); addSearchRow(&*it);
@ -1266,7 +1270,7 @@ void StickersListWidget::searchResultsDone(
setData = &d.vset().c_stickerSet(); setData = &d.vset().c_stickerSet();
} }
for (const auto &cover : d.vcovers().v) { for (const auto &cover : d.vcovers().v) {
const auto document = Auth().data().processDocument(cover); const auto document = session().data().processDocument(cover);
if (document->sticker()) { if (document->sticker()) {
covers.push_back(document); covers.push_back(document);
} }
@ -1932,7 +1936,7 @@ void StickersListWidget::removeRecentSticker(int section, int index) {
break; break;
} }
} }
auto &sets = Auth().data().stickerSetsRef(); auto &sets = session().data().stickerSetsRef();
auto it = sets.find(Stickers::CustomSetId); auto it = sets.find(Stickers::CustomSetId);
if (it != sets.cend()) { if (it != sets.cend()) {
for (int i = 0, l = it->stickers.size(); i < l; ++i) { for (int i = 0, l = it->stickers.size(); i < l; ++i) {
@ -1965,7 +1969,7 @@ void StickersListWidget::removeFavedSticker(int section, int index) {
const auto &sticker = _mySets[section].stickers[index]; const auto &sticker = _mySets[section].stickers[index];
const auto document = sticker.document; const auto document = sticker.document;
Stickers::SetFaved(document, false); Stickers::SetFaved(document, false);
Auth().api().toggleFavedSticker( session().api().toggleFavedSticker(
document, document,
Data::FileOriginStickerSet(Stickers::FavedSetId, 0), Data::FileOriginStickerSet(Stickers::FavedSetId, 0),
false); false);
@ -2077,12 +2081,12 @@ void StickersListWidget::refreshStickers() {
void StickersListWidget::refreshMySets() { void StickersListWidget::refreshMySets() {
_mySets.clear(); _mySets.clear();
_favedStickersMap.clear(); _favedStickersMap.clear();
_mySets.reserve(Auth().data().stickerSetsOrder().size() + 3); _mySets.reserve(session().data().stickerSetsOrder().size() + 3);
refreshFavedStickers(); refreshFavedStickers();
refreshRecentStickers(false); refreshRecentStickers(false);
refreshMegagroupStickers(GroupStickersPlace::Visible); refreshMegagroupStickers(GroupStickersPlace::Visible);
for (const auto setId : Auth().data().stickerSetsOrder()) { for (const auto setId : session().data().stickerSetsOrder()) {
const auto externalLayout = false; const auto externalLayout = false;
appendSet(_mySets, setId, externalLayout, AppendSkip::Archived); appendSet(_mySets, setId, externalLayout, AppendSkip::Archived);
} }
@ -2091,9 +2095,9 @@ void StickersListWidget::refreshMySets() {
void StickersListWidget::refreshFeaturedSets() { void StickersListWidget::refreshFeaturedSets() {
_featuredSets.clear(); _featuredSets.clear();
_featuredSets.reserve(Auth().data().featuredStickerSetsOrder().size()); _featuredSets.reserve(session().data().featuredStickerSetsOrder().size());
for (const auto setId : Auth().data().featuredStickerSetsOrder()) { for (const auto setId : session().data().featuredStickerSetsOrder()) {
const auto externalLayout = true; const auto externalLayout = true;
appendSet(_featuredSets, setId, externalLayout, AppendSkip::Installed); appendSet(_featuredSets, setId, externalLayout, AppendSkip::Installed);
} }
@ -2102,7 +2106,7 @@ void StickersListWidget::refreshFeaturedSets() {
void StickersListWidget::refreshSearchSets() { void StickersListWidget::refreshSearchSets() {
refreshSearchIndex(); refreshSearchIndex();
const auto &sets = Auth().data().stickerSets(); const auto &sets = session().data().stickerSets();
for (auto &set : _searchSets) { for (auto &set : _searchSets) {
if (const auto it = sets.find(set.id); it != sets.end()) { if (const auto it = sets.find(set.id); it != sets.end()) {
set.flags = it->flags; set.flags = it->flags;
@ -2226,7 +2230,7 @@ void StickersListWidget::appendSet(
uint64 setId, uint64 setId,
bool externalLayout, bool externalLayout,
AppendSkip skip) { AppendSkip skip) {
auto &sets = Auth().data().stickerSets(); auto &sets = session().data().stickerSets();
auto it = sets.constFind(setId); auto it = sets.constFind(setId);
if (it == sets.cend() || it->stickers.isEmpty()) { if (it == sets.cend() || it->stickers.isEmpty()) {
return; return;
@ -2267,7 +2271,7 @@ auto StickersListWidget::collectRecentStickers() -> std::vector<Sticker> {
_custom.clear(); _custom.clear();
auto result = std::vector<Sticker>(); auto result = std::vector<Sticker>();
const auto &sets = Auth().data().stickerSets(); const auto &sets = session().data().stickerSets();
const auto &recent = Stickers::GetRecentPack(); const auto &recent = Stickers::GetRecentPack();
const auto customIt = sets.constFind(Stickers::CustomSetId); const auto customIt = sets.constFind(Stickers::CustomSetId);
const auto cloudIt = sets.constFind(Stickers::CloudRecentSetId); const auto cloudIt = sets.constFind(Stickers::CloudRecentSetId);
@ -2353,7 +2357,7 @@ void StickersListWidget::refreshRecentStickers(bool performResize) {
void StickersListWidget::refreshFavedStickers() { void StickersListWidget::refreshFavedStickers() {
clearSelection(); clearSelection();
auto &sets = Auth().data().stickerSets(); auto &sets = session().data().stickerSets();
auto it = sets.constFind(Stickers::FavedSetId); auto it = sets.constFind(Stickers::FavedSetId);
if (it == sets.cend() || it->stickers.isEmpty()) { if (it == sets.cend() || it->stickers.isEmpty()) {
return; return;
@ -2384,7 +2388,7 @@ void StickersListWidget::refreshMegagroupStickers(GroupStickersPlace place) {
}; };
if (_megagroupSet->mgInfo->stickerSet.type() == mtpc_inputStickerSetEmpty) { if (_megagroupSet->mgInfo->stickerSet.type() == mtpc_inputStickerSetEmpty) {
if (canEdit) { if (canEdit) {
auto hidden = Auth().settings().isGroupStickersSectionHidden(_megagroupSet->id); auto hidden = session().settings().isGroupStickersSectionHidden(_megagroupSet->id);
if (isShownHere(hidden)) { if (isShownHere(hidden)) {
const auto shortName = QString(); const auto shortName = QString();
const auto thumbnail = ImagePtr(); const auto thumbnail = ImagePtr();
@ -2402,10 +2406,10 @@ void StickersListWidget::refreshMegagroupStickers(GroupStickersPlace place) {
} }
return; return;
} }
auto hidden = Auth().settings().isGroupStickersSectionHidden(_megagroupSet->id); auto hidden = session().settings().isGroupStickersSectionHidden(_megagroupSet->id);
auto removeHiddenForGroup = [this, &hidden] { auto removeHiddenForGroup = [this, &hidden] {
if (hidden) { if (hidden) {
Auth().settings().removeGroupStickersSectionHidden(_megagroupSet->id); session().settings().removeGroupStickersSectionHidden(_megagroupSet->id);
Local::writeUserSettings(); Local::writeUserSettings();
hidden = false; hidden = false;
} }
@ -2417,7 +2421,7 @@ void StickersListWidget::refreshMegagroupStickers(GroupStickersPlace place) {
return; return;
} }
auto &set = _megagroupSet->mgInfo->stickerSet.c_inputStickerSetID(); auto &set = _megagroupSet->mgInfo->stickerSet.c_inputStickerSetID();
auto &sets = Auth().data().stickerSets(); auto &sets = session().data().stickerSets();
auto it = sets.constFind(set.vid().v); auto it = sets.constFind(set.vid().v);
if (it != sets.cend()) { if (it != sets.cend()) {
auto isInstalled = (it->flags & MTPDstickerSet::Flag::f_installed_date) auto isInstalled = (it->flags & MTPDstickerSet::Flag::f_installed_date)
@ -2461,7 +2465,7 @@ void StickersListWidget::refreshMegagroupStickers(GroupStickersPlace place) {
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);
if (Auth().data().featuredStickerSetsUnreadCount() if (session().data().featuredStickerSetsUnreadCount()
&& !_featuredSets.empty()) { && !_featuredSets.empty()) {
icons.push_back(StickerIcon(Stickers::FeaturedSetId)); icons.push_back(StickerIcon(Stickers::FeaturedSetId));
} }
@ -2510,7 +2514,7 @@ void StickersListWidget::fillIcons(QList<StickerIcon> &icons) {
pixh)); pixh));
} }
if (!Auth().data().featuredStickerSetsUnreadCount() if (!session().data().featuredStickerSetsUnreadCount()
&& !_featuredSets.empty()) { && !_featuredSets.empty()) {
icons.push_back(StickerIcon(Stickers::FeaturedSetId)); icons.push_back(StickerIcon(Stickers::FeaturedSetId));
} }
@ -2761,7 +2765,7 @@ void StickersListWidget::displaySet(uint64 setId) {
return; return;
} }
} }
auto &sets = Auth().data().stickerSets(); auto &sets = session().data().stickerSets();
auto it = sets.constFind(setId); auto it = sets.constFind(setId);
if (it != sets.cend()) { if (it != sets.cend()) {
_displayingSetId = setId; _displayingSetId = setId;
@ -2776,7 +2780,7 @@ void StickersListWidget::displaySet(uint64 setId) {
} }
void StickersListWidget::installSet(uint64 setId) { void StickersListWidget::installSet(uint64 setId) {
auto &sets = Auth().data().stickerSets(); auto &sets = session().data().stickerSets();
auto it = sets.constFind(setId); auto it = sets.constFind(setId);
if (it != sets.cend()) { if (it != sets.cend()) {
const auto input = Stickers::inputSetId(*it); const auto input = Stickers::inputSetId(*it);
@ -2815,7 +2819,7 @@ void StickersListWidget::sendInstallRequest(
void StickersListWidget::removeMegagroupSet(bool locally) { void StickersListWidget::removeMegagroupSet(bool locally) {
if (locally) { if (locally) {
Auth().settings().setGroupStickersSectionHidden(_megagroupSet->id); session().settings().setGroupStickersSectionHidden(_megagroupSet->id);
Local::writeUserSettings(); Local::writeUserSettings();
refreshStickers(); refreshStickers();
return; return;
@ -2825,7 +2829,7 @@ void StickersListWidget::removeMegagroupSet(bool locally) {
Expects(group->mgInfo != nullptr); Expects(group->mgInfo != nullptr);
if (group->mgInfo->stickerSet.type() != mtpc_inputStickerSetEmpty) { if (group->mgInfo->stickerSet.type() != mtpc_inputStickerSetEmpty) {
Auth().api().setGroupStickerSet(group, MTP_inputStickerSetEmpty()); session().api().setGroupStickerSet(group, MTP_inputStickerSetEmpty());
} }
Ui::hideLayer(); Ui::hideLayer();
_removingSetId = 0; _removingSetId = 0;
@ -2837,14 +2841,14 @@ void StickersListWidget::removeMegagroupSet(bool locally) {
} }
void StickersListWidget::removeSet(uint64 setId) { void StickersListWidget::removeSet(uint64 setId) {
auto &sets = Auth().data().stickerSets(); auto &sets = session().data().stickerSets();
auto it = sets.constFind(setId); auto it = sets.constFind(setId);
if (it != sets.cend()) { if (it != sets.cend()) {
_removingSetId = it->id; _removingSetId = it->id;
auto text = tr::lng_stickers_remove_pack(tr::now, lt_sticker_pack, it->title); auto text = tr::lng_stickers_remove_pack(tr::now, lt_sticker_pack, it->title);
Ui::show(Box<ConfirmBox>(text, tr::lng_stickers_remove_pack_confirm(tr::now), crl::guard(this, [=] { Ui::show(Box<ConfirmBox>(text, tr::lng_stickers_remove_pack_confirm(tr::now), crl::guard(this, [=] {
Ui::hideLayer(); Ui::hideLayer();
auto &sets = Auth().data().stickerSetsRef(); auto &sets = session().data().stickerSetsRef();
auto it = sets.find(_removingSetId); auto it = sets.find(_removingSetId);
if (it != sets.cend()) { if (it != sets.cend()) {
if (it->id && it->access) { if (it->id && it->access) {
@ -2871,8 +2875,8 @@ void StickersListWidget::removeSet(uint64 setId) {
// && !(it->flags & MTPDstickerSet_ClientFlag::f_special)) { // && !(it->flags & MTPDstickerSet_ClientFlag::f_special)) {
// sets.erase(it); // sets.erase(it);
//} //}
int removeIndex = Auth().data().stickerSetsOrder().indexOf(_removingSetId); int removeIndex = session().data().stickerSetsOrder().indexOf(_removingSetId);
if (removeIndex >= 0) Auth().data().stickerSetsOrderRef().removeAt(removeIndex); if (removeIndex >= 0) session().data().stickerSetsOrderRef().removeAt(removeIndex);
refreshStickers(); refreshStickers();
Local::writeInstalledStickers(); Local::writeInstalledStickers();
if (writeRecent) Local::writeUserSettings(); if (writeRecent) Local::writeUserSettings();

View File

@ -12,6 +12,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
#include "base/variant.h" #include "base/variant.h"
#include "base/timer.h" #include "base/timer.h"
class AuthSession;
namespace Window { namespace Window {
class SessionController; class SessionController;
} // namespace Window } // namespace Window
@ -40,6 +42,8 @@ public:
QWidget *parent, QWidget *parent,
not_null<Window::SessionController*> controller); not_null<Window::SessionController*> controller);
AuthSession &session() const;
rpl::producer<not_null<DocumentData*>> chosen() const; rpl::producer<not_null<DocumentData*>> chosen() const;
rpl::producer<> scrollUpdated() const; rpl::producer<> scrollUpdated() const;
rpl::producer<> checkForHide() const; rpl::producer<> checkForHide() const;

View File

@ -18,6 +18,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
#include "ui/widgets/discrete_sliders.h" #include "ui/widgets/discrete_sliders.h"
#include "ui/widgets/scroll_area.h" #include "ui/widgets/scroll_area.h"
#include "ui/image/image_prepare.h" #include "ui/image/image_prepare.h"
#include "window/window_session_controller.h"
#include "storage/localstorage.h" #include "storage/localstorage.h"
#include "data/data_channel.h" #include "data/data_channel.h"
#include "lang/lang_keys.h" #include "lang/lang_keys.h"
@ -279,17 +280,18 @@ TabbedSelector::TabbedSelector(
not_null<Window::SessionController*> controller, not_null<Window::SessionController*> controller,
Mode mode) Mode mode)
: RpWidget(parent) : RpWidget(parent)
, _controller(controller)
, _mode(mode) , _mode(mode)
, _topShadow(full() ? object_ptr<Ui::PlainShadow>(this) : nullptr) , _topShadow(full() ? object_ptr<Ui::PlainShadow>(this) : nullptr)
, _bottomShadow(this) , _bottomShadow(this)
, _scroll(this, st::emojiScroll) , _scroll(this, st::emojiScroll)
, _tabs { { , _tabs { {
createTab(SelectorTab::Emoji, controller), createTab(SelectorTab::Emoji),
createTab(SelectorTab::Stickers, controller), createTab(SelectorTab::Stickers),
createTab(SelectorTab::Gifs, controller), createTab(SelectorTab::Gifs),
} } } }
, _currentTabType(full() , _currentTabType(full()
? Auth().settings().selectorTab() ? session().settings().selectorTab()
: SelectorTab::Emoji) { : SelectorTab::Emoji) {
resize(st::emojiPanWidth, st::emojiPanMaxHeight); resize(st::emojiPanWidth, st::emojiPanMaxHeight);
@ -355,7 +357,7 @@ TabbedSelector::TabbedSelector(
Notify::PeerUpdate::Flag::RightsChanged, Notify::PeerUpdate::Flag::RightsChanged,
handleUpdate)); handleUpdate));
Auth().api().stickerSetInstalled( session().api().stickerSetInstalled(
) | rpl::start_with_next([this](uint64 setId) { ) | rpl::start_with_next([this](uint64 setId) {
_tabsSlider->setActiveSection( _tabsSlider->setActiveSection(
static_cast<int>(SelectorTab::Stickers)); static_cast<int>(SelectorTab::Stickers));
@ -368,22 +370,28 @@ TabbedSelector::TabbedSelector(
showAll(); showAll();
} }
TabbedSelector::Tab TabbedSelector::createTab(SelectorTab type, not_null<Window::SessionController*> controller) { TabbedSelector::~TabbedSelector() = default;
auto createWidget = [&]() -> object_ptr<Inner> {
if (!full() && type != SelectorTab::Emoji) { AuthSession &TabbedSelector::session() const {
return { nullptr }; return _controller->session();
} }
switch (type) {
case SelectorTab::Emoji: TabbedSelector::Tab TabbedSelector::createTab(SelectorTab type) {
return object_ptr<EmojiListWidget>(this, controller); auto createWidget = [&]() -> object_ptr<Inner> {
case SelectorTab::Stickers: if (!full() && type != SelectorTab::Emoji) {
return object_ptr<StickersListWidget>(this, controller); return { nullptr };
case SelectorTab::Gifs: }
return object_ptr<GifsListWidget>(this, controller); switch (type) {
} case SelectorTab::Emoji:
Unexpected("Type in TabbedSelector::createTab."); return object_ptr<EmojiListWidget>(this, _controller);
}; case SelectorTab::Stickers:
return Tab{ type, createWidget() }; return object_ptr<StickersListWidget>(this, _controller);
case SelectorTab::Gifs:
return object_ptr<GifsListWidget>(this, _controller);
}
Unexpected("Type in TabbedSelector::createTab.");
};
return Tab{ type, createWidget() };
} }
bool TabbedSelector::full() const { bool TabbedSelector::full() const {
@ -602,8 +610,6 @@ QRect TabbedSelector::rectForFloatPlayer() const {
return mapToGlobal(_scroll->geometry()); return mapToGlobal(_scroll->geometry());
} }
TabbedSelector::~TabbedSelector() = default;
void TabbedSelector::hideFinished() { void TabbedSelector::hideFinished() {
for (auto &tab : _tabs) { for (auto &tab : _tabs) {
if (!tab.widget()) { if (!tab.widget()) {
@ -617,7 +623,7 @@ void TabbedSelector::hideFinished() {
void TabbedSelector::showStarted() { void TabbedSelector::showStarted() {
if (full()) { if (full()) {
Auth().api().updateStickers(); session().api().updateStickers();
} }
currentTab()->widget()->refreshRecent(); currentTab()->widget()->refreshRecent();
currentTab()->widget()->preloadImages(); currentTab()->widget()->preloadImages();
@ -818,8 +824,8 @@ void TabbedSelector::switchTab() {
update(); update();
if (full()) { if (full()) {
Auth().settings().setSelectorTab(_currentTabType); session().settings().setSelectorTab(_currentTabType);
Auth().saveSettingsDelayed(); session().saveSettingsDelayed();
} }
} }

View File

@ -55,6 +55,9 @@ public:
QWidget *parent, QWidget *parent,
not_null<Window::SessionController*> controller, not_null<Window::SessionController*> controller,
Mode mode = Mode::Full); Mode mode = Mode::Full);
~TabbedSelector();
AuthSession &session() const;
rpl::producer<EmojiPtr> emojiChosen() const; rpl::producer<EmojiPtr> emojiChosen() const;
rpl::producer<not_null<DocumentData*>> fileChosen() const; rpl::producer<not_null<DocumentData*>> fileChosen() const;
@ -99,8 +102,6 @@ public:
return _showRequests.events(); return _showRequests.events();
} }
~TabbedSelector();
class Inner; class Inner;
class InnerFooter; class InnerFooter;
@ -146,9 +147,7 @@ private:
}; };
bool full() const; bool full() const;
Tab createTab( Tab createTab(SelectorTab type);
SelectorTab type,
not_null<Window::SessionController*> controller);
void paintSlideFrame(Painter &p); void paintSlideFrame(Painter &p);
void paintContent(Painter &p); void paintContent(Painter &p);
@ -185,6 +184,8 @@ private:
not_null<StickersListWidget*> stickers() const; not_null<StickersListWidget*> stickers() const;
not_null<GifsListWidget*> gifs() const; not_null<GifsListWidget*> gifs() const;
const not_null<Window::SessionController*> _controller;
Mode _mode = Mode::Full; Mode _mode = Mode::Full;
int _roundRadius = 0; int _roundRadius = 0;
int _footerTop = 0; int _footerTop = 0;

View File

@ -737,11 +737,11 @@ void DocumentData::automaticLoad(
const auto shouldLoadFromCloud = !Data::IsExecutableName(filename) const auto shouldLoadFromCloud = !Data::IsExecutableName(filename)
&& (item && (item
? Data::AutoDownload::Should( ? Data::AutoDownload::Should(
Auth().settings().autoDownload(), session().settings().autoDownload(),
item->history()->peer, item->history()->peer,
this) this)
: Data::AutoDownload::Should( : Data::AutoDownload::Should(
Auth().settings().autoDownload(), session().settings().autoDownload(),
this)); this));
const auto loadFromCloud = shouldLoadFromCloud const auto loadFromCloud = shouldLoadFromCloud
? LoadFromCloudOrLocal ? LoadFromCloudOrLocal

View File

@ -1645,7 +1645,7 @@ bool Session::checkEntitiesAndViewsUpdate(const MTPDmessage &data) {
} }
requestItemTextRefresh(existing); requestItemTextRefresh(existing);
if (existing->mainView()) { if (existing->mainView()) {
App::checkSavedGif(existing); checkSavedGif(existing);
return true; return true;
} }
return false; return false;
@ -1653,6 +1653,40 @@ bool Session::checkEntitiesAndViewsUpdate(const MTPDmessage &data) {
return false; return false;
} }
void Session::addSavedGif(not_null<DocumentData*> document) {
const auto index = _savedGifs.indexOf(document);
if (!index) {
return;
}
if (index > 0) {
_savedGifs.remove(index);
}
_savedGifs.push_front(document);
if (_savedGifs.size() > Global::SavedGifsLimit()) {
_savedGifs.pop_back();
}
Local::writeSavedGifs();
notifySavedGifsUpdated();
setLastSavedGifsUpdate(0);
session().api().updateStickers();
}
void Session::checkSavedGif(not_null<HistoryItem*> item) {
if (item->Has<HistoryMessageForwarded>()
|| (!item->out()
&& item->history()->peer != session().user())) {
return;
}
if (const auto media = item->media()) {
if (const auto document = media->document()) {
if (document->isGifv()) {
addSavedGif(document);
}
}
}
}
void Session::updateEditedMessage(const MTPMessage &data) { void Session::updateEditedMessage(const MTPMessage &data) {
const auto existing = data.match([](const MTPDmessageEmpty &) const auto existing = data.match([](const MTPDmessageEmpty &)
-> HistoryItem* { -> HistoryItem* {

View File

@ -309,6 +309,9 @@ public:
return _savedGifs; return _savedGifs;
} }
void addSavedGif(not_null<DocumentData*> document);
void checkSavedGif(not_null<HistoryItem*> item);
HistoryItemsList idsToItems(const MessageIdsList &ids) const; HistoryItemsList idsToItems(const MessageIdsList &ids) const;
MessageIdsList itemsToIds(const HistoryItemsList &items) const; MessageIdsList itemsToIds(const HistoryItemsList &items) const;
MessageIdsList itemOrItsGroup(not_null<HistoryItem*> item) const; MessageIdsList itemOrItsGroup(not_null<HistoryItem*> item) const;

View File

@ -115,7 +115,9 @@ void activateBotCommand(
Ui::showPeerHistory(history, ShowAtTheEndMsgId); Ui::showPeerHistory(history, ShowAtTheEndMsgId);
auto options = ApiWrap::SendOptions(history); auto options = ApiWrap::SendOptions(history);
options.replyTo = msgId; options.replyTo = msgId;
history->session().api().shareContact(Auth().user(), options); history->session().api().shareContact(
history->session().user(),
options);
})); }));
} break; } break;

View File

@ -227,25 +227,25 @@ InnerWidget::InnerWidget(
, _idManager(_history->adminLogIdManager()) { , _idManager(_history->adminLogIdManager()) {
setMouseTracking(true); setMouseTracking(true);
_scrollDateHideTimer.setCallback([this] { scrollDateHideByTimer(); }); _scrollDateHideTimer.setCallback([this] { scrollDateHideByTimer(); });
Auth().data().viewRepaintRequest( session().data().viewRepaintRequest(
) | rpl::start_with_next([this](auto view) { ) | rpl::start_with_next([this](auto view) {
if (view->delegate() == this) { if (view->delegate() == this) {
repaintItem(view); repaintItem(view);
} }
}, lifetime()); }, lifetime());
Auth().data().viewResizeRequest( session().data().viewResizeRequest(
) | rpl::start_with_next([this](auto view) { ) | rpl::start_with_next([this](auto view) {
if (view->delegate() == this) { if (view->delegate() == this) {
resizeItem(view); resizeItem(view);
} }
}, lifetime()); }, lifetime());
Auth().data().itemViewRefreshRequest( session().data().itemViewRefreshRequest(
) | rpl::start_with_next([this](auto item) { ) | rpl::start_with_next([this](auto item) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
refreshItem(view); refreshItem(view);
} }
}, lifetime()); }, lifetime());
Auth().data().viewLayoutChanged( session().data().viewLayoutChanged(
) | rpl::start_with_next([this](auto view) { ) | rpl::start_with_next([this](auto view) {
if (view->delegate() == this) { if (view->delegate() == this) {
if (view->isUnderCursor()) { if (view->isUnderCursor()) {
@ -253,7 +253,7 @@ InnerWidget::InnerWidget(
} }
} }
}, lifetime()); }, lifetime());
Auth().data().animationPlayInlineRequest( session().data().animationPlayInlineRequest(
) | rpl::start_with_next([this](auto item) { ) | rpl::start_with_next([this](auto item) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
if (const auto media = view->media()) { if (const auto media = view->media()) {
@ -261,7 +261,7 @@ InnerWidget::InnerWidget(
} }
} }
}, lifetime()); }, lifetime());
subscribe(Auth().data().queryItemVisibility(), [this](const Data::Session::ItemVisibilityQuery &query) { subscribe(session().data().queryItemVisibility(), [this](const Data::Session::ItemVisibilityQuery &query) {
if (_history != query.item->history() || !query.item->isLogEntry() || !isVisible()) { if (_history != query.item->history() || !query.item->isLogEntry() || !isVisible()) {
return; return;
} }
@ -277,6 +277,10 @@ InnerWidget::InnerWidget(
requestAdmins(); requestAdmins();
} }
AuthSession &InnerWidget::session() const {
return _controller->session();
}
void InnerWidget::visibleTopBottomUpdated( void InnerWidget::visibleTopBottomUpdated(
int visibleTop, int visibleTop,
int visibleBottom) { int visibleBottom) {
@ -389,7 +393,7 @@ void InnerWidget::requestAdmins() {
MTP_int(kMaxChannelAdmins), MTP_int(kMaxChannelAdmins),
MTP_int(participantsHash) MTP_int(participantsHash)
)).done([this](const MTPchannels_ChannelParticipants &result) { )).done([this](const MTPchannels_ChannelParticipants &result) {
Auth().api().parseChannelParticipants(_channel, result, [&]( session().api().parseChannelParticipants(_channel, result, [&](
int availableCount, int availableCount,
const QVector<MTPChannelParticipant> &list) { const QVector<MTPChannelParticipant> &list) {
auto filtered = ( auto filtered = (
@ -407,7 +411,7 @@ void InnerWidget::requestAdmins() {
return std::make_pair(userId, canEdit); return std::make_pair(userId, canEdit);
}) | ranges::view::transform([&](auto &&pair) { }) | ranges::view::transform([&](auto &&pair) {
return std::make_pair( return std::make_pair(
Auth().data().userLoaded(pair.first), session().data().userLoaded(pair.first),
pair.second); pair.second);
}) | ranges::view::filter([&](auto &&pair) { }) | ranges::view::filter([&](auto &&pair) {
return (pair.first != nullptr); return (pair.first != nullptr);
@ -421,7 +425,7 @@ void InnerWidget::requestAdmins() {
} }
}); });
if (_admins.empty()) { if (_admins.empty()) {
_admins.push_back(Auth().user()); _admins.push_back(session().user());
} }
if (_showFilterCallback) { if (_showFilterCallback) {
showFilter(std::move(_showFilterCallback)); showFilter(std::move(_showFilterCallback));
@ -514,7 +518,7 @@ bool InnerWidget::elementUnderCursor(
void InnerWidget::elementAnimationAutoplayAsync( void InnerWidget::elementAnimationAutoplayAsync(
not_null<const HistoryView::Element*> view) { not_null<const HistoryView::Element*> view) {
crl::on_main(this, [this, msgId = view->data()->fullId()] { crl::on_main(this, [this, msgId = view->data()->fullId()] {
if (const auto item = Auth().data().message(msgId)) { if (const auto item = session().data().message(msgId)) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
if (const auto media = view->media()) { if (const auto media = view->media()) {
media->autoplayAnimation(); media->autoplayAnimation();
@ -1144,7 +1148,7 @@ void InnerWidget::showContextInFolder(not_null<DocumentData*> document) {
} }
void InnerWidget::openContextGif(FullMsgId itemId) { void InnerWidget::openContextGif(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto media = item->media()) { if (const auto media = item->media()) {
if (const auto document = media->document()) { if (const auto document = media->document()) {
Core::App().showDocument(document, item); Core::App().showDocument(document, item);
@ -1154,7 +1158,7 @@ void InnerWidget::openContextGif(FullMsgId itemId) {
} }
void InnerWidget::copyContextText(FullMsgId itemId) { void InnerWidget::copyContextText(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
SetClipboardText(HistoryItemText(item)); SetClipboardText(HistoryItemText(item));
} }
} }
@ -1612,7 +1616,7 @@ void InnerWidget::performDrag() {
// if (uponSelected && !Adaptive::OneColumn()) { // if (uponSelected && !Adaptive::OneColumn()) {
// auto selectedState = getSelectionState(); // auto selectedState = getSelectionState();
// if (selectedState.count > 0 && selectedState.count == selectedState.canForwardCount) { // if (selectedState.count > 0 && selectedState.count == selectedState.canForwardCount) {
// Auth().data().setMimeForwardIds(getSelectedItems()); // session().data().setMimeForwardIds(getSelectedItems());
// mimeData->setData(qsl("application/x-td-forward"), "1"); // mimeData->setData(qsl("application/x-td-forward"), "1");
// } // }
// } // }
@ -1626,8 +1630,8 @@ void InnerWidget::performDrag() {
// if (_mouseCursorState == CursorState::Date // if (_mouseCursorState == CursorState::Date
// || (pressedMedia && pressedMedia->dragItem())) { // || (pressedMedia && pressedMedia->dragItem())) {
// forwardMimeType = qsl("application/x-td-forward"); // forwardMimeType = qsl("application/x-td-forward");
// Auth().data().setMimeForwardIds( // session().data().setMimeForwardIds(
// Auth().data().itemOrItsGroup(pressedItem->data())); // session().data().itemOrItsGroup(pressedItem->data()));
// } // }
// } // }
// if (auto pressedLnkItem = App::pressedLinkItem()) { // if (auto pressedLnkItem = App::pressedLinkItem()) {
@ -1635,7 +1639,7 @@ void InnerWidget::performDrag() {
// if (forwardMimeType.isEmpty() // if (forwardMimeType.isEmpty()
// && pressedMedia->dragItemByHandler(pressedHandler)) { // && pressedMedia->dragItemByHandler(pressedHandler)) {
// forwardMimeType = qsl("application/x-td-forward"); // forwardMimeType = qsl("application/x-td-forward");
// Auth().data().setMimeForwardIds( // session().data().setMimeForwardIds(
// { 1, pressedLnkItem->fullId() }); // { 1, pressedLnkItem->fullId() });
// } // }
// } // }

View File

@ -16,6 +16,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
#include "mtproto/sender.h" #include "mtproto/sender.h"
#include "base/timer.h" #include "base/timer.h"
class AuthSession;
namespace HistoryView { namespace HistoryView {
class Element; class Element;
struct TextState; struct TextState;
@ -48,6 +50,8 @@ public:
not_null<Window::SessionController*> controller, not_null<Window::SessionController*> controller,
not_null<ChannelData*> channel); not_null<ChannelData*> channel);
AuthSession &session() const;
base::Observable<void> showSearchSignal; base::Observable<void> showSearchSignal;
base::Observable<int> scrollToSignal; base::Observable<int> scrollToSignal;
base::Observable<void> cancelledSignal; base::Observable<void> cancelledSignal;

View File

@ -1005,7 +1005,7 @@ void History::applyMessageChanges(
if (data.type() == mtpc_messageService) { if (data.type() == mtpc_messageService) {
applyServiceChanges(item, data.c_messageService()); applyServiceChanges(item, data.c_messageService());
} }
App::checkSavedGif(item); owner().checkSavedGif(item);
} }
void History::applyServiceChanges( void History::applyServiceChanges(

View File

@ -153,31 +153,31 @@ HistoryInner::HistoryInner(
subscribe(_controller->window()->dragFinished(), [this] { subscribe(_controller->window()->dragFinished(), [this] {
mouseActionUpdate(QCursor::pos()); mouseActionUpdate(QCursor::pos());
}); });
Auth().data().itemRemoved( session().data().itemRemoved(
) | rpl::start_with_next( ) | rpl::start_with_next(
[this](auto item) { itemRemoved(item); }, [this](auto item) { itemRemoved(item); },
lifetime()); lifetime());
Auth().data().viewRemoved( session().data().viewRemoved(
) | rpl::start_with_next( ) | rpl::start_with_next(
[this](auto view) { viewRemoved(view); }, [this](auto view) { viewRemoved(view); },
lifetime()); lifetime());
Auth().data().itemViewRefreshRequest( session().data().itemViewRefreshRequest(
) | rpl::start_with_next( ) | rpl::start_with_next(
[this](auto item) { refreshView(item); }, [this](auto item) { refreshView(item); },
lifetime()); lifetime());
rpl::merge( rpl::merge(
Auth().data().historyUnloaded(), session().data().historyUnloaded(),
Auth().data().historyCleared() session().data().historyCleared()
) | rpl::filter([this](not_null<const History*> history) { ) | rpl::filter([this](not_null<const History*> history) {
return (_history == history); return (_history == history);
}) | rpl::start_with_next([this] { }) | rpl::start_with_next([this] {
mouseActionCancel(); mouseActionCancel();
}, lifetime()); }, lifetime());
Auth().data().viewRepaintRequest( session().data().viewRepaintRequest(
) | rpl::start_with_next([this](not_null<const Element*> view) { ) | rpl::start_with_next([this](not_null<const Element*> view) {
repaintItem(view); repaintItem(view);
}, lifetime()); }, lifetime());
Auth().data().viewLayoutChanged( session().data().viewLayoutChanged(
) | rpl::filter([](not_null<const Element*> view) { ) | rpl::filter([](not_null<const Element*> view) {
return (view == view->data()->mainView()) && view->isUnderCursor(); return (view == view->data()->mainView()) && view->isUnderCursor();
}) | rpl::start_with_next([this](not_null<const Element*> view) { }) | rpl::start_with_next([this](not_null<const Element*> view) {
@ -185,6 +185,10 @@ HistoryInner::HistoryInner(
}, lifetime()); }, lifetime());
} }
AuthSession &HistoryInner::session() const {
return _controller->session();
}
void HistoryInner::messagesReceived( void HistoryInner::messagesReceived(
PeerData *peer, PeerData *peer,
const QVector<MTPMessage> &messages) { const QVector<MTPMessage> &messages) {
@ -493,7 +497,7 @@ TextSelection HistoryInner::computeRenderSelection(
if (result != TextSelection() && result != FullSelection) { if (result != TextSelection() && result != FullSelection) {
return result; return result;
} }
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = session().data().groups().find(item)) {
auto parts = TextSelection(); auto parts = TextSelection();
auto allFullSelected = true; auto allFullSelected = true;
const auto count = int(group->items.size()); const auto count = int(group->items.size());
@ -681,7 +685,7 @@ void HistoryInner::paintEvent(QPaintEvent *e) {
} }
if (!readMentions.empty() && App::wnd()->doWeReadMentions()) { if (!readMentions.empty() && App::wnd()->doWeReadMentions()) {
Auth().api().markMediaRead(readMentions); session().api().markMediaRead(readMentions);
} }
if (mtop >= 0 || htop >= 0) { if (mtop >= 0 || htop >= 0) {
@ -1183,7 +1187,7 @@ std::unique_ptr<QMimeData> HistoryInner::prepareDrag() {
if (uponSelected && !Adaptive::OneColumn()) { if (uponSelected && !Adaptive::OneColumn()) {
auto selectedState = getSelectionState(); auto selectedState = getSelectionState();
if (selectedState.count > 0 && selectedState.count == selectedState.canForwardCount) { if (selectedState.count > 0 && selectedState.count == selectedState.canForwardCount) {
Auth().data().setMimeForwardIds(getSelectedItems()); session().data().setMimeForwardIds(getSelectedItems());
mimeData->setData(qsl("application/x-td-forward"), "1"); mimeData->setData(qsl("application/x-td-forward"), "1");
} }
} }
@ -1195,7 +1199,7 @@ std::unique_ptr<QMimeData> HistoryInner::prepareDrag() {
} }
auto forwardIds = MessageIdsList(); auto forwardIds = MessageIdsList();
if (_mouseCursorState == CursorState::Date) { if (_mouseCursorState == CursorState::Date) {
forwardIds = Auth().data().itemOrItsGroup(_dragStateItem); forwardIds = session().data().itemOrItsGroup(_dragStateItem);
} else if (view->isHiddenByGroup() && pressedHandler) { } else if (view->isHiddenByGroup() && pressedHandler) {
forwardIds = MessageIdsList(1, _dragStateItem->fullId()); forwardIds = MessageIdsList(1, _dragStateItem->fullId());
} else if (const auto media = view->media()) { } else if (const auto media = view->media()) {
@ -1207,7 +1211,7 @@ std::unique_ptr<QMimeData> HistoryInner::prepareDrag() {
if (forwardIds.empty()) { if (forwardIds.empty()) {
return nullptr; return nullptr;
} }
Auth().data().setMimeForwardIds(std::move(forwardIds)); session().data().setMimeForwardIds(std::move(forwardIds));
auto result = std::make_unique<QMimeData>(); auto result = std::make_unique<QMimeData>();
result->setData(qsl("application/x-td-forward"), "1"); result->setData(qsl("application/x-td-forward"), "1");
if (const auto media = view->media()) { if (const auto media = view->media()) {
@ -1534,7 +1538,7 @@ void HistoryInner::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
}); });
if (photo->hasSticker) { if (photo->hasSticker) {
_menu->addAction(tr::lng_context_attached_stickers(tr::now), [=] { _menu->addAction(tr::lng_context_attached_stickers(tr::now), [=] {
Auth().api().requestAttachedStickerSets(photo); session().api().requestAttachedStickerSets(photo);
}); });
} }
}; };
@ -1628,7 +1632,7 @@ void HistoryInner::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
} }
if (IsServerMsgId(item->id) && !item->serviceMsg()) { if (IsServerMsgId(item->id) && !item->serviceMsg()) {
_menu->addAction(tr::lng_context_select_msg(tr::now), [=] { _menu->addAction(tr::lng_context_select_msg(tr::now), [=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto view = item->mainView()) { if (const auto view = item->mainView()) {
changeSelection(&_selected, item, SelectAction::Select); changeSelection(&_selected, item, SelectAction::Select);
repaintItem(item); repaintItem(item);
@ -1645,7 +1649,7 @@ void HistoryInner::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
: App::hoveredLinkItem() : App::hoveredLinkItem()
? App::hoveredLinkItem()->data().get() ? App::hoveredLinkItem()->data().get()
: nullptr) { : nullptr) {
if (const auto group = Auth().data().groups().find(result)) { if (const auto group = session().data().groups().find(result)) {
return group->items.front(); return group->items.front();
} }
return result; return result;
@ -1680,7 +1684,7 @@ void HistoryInner::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
showStickerPackInfo(document); showStickerPackInfo(document);
}); });
_menu->addAction(Stickers::IsFaved(document) ? tr::lng_faved_stickers_remove(tr::now) : tr::lng_faved_stickers_add(tr::now), [=] { _menu->addAction(Stickers::IsFaved(document) ? tr::lng_faved_stickers_remove(tr::now) : tr::lng_faved_stickers_add(tr::now), [=] {
Auth().api().toggleFavedSticker( session().api().toggleFavedSticker(
document, document,
itemId, itemId,
!Stickers::IsFaved(document)); !Stickers::IsFaved(document));
@ -1696,7 +1700,7 @@ void HistoryInner::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
if (!poll->closed) { if (!poll->closed) {
if (poll->voted()) { if (poll->voted()) {
_menu->addAction(tr::lng_polls_retract(tr::now), [=] { _menu->addAction(tr::lng_polls_retract(tr::now), [=] {
Auth().api().sendPollVotes(itemId, {}); session().api().sendPollVotes(itemId, {});
}); });
} }
if (item->canStopPoll()) { if (item->canStopPoll()) {
@ -1768,7 +1772,7 @@ void HistoryInner::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
} }
if (item->id > 0 && !item->serviceMsg()) { if (item->id > 0 && !item->serviceMsg()) {
_menu->addAction(tr::lng_context_select_msg(tr::now), [=] { _menu->addAction(tr::lng_context_select_msg(tr::now), [=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto view = item->mainView()) { if (const auto view = item->mainView()) {
changeSelectionAsGroup(&_selected, item, SelectAction::Select); changeSelectionAsGroup(&_selected, item, SelectAction::Select);
repaintItem(view); repaintItem(view);
@ -1783,7 +1787,7 @@ void HistoryInner::showContextMenu(QContextMenuEvent *e, bool showFromTouch) {
&& !App::mousedItem()->data()->serviceMsg()) { && !App::mousedItem()->data()->serviceMsg()) {
const auto itemId = App::mousedItem()->data()->fullId(); const auto itemId = App::mousedItem()->data()->fullId();
_menu->addAction(tr::lng_context_select_msg(tr::now), [=] { _menu->addAction(tr::lng_context_select_msg(tr::now), [=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto view = item->mainView()) { if (const auto view = item->mainView()) {
changeSelectionAsGroup(&_selected, item, SelectAction::Select); changeSelectionAsGroup(&_selected, item, SelectAction::Select);
repaintItem(item); repaintItem(item);
@ -1857,7 +1861,7 @@ void HistoryInner::saveDocumentToFile(
} }
void HistoryInner::openContextGif(FullMsgId itemId) { void HistoryInner::openContextGif(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto media = item->media()) { if (const auto media = item->media()) {
if (const auto document = media->document()) { if (const auto document = media->document()) {
Core::App().showDocument(document, item); Core::App().showDocument(document, item);
@ -1867,18 +1871,18 @@ void HistoryInner::openContextGif(FullMsgId itemId) {
} }
void HistoryInner::saveContextGif(FullMsgId itemId) { void HistoryInner::saveContextGif(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto media = item->media()) { if (const auto media = item->media()) {
if (const auto document = media->document()) { if (const auto document = media->document()) {
Auth().api().toggleSavedGif(document, item->fullId(), true); session().api().toggleSavedGif(document, item->fullId(), true);
} }
} }
} }
} }
void HistoryInner::copyContextText(FullMsgId itemId) { void HistoryInner::copyContextText(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = session().data().groups().find(item)) {
SetClipboardText(HistoryGroupText(group)); SetClipboardText(HistoryGroupText(group));
} else { } else {
SetClipboardText(HistoryItemText(item)); SetClipboardText(HistoryItemText(item));
@ -1937,7 +1941,7 @@ TextForMimeData HistoryInner::getSelectedText() const {
}; };
for (const auto [item, selection] : selected) { for (const auto [item, selection] : selected) {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = session().data().groups().find(item)) {
if (groups.contains(group)) { if (groups.contains(group)) {
continue; continue;
} }
@ -2149,7 +2153,7 @@ void HistoryInner::visibleAreaUpdated(int top, int bottom) {
const auto pages = kUnloadHeavyPartsPages; const auto pages = kUnloadHeavyPartsPages;
const auto from = _visibleAreaTop - pages * visibleAreaHeight; const auto from = _visibleAreaTop - pages * visibleAreaHeight;
const auto till = _visibleAreaBottom + pages * visibleAreaHeight; const auto till = _visibleAreaBottom + pages * visibleAreaHeight;
Auth().data().unloadHeavyViewParts(ElementDelegate(), from, till); session().data().unloadHeavyViewParts(ElementDelegate(), from, till);
} }
bool HistoryInner::displayScrollDate() const { bool HistoryInner::displayScrollDate() const {
@ -2494,7 +2498,7 @@ void HistoryInner::mouseActionUpdate() {
dragState = TextState(nullptr, _botAbout->info->text.getState( dragState = TextState(nullptr, _botAbout->info->text.getState(
point - _botAbout->rect.topLeft() - QPoint(st::msgPadding.left(), st::msgPadding.top() + st::botDescSkip + st::msgNameFont->height), point - _botAbout->rect.topLeft() - QPoint(st::msgPadding.left(), st::msgPadding.top() + st::botDescSkip + st::msgNameFont->height),
_botAbout->width)); _botAbout->width));
_dragStateItem = Auth().data().message(dragState.itemId); _dragStateItem = session().data().message(dragState.itemId);
lnkhost = _botAbout.get(); lnkhost = _botAbout.get();
} }
} else if (item) { } else if (item) {
@ -2552,7 +2556,7 @@ void HistoryInner::mouseActionUpdate() {
dragState = TextState( dragState = TextState(
nullptr, nullptr,
_scrollDateLink); _scrollDateLink);
_dragStateItem = Auth().data().message(dragState.itemId); _dragStateItem = session().data().message(dragState.itemId);
lnkhost = view; lnkhost = view;
} }
} }
@ -2568,7 +2572,7 @@ void HistoryInner::mouseActionUpdate() {
selectingText = false; selectingText = false;
} }
dragState = view->textState(m, request); dragState = view->textState(m, request);
_dragStateItem = Auth().data().message(dragState.itemId); _dragStateItem = session().data().message(dragState.itemId);
lnkhost = view; lnkhost = view;
if (!dragState.link && m.x() >= st::historyPhotoLeft && m.x() < st::historyPhotoLeft + st::msgPhotoSize) { if (!dragState.link && m.x() >= st::historyPhotoLeft && m.x() < st::historyPhotoLeft + st::msgPhotoSize) {
if (auto msg = item->toHistoryMessage()) { if (auto msg = item->toHistoryMessage()) {
@ -2588,7 +2592,7 @@ void HistoryInner::mouseActionUpdate() {
dragState = TextState(nullptr, from dragState = TextState(nullptr, from
? from->openLink() ? from->openLink()
: hiddenUserpicLink(message->fullId())); : hiddenUserpicLink(message->fullId()));
_dragStateItem = Auth().data().message(dragState.itemId); _dragStateItem = session().data().message(dragState.itemId);
lnkhost = view; lnkhost = view;
return false; return false;
} }
@ -2826,7 +2830,7 @@ void HistoryInner::notifyIsBotChanged() {
if (newinfo) { if (newinfo) {
_botAbout = std::make_unique<BotAbout>(this, newinfo); _botAbout = std::make_unique<BotAbout>(this, newinfo);
if (newinfo && !newinfo->inited) { if (newinfo && !newinfo->inited) {
Auth().api().requestFullPeer(_peer); session().api().requestFullPeer(_peer);
} }
} else { } else {
_botAbout = nullptr; _botAbout = nullptr;
@ -2877,7 +2881,7 @@ bool HistoryInner::isSelectedGroup(
bool HistoryInner::isSelectedAsGroup( bool HistoryInner::isSelectedAsGroup(
not_null<SelectedItems*> toItems, not_null<SelectedItems*> toItems,
not_null<HistoryItem*> item) const { not_null<HistoryItem*> item) const {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = session().data().groups().find(item)) {
return isSelectedGroup(toItems, group); return isSelectedGroup(toItems, group);
} }
return isSelected(toItems, item); return isSelected(toItems, item);
@ -2940,7 +2944,7 @@ void HistoryInner::changeSelectionAsGroup(
not_null<SelectedItems*> toItems, not_null<SelectedItems*> toItems,
not_null<HistoryItem*> item, not_null<HistoryItem*> item,
SelectAction action) const { SelectAction action) const {
const auto group = Auth().data().groups().find(item); const auto group = session().data().groups().find(item);
if (!group) { if (!group) {
return changeSelection(toItems, item, action); return changeSelection(toItems, item, action);
} }
@ -2974,13 +2978,13 @@ void HistoryInner::forwardItem(FullMsgId itemId) {
} }
void HistoryInner::forwardAsGroup(FullMsgId itemId) { void HistoryInner::forwardAsGroup(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
Window::ShowForwardMessagesBox(Auth().data().itemOrItsGroup(item)); Window::ShowForwardMessagesBox(session().data().itemOrItsGroup(item));
} }
} }
void HistoryInner::deleteItem(FullMsgId itemId) { void HistoryInner::deleteItem(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
deleteItem(item); deleteItem(item);
} }
} }
@ -3002,13 +3006,13 @@ bool HistoryInner::hasPendingResizedItems() const {
} }
void HistoryInner::deleteAsGroup(FullMsgId itemId) { void HistoryInner::deleteAsGroup(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
const auto group = Auth().data().groups().find(item); const auto group = session().data().groups().find(item);
if (!group) { if (!group) {
return deleteItem(item); return deleteItem(item);
} }
Ui::show(Box<DeleteMessagesBox>( Ui::show(Box<DeleteMessagesBox>(
Auth().data().itemsToIds(group->items))); session().data().itemsToIds(group->items)));
} }
} }
@ -3017,14 +3021,14 @@ void HistoryInner::reportItem(FullMsgId itemId) {
} }
void HistoryInner::reportAsGroup(FullMsgId itemId) { void HistoryInner::reportAsGroup(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
const auto group = Auth().data().groups().find(item); const auto group = session().data().groups().find(item);
if (!group) { if (!group) {
return reportItem(itemId); return reportItem(itemId);
} }
Ui::show(Box<ReportBox>( Ui::show(Box<ReportBox>(
_peer, _peer,
Auth().data().itemsToIds(group->items))); session().data().itemsToIds(group->items)));
} }
} }

View File

@ -52,6 +52,8 @@ public:
Ui::ScrollArea *scroll, Ui::ScrollArea *scroll,
not_null<History*> history); not_null<History*> history);
AuthSession &session() const;
void messagesReceived(PeerData *peer, const QVector<MTPMessage> &messages); void messagesReceived(PeerData *peer, const QVector<MTPMessage> &messages);
void messagesReceivedDown(PeerData *peer, const QVector<MTPMessage> &messages); void messagesReceivedDown(PeerData *peer, const QVector<MTPMessage> &messages);

View File

@ -184,17 +184,18 @@ void FastShareMessage(not_null<HistoryItem*> item) {
base::flat_set<mtpRequestId> requests; base::flat_set<mtpRequestId> requests;
}; };
const auto history = item->history(); const auto history = item->history();
const auto owner = &history->owner();
const auto data = std::make_shared<ShareData>( const auto data = std::make_shared<ShareData>(
history->peer, history->peer,
history->owner().itemOrItsGroup(item)); owner->itemOrItsGroup(item));
const auto isGroup = (history->owner().groups().find(item) != nullptr); const auto isGroup = (owner->groups().find(item) != nullptr);
const auto isGame = item->getMessageBot() const auto isGame = item->getMessageBot()
&& item->media() && item->media()
&& (item->media()->game() != nullptr); && (item->media()->game() != nullptr);
const auto canCopyLink = item->hasDirectLink() || isGame; const auto canCopyLink = item->hasDirectLink() || isGame;
auto copyCallback = [=]() { auto copyCallback = [=]() {
if (auto item = Auth().data().message(data->msgIds[0])) { if (const auto item = owner->message(data->msgIds[0])) {
if (item->hasDirectLink()) { if (item->hasDirectLink()) {
HistoryView::CopyPostLink(item->fullId()); HistoryView::CopyPostLink(item->fullId());
} else if (const auto bot = item->getMessageBot()) { } else if (const auto bot = item->getMessageBot()) {
@ -321,7 +322,7 @@ void FastShareMessage(not_null<HistoryItem*> item) {
Fn<void(ChannelData*, MsgId)> HistoryDependentItemCallback( Fn<void(ChannelData*, MsgId)> HistoryDependentItemCallback(
const FullMsgId &msgId) { const FullMsgId &msgId) {
return [dependent = msgId](ChannelData *channel, MsgId msgId) { return [dependent = msgId](ChannelData *channel, MsgId msgId) {
if (auto item = Auth().data().message(dependent)) { if (const auto item = Auth().data().message(dependent)) {
item->updateDependencyItem(); item->updateDependencyItem();
} }
}; };

View File

@ -42,11 +42,14 @@ ClickHandlerPtr sendMessageClickHandler(PeerData *peer) {
} }
ClickHandlerPtr addContactClickHandler(not_null<HistoryItem*> item) { ClickHandlerPtr addContactClickHandler(not_null<HistoryItem*> item) {
return std::make_shared<LambdaClickHandler>([fullId = item->fullId()] { const auto session = &item->history()->session();
if (const auto item = Auth().data().message(fullId)) { const auto fullId = item->fullId();
return std::make_shared<LambdaClickHandler>([=] {
if (const auto item = session->data().message(fullId)) {
if (const auto media = item->media()) { if (const auto media = item->media()) {
if (const auto contact = media->sharedContact()) { if (const auto contact = media->sharedContact()) {
Ui::show(Box<AddContactBox>( Ui::show(Box<AddContactBox>(
session,
contact->firstName, contact->firstName,
contact->lastName, contact->lastName,
contact->phoneNumber)); contact->phoneNumber));

View File

@ -64,7 +64,7 @@ void SavePhotoToFile(not_null<PhotoData*> photo) {
tr::lng_save_photo(tr::now), tr::lng_save_photo(tr::now),
qsl("JPEG Image (*.jpg);;") + FileDialog::AllFilesFilter(), qsl("JPEG Image (*.jpg);;") + FileDialog::AllFilesFilter(),
filedialogDefaultName(qsl("photo"), qsl(".jpg")), filedialogDefaultName(qsl("photo"), qsl(".jpg")),
crl::guard(&Auth(), [=](const QString &result) { crl::guard(&photo->session(), [=](const QString &result) {
if (!result.isEmpty()) { if (!result.isEmpty()) {
photo->large()->original().save(result, "JPG"); photo->large()->original().save(result, "JPG");
} }
@ -86,7 +86,7 @@ void ShowStickerPackInfo(not_null<DocumentData*> document) {
void ToggleFavedSticker( void ToggleFavedSticker(
not_null<DocumentData*> document, not_null<DocumentData*> document,
FullMsgId contextId) { FullMsgId contextId) {
Auth().api().toggleFavedSticker( document->session().api().toggleFavedSticker(
document, document,
contextId, contextId,
!Stickers::IsFaved(document)); !Stickers::IsFaved(document));
@ -99,7 +99,7 @@ void AddPhotoActions(
tr::lng_context_save_image(tr::now), tr::lng_context_save_image(tr::now),
App::LambdaDelayed( App::LambdaDelayed(
st::defaultDropdownMenu.menu.ripple.hideDuration, st::defaultDropdownMenu.menu.ripple.hideDuration,
&Auth(), &photo->session(),
[=] { SavePhotoToFile(photo); })); [=] { SavePhotoToFile(photo); }));
menu->addAction(tr::lng_context_copy_image(tr::now), [=] { menu->addAction(tr::lng_context_copy_image(tr::now), [=] {
CopyImage(photo); CopyImage(photo);
@ -147,7 +147,7 @@ void AddSaveDocumentAction(
: tr::lng_context_save_file(tr::now))))), : tr::lng_context_save_file(tr::now))))),
App::LambdaDelayed( App::LambdaDelayed(
st::defaultDropdownMenu.menu.ripple.hideDuration, st::defaultDropdownMenu.menu.ripple.hideDuration,
&Auth(), &document->session(),
save)); save));
} }
@ -255,9 +255,10 @@ bool AddForwardMessageAction(
} else if (!item || !item->allowsForward()) { } else if (!item || !item->allowsForward()) {
return false; return false;
} }
const auto owner = &item->history()->owner();
const auto asGroup = (request.pointState != PointState::GroupPart); const auto asGroup = (request.pointState != PointState::GroupPart);
if (asGroup) { if (asGroup) {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = owner->groups().find(item)) {
if (ranges::find_if(group->items, [](auto item) { if (ranges::find_if(group->items, [](auto item) {
return !item->allowsForward(); return !item->allowsForward();
}) != end(group->items)) { }) != end(group->items)) {
@ -267,9 +268,9 @@ bool AddForwardMessageAction(
} }
const auto itemId = item->fullId(); const auto itemId = item->fullId();
menu->addAction(tr::lng_context_forward_msg(tr::now), [=] { menu->addAction(tr::lng_context_forward_msg(tr::now), [=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = owner->message(itemId)) {
Window::ShowForwardMessagesBox(asGroup Window::ShowForwardMessagesBox(asGroup
? Auth().data().itemOrItsGroup(item) ? owner->itemOrItsGroup(item)
: MessageIdsList{ 1, itemId }); : MessageIdsList{ 1, itemId });
} }
}); });
@ -320,9 +321,10 @@ bool AddDeleteMessageAction(
} else if (!item || !item->canDelete()) { } else if (!item || !item->canDelete()) {
return false; return false;
} }
const auto owner = &item->history()->owner();
const auto asGroup = (request.pointState != PointState::GroupPart); const auto asGroup = (request.pointState != PointState::GroupPart);
if (asGroup) { if (asGroup) {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = owner->groups().find(item)) {
if (ranges::find_if(group->items, [](auto item) { if (ranges::find_if(group->items, [](auto item) {
return !IsServerMsgId(item->id) || !item->canDelete(); return !IsServerMsgId(item->id) || !item->canDelete();
}) != end(group->items)) { }) != end(group->items)) {
@ -332,11 +334,11 @@ bool AddDeleteMessageAction(
} }
const auto itemId = item->fullId(); const auto itemId = item->fullId();
menu->addAction(tr::lng_context_delete_msg(tr::now), [=] { menu->addAction(tr::lng_context_delete_msg(tr::now), [=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = owner->message(itemId)) {
if (asGroup) { if (asGroup) {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = owner->groups().find(item)) {
Ui::show(Box<DeleteMessagesBox>( Ui::show(Box<DeleteMessagesBox>(
Auth().data().itemsToIds(group->items))); owner->itemsToIds(group->items)));
return; return;
} }
} }
@ -385,10 +387,11 @@ bool AddSelectMessageAction(
} else if (!item || !IsServerMsgId(item->id) || item->serviceMsg()) { } else if (!item || !IsServerMsgId(item->id) || item->serviceMsg()) {
return false; return false;
} }
const auto owner = &item->history()->owner();
const auto itemId = item->fullId(); const auto itemId = item->fullId();
const auto asGroup = (request.pointState != PointState::GroupPart); const auto asGroup = (request.pointState != PointState::GroupPart);
menu->addAction(tr::lng_context_select_msg(tr::now), [=] { menu->addAction(tr::lng_context_select_msg(tr::now), [=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = owner->message(itemId)) {
if (asGroup) { if (asGroup) {
list->selectItemAsGroup(item); list->selectItemAsGroup(item);
} else { } else {
@ -485,6 +488,7 @@ base::unique_qptr<Ui::PopupMenu> FillContextMenu(
// AddToggleGroupingAction(result, linkPeer->peer()); // AddToggleGroupingAction(result, linkPeer->peer());
// } // }
} else if (!request.overSelection && view && !hasSelection) { } else if (!request.overSelection && view && !hasSelection) {
const auto owner = &view->data()->history()->owner();
const auto media = view->media(); const auto media = view->media();
const auto mediaHasTextForCopy = media && media->hasTextForCopy(); const auto mediaHasTextForCopy = media && media->hasTextForCopy();
if (const auto document = media ? media->getDocument() : nullptr) { if (const auto document = media ? media->getDocument() : nullptr) {
@ -493,9 +497,9 @@ base::unique_qptr<Ui::PopupMenu> FillContextMenu(
if (!link && (view->hasVisibleText() || mediaHasTextForCopy)) { if (!link && (view->hasVisibleText() || mediaHasTextForCopy)) {
const auto asGroup = (request.pointState != PointState::GroupPart); const auto asGroup = (request.pointState != PointState::GroupPart);
result->addAction(tr::lng_context_copy_text(tr::now), [=] { result->addAction(tr::lng_context_copy_text(tr::now), [=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = owner->message(itemId)) {
if (asGroup) { if (asGroup) {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = owner->groups().find(item)) {
SetClipboardText(HistoryGroupText(group)); SetClipboardText(HistoryGroupText(group));
return; return;
} }

View File

@ -245,25 +245,25 @@ ListWidget::ListWidget(
, _highlightTimer([this] { updateHighlightedMessage(); }) { , _highlightTimer([this] { updateHighlightedMessage(); }) {
setMouseTracking(true); setMouseTracking(true);
_scrollDateHideTimer.setCallback([this] { scrollDateHideByTimer(); }); _scrollDateHideTimer.setCallback([this] { scrollDateHideByTimer(); });
Auth().data().viewRepaintRequest( session().data().viewRepaintRequest(
) | rpl::start_with_next([this](auto view) { ) | rpl::start_with_next([this](auto view) {
if (view->delegate() == this) { if (view->delegate() == this) {
repaintItem(view); repaintItem(view);
} }
}, lifetime()); }, lifetime());
Auth().data().viewResizeRequest( session().data().viewResizeRequest(
) | rpl::start_with_next([this](auto view) { ) | rpl::start_with_next([this](auto view) {
if (view->delegate() == this) { if (view->delegate() == this) {
resizeItem(view); resizeItem(view);
} }
}, lifetime()); }, lifetime());
Auth().data().itemViewRefreshRequest( session().data().itemViewRefreshRequest(
) | rpl::start_with_next([this](auto item) { ) | rpl::start_with_next([this](auto item) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
refreshItem(view); refreshItem(view);
} }
}, lifetime()); }, lifetime());
Auth().data().viewLayoutChanged( session().data().viewLayoutChanged(
) | rpl::start_with_next([this](auto view) { ) | rpl::start_with_next([this](auto view) {
if (view->delegate() == this) { if (view->delegate() == this) {
if (view->isUnderCursor()) { if (view->isUnderCursor()) {
@ -271,7 +271,7 @@ ListWidget::ListWidget(
} }
} }
}, lifetime()); }, lifetime());
Auth().data().animationPlayInlineRequest( session().data().animationPlayInlineRequest(
) | rpl::start_with_next([this](auto item) { ) | rpl::start_with_next([this](auto item) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
if (const auto media = view->media()) { if (const auto media = view->media()) {
@ -279,11 +279,11 @@ ListWidget::ListWidget(
} }
} }
}, lifetime()); }, lifetime());
Auth().data().itemRemoved( session().data().itemRemoved(
) | rpl::start_with_next( ) | rpl::start_with_next(
[this](auto item) { itemRemoved(item); }, [this](auto item) { itemRemoved(item); },
lifetime()); lifetime());
subscribe(Auth().data().queryItemVisibility(), [this](const Data::Session::ItemVisibilityQuery &query) { subscribe(session().data().queryItemVisibility(), [this](const Data::Session::ItemVisibilityQuery &query) {
if (const auto view = viewForItem(query.item)) { if (const auto view = viewForItem(query.item)) {
const auto top = itemTop(view); const auto top = itemTop(view);
if (top >= 0 if (top >= 0
@ -295,6 +295,10 @@ ListWidget::ListWidget(
}); });
} }
AuthSession &ListWidget::session() const {
return _controller->session();
}
not_null<ListDelegate*> ListWidget::delegate() const { not_null<ListDelegate*> ListWidget::delegate() const {
return _delegate; return _delegate;
} }
@ -317,7 +321,7 @@ void ListWidget::refreshRows() {
_items.clear(); _items.clear();
_items.reserve(_slice.ids.size()); _items.reserve(_slice.ids.size());
for (const auto &fullId : _slice.ids) { for (const auto &fullId : _slice.ids) {
if (const auto item = Auth().data().message(fullId)) { if (const auto item = session().data().message(fullId)) {
_items.push_back(enforceViewForItem(item)); _items.push_back(enforceViewForItem(item));
} }
} }
@ -350,7 +354,7 @@ std::optional<int> ListWidget::scrollTopForPosition(
std::optional<int> ListWidget::scrollTopForView( std::optional<int> ListWidget::scrollTopForView(
not_null<Element*> view) const { not_null<Element*> view) const {
if (view->isHiddenByGroup()) { if (view->isHiddenByGroup()) {
if (const auto group = Auth().data().groups().find(view->data())) { if (const auto group = session().data().groups().find(view->data())) {
if (const auto leader = viewForItem(group->items.back())) { if (const auto leader = viewForItem(group->items.back())) {
if (!leader->isHiddenByGroup()) { if (!leader->isHiddenByGroup()) {
return scrollTopForView(leader); return scrollTopForView(leader);
@ -398,7 +402,7 @@ void ListWidget::animatedScrollTo(
void ListWidget::scrollToAnimationCallback( void ListWidget::scrollToAnimationCallback(
FullMsgId attachToId, FullMsgId attachToId,
int relativeTo) { int relativeTo) {
const auto attachTo = Auth().data().message(attachToId); const auto attachTo = session().data().message(attachToId);
const auto attachToView = viewForItem(attachTo); const auto attachToView = viewForItem(attachTo);
if (!attachToView) { if (!attachToView) {
_scrollToAnimation.stop(); _scrollToAnimation.stop();
@ -424,7 +428,7 @@ bool ListWidget::isBelowPosition(Data::MessagePosition position) const {
} }
void ListWidget::highlightMessage(FullMsgId itemId) { void ListWidget::highlightMessage(FullMsgId itemId) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
_highlightStart = crl::now(); _highlightStart = crl::now();
_highlightedMessageId = itemId; _highlightedMessageId = itemId;
@ -436,7 +440,7 @@ void ListWidget::highlightMessage(FullMsgId itemId) {
} }
void ListWidget::updateHighlightedMessage() { void ListWidget::updateHighlightedMessage() {
if (const auto item = Auth().data().message(_highlightedMessageId)) { if (const auto item = session().data().message(_highlightedMessageId)) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
repaintItem(view); repaintItem(view);
auto duration = st::activeFadeInDuration + st::activeFadeOutDuration; auto duration = st::activeFadeInDuration + st::activeFadeOutDuration;
@ -488,7 +492,7 @@ void ListWidget::restoreScrollState() {
} }
Element *ListWidget::viewForItem(FullMsgId itemId) const { Element *ListWidget::viewForItem(FullMsgId itemId) const {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
return viewForItem(item); return viewForItem(item);
} }
return nullptr; return nullptr;
@ -736,7 +740,7 @@ bool ListWidget::isSelectedGroup(
bool ListWidget::isSelectedAsGroup( bool ListWidget::isSelectedAsGroup(
const SelectedMap &applyTo, const SelectedMap &applyTo,
not_null<HistoryItem*> item) const { not_null<HistoryItem*> item) const {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = session().data().groups().find(item)) {
return isSelectedGroup(applyTo, group); return isSelectedGroup(applyTo, group);
} }
return applyTo.contains(item->fullId()); return applyTo.contains(item->fullId());
@ -803,7 +807,7 @@ void ListWidget::changeSelectionAsGroup(
SelectedMap &applyTo, SelectedMap &applyTo,
not_null<HistoryItem*> item, not_null<HistoryItem*> item,
SelectAction action) const { SelectAction action) const {
const auto group = Auth().data().groups().find(item); const auto group = session().data().groups().find(item);
if (!group) { if (!group) {
return changeSelection(applyTo, item, action); return changeSelection(applyTo, item, action);
} }
@ -1228,7 +1232,7 @@ TextSelection ListWidget::computeRenderSelection(
return TextSelection(); return TextSelection();
}; };
const auto item = view->data(); const auto item = view->data();
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = session().data().groups().find(item)) {
if (group->items.back() != item) { if (group->items.back() != item) {
return TextSelection(); return TextSelection();
} }
@ -1393,7 +1397,7 @@ void ListWidget::applyDragSelection(SelectedMap &applyTo) const {
if (applyTo.size() >= MaxSelectedItems) { if (applyTo.size() >= MaxSelectedItems) {
break; break;
} else if (!applyTo.contains(itemId)) { } else if (!applyTo.contains(itemId)) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
addToSelection(applyTo, item); addToSelection(applyTo, item);
} }
} }
@ -1451,8 +1455,8 @@ TextForMimeData ListWidget::getSelectedText() const {
}; };
for (const auto [itemId, data] : selected) { for (const auto [itemId, data] : selected) {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = session().data().message(itemId)) {
if (const auto group = Auth().data().groups().find(item)) { if (const auto group = session().data().groups().find(item)) {
if (groups.contains(group)) { if (groups.contains(group)) {
continue; continue;
} }
@ -1694,7 +1698,7 @@ void ListWidget::updateDragSelection() {
} else if (_items.empty() || !_overElement || !_selectEnabled) { } else if (_items.empty() || !_overElement || !_selectEnabled) {
return; return;
} }
const auto pressItem = Auth().data().message(_pressState.itemId); const auto pressItem = session().data().message(_pressState.itemId);
if (!pressItem) { if (!pressItem) {
return; return;
} }
@ -1792,7 +1796,7 @@ void ListWidget::updateDragSelection(
std::vector<not_null<Element*>>::const_iterator till) { std::vector<not_null<Element*>>::const_iterator till) {
Expects(from < till); Expects(from < till);
const auto &groups = Auth().data().groups(); const auto &groups = session().data().groups();
const auto changeItem = [&](not_null<HistoryItem*> item, bool add) { const auto changeItem = [&](not_null<HistoryItem*> item, bool add) {
const auto itemId = item->fullId(); const auto itemId = item->fullId();
if (add) { if (add) {
@ -2011,7 +2015,7 @@ void ListWidget::mouseActionFinish(
return; return;
} }
if (needItemSelectionToggle) { if (needItemSelectionToggle) {
if (const auto item = Auth().data().message(pressState.itemId)) { if (const auto item = session().data().message(pressState.itemId)) {
clearTextSelection(); clearTextSelection();
if (pressState.pointState == PointState::GroupPart) { if (pressState.pointState == PointState::GroupPart) {
changeSelection( changeSelection(
@ -2144,7 +2148,7 @@ void ListWidget::mouseActionUpdate() {
dragState = TextState( dragState = TextState(
nullptr, nullptr,
_scrollDateLink); _scrollDateLink);
_overItemExact = Auth().data().message(dragState.itemId); _overItemExact = session().data().message(dragState.itemId);
lnkhost = view; lnkhost = view;
} }
} }
@ -2154,7 +2158,7 @@ void ListWidget::mouseActionUpdate() {
}); });
if (!dragState.link) { if (!dragState.link) {
dragState = view->textState(itemPoint, request); dragState = view->textState(itemPoint, request);
_overItemExact = Auth().data().message(dragState.itemId); _overItemExact = session().data().message(dragState.itemId);
lnkhost = view; lnkhost = view;
if (!dragState.link if (!dragState.link
&& itemPoint.x() >= st::historyPhotoLeft && itemPoint.x() >= st::historyPhotoLeft
@ -2175,7 +2179,7 @@ void ListWidget::mouseActionUpdate() {
dragState = TextState(nullptr, from dragState = TextState(nullptr, from
? from->openLink() ? from->openLink()
: hiddenUserpicLink(message->fullId())); : hiddenUserpicLink(message->fullId()));
_overItemExact = Auth().data().message(dragState.itemId); _overItemExact = session().data().message(dragState.itemId);
lnkhost = view; lnkhost = view;
return false; return false;
} }
@ -2231,7 +2235,7 @@ void ListWidget::mouseActionUpdate() {
// Voice message seek support. // Voice message seek support.
if (_pressState.pointState != PointState::Outside if (_pressState.pointState != PointState::Outside
&& ClickHandler::getPressed()) { && ClickHandler::getPressed()) {
if (const auto item = Auth().data().message(_pressState.itemId)) { if (const auto item = session().data().message(_pressState.itemId)) {
if (const auto view = viewForItem(item)) { if (const auto view = viewForItem(item)) {
auto adjustedPoint = mapPointToItem(point, view); auto adjustedPoint = mapPointToItem(point, view);
view->updatePressed(adjustedPoint); view->updatePressed(adjustedPoint);
@ -2272,7 +2276,7 @@ std::unique_ptr<QMimeData> ListWidget::prepareDrag() {
return nullptr; return nullptr;
} }
const auto pressedItem = Auth().data().message(_pressState.itemId); const auto pressedItem = session().data().message(_pressState.itemId);
const auto pressedView = viewForItem(pressedItem); const auto pressedView = viewForItem(pressedItem);
const auto uponSelected = pressedView && isInsideSelection( const auto uponSelected = pressedView && isInsideSelection(
pressedView, pressedView,
@ -2311,7 +2315,7 @@ std::unique_ptr<QMimeData> ListWidget::prepareDrag() {
? getSelectedItems() ? getSelectedItems()
: MessageIdsList(); : MessageIdsList();
if (!items.empty()) { if (!items.empty()) {
Auth().data().setMimeForwardIds(std::move(items)); session().data().setMimeForwardIds(std::move(items));
mimeData->setData(qsl("application/x-td-forward"), "1"); mimeData->setData(qsl("application/x-td-forward"), "1");
} }
} }
@ -2322,7 +2326,7 @@ std::unique_ptr<QMimeData> ListWidget::prepareDrag() {
? _pressItemExact ? _pressItemExact
: pressedItem; : pressedItem;
if (_mouseCursorState == CursorState::Date) { if (_mouseCursorState == CursorState::Date) {
forwardIds = Auth().data().itemOrItsGroup(_overElement->data()); forwardIds = session().data().itemOrItsGroup(_overElement->data());
} else if (_pressState.pointState == PointState::GroupPart) { } else if (_pressState.pointState == PointState::GroupPart) {
forwardIds = MessageIdsList(1, exactItem->fullId()); forwardIds = MessageIdsList(1, exactItem->fullId());
} else if (const auto media = pressedView->media()) { } else if (const auto media = pressedView->media()) {
@ -2334,7 +2338,7 @@ std::unique_ptr<QMimeData> ListWidget::prepareDrag() {
if (forwardIds.empty()) { if (forwardIds.empty()) {
return nullptr; return nullptr;
} }
Auth().data().setMimeForwardIds(std::move(forwardIds)); session().data().setMimeForwardIds(std::move(forwardIds));
auto result = std::make_unique<QMimeData>(); auto result = std::make_unique<QMimeData>();
result->setData(qsl("application/x-td-forward"), "1"); result->setData(qsl("application/x-td-forward"), "1");
if (const auto media = pressedView->media()) { if (const auto media = pressedView->media()) {

View File

@ -15,6 +15,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
#include "data/data_messages.h" #include "data/data_messages.h"
#include "history/view/history_view_element.h" #include "history/view/history_view_element.h"
class AuthSession;
namespace Ui { namespace Ui {
class PopupMenu; class PopupMenu;
} // namespace Ui } // namespace Ui
@ -128,6 +130,8 @@ public:
not_null<Window::SessionController*> controller, not_null<Window::SessionController*> controller,
not_null<ListDelegate*> delegate); not_null<ListDelegate*> delegate);
AuthSession &session() const;
not_null<ListDelegate*> delegate() const; not_null<ListDelegate*> delegate() const;
// Set the correct scroll position after being resized. // Set the correct scroll position after being resized.

View File

@ -1457,12 +1457,13 @@ void Message::drawRightAction(
ClickHandlerPtr Message::rightActionLink() const { ClickHandlerPtr Message::rightActionLink() const {
if (!_rightActionLink) { if (!_rightActionLink) {
const auto owner = &data()->history()->owner();
const auto itemId = data()->fullId(); const auto itemId = data()->fullId();
const auto forwarded = data()->Get<HistoryMessageForwarded>(); const auto forwarded = data()->Get<HistoryMessageForwarded>();
const auto savedFromPeer = forwarded ? forwarded->savedFromPeer : nullptr; const auto savedFromPeer = forwarded ? forwarded->savedFromPeer : nullptr;
const auto savedFromMsgId = forwarded ? forwarded->savedFromMsgId : 0; const auto savedFromMsgId = forwarded ? forwarded->savedFromMsgId : 0;
_rightActionLink = std::make_shared<LambdaClickHandler>([=] { _rightActionLink = std::make_shared<LambdaClickHandler>([=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = owner->message(itemId)) {
if (savedFromPeer && savedFromMsgId) { if (savedFromPeer && savedFromMsgId) {
App::wnd()->sessionController()->showPeerHistory( App::wnd()->sessionController()->showPeerHistory(
savedFromPeer, savedFromPeer,
@ -1479,9 +1480,10 @@ ClickHandlerPtr Message::rightActionLink() const {
ClickHandlerPtr Message::fastReplyLink() const { ClickHandlerPtr Message::fastReplyLink() const {
if (!_fastReplyLink) { if (!_fastReplyLink) {
const auto owner = &data()->history()->owner();
const auto itemId = data()->fullId(); const auto itemId = data()->fullId();
_fastReplyLink = std::make_shared<LambdaClickHandler>([=] { _fastReplyLink = std::make_shared<LambdaClickHandler>([=] {
if (const auto item = Auth().data().message(itemId)) { if (const auto item = owner->message(itemId)) {
if (const auto main = App::main()) { if (const auto main = App::main()) {
main->replyToItem(item); main->replyToItem(item);
} }

View File

@ -59,7 +59,7 @@ TopBarWidget::TopBarWidget(
, _infoToggle(this, st::topBarInfo) , _infoToggle(this, st::topBarInfo)
, _menuToggle(this, st::topBarMenuToggle) , _menuToggle(this, st::topBarMenuToggle)
, _titlePeerText(st::windowMinWidth / 3) , _titlePeerText(st::windowMinWidth / 3)
, _onlineUpdater([this] { updateOnlineDisplay(); }) { , _onlineUpdater([=] { updateOnlineDisplay(); }) {
subscribe(Lang::Current().updated(), [this] { refreshLang(); }); subscribe(Lang::Current().updated(), [this] { refreshLang(); });
setAttribute(Qt::WA_OpaquePaintEvent); setAttribute(Qt::WA_OpaquePaintEvent);
@ -100,7 +100,7 @@ TopBarWidget::TopBarWidget(
refreshUnreadBadge(); refreshUnreadBadge();
{ {
using AnimationUpdate = Data::Session::SendActionAnimationUpdate; using AnimationUpdate = Data::Session::SendActionAnimationUpdate;
Auth().data().sendActionAnimationUpdated( session().data().sendActionAnimationUpdated(
) | rpl::filter([=](const AnimationUpdate &update) { ) | rpl::filter([=](const AnimationUpdate &update) {
return (update.history == _activeChat.history()); return (update.history == _activeChat.history());
}) | rpl::start_with_next([=] { }) | rpl::start_with_next([=] {
@ -127,8 +127,8 @@ TopBarWidget::TopBarWidget(
}); });
rpl::combine( rpl::combine(
Auth().settings().thirdSectionInfoEnabledValue(), session().settings().thirdSectionInfoEnabledValue(),
Auth().settings().tabbedReplacedWithInfoValue() session().settings().tabbedReplacedWithInfoValue()
) | rpl::start_with_next( ) | rpl::start_with_next(
[this] { updateInfoToggleActive(); }, [this] { updateInfoToggleActive(); },
lifetime()); lifetime());
@ -143,6 +143,12 @@ TopBarWidget::TopBarWidget(
updateControlsVisibility(); updateControlsVisibility();
} }
TopBarWidget::~TopBarWidget() = default;
AuthSession &TopBarWidget::session() const {
return _controller->session();
}
void TopBarWidget::updateConnectingState() { void TopBarWidget::updateConnectingState() {
const auto mtp = MTP::dcstate(); const auto mtp = MTP::dcstate();
if (mtp == MTP::ConnectedState) { if (mtp == MTP::ConnectedState) {
@ -236,13 +242,13 @@ void TopBarWidget::showMenu() {
void TopBarWidget::toggleInfoSection() { void TopBarWidget::toggleInfoSection() {
if (Adaptive::ThreeColumn() if (Adaptive::ThreeColumn()
&& (Auth().settings().thirdSectionInfoEnabled() && (session().settings().thirdSectionInfoEnabled()
|| Auth().settings().tabbedReplacedWithInfo())) { || session().settings().tabbedReplacedWithInfo())) {
_controller->closeThirdSection(); _controller->closeThirdSection();
} else if (_activeChat.peer()) { } else if (_activeChat.peer()) {
if (_controller->canShowThirdSection()) { if (_controller->canShowThirdSection()) {
Auth().settings().setThirdSectionInfoEnabled(true); session().settings().setThirdSectionInfoEnabled(true);
Auth().saveSettingsDelayed(); session().saveSettingsDelayed();
if (Adaptive::ThreeColumn()) { if (Adaptive::ThreeColumn()) {
_controller->showSection( _controller->showSection(
Info::Memento::Default(_activeChat.peer()), Info::Memento::Default(_activeChat.peer()),
@ -745,8 +751,8 @@ void TopBarWidget::refreshUnreadBadge() {
void TopBarWidget::updateUnreadBadge() { void TopBarWidget::updateUnreadBadge() {
if (!_unreadBadge) return; if (!_unreadBadge) return;
const auto muted = Auth().data().unreadBadgeMutedIgnoreOne(_activeChat); const auto muted = session().data().unreadBadgeMutedIgnoreOne(_activeChat);
const auto counter = Auth().data().unreadBadgeIgnoreOne(_activeChat); const auto counter = session().data().unreadBadgeIgnoreOne(_activeChat);
const auto text = [&] { const auto text = [&] {
if (!counter) { if (!counter) {
return QString(); return QString();
@ -760,8 +766,8 @@ void TopBarWidget::updateUnreadBadge() {
void TopBarWidget::updateInfoToggleActive() { void TopBarWidget::updateInfoToggleActive() {
auto infoThirdActive = Adaptive::ThreeColumn() auto infoThirdActive = Adaptive::ThreeColumn()
&& (Auth().settings().thirdSectionInfoEnabled() && (session().settings().thirdSectionInfoEnabled()
|| Auth().settings().tabbedReplacedWithInfo()); || session().settings().tabbedReplacedWithInfo());
auto iconOverride = infoThirdActive auto iconOverride = infoThirdActive
? &st::topBarInfoActive ? &st::topBarInfoActive
: nullptr; : nullptr;
@ -779,8 +785,8 @@ void TopBarWidget::updateOnlineDisplay() {
const auto now = base::unixtime::now(); const auto now = base::unixtime::now();
bool titlePeerTextOnline = false; bool titlePeerTextOnline = false;
if (const auto user = _activeChat.peer()->asUser()) { if (const auto user = _activeChat.peer()->asUser()) {
if (Auth().supportMode() if (session().supportMode()
&& !Auth().supportHelper().infoCurrent(user).text.empty()) { && !session().supportHelper().infoCurrent(user).text.empty()) {
text = QString::fromUtf8("\xe2\x9a\xa0\xef\xb8\x8f check info"); text = QString::fromUtf8("\xe2\x9a\xa0\xef\xb8\x8f check info");
titlePeerTextOnline = false; titlePeerTextOnline = false;
} else { } else {
@ -799,7 +805,7 @@ void TopBarWidget::updateOnlineDisplay() {
text = tr::lng_chat_status_members(tr::now, lt_count_decimal, chat->count); text = tr::lng_chat_status_members(tr::now, lt_count_decimal, chat->count);
} }
} else { } else {
const auto self = Auth().user(); const auto self = session().user();
auto online = 0; auto online = 0;
auto onlyMe = true; auto onlyMe = true;
for (const auto user : chat->participants) { for (const auto user : chat->participants) {
@ -821,9 +827,9 @@ void TopBarWidget::updateOnlineDisplay() {
} else if (const auto channel = _activeChat.peer()->asChannel()) { } else if (const auto channel = _activeChat.peer()->asChannel()) {
if (channel->isMegagroup() && channel->membersCount() > 0 && channel->membersCount() <= Global::ChatSizeMax()) { if (channel->isMegagroup() && channel->membersCount() > 0 && channel->membersCount() <= Global::ChatSizeMax()) {
if (channel->mgInfo->lastParticipants.empty() || channel->lastParticipantsCountOutdated()) { if (channel->mgInfo->lastParticipants.empty() || channel->lastParticipantsCountOutdated()) {
Auth().api().requestLastParticipants(channel); session().api().requestLastParticipants(channel);
} }
const auto self = Auth().user(); const auto self = session().user();
auto online = 0; auto online = 0;
auto onlyMe = true; auto onlyMe = true;
for (auto &participant : std::as_const(channel->mgInfo->lastParticipants)) { for (auto &participant : std::as_const(channel->mgInfo->lastParticipants)) {
@ -883,6 +889,4 @@ void TopBarWidget::updateOnlineDisplayIn(crl::time timeout) {
_onlineUpdater.callOnce(timeout); _onlineUpdater.callOnce(timeout);
} }
TopBarWidget::~TopBarWidget() = default;
} // namespace HistoryView } // namespace HistoryView

View File

@ -12,6 +12,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
#include "base/timer.h" #include "base/timer.h"
#include "dialogs/dialogs_key.h" #include "dialogs/dialogs_key.h"
class AuthSession;
namespace Ui { namespace Ui {
class AbstractButton; class AbstractButton;
class RoundButton; class RoundButton;
@ -29,10 +31,6 @@ namespace HistoryView {
class TopBarWidget : public Ui::RpWidget, private base::Subscriber { class TopBarWidget : public Ui::RpWidget, private base::Subscriber {
public: public:
TopBarWidget(
QWidget *parent,
not_null<Window::SessionController*> controller);
struct SelectedState { struct SelectedState {
bool textSelected = false; bool textSelected = false;
int count = 0; int count = 0;
@ -40,8 +38,13 @@ public:
int canForwardCount = 0; int canForwardCount = 0;
}; };
TopBarWidget(
QWidget *parent,
not_null<Window::SessionController*> controller);
~TopBarWidget(); ~TopBarWidget();
AuthSession &session() const;
void updateControlsVisibility(); void updateControlsVisibility();
void finishAnimating(); void finishAnimating();
void showSelected(SelectedState state); void showSelected(SelectedState state);

View File

@ -554,6 +554,10 @@ ListWidget::ListWidget(
start(); start();
} }
AuthSession &ListWidget::session() const {
return _controller->session();
}
void ListWidget::start() { void ListWidget::start() {
_controller->setSearchEnabledByContent(false); _controller->setSearchEnabledByContent(false);
ObservableViewer( ObservableViewer(
@ -564,17 +568,17 @@ void ListWidget::start() {
} }
}, lifetime()); }, lifetime());
ObservableViewer( ObservableViewer(
Auth().downloader().taskFinished() session().downloader().taskFinished()
) | rpl::start_with_next([this] { update(); }, lifetime()); ) | rpl::start_with_next([this] { update(); }, lifetime());
Auth().data().itemLayoutChanged( session().data().itemLayoutChanged(
) | rpl::start_with_next([this](auto item) { ) | rpl::start_with_next([this](auto item) {
itemLayoutChanged(item); itemLayoutChanged(item);
}, lifetime()); }, lifetime());
Auth().data().itemRemoved( session().data().itemRemoved(
) | rpl::start_with_next([this](auto item) { ) | rpl::start_with_next([this](auto item) {
itemRemoved(item); itemRemoved(item);
}, lifetime()); }, lifetime());
Auth().data().itemRepaintRequest( session().data().itemRepaintRequest(
) | rpl::start_with_next([this](auto item) { ) | rpl::start_with_next([this](auto item) {
repaintItem(item); repaintItem(item);
}, lifetime()); }, lifetime());
@ -839,7 +843,7 @@ BaseLayout *ListWidget::getExistingLayout(
std::unique_ptr<BaseLayout> ListWidget::createLayout( std::unique_ptr<BaseLayout> ListWidget::createLayout(
UniversalMsgId universalId, UniversalMsgId universalId,
Type type) { Type type) {
auto item = Auth().data().message(computeFullId(universalId)); auto item = session().data().message(computeFullId(universalId));
if (!item) { if (!item) {
return nullptr; return nullptr;
} }
@ -1180,7 +1184,7 @@ void ListWidget::showContextMenu(
mouseActionUpdate(e->globalPos()); mouseActionUpdate(e->globalPos());
} }
auto item = Auth().data().message(computeFullId(_overState.itemId)); auto item = session().data().message(computeFullId(_overState.itemId));
if (!item || !_overState.inside) { if (!item || !_overState.inside) {
return; return;
} }
@ -1225,11 +1229,12 @@ void ListWidget::showContextMenu(
auto link = ClickHandler::getActive(); auto link = ClickHandler::getActive();
const auto itemFullId = item->fullId(); const auto itemFullId = item->fullId();
const auto owner = &session().data();
_contextMenu = base::make_unique_q<Ui::PopupMenu>(this); _contextMenu = base::make_unique_q<Ui::PopupMenu>(this);
_contextMenu->addAction( _contextMenu->addAction(
tr::lng_context_to_msg(tr::now), tr::lng_context_to_msg(tr::now),
[itemFullId] { [=] {
if (auto item = Auth().data().message(itemFullId)) { if (const auto item = owner->message(itemFullId)) {
Ui::showPeerHistoryAtItem(item); Ui::showPeerHistoryAtItem(item);
} }
}); });
@ -1381,7 +1386,7 @@ void ListWidget::forwardSelected() {
} }
void ListWidget::forwardItem(UniversalMsgId universalId) { void ListWidget::forwardItem(UniversalMsgId universalId) {
if (const auto item = Auth().data().message(computeFullId(universalId))) { if (const auto item = session().data().message(computeFullId(universalId))) {
forwardItems({ 1, item->fullId() }); forwardItems({ 1, item->fullId() });
} }
} }
@ -1409,7 +1414,7 @@ void ListWidget::deleteSelected() {
} }
void ListWidget::deleteItem(UniversalMsgId universalId) { void ListWidget::deleteItem(UniversalMsgId universalId) {
if (const auto item = Auth().data().message(computeFullId(universalId))) { if (const auto item = session().data().message(computeFullId(universalId))) {
deleteItems({ 1, item->fullId() }); deleteItems({ 1, item->fullId() });
} }
} }
@ -1513,7 +1518,7 @@ bool ListWidget::changeItemSelection(
universalId, universalId,
selection); selection);
if (ok) { if (ok) {
auto item = Auth().data().message(computeFullId(universalId)); auto item = session().data().message(computeFullId(universalId));
if (!item) { if (!item) {
selected.erase(iterator); selected.erase(iterator);
return false; return false;
@ -1932,7 +1937,7 @@ void ListWidget::performDrag() {
// if (uponSelected && !Adaptive::OneColumn()) { // if (uponSelected && !Adaptive::OneColumn()) {
// auto selectedState = getSelectionState(); // auto selectedState = getSelectionState();
// if (selectedState.count > 0 && selectedState.count == selectedState.canForwardCount) { // if (selectedState.count > 0 && selectedState.count == selectedState.canForwardCount) {
// Auth().data().setMimeForwardIds(collectSelectedIds()); // session().data().setMimeForwardIds(collectSelectedIds());
// mimeData->setData(qsl("application/x-td-forward"), "1"); // mimeData->setData(qsl("application/x-td-forward"), "1");
// } // }
// } // }
@ -1944,14 +1949,14 @@ void ListWidget::performDrag() {
// if (auto pressedItem = _pressState.layout) { // if (auto pressedItem = _pressState.layout) {
// pressedMedia = pressedItem->getMedia(); // pressedMedia = pressedItem->getMedia();
// if (_mouseCursorState == CursorState::Date || (pressedMedia && pressedMedia->dragItem())) { // if (_mouseCursorState == CursorState::Date || (pressedMedia && pressedMedia->dragItem())) {
// Auth().data().setMimeForwardIds(Auth().data().itemOrItsGroup(pressedItem)); // session().data().setMimeForwardIds(session().data().itemOrItsGroup(pressedItem));
// forwardMimeType = qsl("application/x-td-forward"); // forwardMimeType = qsl("application/x-td-forward");
// } // }
// } // }
// if (auto pressedLnkItem = App::pressedLinkItem()) { // if (auto pressedLnkItem = App::pressedLinkItem()) {
// if ((pressedMedia = pressedLnkItem->getMedia())) { // if ((pressedMedia = pressedLnkItem->getMedia())) {
// if (forwardMimeType.isEmpty() && pressedMedia->dragItemByHandler(pressedHandler)) { // if (forwardMimeType.isEmpty() && pressedMedia->dragItemByHandler(pressedHandler)) {
// Auth().data().setMimeForwardIds({ 1, pressedLnkItem->fullId() }); // session().data().setMimeForwardIds({ 1, pressedLnkItem->fullId() });
// forwardMimeType = qsl("application/x-td-forward"); // forwardMimeType = qsl("application/x-td-forward");
// } // }
// } // }

View File

@ -12,6 +12,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
#include "data/data_shared_media.h" #include "data/data_shared_media.h"
class DeleteMessagesBox; class DeleteMessagesBox;
class AuthSession;
namespace HistoryView { namespace HistoryView {
struct TextState; struct TextState;
@ -49,6 +50,8 @@ public:
QWidget *parent, QWidget *parent,
not_null<AbstractController*> controller); not_null<AbstractController*> controller);
AuthSession &session() const;
void restart(); void restart();
rpl::producer<int> scrollToRequests() const; rpl::producer<int> scrollToRequests() const;

View File

@ -351,10 +351,10 @@ object_ptr<Ui::RpWidget> DetailsFiller::setupMuteToggle() {
result->toggleOn( result->toggleOn(
NotificationsEnabledValue(peer) NotificationsEnabledValue(peer)
)->addClickHandler([=] { )->addClickHandler([=] {
const auto muteForSeconds = Auth().data().notifyIsMuted(peer) const auto muteForSeconds = peer->owner().notifyIsMuted(peer)
? 0 ? 0
: Data::NotifySettings::kDefaultMutePeriod; : Data::NotifySettings::kDefaultMutePeriod;
Auth().data().updateNotifySettings(peer, muteForSeconds); peer->owner().updateNotifySettings(peer, muteForSeconds);
}); });
object_ptr<FloatingIcon>( object_ptr<FloatingIcon>(
result, result,
@ -653,7 +653,7 @@ void ActionsFiller::addJoinChannelAction(
_wrap, _wrap,
tr::lng_profile_join_channel(), tr::lng_profile_join_channel(),
rpl::duplicate(joinVisible), rpl::duplicate(joinVisible),
[channel] { Auth().api().joinChannel(channel); }); [=] { channel->session().api().joinChannel(channel); });
_wrap->add(object_ptr<Ui::SlideWrap<Ui::FixedHeightWidget>>( _wrap->add(object_ptr<Ui::SlideWrap<Ui::FixedHeightWidget>>(
_wrap, _wrap,
CreateSkipWidget( CreateSkipWidget(
@ -749,19 +749,20 @@ object_ptr<Ui::RpWidget> ActionsFiller::fill() {
// //
//object_ptr<Ui::RpWidget> FeedDetailsFiller::setupDefaultToggle() { //object_ptr<Ui::RpWidget> FeedDetailsFiller::setupDefaultToggle() {
// using namespace rpl::mappers; // using namespace rpl::mappers;
// const auto feedId = _feed->id(); // const auto feed = _feed;
// const auto feedId = feed->id();
// auto result = object_ptr<Button>( // auto result = object_ptr<Button>(
// _wrap, // _wrap,
// tr::lng_info_feed_is_default(), // tr::lng_info_feed_is_default(),
// st::infoNotificationsButton); // st::infoNotificationsButton);
// result->toggleOn( // result->toggleOn(
// Auth().data().defaultFeedIdValue( // feed->owner().defaultFeedIdValue(
// ) | rpl::map(_1 == feedId) // ) | rpl::map(_1 == feedId)
// )->addClickHandler([=] { // )->addClickHandler([=] {
// const auto makeDefault = (Auth().data().defaultFeedId() != feedId); // const auto makeDefault = (feed->owner().defaultFeedId() != feedId);
// const auto defaultFeedId = makeDefault ? feedId : 0; // const auto defaultFeedId = makeDefault ? feedId : 0;
// Auth().data().setDefaultFeedId(defaultFeedId); // feed->owner().setDefaultFeedId(defaultFeedId);
//// Auth().api().saveDefaultFeedId(feedId, makeDefault); // #feed //// feed->session().api().saveDefaultFeedId(feedId, makeDefault); // #feed
// }); // });
// object_ptr<FloatingIcon>( // object_ptr<FloatingIcon>(
// result, // result,

View File

@ -590,7 +590,9 @@ void MainWindow::onShowAddContact() {
if (isHidden()) showFromTray(); if (isHidden()) showFromTray();
if (account().sessionExists()) { if (account().sessionExists()) {
Ui::show(Box<AddContactBox>(), LayerOption::KeepOther); Ui::show(
Box<AddContactBox>(&account().session()),
LayerOption::KeepOther);
} }
} }
@ -599,7 +601,9 @@ void MainWindow::onShowNewGroup() {
if (account().sessionExists()) { if (account().sessionExists()) {
Ui::show( Ui::show(
Box<GroupInfoBox>(GroupInfoBox::Type::Group), Box<GroupInfoBox>(
&account().session(),
GroupInfoBox::Type::Group),
LayerOption::KeepOther); LayerOption::KeepOther);
} }
} }
@ -609,7 +613,9 @@ void MainWindow::onShowNewChannel() {
if (_main) { if (_main) {
Ui::show( Ui::show(
Box<GroupInfoBox>(GroupInfoBox::Type::Channel), Box<GroupInfoBox>(
&account().session(),
GroupInfoBox::Type::Channel),
LayerOption::KeepOther); LayerOption::KeepOther);
} }
} }

View File

@ -24,6 +24,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
#include "storage/localstorage.h" #include "storage/localstorage.h"
#include "auth_session.h" #include "auth_session.h"
#include "apiwrap.h" #include "apiwrap.h"
#include "window/window_session_controller.h"
#include "core/file_utilities.h" #include "core/file_utilities.h"
#include "styles/style_settings.h" #include "styles/style_settings.h"
@ -297,8 +298,8 @@ void Main::setupContent(not_null<Window::SessionController*> controller) {
Ui::ResizeFitChild(this, content); Ui::ResizeFitChild(this, content);
// If we load this in advance it won't jump when we open its' section. // If we load this in advance it won't jump when we open its' section.
Auth().api().reloadPasswordState(); controller->session().api().reloadPasswordState();
Auth().api().reloadContactSignupSilent(); controller->session().api().reloadContactSignupSilent();
} }
rpl::producer<Type> Main::sectionShowOther() { rpl::producer<Type> Main::sectionShowOther() {

View File

@ -584,7 +584,7 @@ void UserpicButton::changePhotoLazy() {
void UserpicButton::uploadNewPeerPhoto() { void UserpicButton::uploadNewPeerPhoto() {
auto callback = crl::guard(this, [=](QImage &&image) { auto callback = crl::guard(this, [=](QImage &&image) {
Auth().api().uploadPeerPhoto(_peer, std::move(image)); _peer->session().api().uploadPeerPhoto(_peer, std::move(image));
}); });
ShowChoosePhotoBox(this, _cropTitle, std::move(callback)); ShowChoosePhotoBox(this, _cropTitle, std::move(callback));
} }
@ -602,7 +602,7 @@ void UserpicButton::openPeerPhoto() {
if (!id) { if (!id) {
return; return;
} }
const auto photo = Auth().data().photo(id); const auto photo = _peer->owner().photo(id);
if (photo->date) { if (photo->date) {
Core::App().showPhoto(photo, _peer); Core::App().showPhoto(photo, _peer);
} }
@ -616,8 +616,9 @@ void UserpicButton::setupPeerViewers() {
processNewPeerPhoto(); processNewPeerPhoto();
update(); update();
}, lifetime()); }, lifetime());
base::ObservableViewer( base::ObservableViewer(
Auth().downloaderTaskFinished() _peer->session().downloaderTaskFinished()
) | rpl::start_with_next([this] { ) | rpl::start_with_next([this] {
if (_waiting && _peer->userpicLoaded()) { if (_waiting && _peer->userpicLoaded()) {
_waiting = false; _waiting = false;
@ -958,7 +959,7 @@ void UserpicButton::prepareUserpicPixmap() {
//void FeedUserpicButton::prepare() { //void FeedUserpicButton::prepare() {
// resize(_st.size); // resize(_st.size);
// //
// Auth().data().feedUpdated( // _feed->owner().feedUpdated(
// ) | rpl::filter([=](const Data::FeedUpdate &update) { // ) | rpl::filter([=](const Data::FeedUpdate &update) {
// return (update.feed == _feed) // return (update.feed == _feed)
// && (update.flag == Data::FeedUpdateFlag::Channels); // && (update.flag == Data::FeedUpdateFlag::Channels);
@ -1035,8 +1036,8 @@ void UserpicButton::prepareUserpicPixmap() {
SilentToggle::SilentToggle(QWidget *parent, not_null<ChannelData*> channel) SilentToggle::SilentToggle(QWidget *parent, not_null<ChannelData*> channel)
: IconButton(parent, st::historySilentToggle) : IconButton(parent, st::historySilentToggle)
, _channel(channel) , _channel(channel)
, _checked(Auth().data().notifySilentPosts(_channel)) { , _checked(channel->owner().notifySilentPosts(_channel)) {
Expects(!Auth().data().notifySilentPostsUnknown(_channel)); Expects(!channel->owner().notifySilentPostsUnknown(_channel));
if (_checked) { if (_checked) {
refreshIconOverrides(); refreshIconOverrides();
@ -1079,7 +1080,7 @@ void SilentToggle::mouseReleaseEvent(QMouseEvent *e) {
setChecked(!_checked); setChecked(!_checked);
IconButton::mouseReleaseEvent(e); IconButton::mouseReleaseEvent(e);
Ui::Tooltip::Show(0, this); Ui::Tooltip::Show(0, this);
Auth().data().updateNotifySettings( _channel->owner().updateNotifySettings(
_channel, _channel,
std::nullopt, std::nullopt,
_checked); _checked);

View File

@ -861,7 +861,9 @@ MediaPreviewWidget::MediaPreviewWidget(
, _controller(controller) , _controller(controller)
, _emojiSize(Ui::Emoji::GetSizeLarge() / cIntRetinaFactor()) { , _emojiSize(Ui::Emoji::GetSizeLarge() / cIntRetinaFactor()) {
setAttribute(Qt::WA_TransparentForMouseEvents); setAttribute(Qt::WA_TransparentForMouseEvents);
subscribe(Auth().downloaderTaskFinished(), [this] { update(); }); subscribe(_controller->session().downloaderTaskFinished(), [=] {
update();
});
} }
QRect MediaPreviewWidget::updateArea() const { QRect MediaPreviewWidget::updateArea() const {

View File

@ -61,7 +61,9 @@ void System::createManager() {
} }
} }
void System::schedule(History *history, HistoryItem *item) { void System::schedule(
not_null<History*> history,
not_null<HistoryItem*> item) {
if (App::quitting() if (App::quitting()
|| !history->currentNotification() || !history->currentNotification()
|| !AuthSession::Exists()) return; || !AuthSession::Exists()) return;
@ -75,16 +77,16 @@ void System::schedule(History *history, HistoryItem *item) {
return; return;
} }
Auth().data().requestNotifySettings(history->peer); history->owner().requestNotifySettings(history->peer);
if (notifyBy) { if (notifyBy) {
Auth().data().requestNotifySettings(notifyBy); history->owner().requestNotifySettings(notifyBy);
} }
auto haveSetting = !Auth().data().notifyMuteUnknown(history->peer); auto haveSetting = !history->owner().notifyMuteUnknown(history->peer);
if (haveSetting && Auth().data().notifyIsMuted(history->peer)) { if (haveSetting && history->owner().notifyIsMuted(history->peer)) {
if (notifyBy) { if (notifyBy) {
haveSetting = !Auth().data().notifyMuteUnknown(notifyBy); haveSetting = !history->owner().notifyMuteUnknown(notifyBy);
if (haveSetting) { if (haveSetting) {
if (Auth().data().notifyIsMuted(notifyBy)) { if (history->owner().notifyIsMuted(notifyBy)) {
history->popNotification(item); history->popNotification(item);
return; return;
} }
@ -174,12 +176,12 @@ void System::checkDelayed() {
const auto peer = history->peer; const auto peer = history->peer;
auto loaded = false; auto loaded = false;
auto muted = false; auto muted = false;
if (!Auth().data().notifyMuteUnknown(peer)) { if (!peer->owner().notifyMuteUnknown(peer)) {
if (!Auth().data().notifyIsMuted(peer)) { if (!peer->owner().notifyIsMuted(peer)) {
loaded = true; loaded = true;
} else if (const auto from = i.value().notifyBy) { } else if (const auto from = i.value().notifyBy) {
if (!Auth().data().notifyMuteUnknown(from)) { if (!peer->owner().notifyMuteUnknown(from)) {
if (!Auth().data().notifyIsMuted(from)) { if (!peer->owner().notifyIsMuted(from)) {
loaded = true; loaded = true;
} else { } else {
loaded = muted = true; loaded = muted = true;
@ -193,7 +195,7 @@ void System::checkDelayed() {
const auto fullId = FullMsgId( const auto fullId = FullMsgId(
history->channelId(), history->channelId(),
i.value().msg); i.value().msg);
if (const auto item = Auth().data().message(fullId)) { if (const auto item = peer->owner().message(fullId)) {
if (!item->notificationReady()) { if (!item->notificationReady()) {
loaded = false; loaded = false;
} }
@ -215,7 +217,7 @@ void System::checkDelayed() {
} }
void System::showGrouped() { void System::showGrouped() {
if (const auto lastItem = Auth().data().message(_lastHistoryItemId)) { if (const auto lastItem = session().data().message(_lastHistoryItemId)) {
_waitForAllGroupedTimer.cancel(); _waitForAllGroupedTimer.cancel();
_manager->showNotification(lastItem, _lastForwardedCount); _manager->showNotification(lastItem, _lastForwardedCount);
_lastForwardedCount = 0; _lastForwardedCount = 0;
@ -230,7 +232,9 @@ void System::showNext() {
if (!_lastHistoryItemId || !item) { if (!_lastHistoryItemId || !item) {
return false; return false;
} }
if (const auto lastItem = Auth().data().message(_lastHistoryItemId)) { const auto lastItem = item->history()->owner().message(
_lastHistoryItemId);
if (lastItem) {
return (lastItem->groupId() == item->groupId() || lastItem->author() == item->author()); return (lastItem->groupId() == item->groupId() || lastItem->author() == item->author());
} }
return false; return false;
@ -242,14 +246,14 @@ void System::showNext() {
for (auto i = _whenAlerts.begin(); i != _whenAlerts.end();) { for (auto i = _whenAlerts.begin(); i != _whenAlerts.end();) {
while (!i.value().isEmpty() && i.value().begin().key() <= ms) { while (!i.value().isEmpty() && i.value().begin().key() <= ms) {
const auto peer = i.key()->peer; const auto peer = i.key()->peer;
const auto peerUnknown = Auth().data().notifyMuteUnknown(peer); const auto peerUnknown = peer->owner().notifyMuteUnknown(peer);
const auto peerAlert = !peerUnknown const auto peerAlert = !peerUnknown
&& !Auth().data().notifyIsMuted(peer); && !peer->owner().notifyIsMuted(peer);
const auto from = i.value().begin().value(); const auto from = i.value().begin().value();
const auto fromUnknown = (!from const auto fromUnknown = (!from
|| Auth().data().notifyMuteUnknown(from)); || peer->owner().notifyMuteUnknown(from));
const auto fromAlert = !fromUnknown const auto fromAlert = !fromUnknown
&& !Auth().data().notifyIsMuted(from); && !peer->owner().notifyIsMuted(from);
if (peerAlert || fromAlert) { if (peerAlert || fromAlert) {
alert = true; alert = true;
} }
@ -432,7 +436,7 @@ void System::ensureSoundCreated() {
_soundTrack = Media::Audio::Current().createTrack(); _soundTrack = Media::Audio::Current().createTrack();
_soundTrack->fillFromFile( _soundTrack->fillFromFile(
Auth().settings().getSoundPath(qsl("msg_incoming"))); session().settings().getSoundPath(qsl("msg_incoming")));
} }
void System::updateAll() { void System::updateAll() {
@ -458,7 +462,7 @@ Manager::DisplayOptions Manager::getNotificationOptions(HistoryItem *item) {
void Manager::notificationActivated(PeerId peerId, MsgId msgId) { void Manager::notificationActivated(PeerId peerId, MsgId msgId) {
onBeforeNotificationActivated(peerId, msgId); onBeforeNotificationActivated(peerId, msgId);
if (auto window = App::wnd()) { if (auto window = App::wnd()) {
auto history = Auth().data().history(peerId); auto history = system()->session().data().history(peerId);
window->showFromTray(); window->showFromTray();
window->reActivateWindow(); window->reActivateWindow();
if (Core::App().locked()) { if (Core::App().locked()) {
@ -480,7 +484,7 @@ void Manager::openNotificationMessage(
|| !IsServerMsgId(messageId)) { || !IsServerMsgId(messageId)) {
return false; return false;
} }
const auto item = Auth().data().message(history->channelId(), messageId); const auto item = history->owner().message(history->channelId(), messageId);
if (!item || !item->mentionsMe()) { if (!item || !item->mentionsMe()) {
return false; return false;
} }
@ -509,7 +513,7 @@ void Manager::notificationReplied(
const TextWithTags &reply) { const TextWithTags &reply) {
if (!peerId) return; if (!peerId) return;
const auto history = Auth().data().history(peerId); const auto history = system()->session().data().history(peerId);
auto message = ApiWrap::MessageToSend(history); auto message = ApiWrap::MessageToSend(history);
message.textWithTags = reply; message.textWithTags = reply;

View File

@ -60,7 +60,7 @@ public:
void createManager(); void createManager();
void checkDelayed(); void checkDelayed();
void schedule(History *history, HistoryItem *item); void schedule(not_null<History*> history, not_null<HistoryItem*> item);
void clearFromHistory(History *history); void clearFromHistory(History *history);
void clearFromItem(HistoryItem *item); void clearFromItem(HistoryItem *item);
void clearAll(); void clearAll();
@ -117,7 +117,7 @@ private:
class Manager { class Manager {
public: public:
Manager(System *system) : _system(system) { explicit Manager(not_null<System*> system) : _system(system) {
} }
void showNotification(HistoryItem *item, int forwardedCount) { void showNotification(HistoryItem *item, int forwardedCount) {
@ -155,7 +155,7 @@ public:
virtual ~Manager() = default; virtual ~Manager() = default;
protected: protected:
System *system() const { not_null<System*> system() const {
return _system; return _system;
} }
@ -175,7 +175,7 @@ private:
not_null<History*> history, not_null<History*> history,
MsgId messageId); MsgId messageId);
System *_system = nullptr; const not_null<System*> _system;
}; };

View File

@ -128,17 +128,22 @@ MainMenu::MainMenu(
, _version(this, st::mainMenuVersionLabel) { , _version(this, st::mainMenuVersionLabel) {
setAttribute(Qt::WA_OpaquePaintEvent); setAttribute(Qt::WA_OpaquePaintEvent);
const auto showSelfChat = [] { const auto showSelfChat = [=] {
App::main()->choosePeer(Auth().userPeerId(), ShowAtUnreadMsgId); App::main()->choosePeer(
_controller->session().userPeerId(),
ShowAtUnreadMsgId);
}; };
const auto showArchive = [=] { const auto showArchive = [=] {
if (const auto folder = Auth().data().folderLoaded(Data::Folder::kId)) { const auto folder = _controller->session().data().folderLoaded(
Data::Folder::kId);
if (folder) {
App::wnd()->sessionController()->openFolder(folder); App::wnd()->sessionController()->openFolder(folder);
Ui::hideSettingsAndLayer(); Ui::hideSettingsAndLayer();
} }
}; };
const auto checkArchive = [=] { const auto checkArchive = [=] {
const auto folder = Auth().data().folderLoaded(Data::Folder::kId); const auto folder = _controller->session().data().folderLoaded(
Data::Folder::kId);
return folder return folder
&& !folder->chatsList()->empty() && !folder->chatsList()->empty()
&& _controller->session().settings().archiveInMainMenu(); && _controller->session().settings().archiveInMainMenu();
@ -146,7 +151,7 @@ MainMenu::MainMenu(
_userpicButton.create( _userpicButton.create(
this, this,
_controller, _controller,
Auth().user(), _controller->session().user(),
Ui::UserpicButton::Role::Custom, Ui::UserpicButton::Role::Custom,
st::mainMenuUserpic); st::mainMenuUserpic);
_userpicButton->setClickedCallback(showSelfChat); _userpicButton->setClickedCallback(showSelfChat);
@ -201,8 +206,7 @@ MainMenu::MainMenu(
_version->setLink(1, std::make_shared<UrlClickHandler>(qsl("https://desktop.telegram.org/changelog"))); _version->setLink(1, std::make_shared<UrlClickHandler>(qsl("https://desktop.telegram.org/changelog")));
_version->setLink(2, std::make_shared<LambdaClickHandler>([] { Ui::show(Box<AboutBox>()); })); _version->setLink(2, std::make_shared<LambdaClickHandler>([] { Ui::show(Box<AboutBox>()); }));
subscribe(Auth().downloaderTaskFinished(), [this] { update(); }); subscribe(_controller->session().downloaderTaskFinished(), [=] { update(); });
subscribe(Auth().downloaderTaskFinished(), [this] { update(); });
subscribe(Notify::PeerUpdated(), Notify::PeerUpdatedHandler(Notify::PeerUpdate::Flag::UserPhoneChanged, [this](const Notify::PeerUpdate &update) { subscribe(Notify::PeerUpdated(), Notify::PeerUpdatedHandler(Notify::PeerUpdate::Flag::UserPhoneChanged, [this](const Notify::PeerUpdate &update) {
if (update.peer->isSelf()) { if (update.peer->isSelf()) {
updatePhone(); updatePhone();
@ -217,7 +221,7 @@ MainMenu::MainMenu(
refreshBackground(); refreshBackground();
} }
}); });
Auth().data().chatsListChanges( _controller->session().data().chatsListChanges(
) | rpl::filter([](Data::Folder *folder) { ) | rpl::filter([](Data::Folder *folder) {
return folder && (folder->id() == Data::Folder::kId); return folder && (folder->id() == Data::Folder::kId);
}) | rpl::start_with_next([=](Data::Folder *folder) { }) | rpl::start_with_next([=](Data::Folder *folder) {
@ -230,7 +234,7 @@ MainMenu::MainMenu(
void MainMenu::refreshMenu() { void MainMenu::refreshMenu() {
_menu->clearActions(); _menu->clearActions();
if (!Auth().supportMode()) { if (!_controller->session().supportMode()) {
_menu->addAction(tr::lng_create_group_title(tr::now), [] { _menu->addAction(tr::lng_create_group_title(tr::now), [] {
App::wnd()->onShowNewGroup(); App::wnd()->onShowNewGroup();
}, &st::mainMenuNewGroup, &st::mainMenuNewGroupOver); }, &st::mainMenuNewGroup, &st::mainMenuNewGroupOver);
@ -265,14 +269,16 @@ void MainMenu::refreshMenu() {
const auto fix = std::make_shared<QPointer<QAction>>(); const auto fix = std::make_shared<QPointer<QAction>>();
*fix = _menu->addAction(qsl("Fix chats order"), [=] { *fix = _menu->addAction(qsl("Fix chats order"), [=] {
(*fix)->setChecked(!(*fix)->isChecked()); (*fix)->setChecked(!(*fix)->isChecked());
Auth().settings().setSupportFixChatsOrder((*fix)->isChecked()); _controller->session().settings().setSupportFixChatsOrder(
(*fix)->isChecked());
Local::writeUserSettings(); Local::writeUserSettings();
}, &st::mainMenuFixOrder, &st::mainMenuFixOrderOver); }, &st::mainMenuFixOrder, &st::mainMenuFixOrderOver);
(*fix)->setCheckable(true); (*fix)->setCheckable(true);
(*fix)->setChecked(Auth().settings().supportFixChatsOrder()); (*fix)->setChecked(
_controller->session().settings().supportFixChatsOrder());
_menu->addAction(qsl("Reload templates"), [=] { _menu->addAction(qsl("Reload templates"), [=] {
Auth().supportTemplates().reload(); _controller->session().supportTemplates().reload();
}, &st::mainMenuReload, &st::mainMenuReloadOver); }, &st::mainMenuReload, &st::mainMenuReloadOver);
} }
_menu->addAction(tr::lng_menu_settings(tr::now), [] { _menu->addAction(tr::lng_menu_settings(tr::now), [] {
@ -335,7 +341,8 @@ void MainMenu::refreshBackground() {
st::mainMenuCoverTextLeft, st::mainMenuCoverTextLeft,
st::mainMenuCoverNameTop, st::mainMenuCoverNameTop,
std::max( std::max(
st::semiboldFont->width(Auth().user()->nameText().toString()), st::semiboldFont->width(
_controller->session().user()->nameText().toString()),
st::normalFont->width(_phoneText)), st::normalFont->width(_phoneText)),
st::semiboldFont->height * 2); st::semiboldFont->height * 2);
@ -376,7 +383,7 @@ void MainMenu::updateControlsGeometry() {
} }
void MainMenu::updatePhone() { void MainMenu::updatePhone() {
_phoneText = App::formatPhone(Auth().user()->phone()); _phoneText = App::formatPhone(_controller->session().user()->phone());
update(); update();
} }
@ -408,7 +415,7 @@ void MainMenu::paintEvent(QPaintEvent *e) {
} }
p.setPen(st::mainMenuCoverFg); p.setPen(st::mainMenuCoverFg);
p.setFont(st::semiboldFont); p.setFont(st::semiboldFont);
Auth().user()->nameText().drawLeftElided( _controller->session().user()->nameText().drawLeftElided(
p, p,
st::mainMenuCoverTextLeft, st::mainMenuCoverTextLeft,
st::mainMenuCoverNameTop, st::mainMenuCoverNameTop,
@ -429,7 +436,9 @@ void MainMenu::paintEvent(QPaintEvent *e) {
// Draw Archive button. // Draw Archive button.
if (!_archiveButton->isHidden()) { if (!_archiveButton->isHidden()) {
if (const auto folder = Auth().data().folderLoaded(Data::Folder::kId)) { const auto folder = _controller->session().data().folderLoaded(
Data::Folder::kId);
if (folder) {
folder->paintUserpic( folder->paintUserpic(
p, p,
_archiveButton->x() + (_archiveButton->width() - st::mainMenuCloudSize) / 2, _archiveButton->x() + (_archiveButton->width() - st::mainMenuCloudSize) / 2,

View File

@ -105,8 +105,8 @@ private:
}; };
History *FindWastedPin(Data::Folder *folder) { History *FindWastedPin(not_null<Data::Session*> data, Data::Folder *folder) {
const auto &order = Auth().data().pinnedChatsOrder(folder); const auto &order = data->pinnedChatsOrder(folder);
for (const auto &pinned : order) { for (const auto &pinned : order) {
if (const auto history = pinned.history()) { if (const auto history = pinned.history()) {
if (history->peer->isChat() if (history->peer->isChat()
@ -126,17 +126,19 @@ void AddChatMembers(not_null<ChatData*> chat) {
bool PinnedLimitReached(Dialogs::Key key) { bool PinnedLimitReached(Dialogs::Key key) {
Expects(key.entry()->folderKnown()); Expects(key.entry()->folderKnown());
const auto folder = key.entry()->folder(); const auto entry = key.entry();
const auto pinnedCount = Auth().data().pinnedChatsCount(folder); const auto owner = &entry->owner();
const auto pinnedMax = Auth().data().pinnedChatsLimit(folder); const auto folder = entry->folder();
const auto pinnedCount = owner->pinnedChatsCount(folder);
const auto pinnedMax = owner->pinnedChatsLimit(folder);
if (pinnedCount < pinnedMax) { if (pinnedCount < pinnedMax) {
return false; return false;
} }
// Some old chat, that was converted, maybe is still pinned. // Some old chat, that was converted, maybe is still pinned.
if (const auto wasted = FindWastedPin(folder)) { if (const auto wasted = FindWastedPin(owner, folder)) {
Auth().data().setChatPinned(wasted, false); owner->setChatPinned(wasted, false);
Auth().data().setChatPinned(key, true); owner->setChatPinned(key, true);
Auth().api().savePinnedOrder(folder); entry->session().api().savePinnedOrder(folder);
} else { } else {
auto errorText = tr::lng_error_pinned_max( auto errorText = tr::lng_error_pinned_max(
tr::now, tr::now,
@ -151,12 +153,13 @@ void TogglePinnedDialog(Dialogs::Key key) {
if (!key.entry()->folderKnown()) { if (!key.entry()->folderKnown()) {
return; return;
} }
const auto owner = &key.entry()->owner();
const auto isPinned = !key.entry()->isPinnedDialog(); const auto isPinned = !key.entry()->isPinnedDialog();
if (isPinned && PinnedLimitReached(key)) { if (isPinned && PinnedLimitReached(key)) {
return; return;
} }
Auth().data().setChatPinned(key, isPinned); owner->setChatPinned(key, isPinned);
const auto flags = isPinned const auto flags = isPinned
? MTPmessages_ToggleDialogPin::Flag::f_pinned ? MTPmessages_ToggleDialogPin::Flag::f_pinned
: MTPmessages_ToggleDialogPin::Flag(0); : MTPmessages_ToggleDialogPin::Flag(0);
@ -165,7 +168,7 @@ void TogglePinnedDialog(Dialogs::Key key) {
MTP_flags(flags), MTP_flags(flags),
MTP_inputDialogPeer(key.history()->peer->input) MTP_inputDialogPeer(key.history()->peer->input)
)).done([=](const MTPBool &result) { )).done([=](const MTPBool &result) {
Auth().data().notifyPinnedDialogsOrderUpdated(); owner->notifyPinnedDialogsOrderUpdated();
}).send(); }).send();
} else if (const auto folder = key.folder()) { } else if (const auto folder = key.folder()) {
folder->session().api().request(MTPmessages_ToggleDialogPin( folder->session().api().request(MTPmessages_ToggleDialogPin(
@ -199,8 +202,8 @@ bool Filler::showInfo() {
} else if (!Adaptive::ThreeColumn()) { } else if (!Adaptive::ThreeColumn()) {
return true; return true;
} else if ( } else if (
!Auth().settings().thirdSectionInfoEnabled() && !_peer->session().settings().thirdSectionInfoEnabled() &&
!Auth().settings().tabbedReplacedWithInfo()) { !_peer->session().settings().tabbedReplacedWithInfo()) {
return true; return true;
} }
return false; return false;
@ -290,9 +293,11 @@ void Filler::addToggleUnreadMark() {
const auto markAsRead = isUnread(peer); const auto markAsRead = isUnread(peer);
const auto handle = [&](not_null<History*> history) { const auto handle = [&](not_null<History*> history) {
if (markAsRead) { if (markAsRead) {
Auth().api().readServerHistory(history); peer->session().api().readServerHistory(history);
} else { } else {
Auth().api().changeDialogUnreadMark(history, !markAsRead); peer->session().api().changeDialogUnreadMark(
history,
!markAsRead);
} }
}; };
const auto history = peer->owner().history(peer); const auto history = peer->owner().history(peer);
@ -361,16 +366,16 @@ void Filler::addBlockUser(not_null<UserData*> user) {
}, *lifetime); }, *lifetime);
if (user->blockStatus() == UserData::BlockStatus::Unknown) { if (user->blockStatus() == UserData::BlockStatus::Unknown) {
Auth().api().requestFullPeer(user); user->session().api().requestFullPeer(user);
} }
} }
void Filler::addUserActions(not_null<UserData*> user) { void Filler::addUserActions(not_null<UserData*> user) {
const auto window = &_controller->window()->controller(); const auto window = &_controller->window()->controller();
if (_source != PeerMenuSource::ChatsList) { if (_source != PeerMenuSource::ChatsList) {
if (Auth().supportMode()) { if (user->session().supportMode()) {
_addAction("Edit support info", [=] { _addAction("Edit support info", [=] {
Auth().supportHelper().editInfo(user); user->session().supportHelper().editInfo(user);
}); });
} }
if (!user->isContact() && !user->isSelf() && !user->isBot()) { if (!user->isContact() && !user->isSelf() && !user->isBot()) {
@ -409,7 +414,7 @@ void Filler::addUserActions(not_null<UserData*> user) {
tr::lng_profile_clear_history(tr::now), tr::lng_profile_clear_history(tr::now),
ClearHistoryHandler(user)); ClearHistoryHandler(user));
if (!user->isInaccessible() if (!user->isInaccessible()
&& user != Auth().user() && user != user->session().user()
&& _source != PeerMenuSource::ChatsList) { && _source != PeerMenuSource::ChatsList) {
addBlockUser(user); addBlockUser(user);
} }
@ -503,7 +508,7 @@ void Filler::addChannelActions(not_null<ChannelData*> channel) {
: tr::lng_profile_join_channel(tr::now); : tr::lng_profile_join_channel(tr::now);
_addAction( _addAction(
text, text,
[channel] { Auth().api().joinChannel(channel); }); [=] { channel->session().api().joinChannel(channel); });
} }
if (_source != PeerMenuSource::ChatsList) { if (_source != PeerMenuSource::ChatsList) {
const auto needReport = !channel->amCreator() const auto needReport = !channel->amCreator()
@ -622,7 +627,7 @@ void FolderFiller::addTogglesForArchive() {
} // namespace } // namespace
void PeerMenuExportChat(not_null<PeerData*> peer) { void PeerMenuExportChat(not_null<PeerData*> peer) {
Auth().data().startExport(peer); peer->owner().startExport(peer);
} }
void PeerMenuDeleteContact(not_null<UserData*> user) { void PeerMenuDeleteContact(not_null<UserData*> user) {
@ -654,7 +659,7 @@ void PeerMenuShareContactBox(not_null<UserData*> user) {
return; return;
} else if (peer->isSelf()) { } else if (peer->isSelf()) {
auto options = ApiWrap::SendOptions(peer->owner().history(peer)); auto options = ApiWrap::SendOptions(peer->owner().history(peer));
Auth().api().shareContact(user, options); user->session().api().shareContact(user, options);
Ui::Toast::Show(tr::lng_share_done(tr::now)); Ui::Toast::Show(tr::lng_share_done(tr::now));
if (auto strong = *weak) { if (auto strong = *weak) {
strong->closeBox(); strong->closeBox();
@ -671,7 +676,7 @@ void PeerMenuShareContactBox(not_null<UserData*> user) {
const auto history = peer->owner().history(peer); const auto history = peer->owner().history(peer);
Ui::showPeerHistory(history, ShowAtTheEndMsgId); Ui::showPeerHistory(history, ShowAtTheEndMsgId);
auto options = ApiWrap::SendOptions(history); auto options = ApiWrap::SendOptions(history);
Auth().api().shareContact(user, options); user->session().api().shareContact(user, options);
}), LayerOption::KeepOther); }), LayerOption::KeepOther);
}; };
*weak = Ui::show(Box<PeerListBox>( *weak = Ui::show(Box<PeerListBox>(
@ -698,8 +703,8 @@ void PeerMenuCreatePoll(not_null<PeerData*> peer) {
if (const auto localDraft = options.history->localDraft()) { if (const auto localDraft = options.history->localDraft()) {
options.clearDraft = localDraft->textWithTags.text.isEmpty(); options.clearDraft = localDraft->textWithTags.text.isEmpty();
} }
const auto api = &peer->session().api();
Auth().api().createPoll(result, options, crl::guard(box, [=] { api->createPoll(result, options, crl::guard(box, [=] {
box->closeBox(); box->closeBox();
}), crl::guard(box, [=](const RPCError &error) { }), crl::guard(box, [=](const RPCError &error) {
*lock = false; *lock = false;
@ -802,11 +807,12 @@ QPointer<Ui::RpWidget> ShowForwardMessagesBox(
weak weak
](not_null<PeerData*> peer) mutable { ](not_null<PeerData*> peer) mutable {
if (peer->isSelf()) { if (peer->isSelf()) {
auto items = Auth().data().idsToItems(ids); auto items = peer->owner().idsToItems(ids);
if (!items.empty()) { if (!items.empty()) {
const auto api = &peer->session().api();
auto options = ApiWrap::SendOptions(peer->owner().history(peer)); auto options = ApiWrap::SendOptions(peer->owner().history(peer));
options.generateLocal = false; options.generateLocal = false;
Auth().api().forwardMessages(std::move(items), options, [] { api->forwardMessages(std::move(items), options, [] {
Ui::Toast::Show(tr::lng_share_done(tr::now)); Ui::Toast::Show(tr::lng_share_done(tr::now));
}); });
} }
@ -839,8 +845,10 @@ void PeerMenuAddChannelMembers(not_null<ChannelData*> channel) {
LayerOption::KeepOther); LayerOption::KeepOther);
return; return;
} }
auto callback = [=](const MTPchannels_ChannelParticipants &result) { const auto api = &channel->session().api();
Auth().api().parseChannelParticipants(channel, result, [&]( api->requestChannelMembersForAdd(channel, [=](
const MTPchannels_ChannelParticipants &result) {
api->parseChannelParticipants(channel, result, [&](
int availableCount, int availableCount,
const QVector<MTPChannelParticipant> &list) { const QVector<MTPChannelParticipant> &list) {
auto already = ( auto already = (
@ -849,8 +857,8 @@ void PeerMenuAddChannelMembers(not_null<ChannelData*> channel) {
return p.match([](const auto &data) { return p.match([](const auto &data) {
return data.vuser_id().v; return data.vuser_id().v;
}); });
}) | ranges::view::transform([](UserId userId) { }) | ranges::view::transform([&](UserId userId) {
return Auth().data().userLoaded(userId); return channel->owner().userLoaded(userId);
}) | ranges::view::filter([](UserData *user) { }) | ranges::view::filter([](UserData *user) {
return (user != nullptr); return (user != nullptr);
}) | ranges::to_vector; }) | ranges::to_vector;
@ -859,24 +867,23 @@ void PeerMenuAddChannelMembers(not_null<ChannelData*> channel) {
channel, channel,
{ already.begin(), already.end() }); { already.begin(), already.end() });
}); });
}; });
Auth().api().requestChannelMembersForAdd(channel, callback);
} }
void PeerMenuAddMuteAction( void PeerMenuAddMuteAction(
not_null<PeerData*> peer, not_null<PeerData*> peer,
const PeerMenuCallback &addAction) { const PeerMenuCallback &addAction) {
Auth().data().requestNotifySettings(peer); peer->owner().requestNotifySettings(peer);
const auto muteText = [](bool isMuted) { const auto muteText = [](bool isMuted) {
return isMuted return isMuted
? tr::lng_enable_notifications_from_tray(tr::now) ? tr::lng_enable_notifications_from_tray(tr::now)
: tr::lng_disable_notifications_from_tray(tr::now); : tr::lng_disable_notifications_from_tray(tr::now);
}; };
const auto muteAction = addAction(QString("-"), [=] { const auto muteAction = addAction(QString("-"), [=] {
if (!Auth().data().notifyIsMuted(peer)) { if (!peer->owner().notifyIsMuted(peer)) {
Ui::show(Box<MuteSettingsBox>(peer)); Ui::show(Box<MuteSettingsBox>(peer));
} else { } else {
Auth().data().updateNotifySettings(peer, 0); peer->owner().updateNotifySettings(peer, 0);
} }
}); });
@ -892,7 +899,7 @@ void PeerMenuAddMuteAction(
// Ui::show(Box<ConfirmBox>( // Ui::show(Box<ConfirmBox>(
// tr::lng_feed_sure_ungroup_all(tr::now), // tr::lng_feed_sure_ungroup_all(tr::now),
// tr::lng_feed_ungroup_sure(tr::now), // tr::lng_feed_ungroup_sure(tr::now),
// [=] { Ui::hideLayer(); Auth().api().ungroupAllFromFeed(feed); })); // [=] { Ui::hideLayer(); feed->session().api().ungroupAllFromFeed(feed); }));
//} //}
// //
void ToggleHistoryArchived(not_null<History*> history, bool archived) { void ToggleHistoryArchived(not_null<History*> history, bool archived) {