Add MessagesManager::set_folder_pinned_dialogs.
This commit is contained in:
parent
3e66162c07
commit
c0d78b9f04
@ -14578,44 +14578,9 @@ void MessagesManager::on_get_dialogs(FolderId folder_id, vector<tl_object_ptr<te
|
|||||||
bool are_pinned_dialogs_saved = folder_list->are_pinned_dialogs_inited_;
|
bool are_pinned_dialogs_saved = folder_list->are_pinned_dialogs_inited_;
|
||||||
folder_list->are_pinned_dialogs_inited_ = true;
|
folder_list->are_pinned_dialogs_inited_ = true;
|
||||||
if (pinned_dialog_ids != added_dialog_ids) {
|
if (pinned_dialog_ids != added_dialog_ids) {
|
||||||
LOG(INFO) << "Update pinned chats order from " << format::as_array(pinned_dialog_ids) << " to "
|
if (set_folder_pinned_dialogs(folder_id, std::move(pinned_dialog_ids), std::move(added_dialog_ids))) {
|
||||||
<< format::as_array(added_dialog_ids);
|
|
||||||
FlatHashSet<DialogId, DialogIdHash> old_pinned_dialog_ids;
|
|
||||||
for (auto pinned_dialog_id : pinned_dialog_ids) {
|
|
||||||
old_pinned_dialog_ids.insert(pinned_dialog_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::reverse(pinned_dialog_ids.begin(), pinned_dialog_ids.end());
|
|
||||||
std::reverse(added_dialog_ids.begin(), added_dialog_ids.end());
|
|
||||||
auto old_it = pinned_dialog_ids.begin();
|
|
||||||
for (auto dialog_id : added_dialog_ids) {
|
|
||||||
old_pinned_dialog_ids.erase(dialog_id);
|
|
||||||
while (old_it < pinned_dialog_ids.end()) {
|
|
||||||
if (*old_it == dialog_id) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
++old_it;
|
|
||||||
}
|
|
||||||
if (old_it < pinned_dialog_ids.end()) {
|
|
||||||
// leave dialog where it is
|
|
||||||
++old_it;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (set_dialog_is_pinned(dialog_id, true)) {
|
|
||||||
are_pinned_dialogs_saved = true;
|
are_pinned_dialogs_saved = true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
for (auto dialog_id : old_pinned_dialog_ids) {
|
|
||||||
Dialog *d = get_dialog_force(dialog_id, "on_get_dialogs pinned");
|
|
||||||
if (d == nullptr) {
|
|
||||||
LOG(ERROR) << "Failed to find " << dialog_id << " to unpin in " << folder_id;
|
|
||||||
force_create_dialog(dialog_id, "from_pinned_dialog_list", true);
|
|
||||||
d = get_dialog_force(dialog_id, "on_get_dialogs pinned 2");
|
|
||||||
}
|
|
||||||
if (d != nullptr && set_dialog_is_pinned(DialogListId(folder_id), d, false)) {
|
|
||||||
are_pinned_dialogs_saved = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
LOG(INFO) << "Pinned chats are not changed";
|
LOG(INFO) << "Pinned chats are not changed";
|
||||||
}
|
}
|
||||||
@ -17735,6 +17700,51 @@ void MessagesManager::toggle_dialog_is_pinned_on_server(DialogId dialog_id, bool
|
|||||||
td_->create_handler<ToggleDialogPinQuery>(get_erase_log_event_promise(log_event_id))->send(dialog_id, is_pinned);
|
td_->create_handler<ToggleDialogPinQuery>(get_erase_log_event_promise(log_event_id))->send(dialog_id, is_pinned);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool MessagesManager::set_folder_pinned_dialogs(FolderId folder_id, vector<DialogId> old_dialog_ids,
|
||||||
|
vector<DialogId> new_dialog_ids) {
|
||||||
|
LOG(INFO) << "Reorder pinned chats in " << folder_id << " from " << old_dialog_ids << " to " << new_dialog_ids;
|
||||||
|
|
||||||
|
std::reverse(old_dialog_ids.begin(), old_dialog_ids.end());
|
||||||
|
std::reverse(new_dialog_ids.begin(), new_dialog_ids.end());
|
||||||
|
|
||||||
|
FlatHashSet<DialogId, DialogIdHash> all_old_pinned_dialog_ids;
|
||||||
|
for (auto dialog_id : old_dialog_ids) {
|
||||||
|
all_old_pinned_dialog_ids.insert(dialog_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool are_pinned_dialogs_saved = false;
|
||||||
|
auto old_it = old_dialog_ids.begin();
|
||||||
|
for (auto dialog_id : new_dialog_ids) {
|
||||||
|
all_old_pinned_dialog_ids.erase(dialog_id);
|
||||||
|
while (old_it < old_dialog_ids.end()) {
|
||||||
|
if (*old_it == dialog_id) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
++old_it;
|
||||||
|
}
|
||||||
|
if (old_it < old_dialog_ids.end()) {
|
||||||
|
// leave dialog where it is
|
||||||
|
++old_it;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (set_dialog_is_pinned(dialog_id, true)) {
|
||||||
|
are_pinned_dialogs_saved = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (auto dialog_id : all_old_pinned_dialog_ids) {
|
||||||
|
Dialog *d = get_dialog_force(dialog_id, "set_folder_pinned_dialogs 1");
|
||||||
|
if (d == nullptr) {
|
||||||
|
LOG(ERROR) << "Failed to find " << dialog_id << " to unpin in " << folder_id;
|
||||||
|
force_create_dialog(dialog_id, "set_folder_pinned_dialogs 2", true);
|
||||||
|
d = get_dialog_force(dialog_id, "set_folder_pinned_dialogs 3");
|
||||||
|
}
|
||||||
|
if (d != nullptr && set_dialog_is_pinned(DialogListId(folder_id), d, false)) {
|
||||||
|
are_pinned_dialogs_saved = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return are_pinned_dialogs_saved;
|
||||||
|
}
|
||||||
|
|
||||||
Status MessagesManager::set_pinned_dialogs(DialogListId dialog_list_id, vector<DialogId> dialog_ids) {
|
Status MessagesManager::set_pinned_dialogs(DialogListId dialog_list_id, vector<DialogId> dialog_ids) {
|
||||||
if (td_->auth_manager_->is_bot()) {
|
if (td_->auth_manager_->is_bot()) {
|
||||||
return Status::Error(400, "Bots can't reorder pinned chats");
|
return Status::Error(400, "Bots can't reorder pinned chats");
|
||||||
@ -17786,7 +17796,6 @@ Status MessagesManager::set_pinned_dialogs(DialogListId dialog_list_id, vector<D
|
|||||||
if (pinned_dialog_ids == dialog_ids) {
|
if (pinned_dialog_ids == dialog_ids) {
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
LOG(INFO) << "Reorder pinned chats in " << dialog_list_id << " from " << pinned_dialog_ids << " to " << dialog_ids;
|
|
||||||
|
|
||||||
auto server_old_dialog_ids = DialogId::remove_secret_chat_dialog_ids(pinned_dialog_ids);
|
auto server_old_dialog_ids = DialogId::remove_secret_chat_dialog_ids(pinned_dialog_ids);
|
||||||
auto server_new_dialog_ids = DialogId::remove_secret_chat_dialog_ids(dialog_ids);
|
auto server_new_dialog_ids = DialogId::remove_secret_chat_dialog_ids(dialog_ids);
|
||||||
@ -17799,45 +17808,11 @@ Status MessagesManager::set_pinned_dialogs(DialogListId dialog_list_id, vector<D
|
|||||||
server_old_dialog_ids != server_new_dialog_ids);
|
server_old_dialog_ids != server_new_dialog_ids);
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(dialog_list_id.is_folder());
|
auto folder_id = dialog_list_id.get_folder_id();
|
||||||
|
set_folder_pinned_dialogs(folder_id, std::move(pinned_dialog_ids), std::move(dialog_ids));
|
||||||
std::reverse(pinned_dialog_ids.begin(), pinned_dialog_ids.end());
|
|
||||||
std::reverse(dialog_ids.begin(), dialog_ids.end());
|
|
||||||
|
|
||||||
FlatHashSet<DialogId, DialogIdHash> old_pinned_dialog_ids;
|
|
||||||
for (auto dialog_id : pinned_dialog_ids) {
|
|
||||||
old_pinned_dialog_ids.insert(dialog_id);
|
|
||||||
}
|
|
||||||
auto old_it = pinned_dialog_ids.begin();
|
|
||||||
for (auto dialog_id : dialog_ids) {
|
|
||||||
old_pinned_dialog_ids.erase(dialog_id);
|
|
||||||
while (old_it < pinned_dialog_ids.end()) {
|
|
||||||
if (*old_it == dialog_id) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
++old_it;
|
|
||||||
}
|
|
||||||
if (old_it < pinned_dialog_ids.end()) {
|
|
||||||
// leave dialog where it is
|
|
||||||
++old_it;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
set_dialog_is_pinned(dialog_id, true);
|
|
||||||
}
|
|
||||||
for (auto dialog_id : old_pinned_dialog_ids) {
|
|
||||||
Dialog *d = get_dialog_force(dialog_id, "set_pinned_dialogs 2");
|
|
||||||
if (d == nullptr) {
|
|
||||||
LOG(ERROR) << "Failed to find " << dialog_id << " to unpin in " << dialog_list_id;
|
|
||||||
force_create_dialog(dialog_id, "set_pinned_dialogs", true);
|
|
||||||
d = get_dialog_force(dialog_id, "set_pinned_dialogs 3");
|
|
||||||
}
|
|
||||||
if (d != nullptr) {
|
|
||||||
set_dialog_is_pinned(dialog_list_id, d, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (server_old_dialog_ids != server_new_dialog_ids) {
|
if (server_old_dialog_ids != server_new_dialog_ids) {
|
||||||
reorder_pinned_dialogs_on_server(dialog_list_id.get_folder_id(), server_new_dialog_ids, 0);
|
reorder_pinned_dialogs_on_server(folder_id, server_new_dialog_ids, 0);
|
||||||
}
|
}
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
@ -2600,6 +2600,8 @@ class MessagesManager final : public Actor {
|
|||||||
|
|
||||||
vector<DialogId> get_pinned_dialog_ids(DialogListId dialog_list_id) const;
|
vector<DialogId> get_pinned_dialog_ids(DialogListId dialog_list_id) const;
|
||||||
|
|
||||||
|
bool set_folder_pinned_dialogs(FolderId folder_id, vector<DialogId> old_dialog_ids, vector<DialogId> new_dialog_ids);
|
||||||
|
|
||||||
void reload_pinned_dialogs(DialogListId dialog_list_id, Promise<Unit> &&promise);
|
void reload_pinned_dialogs(DialogListId dialog_list_id, Promise<Unit> &&promise);
|
||||||
|
|
||||||
void update_dialogs_hints(const Dialog *d);
|
void update_dialogs_hints(const Dialog *d);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user