diff --git a/core.cpp b/core.cpp index fdc91616a..ea83116b8 100644 --- a/core.cpp +++ b/core.cpp @@ -439,9 +439,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 b911d3372..9c67da6f6 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/smileys/default/Kappa.png b/smileys/default/Kappa.png new file mode 100644 index 000000000..a7ebbec4d Binary files /dev/null and b/smileys/default/Kappa.png differ diff --git a/smileys/default/emoticons.xml b/smileys/default/emoticons.xml index d1fe8c715..c6f816f7b 100644 --- a/smileys/default/emoticons.xml +++ b/smileys/default/emoticons.xml @@ -82,4 +82,7 @@ XD + + :Kappa: + diff --git a/tools/buildPackages.sh b/tools/buildPackages.sh index 0c12e11c6..501d7b429 100755 --- a/tools/buildPackages.sh +++ b/tools/buildPackages.sh @@ -87,7 +87,7 @@ mv qTox-master $VERNAME # Build packages cd $VERNAME -./bootstrap.sh +./bootstrap.sh --local debuild -us -uc -aamd64 debuild -us -uc -ai386 cd .. diff --git a/widget/chatareawidget.cpp b/widget/chatareawidget.cpp index c743574fa..d3d326b63 100644 --- a/widget/chatareawidget.cpp +++ b/widget/chatareawidget.cpp @@ -38,7 +38,7 @@ ChatAreaWidget::ChatAreaWidget(QWidget *parent) setFrameStyle(QFrame::NoFrame); QTextTableFormat tableFormat; - tableFormat.setCellSpacing(15); + tableFormat.setCellSpacing(5); tableFormat.setBorderStyle(QTextFrameFormat::BorderStyle_None); tableFormat.setColumnWidthConstraints({QTextLength(QTextLength::FixedLength,nameWidth), QTextLength(QTextLength::PercentageLength,100), 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 ad08389bf..53a34449c 100644 --- a/widget/widget.cpp +++ b/widget/widget.cpp @@ -212,7 +212,7 @@ void Widget::closeEvent(QCloseEvent *event) QString Widget::getUsername() { - return ui->nameLabel->text(); + return core->getUsername(); } Camera* Widget::getCamera() @@ -574,21 +574,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 aae819adc..c9d4e6388 100644 --- a/widget/widget.h +++ b/widget/widget.h @@ -94,7 +94,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);