diff --git a/src/widget/contentdialog.cpp b/src/widget/contentdialog.cpp index ae0097d76..6d5b8bf93 100644 --- a/src/widget/contentdialog.cpp +++ b/src/widget/contentdialog.cpp @@ -557,6 +557,26 @@ void ContentDialog::keyPressEvent(QKeyEvent* event) } } +void ContentDialog::focusFriend(int friendId) +{ + focusCommon(friendId, friendWidgets); +} + +void ContentDialog::focusGroup(int groupId) +{ + focusCommon(groupId, groupWidgets); +} + +void ContentDialog::focusCommon(int id, QHash list) +{ + auto it = list.find(id); + if (it == list.end()) { + return; + } + + activate(*it); +} + /** * @brief Show ContentDialog, activate chatroom widget. * @param widget Widget which should be activated. diff --git a/src/widget/contentdialog.h b/src/widget/contentdialog.h index ba18ee56f..2ab91f3f9 100644 --- a/src/widget/contentdialog.h +++ b/src/widget/contentdialog.h @@ -74,6 +74,9 @@ public: bool hasFriendWidget(int friendId) const; bool hasGroupWidget(int groupId) const; + void focusFriend(int friendId); + void focusGroup(int groupId); + signals: void friendDialogShown(const Friend* f); void groupDialogShown(Group* g); @@ -111,6 +114,9 @@ private: void saveSplitterState(); QLayout* nextLayout(QLayout* layout, bool forward) const; int getCurrentLayout(QLayout*& layout); + void focusCommon(int id, QHash list); + +private: QList layouts; QSplitter* splitter; diff --git a/src/widget/contentdialogmanager.cpp b/src/widget/contentdialogmanager.cpp index 3bee0f1a2..02d0bb1a7 100644 --- a/src/widget/contentdialogmanager.cpp +++ b/src/widget/contentdialogmanager.cpp @@ -97,34 +97,39 @@ bool ContentDialogManager::existsWidget(int id, const QHash& l void ContentDialogManager::focusFriend(int friendId) { - focusDialog(friendId, friendList); + auto dialog = focusDialog(friendId, friendDialogs); + if (dialog != nullptr) + dialog->focusFriend(friendId); } void ContentDialogManager::focusGroup(int groupId) { - focusDialog(groupId, groupList); + auto dialog = focusDialog(groupId, groupDialogs); + if (dialog != nullptr) + dialog->focusGroup(groupId); } /** * @brief Focus the dialog if it exists. * @param id User Id. - * @param list List with contact info. + * @param list List with dialogs + * @return ContentDialog if found, nullptr otherwise */ -void ContentDialogManager::focusDialog(int id, const QHash& list) +ContentDialog* ContentDialogManager::focusDialog(int id, const QHash& list) { auto iter = list.find(id); if (iter == list.end()) { - return; + return nullptr; } - ContentDialog* dialog = std::get<0>(*iter); + ContentDialog* dialog = *iter; if (dialog->windowState() & Qt::WindowMinimized) { dialog->showNormal(); } dialog->raise(); dialog->activateWindow(); - dialog->activate(std::get<1>(iter.value())); + return dialog; } void ContentDialogManager::updateFriendStatus(int friendId) diff --git a/src/widget/contentdialogmanager.h b/src/widget/contentdialogmanager.h index 6f8eaacfa..ac0c8d43b 100644 --- a/src/widget/contentdialogmanager.h +++ b/src/widget/contentdialogmanager.h @@ -55,8 +55,8 @@ private slots: void onDialogActivate(); private: + ContentDialog* focusDialog(int id, const QHash& list); bool existsWidget(int id, const QHash& list); - void focusDialog(int id, const QHash& list); void updateStatus(int id, const QHash& list); bool isWidgetActive(int id, const QHash& list); ContentDialog* getDialog(int id, const QHash& list) const;