From 239dfdc65c1fbb2f8f57b556371f91057c52f25e Mon Sep 17 00:00:00 2001 From: Anthony Bilinski Date: Sat, 16 Nov 2019 18:06:33 -0800 Subject: [PATCH] refactor(status): move isOnline into Status from Friend Allows checking if a status if equivalent to Online without needing a Friend class. --- src/model/chatroom/friendchatroom.cpp | 3 ++- src/model/chatroom/groupchatroom.cpp | 3 ++- src/model/friend.cpp | 5 ----- src/model/friend.h | 2 -- src/model/friendmessagedispatcher.cpp | 5 +++-- src/model/status.cpp | 5 +++++ src/model/status.h | 1 + src/persistence/offlinemsgengine.cpp | 3 ++- src/widget/form/chatform.cpp | 4 ++-- src/widget/form/groupchatform.cpp | 2 +- src/widget/widget.cpp | 2 +- test/persistence/offlinemsgengine_test.cpp | 5 +++-- 12 files changed, 22 insertions(+), 18 deletions(-) diff --git a/src/model/chatroom/friendchatroom.cpp b/src/model/chatroom/friendchatroom.cpp index 79f06a63f..d97d4d148 100644 --- a/src/model/chatroom/friendchatroom.cpp +++ b/src/model/chatroom/friendchatroom.cpp @@ -22,6 +22,7 @@ #include "src/model/dialogs/idialogsmanager.h" #include "src/model/friend.h" #include "src/model/group.h" +#include "src/model/status.h" #include "src/persistence/settings.h" #include "src/widget/contentdialog.h" @@ -67,7 +68,7 @@ void FriendChatroom::setActive(bool _active) bool FriendChatroom::canBeInvited() const { - return frnd->isOnline(); + return Status::isOnline(frnd->getStatus()); } int FriendChatroom::getCircleId() const diff --git a/src/model/chatroom/groupchatroom.cpp b/src/model/chatroom/groupchatroom.cpp index 3efeb8669..3c8327948 100644 --- a/src/model/chatroom/groupchatroom.cpp +++ b/src/model/chatroom/groupchatroom.cpp @@ -25,6 +25,7 @@ #include "src/model/dialogs/idialogsmanager.h" #include "src/model/friend.h" #include "src/model/group.h" +#include "src/model/status.h" #include "src/persistence/settings.h" GroupChatroom::GroupChatroom(Group* group, IDialogsManager* dialogsManager) @@ -64,7 +65,7 @@ void GroupChatroom::inviteFriend(const ToxPk& pk) const Friend* frnd = FriendList::findFriend(pk); const auto friendId = frnd->getId(); const auto groupId = group->getId(); - const auto canInvite = frnd->isOnline(); + const auto canInvite = Status::isOnline(frnd->getStatus()); if (canInvite) { Core::getInstance()->groupInviteFriend(friendId, groupId); diff --git a/src/model/friend.cpp b/src/model/friend.cpp index 08f80dadf..08bd1fc90 100644 --- a/src/model/friend.cpp +++ b/src/model/friend.cpp @@ -162,11 +162,6 @@ Status::Status Friend::getStatus() const return friendStatus; } -bool Friend::isOnline() const -{ - return friendStatus != Status::Status::Offline && friendStatus != Status::Status::Blocked; -} - bool Friend::useHistory() const { return true; diff --git a/src/model/friend.h b/src/model/friend.h index a3eaee790..8c48daf29 100644 --- a/src/model/friend.h +++ b/src/model/friend.h @@ -53,8 +53,6 @@ public: void setStatus(Status::Status s); Status::Status getStatus() const; - bool isOnline() const; - bool useHistory() const override final; signals: diff --git a/src/model/friendmessagedispatcher.cpp b/src/model/friendmessagedispatcher.cpp index 803b4645c..4927de7cb 100644 --- a/src/model/friendmessagedispatcher.cpp +++ b/src/model/friendmessagedispatcher.cpp @@ -19,6 +19,7 @@ #include "friendmessagedispatcher.h" #include "src/persistence/settings.h" +#include "src/model/status.h" namespace { @@ -69,7 +70,7 @@ FriendMessageDispatcher::sendMessage(bool isAction, const QString& content) bool messageSent = false; - if (f.isOnline()) { + if (Status::isOnline(f.getStatus())) { messageSent = sendMessageToCore(messageSender, f, message, receipt); } @@ -109,7 +110,7 @@ void FriendMessageDispatcher::onReceiptReceived(ReceiptNum receipt) */ void FriendMessageDispatcher::onFriendStatusChange(const ToxPk&, Status::Status) { - if (f.isOnline()) { + if (Status::isOnline(f.getStatus())) { offlineMsgEngine.deliverOfflineMsgs(); } } diff --git a/src/model/status.cpp b/src/model/status.cpp index 292ad97c3..50220126a 100644 --- a/src/model/status.cpp +++ b/src/model/status.cpp @@ -75,4 +75,9 @@ namespace Status return ":/img/status/" + statusSuffix + eventSuffix + ".svg"; } } + + bool isOnline(Status status) + { + return status != Status::Offline && status != Status::Blocked; + } } // namespace Status diff --git a/src/model/status.h b/src/model/status.h index b80c014cf..5ee11664e 100644 --- a/src/model/status.h +++ b/src/model/status.h @@ -38,6 +38,7 @@ namespace Status QString getIconPath(Status status, bool event = false); QString getTitle(Status status); QString getAssetSuffix(Status status); + bool isOnline(Status status); } #endif // STATUS_H diff --git a/src/persistence/offlinemsgengine.cpp b/src/persistence/offlinemsgengine.cpp index b1cff673b..053cba5e6 100644 --- a/src/persistence/offlinemsgengine.cpp +++ b/src/persistence/offlinemsgengine.cpp @@ -23,6 +23,7 @@ #include "src/nexus.h" #include "src/persistence/profile.h" #include "src/persistence/settings.h" +#include "src/model/status.h" #include #include #include @@ -91,7 +92,7 @@ void OfflineMsgEngine::deliverOfflineMsgs() { QMutexLocker ml(&mutex); - if (!f->isOnline()) { + if (!Status::isOnline(f->getStatus())) { return; } diff --git a/src/widget/form/chatform.cpp b/src/widget/form/chatform.cpp index 3489aacd5..7f4ecb927 100644 --- a/src/widget/form/chatform.cpp +++ b/src/widget/form/chatform.cpp @@ -404,7 +404,7 @@ void ChatForm::updateCallButtons() CoreAV* av = Core::getInstance()->getAv(); const bool audio = av->isCallActive(f); const bool video = av->isCallVideoEnabled(f); - const bool online = f->isOnline(); + const bool online = Status::isOnline(f->getStatus()); headWidget->updateCallButtons(online, audio, video); updateMuteMicButton(); updateMuteVolButton(); @@ -431,7 +431,7 @@ void ChatForm::onFriendStatusChanged(uint32_t friendId, Status::Status status) return; } - if (!f->isOnline()) { + if (!Status::isOnline(f->getStatus())) { // Hide the "is typing" message when a friend goes offline setFriendTyping(false); } diff --git a/src/widget/form/groupchatform.cpp b/src/widget/form/groupchatform.cpp index 58e23b027..454afbb92 100644 --- a/src/widget/form/groupchatform.cpp +++ b/src/widget/form/groupchatform.cpp @@ -307,7 +307,7 @@ void GroupChatForm::dropEvent(QDropEvent* ev) int friendId = frnd->getId(); int groupId = group->getId(); - if (frnd->isOnline()) { + if (Status::isOnline(frnd->getStatus())) { Core::getInstance()->groupInviteFriend(friendId, groupId); } } diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp index 57c7d4594..8770ab4dd 100644 --- a/src/widget/widget.cpp +++ b/src/widget/widget.cpp @@ -1231,7 +1231,7 @@ void Widget::onFriendStatusChanged(int friendId, Status::Status status) FriendWidget* widget = friendWidgets[f->getPublicKey()]; if (isActualChange) { - if (!f->isOnline()) { + if (!Status::isOnline(f->getStatus())) { contactListWidget->moveWidget(widget, Status::Status::Online); } else if (status == Status::Status::Offline) { contactListWidget->moveWidget(widget, Status::Status::Offline); diff --git a/test/persistence/offlinemsgengine_test.cpp b/test/persistence/offlinemsgengine_test.cpp index 22dcdf848..5a421d07c 100644 --- a/test/persistence/offlinemsgengine_test.cpp +++ b/test/persistence/offlinemsgengine_test.cpp @@ -19,6 +19,7 @@ #include "src/core/core.h" #include "src/model/friend.h" +#include "src/model/status.h" #include "src/persistence/offlinemsgengine.h" #include @@ -35,7 +36,7 @@ public: } bool sendMessage(uint32_t friendId, const QString& message, ReceiptNum& receipt) override { - if (f->isOnline()) { + if (Status::isOnline(f->getStatus())) { receipt.get() = receiptNum++; if (!dropReceipts) { msgs.push_back(message); @@ -45,7 +46,7 @@ public: } else { numMessagesFailed++; } - return f->isOnline(); + return Status::isOnline(f->getStatus()); } signals: