From aaf5229ece69fb694381164f10bb85eb6fd53ee3 Mon Sep 17 00:00:00 2001 From: Monsterovich Date: Mon, 22 Oct 2018 02:01:05 +0200 Subject: [PATCH 1/6] feat(ui): Added feature to generate colors for user names in tox groups --- src/chatlog/chatmessage.cpp | 19 ++++++++++++++++++- src/persistence/settings.cpp | 13 +++++++++++++ src/persistence/settings.h | 3 +++ .../form/settings/userinterfaceform.cpp | 6 ++++++ src/widget/form/settings/userinterfaceform.h | 2 ++ .../form/settings/userinterfacesettings.ui | 11 +++++++++-- 6 files changed, 51 insertions(+), 3 deletions(-) diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp index ebb491dda..05aad0a45 100644 --- a/src/chatlog/chatmessage.cpp +++ b/src/chatlog/chatmessage.cpp @@ -29,6 +29,7 @@ #include "src/widget/style.h" #include +#include #include "src/persistence/settings.h" #include "src/persistence/smileypack.h" @@ -36,6 +37,8 @@ #define NAME_COL_WIDTH 90.0 #define TIME_COL_WIDTH 90.0 +QMap authorColor; + ChatMessage::ChatMessage() { } @@ -86,8 +89,22 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt if (isMe) authorFont.setBold(true); + QColor color = QColor(0, 0, 0); + + if (Settings::getInstance().getEnableGroupChatsColor()) + { + QByteArray hash = QCryptographicHash::hash((sender.toUtf8()), QCryptographicHash::Md5); + quint8 *data = (quint8*)hash.data(); + + if (!authorColor[sender].isValid()) + authorColor[sender] = QColor(data[0], data[1], data[2]); + + if (!isMe) + color = authorColor[sender]; + } + msg->addColumn(new Text(senderText, authorFont, true, sender, - type == ACTION ? actionColor : Qt::black), + type == ACTION ? actionColor : color), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); msg->addColumn(new Text(text, baseFont, false, ((type == ACTION) && isMe) ? QString("%1 %2").arg(sender, rawMessage) diff --git a/src/persistence/settings.cpp b/src/persistence/settings.cpp index ba14d71c3..057f989c2 100644 --- a/src/persistence/settings.cpp +++ b/src/persistence/settings.cpp @@ -242,6 +242,7 @@ void Settings::loadGlobal() else style = "None"; } + groupNameColors = s.value("groupNameColors", false).toBool(); } s.endGroup(); @@ -547,6 +548,7 @@ void Settings::saveGlobal() s.setValue("useEmoticons", useEmoticons); s.setValue("themeColor", themeColor); s.setValue("style", style); + s.setValue("groupNameColors", groupNameColors); s.setValue("statusChangeNotificationEnabled", statusChangeNotificationEnabled); s.setValue("spellCheckingEnabled", spellCheckingEnabled); } @@ -2417,6 +2419,17 @@ void Settings::setAutoLogin(bool state) } } +void Settings::setEnableGroupChatsColor(bool state) +{ + QMutexLocker locker{&bigLock}; + groupNameColors = state; +} + +bool Settings::getEnableGroupChatsColor() const +{ + return groupNameColors; +} + /** * @brief Write a default personal .ini settings file for a profile. * @param basename Filename without extension to save settings. diff --git a/src/persistence/settings.h b/src/persistence/settings.h index ecbebb256..4a999adff 100644 --- a/src/persistence/settings.h +++ b/src/persistence/settings.h @@ -530,6 +530,8 @@ public: bool getAutoLogin() const; void setAutoLogin(bool state); + void setEnableGroupChatsColor(bool state); + bool getEnableGroupChatsColor() const; int getCircleCount() const; int addCircle(const QString& name = QString()); @@ -606,6 +608,7 @@ private: bool notifySound; bool busySound; bool groupAlwaysNotify; + bool groupNameColors; bool forceTCP; bool enableLanDiscovery; diff --git a/src/widget/form/settings/userinterfaceform.cpp b/src/widget/form/settings/userinterfaceform.cpp index 9ed593efe..71f674742 100644 --- a/src/widget/form/settings/userinterfaceform.cpp +++ b/src/widget/form/settings/userinterfaceform.cpp @@ -73,6 +73,7 @@ UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) bodyUI->txtChatFont->setCurrentFont(chatBaseFont); int index = static_cast(s.getStylePreference()); bodyUI->textStyleComboBox->setCurrentIndex(index); + bodyUI->gcColors->setChecked(s.getEnableGroupChatsColor()); bodyUI->notify->setChecked(s.getNotify()); // Note: UI is boolean inversed from settings to maintain setting file backwards compatibility @@ -374,3 +375,8 @@ void UserInterfaceForm::on_txtChatFontSize_valueChanged(int px) s.setChatMessageFont(tmpFont); } } + +void UserInterfaceForm::on_gcColors_stateChanged(int arg1) +{ + Settings::getInstance().setEnableGroupChatsColor(arg1); +} diff --git a/src/widget/form/settings/userinterfaceform.h b/src/widget/form/settings/userinterfaceform.h index 7da4f5f21..16a179570 100644 --- a/src/widget/form/settings/userinterfaceform.h +++ b/src/widget/form/settings/userinterfaceform.h @@ -64,6 +64,8 @@ private slots: void on_txtChatFontSize_valueChanged(int arg1); + void on_gcColors_stateChanged(int arg1); + private: void retranslateUi(); void reloadSmileys(); diff --git a/src/widget/form/settings/userinterfacesettings.ui b/src/widget/form/settings/userinterfacesettings.ui index 899ccf3a0..bcdae0a77 100644 --- a/src/widget/form/settings/userinterfacesettings.ui +++ b/src/widget/form/settings/userinterfacesettings.ui @@ -39,8 +39,8 @@ 0 0 - 664 - 796 + 650 + 892 @@ -149,6 +149,13 @@ + + + + Use colors in group chats + + + From ab89ca2d8ebb641d7af2d5b1100eafe8bde759d4 Mon Sep 17 00:00:00 2001 From: Monsterovich Date: Mon, 22 Oct 2018 17:37:28 +0200 Subject: [PATCH 2/6] fix(ui): groupcolors fix1 --- src/persistence/settings.cpp | 8 ++++---- src/persistence/settings.h | 2 +- src/widget/form/settings/userinterfaceform.cpp | 4 ++-- src/widget/form/settings/userinterfaceform.h | 4 +--- src/widget/form/settings/userinterfacesettings.ui | 4 ++-- 5 files changed, 10 insertions(+), 12 deletions(-) diff --git a/src/persistence/settings.cpp b/src/persistence/settings.cpp index 057f989c2..a4fc6136f 100644 --- a/src/persistence/settings.cpp +++ b/src/persistence/settings.cpp @@ -242,7 +242,7 @@ void Settings::loadGlobal() else style = "None"; } - groupNameColors = s.value("groupNameColors", false).toBool(); + nameColors = s.value("nameColors", false).toBool(); } s.endGroup(); @@ -548,7 +548,7 @@ void Settings::saveGlobal() s.setValue("useEmoticons", useEmoticons); s.setValue("themeColor", themeColor); s.setValue("style", style); - s.setValue("groupNameColors", groupNameColors); + s.setValue("nameColors", nameColors); s.setValue("statusChangeNotificationEnabled", statusChangeNotificationEnabled); s.setValue("spellCheckingEnabled", spellCheckingEnabled); } @@ -2422,12 +2422,12 @@ void Settings::setAutoLogin(bool state) void Settings::setEnableGroupChatsColor(bool state) { QMutexLocker locker{&bigLock}; - groupNameColors = state; + nameColors = state; } bool Settings::getEnableGroupChatsColor() const { - return groupNameColors; + return nameColors; } /** diff --git a/src/persistence/settings.h b/src/persistence/settings.h index 4a999adff..f38f7d3b1 100644 --- a/src/persistence/settings.h +++ b/src/persistence/settings.h @@ -608,7 +608,7 @@ private: bool notifySound; bool busySound; bool groupAlwaysNotify; - bool groupNameColors; + bool nameColors; bool forceTCP; bool enableLanDiscovery; diff --git a/src/widget/form/settings/userinterfaceform.cpp b/src/widget/form/settings/userinterfaceform.cpp index 71f674742..f2df8331b 100644 --- a/src/widget/form/settings/userinterfaceform.cpp +++ b/src/widget/form/settings/userinterfaceform.cpp @@ -73,7 +73,7 @@ UserInterfaceForm::UserInterfaceForm(SettingsWidget* myParent) bodyUI->txtChatFont->setCurrentFont(chatBaseFont); int index = static_cast(s.getStylePreference()); bodyUI->textStyleComboBox->setCurrentIndex(index); - bodyUI->gcColors->setChecked(s.getEnableGroupChatsColor()); + bodyUI->useNameColors->setChecked(s.getEnableGroupChatsColor()); bodyUI->notify->setChecked(s.getNotify()); // Note: UI is boolean inversed from settings to maintain setting file backwards compatibility @@ -376,7 +376,7 @@ void UserInterfaceForm::on_txtChatFontSize_valueChanged(int px) } } -void UserInterfaceForm::on_gcColors_stateChanged(int arg1) +void UserInterfaceForm::on_useNameColors_stateChanged(int arg1) { Settings::getInstance().setEnableGroupChatsColor(arg1); } diff --git a/src/widget/form/settings/userinterfaceform.h b/src/widget/form/settings/userinterfaceform.h index 16a179570..273101420 100644 --- a/src/widget/form/settings/userinterfaceform.h +++ b/src/widget/form/settings/userinterfaceform.h @@ -62,10 +62,8 @@ private slots: void on_txtChatFont_currentFontChanged(const QFont& f); void on_txtChatFontSize_valueChanged(int arg1); + void on_useNameColors_stateChanged(int arg1); - - void on_gcColors_stateChanged(int arg1); - private: void retranslateUi(); void reloadSmileys(); diff --git a/src/widget/form/settings/userinterfacesettings.ui b/src/widget/form/settings/userinterfacesettings.ui index bcdae0a77..48d98d94e 100644 --- a/src/widget/form/settings/userinterfacesettings.ui +++ b/src/widget/form/settings/userinterfacesettings.ui @@ -150,9 +150,9 @@ - + - Use colors in group chats + Use colored nicknames in chats From a4a8e361d0e5aed1b3461dacd63b6a3600339a6f Mon Sep 17 00:00:00 2001 From: Monsterovich Date: Mon, 22 Oct 2018 18:23:41 +0200 Subject: [PATCH 3/6] fix(ui): groupcolors fix2 --- src/chatlog/chatmessage.cpp | 4 ++-- src/chatlog/chatmessage.h | 2 +- src/widget/form/genericchatform.cpp | 14 +++++++------- src/widget/form/genericchatform.h | 6 +++--- src/widget/widget.cpp | 5 +++-- 5 files changed, 16 insertions(+), 15 deletions(-) diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp index 05aad0a45..ce5bdad9c 100644 --- a/src/chatlog/chatmessage.cpp +++ b/src/chatlog/chatmessage.cpp @@ -44,7 +44,7 @@ ChatMessage::ChatMessage() } ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QString& rawMessage, - MessageType type, bool isMe, const QDateTime& date) + MessageType type, bool isMe, const QDateTime& date, bool colorizeName) { ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage); @@ -91,7 +91,7 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt QColor color = QColor(0, 0, 0); - if (Settings::getInstance().getEnableGroupChatsColor()) + if (colorizeName && Settings::getInstance().getEnableGroupChatsColor()) { QByteArray hash = QCryptographicHash::hash((sender.toUtf8()), QCryptographicHash::Md5); quint8 *data = (quint8*)hash.data(); diff --git a/src/chatlog/chatmessage.h b/src/chatlog/chatmessage.h index 5091224ac..d920fe426 100644 --- a/src/chatlog/chatmessage.h +++ b/src/chatlog/chatmessage.h @@ -49,7 +49,7 @@ public: static ChatMessage::Ptr createChatMessage(const QString& sender, const QString& rawMessage, MessageType type, bool isMe, - const QDateTime& date = QDateTime()); + const QDateTime& date = QDateTime(), bool colorizeName = false); static ChatMessage::Ptr createChatInfoMessage(const QString& rawMessage, SystemMessageType type, const QDateTime& date); static ChatMessage::Ptr createFileTransferMessage(const QString& sender, ToxFile file, diff --git a/src/widget/form/genericchatform.cpp b/src/widget/form/genericchatform.cpp index 02b7c65e6..785fd6338 100644 --- a/src/widget/form/genericchatform.cpp +++ b/src/widget/form/genericchatform.cpp @@ -372,7 +372,7 @@ bool GenericChatForm::needsToHideName(const ToxPk& messageAuthor, const QDateTim * @return ChatMessage object */ ChatMessage::Ptr GenericChatForm::createMessage(const ToxPk& author, const QString& message, - const QDateTime& dt, bool isAction, bool isSent) + const QDateTime& dt, bool isAction, bool isSent, bool colorizeName) { const Core* core = Core::getInstance(); bool isSelf = author == core->getSelfId().getPublicKey(); @@ -383,10 +383,10 @@ ChatMessage::Ptr GenericChatForm::createMessage(const ToxPk& author, const QStri ChatMessage::Ptr msg; if (isAction) { - msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::ACTION, isSelf); + msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::ACTION, isSelf, QDateTime(), colorizeName); previousId = ToxPk{}; } else { - msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::NORMAL, isSelf); + msg = ChatMessage::createChatMessage(authorStr, message, ChatMessage::NORMAL, isSelf, QDateTime(), colorizeName); const QDateTime newMsgDateTime = QDateTime::currentDateTime(); if (needsToHideName(author, newMsgDateTime)) { msg->hideSender(); @@ -418,9 +418,9 @@ ChatMessage::Ptr GenericChatForm::createSelfMessage(const QString& message, cons * @brief Inserts message into ChatLog */ void GenericChatForm::addMessage(const ToxPk& author, const QString& message, const QDateTime& dt, - bool isAction) + bool isAction, bool colorizeName) { - createMessage(author, message, dt, isAction, true); + createMessage(author, message, dt, isAction, true, colorizeName); } /** @@ -431,11 +431,11 @@ void GenericChatForm::addSelfMessage(const QString& message, const QDateTime& da createSelfMessage(message, datetime, isAction, true); } -void GenericChatForm::addAlertMessage(const ToxPk& author, const QString& msg, const QDateTime& dt) +void GenericChatForm::addAlertMessage(const ToxPk& author, const QString& msg, const QDateTime& dt, bool colorizeName) { QString authorStr = resolveToxPk(author); bool isSelf = author == Core::getInstance()->getSelfId().getPublicKey(); - auto chatMsg = ChatMessage::createChatMessage(authorStr, msg, ChatMessage::ALERT, isSelf, dt); + auto chatMsg = ChatMessage::createChatMessage(authorStr, msg, ChatMessage::ALERT, isSelf, dt, colorizeName); const QDateTime newMsgDateTime = QDateTime::currentDateTime(); if (needsToHideName(author, newMsgDateTime)) { chatMsg->hideSender(); diff --git a/src/widget/form/genericchatform.h b/src/widget/form/genericchatform.h index 65f1bf974..ff04bb0d3 100644 --- a/src/widget/form/genericchatform.h +++ b/src/widget/form/genericchatform.h @@ -75,11 +75,11 @@ public: virtual void show(ContentLayout* contentLayout); void addMessage(const ToxPk& author, const QString& message, const QDateTime& datetime, - bool isAction); + bool isAction, bool colorizeName = false); void addSelfMessage(const QString& message, const QDateTime& datetime, bool isAction); void addSystemInfoMessage(const QString& message, ChatMessage::SystemMessageType type, const QDateTime& datetime); - void addAlertMessage(const ToxPk& author, const QString& message, const QDateTime& datetime); + void addAlertMessage(const ToxPk& author, const QString& message, const QDateTime& datetime, bool colorizeName = false); static QString resolveToxPk(const ToxPk& pk); QDate getLatestDate() const; QDate getFirstDate() const; @@ -127,7 +127,7 @@ private: protected: ChatMessage::Ptr createMessage(const ToxPk& author, const QString& message, - const QDateTime& datetime, bool isAction, bool isSent); + const QDateTime& datetime, bool isAction, bool isSent, bool colorizeName = false); ChatMessage::Ptr createSelfMessage(const QString& message, const QDateTime& datetime, bool isAction, bool isSent); bool needsToHideName(const ToxPk& messageAuthor, const QDateTime& messageTime) const; diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp index b274b67ca..a1abd6542 100644 --- a/src/widget/widget.cpp +++ b/src/widget/widget.cpp @@ -1750,10 +1750,11 @@ void Widget::onGroupMessageReceived(int groupnumber, int peernumber, const QStri const auto groupId = g->getId(); const auto date = QDateTime::currentDateTime(); auto form = groupChatForms[groupId]; + if (targeted && !isAction) { - form->addAlertMessage(author, message, date); + form->addAlertMessage(author, message, date, true); } else { - form->addMessage(author, message, date, isAction); + form->addMessage(author, message, date, isAction, true); } newGroupMessageAlert(groupId, targeted || Settings::getInstance().getGroupAlwaysNotify()); From 89cb24254dc21077e2d0b8d014932e87940586ba Mon Sep 17 00:00:00 2001 From: Monsterovich Date: Wed, 24 Oct 2018 00:17:06 +0200 Subject: [PATCH 4/6] fix(ui): fix anything --- src/chatlog/chatmessage.cpp | 9 +++++++-- src/widget/form/settings/userinterfaceform.cpp | 4 ++-- src/widget/form/settings/userinterfaceform.h | 2 +- 3 files changed, 10 insertions(+), 5 deletions(-) diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp index ce5bdad9c..f93cfb1c9 100644 --- a/src/chatlog/chatmessage.cpp +++ b/src/chatlog/chatmessage.cpp @@ -93,14 +93,19 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt if (colorizeName && Settings::getInstance().getEnableGroupChatsColor()) { - QByteArray hash = QCryptographicHash::hash((sender.toUtf8()), QCryptographicHash::Md5); + QByteArray hash = QCryptographicHash::hash((sender.toUtf8()), QCryptographicHash::Sha256); quint8 *data = (quint8*)hash.data(); if (!authorColor[sender].isValid()) - authorColor[sender] = QColor(data[0], data[1], data[2]); + { + color.setHsv(data[0], data[1], data[2]); + authorColor[sender] = color; + } if (!isMe) + { color = authorColor[sender]; + } } msg->addColumn(new Text(senderText, authorFont, true, sender, diff --git a/src/widget/form/settings/userinterfaceform.cpp b/src/widget/form/settings/userinterfaceform.cpp index f2df8331b..37ae38014 100644 --- a/src/widget/form/settings/userinterfaceform.cpp +++ b/src/widget/form/settings/userinterfaceform.cpp @@ -376,7 +376,7 @@ void UserInterfaceForm::on_txtChatFontSize_valueChanged(int px) } } -void UserInterfaceForm::on_useNameColors_stateChanged(int arg1) +void UserInterfaceForm::on_useNameColors_stateChanged(int value) { - Settings::getInstance().setEnableGroupChatsColor(arg1); + Settings::getInstance().setEnableGroupChatsColor(value); } diff --git a/src/widget/form/settings/userinterfaceform.h b/src/widget/form/settings/userinterfaceform.h index 273101420..63d1c5676 100644 --- a/src/widget/form/settings/userinterfaceform.h +++ b/src/widget/form/settings/userinterfaceform.h @@ -62,7 +62,7 @@ private slots: void on_txtChatFont_currentFontChanged(const QFont& f); void on_txtChatFontSize_valueChanged(int arg1); - void on_useNameColors_stateChanged(int arg1); + void on_useNameColors_stateChanged(int value); private: void retranslateUi(); From d54e21064c596dceef87b43b41d5b2723f244131 Mon Sep 17 00:00:00 2001 From: Monsterovich Date: Wed, 24 Oct 2018 00:28:49 +0200 Subject: [PATCH 5/6] fix(ui): oops --- src/chatlog/chatmessage.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp index f93cfb1c9..4305e2ff3 100644 --- a/src/chatlog/chatmessage.cpp +++ b/src/chatlog/chatmessage.cpp @@ -98,8 +98,7 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt if (!authorColor[sender].isValid()) { - color.setHsv(data[0], data[1], data[2]); - authorColor[sender] = color; + authorColor[sender].setHsv(data[0], 255, 196); } if (!isMe) From 2557f5e04521a7e19708e6254936e9d0eb625beb Mon Sep 17 00:00:00 2001 From: Monsterovich Date: Thu, 25 Oct 2018 02:44:11 +0200 Subject: [PATCH 6/6] fix(ui): remove useless variable --- src/chatlog/chatmessage.cpp | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp index 4305e2ff3..42f4ea2e2 100644 --- a/src/chatlog/chatmessage.cpp +++ b/src/chatlog/chatmessage.cpp @@ -37,7 +37,6 @@ #define NAME_COL_WIDTH 90.0 #define TIME_COL_WIDTH 90.0 -QMap authorColor; ChatMessage::ChatMessage() { @@ -90,20 +89,18 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt authorFont.setBold(true); QColor color = QColor(0, 0, 0); + QColor authorColor; if (colorizeName && Settings::getInstance().getEnableGroupChatsColor()) { QByteArray hash = QCryptographicHash::hash((sender.toUtf8()), QCryptographicHash::Sha256); quint8 *data = (quint8*)hash.data(); - if (!authorColor[sender].isValid()) - { - authorColor[sender].setHsv(data[0], 255, 196); - } + authorColor.setHsv(data[0], 255, 196); if (!isMe) { - color = authorColor[sender]; + color = authorColor; } }