diff --git a/core.cpp b/core.cpp index f6b7a2a5c..fddca6eda 100644 --- a/core.cpp +++ b/core.cpp @@ -402,9 +402,10 @@ void Core::onGroupInvite(Tox*, int friendnumber, const uint8_t *group_public_key emit static_cast(core)->groupInviteReceived(friendnumber, group_public_key,length); } -void Core::onGroupMessage(Tox*, int groupnumber, int friendgroupnumber, const uint8_t * message, uint16_t length, void *core) +void Core::onGroupMessage(Tox*, int groupnumber, int peernumber, const uint8_t * message, uint16_t length, void *_core) { - emit static_cast(core)->groupMessageReceived(groupnumber, friendgroupnumber, CString::toString(message, length)); + Core* core = static_cast(_core); + emit core->groupMessageReceived(groupnumber, CString::toString(message, length), core->getGroupPeerName(groupnumber, peernumber)); } void Core::onGroupNamelistChange(Tox*, int groupnumber, int peernumber, uint8_t change, void *core) diff --git a/core.h b/core.h index b1b8c3f43..51d885688 100644 --- a/core.h +++ b/core.h @@ -118,7 +118,7 @@ signals: void emptyGroupCreated(int groupnumber); void groupInviteReceived(int friendnumber, const uint8_t *group_public_key,uint16_t length); - void groupMessageReceived(int groupnumber, int friendgroupnumber, const QString& message); + void groupMessageReceived(int groupnumber, const QString& message, const QString& author); void groupNamelistChanged(int groupnumber, int peernumber, uint8_t change); void usernameSet(const QString& username); diff --git a/group.cpp b/group.cpp index 4898f525a..d74610131 100644 --- a/group.cpp +++ b/group.cpp @@ -24,16 +24,14 @@ #include Group::Group(int GroupId, QString Name) - : groupId(GroupId), nPeers{0}, hasPeerInfo{false}, peerInfoTimer{new QTimer} + : groupId(GroupId), nPeers{0} { widget = new GroupWidget(groupId, Name); chatForm = new GroupChatForm(this); - connect(peerInfoTimer, SIGNAL(timeout()), this, SLOT(queryPeerInfo())); - peerInfoTimer->setInterval(500); - peerInfoTimer->setSingleShot(false); - //peerInfoTimer.start(); - //in groupchats, we only notify on messages containing your name + //in groupchats, we only notify on messages containing your name <-- dumb + // sound notifications should be on all messages, but system popup notification + // on naming is appropriate hasNewMessages = 0; userWasMentioned = 0; } @@ -42,53 +40,6 @@ Group::~Group() { delete chatForm; delete widget; - delete peerInfoTimer; -} - -void Group::queryPeerInfo() -{ - const Core* core = Core::getInstance(); - int nPeersResult = core->getGroupNumberPeers(groupId); - if (nPeersResult == -1) - { - qDebug() << "Group::queryPeerInfo: Can't get number of peers"; - return; - } - nPeers = nPeersResult; - widget->onUserListChanged(); - chatForm->onUserListChanged(); - - if (nPeersResult == 0) - return; - - bool namesOk = true; - QList names = core->getGroupPeerNames(groupId); - if (names.isEmpty()) - { - qDebug() << "Group::queryPeerInfo: Can't get names of peers"; - return; - } - for (int i=0; ionUserListChanged(); - chatForm->onUserListChanged(); - - if (namesOk) - { - qDebug() << "Group::queryPeerInfo: Successfully loaded names"; - hasPeerInfo = true; - peerInfoTimer->stop(); - } } void Group::addPeer(int peerId, QString name) diff --git a/group.h b/group.h index fed4b11ee..cd263538f 100644 --- a/group.h +++ b/group.h @@ -25,7 +25,6 @@ struct Friend; class GroupWidget; class GroupChatForm; -class QTimer; class Group : public QObject { @@ -37,17 +36,12 @@ public: void removePeer(int peerId); void updatePeer(int peerId, QString newName); -private slots: - void queryPeerInfo(); - public: int groupId; QMap peers; int nPeers; GroupWidget* widget; GroupChatForm* chatForm; - bool hasPeerInfo; - QTimer* peerInfoTimer; int hasNewMessages, userWasMentioned; }; diff --git a/widget/form/genericchatform.cpp b/widget/form/genericchatform.cpp index 4a73d3938..08e8040bb 100644 --- a/widget/form/genericchatform.cpp +++ b/widget/form/genericchatform.cpp @@ -172,6 +172,12 @@ void GenericChatForm::addMessage(QString author, QString message, bool isAction, QString date = datetime.toString(Settings::getInstance().getTimestampFormat()); bool isMe = (author == Widget::getInstance()->getUsername()); + if (!isAction && message.startsWith("/me ")) + { // always render actions regardless of what core thinks + isAction = true; + message = message.right(message.length()-4); + } + if (isAction) { chatWidget->insertMessage(new ActionAction (getElidedName(author), message, date, isMe)); diff --git a/widget/form/groupchatform.cpp b/widget/form/groupchatform.cpp index 412ef46e8..5e97d22df 100644 --- a/widget/form/groupchatform.cpp +++ b/widget/form/groupchatform.cpp @@ -80,17 +80,6 @@ void GroupChatForm::onSendTriggered() emit sendMessage(group->groupId, msg); } -void GroupChatForm::addGroupMessage(QString message, int peerId) -{ - QString msgAuthor; - if (group->peers.contains(peerId)) - msgAuthor = group->peers[peerId]; - else - msgAuthor = tr(""); - - addMessage(msgAuthor, message); -} - void GroupChatForm::onUserListChanged() { nusersLabel->setText(tr("%1 users in chat").arg(group->nPeers)); diff --git a/widget/form/groupchatform.h b/widget/form/groupchatform.h index a544034de..6b3984b06 100644 --- a/widget/form/groupchatform.h +++ b/widget/form/groupchatform.h @@ -28,7 +28,6 @@ class GroupChatForm : public GenericChatForm public: GroupChatForm(Group* chatGroup); - void addGroupMessage(QString message, int peerId); void onUserListChanged(); private slots: diff --git a/widget/widget.cpp b/widget/widget.cpp index bfe0a483a..5cbaa74ee 100644 --- a/widget/widget.cpp +++ b/widget/widget.cpp @@ -209,7 +209,7 @@ void Widget::closeEvent(QCloseEvent *event) QString Widget::getUsername() { - return ui->nameLabel->text(); + return core->getUsername(); } Camera* Widget::getCamera() @@ -558,21 +558,21 @@ void Widget::onGroupInviteReceived(int32_t friendId, const uint8_t* publicKey,ui } } -void Widget::onGroupMessageReceived(int groupnumber, int friendgroupnumber, const QString& message) +void Widget::onGroupMessageReceived(int groupnumber, const QString& message, const QString& author) { Group* g = GroupList::findGroup(groupnumber); if (!g) return; - g->chatForm->addGroupMessage(message, friendgroupnumber); + g->chatForm->addMessage(author, message); if ((static_cast(g->widget) != activeChatroomWidget) || isMinimized() || !isActiveWindow()) { g->hasNewMessages = 1; + newMessageAlert(); // sound alert on any message, not just naming user if (message.contains(core->getUsername(), Qt::CaseInsensitive)) { - newMessageAlert(); - g->userWasMentioned = 1; + g->userWasMentioned = 1; // useful for highlighting line or desktop notifications } g->widget->updateStatusLight(); } diff --git a/widget/widget.h b/widget/widget.h index 3d7858e78..7e17f565f 100644 --- a/widget/widget.h +++ b/widget/widget.h @@ -92,7 +92,7 @@ private slots: void onFriendRequestReceived(const QString& userId, const QString& message); void onEmptyGroupCreated(int groupId); void onGroupInviteReceived(int32_t friendId, const uint8_t *publicKey,uint16_t length); - void onGroupMessageReceived(int groupnumber, int friendgroupnumber, const QString& message); + void onGroupMessageReceived(int groupnumber, const QString& message, const QString& author); void onGroupNamelistChanged(int groupnumber, int peernumber, uint8_t change); void removeFriend(int friendId); void copyFriendIdToClipboard(int friendId);