diff --git a/src/friend.cpp b/src/friend.cpp index a2db70fb7..25428b272 100644 --- a/src/friend.cpp +++ b/src/friend.cpp @@ -27,6 +27,8 @@ #include "src/persistence/settings.h" #include "src/persistence/profile.h" #include "src/nexus.h" +#include "src/grouplist.h" +#include "src/group.h" Friend::Friend(uint32_t FriendId, const ToxId &UserId) : userName{Core::getInstance()->getPeerName(UserId)}, @@ -88,6 +90,11 @@ void Friend::setAlias(QString name) GUI::setWindowTitle(dispName); emit displayedNameChanged(getFriendWidget(), getStatus(), hasNewEvents); + + for (Group *g : GroupList::getAllGroups()) + { + g->regeneratePeerList(); + } } void Friend::setStatusMessage(QString message) diff --git a/src/group.cpp b/src/group.cpp index 3497263de..6d541627e 100644 --- a/src/group.cpp +++ b/src/group.cpp @@ -54,8 +54,12 @@ void Group::updatePeer(int peerId, QString name) toxids[toxid] = name; Friend *f = FriendList::findFriend(id); - if (f != nullptr && f->hasAlias()) + { + peers[peerId] = f->getDisplayedName(); + toxids[toxid] = f->getDisplayedName(); + } + else { widget->onUserListChanged(); chatForm->onUserListChanged(); @@ -91,8 +95,11 @@ void Group::regeneratePeerList() QString toxid = id.publicKey; toxids[toxid] = peers[i]; + if (toxids[toxid].isEmpty()) + toxids[toxid] = tr("", "Placeholder when someone's name in a group chat is empty"); + Friend *f = FriendList::findFriend(id); - if (f) + if (f != nullptr && f->hasAlias()) { peers[i] = f->getDisplayedName(); toxids[toxid] = f->getDisplayedName(); diff --git a/src/widget/form/groupchatform.cpp b/src/widget/form/groupchatform.cpp index da7c70a37..c7769d6fa 100644 --- a/src/widget/form/groupchatform.cpp +++ b/src/widget/form/groupchatform.cpp @@ -35,6 +35,7 @@ #include #include #include +#include GroupChatForm::GroupChatForm(Group* chatGroup) : group(chatGroup), inCall{false} @@ -181,7 +182,7 @@ void GroupChatForm::onUserListChanged() peerLabels.clear(); // the list needs peers in peernumber order, nameLayout needs alphabetical - QMap orderizer; + QList nickLabelList; // first traverse in peer number order, storing the QLabels as necessary QStringList names = group->getPeerList(); @@ -193,7 +194,7 @@ void GroupChatForm::onUserListChanged() if (!tooltip.isEmpty()) peerLabels[i]->setToolTip(tooltip); peerLabels[i]->setTextFormat(Qt::PlainText); - orderizer[names[i]] = peerLabels[i]; + nickLabelList.append(peerLabels[i]); if (group->isSelfPeerNumber(i)) peerLabels[i]->setStyleSheet("QLabel {color : green;}"); @@ -205,10 +206,10 @@ void GroupChatForm::onUserListChanged() static_cast(netcam)->clearPeers(); // now alphabetize and add to layout - names.sort(Qt::CaseInsensitive); + qSort(nickLabelList.begin(), nickLabelList.end(), [](QLabel *a, QLabel *b){return a->text().toLower() < b->text().toLower();}); for (unsigned i=0; isetText(label->text() + ", "); diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp index fcd6886d7..104c545b8 100644 --- a/src/widget/widget.cpp +++ b/src/widget/widget.cpp @@ -1500,13 +1500,9 @@ void Widget::onGroupNamelistChanged(int groupnumber, int peernumber, uint8_t Cha g = createGroup(groupnumber); } - QString name = Nexus::getCore()->getGroupPeerName(groupnumber, peernumber); TOX_CHAT_CHANGE change = static_cast(Change); if (change == TOX_CHAT_CHANGE_PEER_ADD) { - if (name.isEmpty()) - name = tr("", "Placeholder when we don't know someone's name in a group chat"); - // g->addPeer(peernumber,name); g->regeneratePeerList(); // g->getChatForm()->addSystemInfoMessage(tr("%1 has joined the chat").arg(name), "white", QDateTime::currentDateTime()); @@ -1521,6 +1517,10 @@ void Widget::onGroupNamelistChanged(int groupnumber, int peernumber, uint8_t Cha } else if (change == TOX_CHAT_CHANGE_PEER_NAME) // core overwrites old name before telling us it changed... { + QString name = Nexus::getCore()->getGroupPeerName(groupnumber, peernumber); + if (name.isEmpty()) + name = tr("", "Placeholder when someone's name in a group chat is empty"); + g->updatePeer(peernumber, name); } }