mirror of https://github.com/procxx/kepka.git
Apply changes in ParticipantsBoxController.
When we add admin / banned / restricted user in a channel using AddParticipantBoxController we now apply the added user in the box.
This commit is contained in:
parent
9e8e49b8d9
commit
240ced395b
|
@ -73,9 +73,13 @@ void ParticipantsBoxController::Start(gsl::not_null<ChannelData*> channel, Role
|
||||||
|
|
||||||
void ParticipantsBoxController::addNewItem() {
|
void ParticipantsBoxController::addNewItem() {
|
||||||
auto weak = base::weak_unique_ptr<ParticipantsBoxController>(this);
|
auto weak = base::weak_unique_ptr<ParticipantsBoxController>(this);
|
||||||
_addBox = Ui::show(Box<PeerListBox>(std::make_unique<AddParticipantBoxController>(_channel, _role, [weak] {
|
_addBox = Ui::show(Box<PeerListBox>(std::make_unique<AddParticipantBoxController>(_channel, _role, [weak](gsl::not_null<UserData*> user, const MTPChannelAdminRights &rights) {
|
||||||
if (weak && weak->_addBox) {
|
if (weak) {
|
||||||
weak->_addBox->closeBox();
|
weak->editAdminDone(user, rights);
|
||||||
|
}
|
||||||
|
}, [weak](gsl::not_null<UserData*> user, const MTPChannelBannedRights &rights) {
|
||||||
|
if (weak) {
|
||||||
|
weak->editRestrictedDone(user, rights);
|
||||||
}
|
}
|
||||||
}), [](PeerListBox *box) {
|
}), [](PeerListBox *box) {
|
||||||
box->addButton(langFactory(lng_cancel), [box] { box->closeBox(); });
|
box->addButton(langFactory(lng_cancel), [box] { box->closeBox(); });
|
||||||
|
@ -237,18 +241,34 @@ void ParticipantsBoxController::editAdmin(gsl::not_null<UserData*> user) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void ParticipantsBoxController::editAdminDone(gsl::not_null<UserData*> user, const MTPChannelAdminRights &rights) {
|
void ParticipantsBoxController::editAdminDone(gsl::not_null<UserData*> user, const MTPChannelAdminRights &rights) {
|
||||||
if (_editBox) _editBox->closeBox();
|
if (_editBox) {
|
||||||
if (rights.c_channelAdminRights().vflags.v == 0) {
|
_editBox->closeBox();
|
||||||
if (auto row = delegate()->peerListFindRow(user->id)) {
|
}
|
||||||
delegate()->peerListRemoveRow(row);
|
if (_addBox) {
|
||||||
if (!delegate()->peerListFullRowsCount()) {
|
_addBox->closeBox();
|
||||||
setDescriptionText(lang(lng_blocked_list_not_found));
|
}
|
||||||
}
|
auto notAdmin = (rights.c_channelAdminRights().vflags.v == 0);
|
||||||
delegate()->peerListRefreshRows();
|
if (notAdmin) {
|
||||||
|
_additional.adminRights.erase(user);
|
||||||
|
_additional.adminPromotedBy.erase(user);
|
||||||
|
_additional.adminCanEdit.erase(user);
|
||||||
|
if (_role == Role::Admins) {
|
||||||
|
removeRow(user);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
// It won't be replaced if the entry already exists.
|
||||||
|
_additional.adminPromotedBy.emplace(user, App::self());
|
||||||
|
_additional.adminCanEdit.emplace(user);
|
||||||
_additional.adminRights[user] = rights;
|
_additional.adminRights[user] = rights;
|
||||||
|
_additional.kicked.erase(user);
|
||||||
|
_additional.restrictedRights.erase(user);
|
||||||
|
if (_role == Role::Admins) {
|
||||||
|
prependRow(user);
|
||||||
|
} else {
|
||||||
|
removeRow(user);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
delegate()->peerListRefreshRows();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ParticipantsBoxController::editRestricted(gsl::not_null<UserData*> user) {
|
void ParticipantsBoxController::editRestricted(gsl::not_null<UserData*> user) {
|
||||||
|
@ -267,18 +287,43 @@ void ParticipantsBoxController::editRestricted(gsl::not_null<UserData*> user) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void ParticipantsBoxController::editRestrictedDone(gsl::not_null<UserData*> user, const MTPChannelBannedRights &rights) {
|
void ParticipantsBoxController::editRestrictedDone(gsl::not_null<UserData*> user, const MTPChannelBannedRights &rights) {
|
||||||
if (_editBox) _editBox->closeBox();
|
if (_editBox) {
|
||||||
if (rights.c_channelBannedRights().vflags.v == 0 || rights.c_channelBannedRights().is_view_messages()) {
|
_editBox->closeBox();
|
||||||
if (auto row = delegate()->peerListFindRow(user->id)) {
|
}
|
||||||
delegate()->peerListRemoveRow(row);
|
if (_addBox) {
|
||||||
if (!delegate()->peerListFullRowsCount()) {
|
_addBox->closeBox();
|
||||||
setDescriptionText(lang(lng_blocked_list_not_found));
|
}
|
||||||
}
|
auto notBanned = (rights.c_channelBannedRights().vflags.v == 0);
|
||||||
delegate()->peerListRefreshRows();
|
auto fullBanned = rights.c_channelBannedRights().is_view_messages();
|
||||||
|
if (notBanned) {
|
||||||
|
_additional.kicked.erase(user);
|
||||||
|
_additional.restrictedRights.erase(user);
|
||||||
|
if (_role != Role::Admins) {
|
||||||
|
removeRow(user);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_additional.restrictedRights[user] = rights;
|
_additional.adminRights.erase(user);
|
||||||
|
_additional.adminCanEdit.erase(user);
|
||||||
|
_additional.adminPromotedBy.erase(user);
|
||||||
|
if (fullBanned) {
|
||||||
|
_additional.kicked.emplace(user);
|
||||||
|
_additional.restrictedRights.erase(user);
|
||||||
|
if (_role == Role::Kicked) {
|
||||||
|
prependRow(user);
|
||||||
|
} else {
|
||||||
|
removeRow(user);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
_additional.restrictedRights[user] = rights;
|
||||||
|
_additional.kicked.erase(user);
|
||||||
|
if (_role == Role::Restricted) {
|
||||||
|
prependRow(user);
|
||||||
|
} else {
|
||||||
|
removeRow(user);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
delegate()->peerListRefreshRows();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ParticipantsBoxController::removeKicked(gsl::not_null<PeerListRow*> row, gsl::not_null<UserData*> user) {
|
void ParticipantsBoxController::removeKicked(gsl::not_null<PeerListRow*> row, gsl::not_null<UserData*> user) {
|
||||||
|
@ -310,6 +355,17 @@ bool ParticipantsBoxController::prependRow(gsl::not_null<UserData*> user) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ParticipantsBoxController::removeRow(gsl::not_null<UserData*> user) {
|
||||||
|
if (auto row = delegate()->peerListFindRow(user->id)) {
|
||||||
|
delegate()->peerListRemoveRow(row);
|
||||||
|
if (!delegate()->peerListFullRowsCount()) {
|
||||||
|
setDescriptionText(lang(lng_blocked_list_not_found));
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
std::unique_ptr<PeerListRow> ParticipantsBoxController::createRow(gsl::not_null<UserData*> user) const {
|
std::unique_ptr<PeerListRow> ParticipantsBoxController::createRow(gsl::not_null<UserData*> user) const {
|
||||||
auto row = std::make_unique<PeerListRowWithLink>(user);
|
auto row = std::make_unique<PeerListRowWithLink>(user);
|
||||||
if (_role == Role::Admins) {
|
if (_role == Role::Admins) {
|
||||||
|
@ -436,10 +492,11 @@ void BannedBoxSearchController::searchDone(mtpRequestId requestId, const MTPchan
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AddParticipantBoxController::AddParticipantBoxController(gsl::not_null<ChannelData*> channel, Role role, base::lambda<void()> doneCallback) : PeerListController(std::make_unique<AddParticipantBoxSearchController>(channel, role, &_additional))
|
AddParticipantBoxController::AddParticipantBoxController(gsl::not_null<ChannelData*> channel, Role role, AdminDoneCallback adminDoneCallback, BannedDoneCallback bannedDoneCallback) : PeerListController(std::make_unique<AddParticipantBoxSearchController>(channel, role, &_additional))
|
||||||
, _channel(channel)
|
, _channel(channel)
|
||||||
, _role(role)
|
, _role(role)
|
||||||
, _doneCallback(std::move(doneCallback)) {
|
, _adminDoneCallback(std::move(adminDoneCallback))
|
||||||
|
, _bannedDoneCallback(std::move(bannedDoneCallback)) {
|
||||||
if (_channel->mgInfo) {
|
if (_channel->mgInfo) {
|
||||||
_additional.creator = _channel->mgInfo->creator;
|
_additional.creator = _channel->mgInfo->creator;
|
||||||
}
|
}
|
||||||
|
@ -638,7 +695,9 @@ void AddParticipantBoxController::editAdminDone(gsl::not_null<UserData*> user, c
|
||||||
_additional.adminPromotedBy.emplace(user, App::self());
|
_additional.adminPromotedBy.emplace(user, App::self());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_doneCallback();
|
if (_adminDoneCallback) {
|
||||||
|
_adminDoneCallback(user, rights);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AddParticipantBoxController::editRestricted(gsl::not_null<UserData*> user, bool sure) {
|
void AddParticipantBoxController::editRestricted(gsl::not_null<UserData*> user, bool sure) {
|
||||||
|
@ -680,7 +739,6 @@ void AddParticipantBoxController::editRestricted(gsl::not_null<UserData*> user,
|
||||||
}
|
}
|
||||||
|
|
||||||
void AddParticipantBoxController::restrictUserSure(gsl::not_null<UserData*> user, const MTPChannelBannedRights &rights) {
|
void AddParticipantBoxController::restrictUserSure(gsl::not_null<UserData*> user, const MTPChannelBannedRights &rights) {
|
||||||
if (_editBox) _editBox->closeBox();
|
|
||||||
auto weak = base::weak_unique_ptr<AddParticipantBoxController>(this);
|
auto weak = base::weak_unique_ptr<AddParticipantBoxController>(this);
|
||||||
MTP::send(MTPchannels_EditBanned(_channel->inputChannel, user->inputUser, rights), rpcDone([megagroup = _channel.get(), user, weak, rights](const MTPUpdates &result) {
|
MTP::send(MTPchannels_EditBanned(_channel->inputChannel, user->inputUser, rights), rpcDone([megagroup = _channel.get(), user, weak, rights](const MTPUpdates &result) {
|
||||||
AuthSession::Current().api().applyUpdates(result);
|
AuthSession::Current().api().applyUpdates(result);
|
||||||
|
@ -707,7 +765,9 @@ void AddParticipantBoxController::editRestrictedDone(gsl::not_null<UserData*> us
|
||||||
_additional.kicked.erase(user);
|
_additional.kicked.erase(user);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_doneCallback();
|
if (_bannedDoneCallback) {
|
||||||
|
_bannedDoneCallback(user, rights);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AddParticipantBoxController::kickUser(gsl::not_null<UserData*> user, bool sure) {
|
void AddParticipantBoxController::kickUser(gsl::not_null<UserData*> user, bool sure) {
|
||||||
|
|
|
@ -71,6 +71,7 @@ private:
|
||||||
void removeKicked(gsl::not_null<PeerListRow*> row, gsl::not_null<UserData*> user);
|
void removeKicked(gsl::not_null<PeerListRow*> row, gsl::not_null<UserData*> user);
|
||||||
bool appendRow(gsl::not_null<UserData*> user);
|
bool appendRow(gsl::not_null<UserData*> user);
|
||||||
bool prependRow(gsl::not_null<UserData*> user);
|
bool prependRow(gsl::not_null<UserData*> user);
|
||||||
|
bool removeRow(gsl::not_null<UserData*> user);
|
||||||
std::unique_ptr<PeerListRow> createRow(gsl::not_null<UserData*> user) const;
|
std::unique_ptr<PeerListRow> createRow(gsl::not_null<UserData*> user) const;
|
||||||
|
|
||||||
gsl::not_null<ChannelData*> _channel;
|
gsl::not_null<ChannelData*> _channel;
|
||||||
|
@ -130,7 +131,9 @@ public:
|
||||||
using Role = ParticipantsBoxController::Role;
|
using Role = ParticipantsBoxController::Role;
|
||||||
using Additional = ParticipantsBoxController::Additional;
|
using Additional = ParticipantsBoxController::Additional;
|
||||||
|
|
||||||
AddParticipantBoxController(gsl::not_null<ChannelData*> channel, Role role, base::lambda<void()> doneCallback);
|
using AdminDoneCallback = base::lambda<void(gsl::not_null<UserData*> user, const MTPChannelAdminRights &adminRights)>;
|
||||||
|
using BannedDoneCallback = base::lambda<void(gsl::not_null<UserData*> user, const MTPChannelBannedRights &bannedRights)>;
|
||||||
|
AddParticipantBoxController(gsl::not_null<ChannelData*> channel, Role role, AdminDoneCallback adminDoneCallback, BannedDoneCallback bannedDoneCallback);
|
||||||
|
|
||||||
void prepare() override;
|
void prepare() override;
|
||||||
void rowClicked(gsl::not_null<PeerListRow*> row) override;
|
void rowClicked(gsl::not_null<PeerListRow*> row) override;
|
||||||
|
@ -164,7 +167,8 @@ private:
|
||||||
bool _allLoaded = false;
|
bool _allLoaded = false;
|
||||||
Additional _additional;
|
Additional _additional;
|
||||||
QPointer<BoxContent> _editBox;
|
QPointer<BoxContent> _editBox;
|
||||||
base::lambda<void()> _doneCallback;
|
AdminDoneCallback _adminDoneCallback;
|
||||||
|
BannedDoneCallback _bannedDoneCallback;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue