diff --git a/src/chatlog/chatlog.cpp b/src/chatlog/chatlog.cpp index ae9bc3184..308514faf 100644 --- a/src/chatlog/chatlog.cpp +++ b/src/chatlog/chatlog.cpp @@ -672,7 +672,7 @@ void ChatLog::scrollToLine(ChatLine::Ptr line) workerStb = false; } else { updateSceneRect(); - verticalScrollBar()->setValue(line->sceneBoundingRect().top()); + verticalScrollBar()->setValue(line->sceneBoundingRect().top()); // NOTE: start here } } diff --git a/src/model/ichatlog.h b/src/model/ichatlog.h index 44a4c0937..f14220073 100644 --- a/src/model/ichatlog.h +++ b/src/model/ichatlog.h @@ -69,7 +69,7 @@ struct SearchPos struct SearchResult { - bool found{false}; + bool found; SearchPos pos; size_t start; size_t len; diff --git a/src/widget/form/genericchatform.cpp b/src/widget/form/genericchatform.cpp index 7827872b0..cdc8a3906 100644 --- a/src/widget/form/genericchatform.cpp +++ b/src/widget/form/genericchatform.cpp @@ -716,11 +716,7 @@ void GenericChatForm::loadHistoryTo(const QDateTime &time) } if (begin != end) { - if (searchResult.found == true) { - renderMessages(begin, searchResult.pos.logIdx, [this]{enableSearchText();}); - } else { - renderMessages(begin, end); - } + renderMessages(begin, end); } else { chatWidget->setScroll(true); } @@ -765,23 +761,13 @@ void GenericChatForm::removeLastsMessages(const int num) void GenericChatForm::disableSearchText() { - auto msgIt = messages.find(searchResult.pos.logIdx); + auto msgIt = messages.find(searchPos.logIdx); if (msgIt != messages.end()) { auto text = qobject_cast(msgIt->second->getContent(1)); text->deselectText(); } } -void GenericChatForm::enableSearchText() -{ - auto msg = messages.at(searchResult.pos.logIdx); - chatWidget->scrollToLine(msg); - - auto text = qobject_cast(msg->getContent(1)); - text->visibilityChanged(true); - text->selectText(searchResult.exp, std::make_pair(searchResult.start, searchResult.len)); -} - void GenericChatForm::clearChatArea() { clearChatArea(/* confirm = */ true, /* inform = */ true); @@ -959,7 +945,6 @@ void GenericChatForm::onExportChat() void GenericChatForm::onSearchTriggered() { if (searchForm->isHidden()) { - searchResult.found = false; searchForm->removeSearchPhrase(); } disableSearchText(); @@ -989,27 +974,27 @@ void GenericChatForm::searchInBegin(const QString& phrase, const ParameterSearch switch (parameter.period) { case PeriodSearch::WithTheFirst: { bForwardSearch = true; - searchResult.pos.logIdx = chatLog.getFirstIdx(); - searchResult.pos.numMatches = 0; + searchPos.logIdx = chatLog.getFirstIdx(); + searchPos.numMatches = 0; break; } case PeriodSearch::WithTheEnd: case PeriodSearch::None: { bForwardSearch = false; - searchResult.pos.logIdx = chatLog.getNextIdx(); - searchResult.pos.numMatches = 0; + searchPos.logIdx = chatLog.getNextIdx(); + searchPos.numMatches = 0; break; } case PeriodSearch::AfterDate: { bForwardSearch = true; - searchResult.pos.logIdx = firstItemAfterDate(parameter.time.date(), chatLog); - searchResult.pos.numMatches = 0; + searchPos.logIdx = firstItemAfterDate(parameter.time.date(), chatLog); + searchPos.numMatches = 0; break; } case PeriodSearch::BeforeDate: { bForwardSearch = false; - searchResult.pos.logIdx = firstItemAfterDate(parameter.time.date(), chatLog); - searchResult.pos.numMatches = 0; + searchPos.logIdx = firstItemAfterDate(parameter.time.date(), chatLog); + searchPos.numMatches = 0; break; } } @@ -1023,13 +1008,13 @@ void GenericChatForm::searchInBegin(const QString& phrase, const ParameterSearch void GenericChatForm::onSearchUp(const QString& phrase, const ParameterSearch& parameter) { - auto result = chatLog.searchBackward(searchResult.pos, phrase, parameter); + auto result = chatLog.searchBackward(searchPos, phrase, parameter); handleSearchResult(result, SearchDirection::Up); } void GenericChatForm::onSearchDown(const QString& phrase, const ParameterSearch& parameter) { - auto result = chatLog.searchForward(searchResult.pos, phrase, parameter); + auto result = chatLog.searchForward(searchPos, phrase, parameter); if (result.found && result.pos.logIdx.get() > messages.end()->first.get()) { const auto dt = chatLog.at(result.pos.logIdx).getTimestamp(); @@ -1048,11 +1033,18 @@ void GenericChatForm::handleSearchResult(SearchResult result, SearchDirection di disableSearchText(); - searchResult = result; + searchPos = result.pos; auto const firstRenderedIdx = (messages.empty()) ? chatLog.getNextIdx() : messages.begin()->first; - renderMessages(searchResult.pos.logIdx, firstRenderedIdx, [this]{enableSearchText();}); + renderMessages(searchPos.logIdx, firstRenderedIdx, [this, result] { + auto msg = messages.at(searchPos.logIdx); + chatWidget->scrollToLine(msg); + + auto text = qobject_cast(msg->getContent(1)); + text->visibilityChanged(true); + text->selectText(result.exp, std::make_pair(result.start, result.len)); + }); } void GenericChatForm::renderItem(const ChatLogItem& item, bool hideName, bool colorizeNames, ChatMessage::Ptr& chatMessage) diff --git a/src/widget/form/genericchatform.h b/src/widget/form/genericchatform.h index a7eb91870..6a5055f26 100644 --- a/src/widget/form/genericchatform.h +++ b/src/widget/form/genericchatform.h @@ -148,7 +148,6 @@ protected: void resizeEvent(QResizeEvent* event) final; bool eventFilter(QObject* object, QEvent* event) final; void disableSearchText(); - void enableSearchText(); bool searchInText(const QString& phrase, const ParameterSearch& parameter, SearchDirection direction); std::pair indexForSearchInLine(const QString& txt, const QString& phrase, const ParameterSearch& parameter, SearchDirection direction); @@ -190,7 +189,7 @@ protected: IChatLog& chatLog; IMessageDispatcher& messageDispatcher; - SearchResult searchResult; + SearchPos searchPos; std::map messages; bool colorizeNames = false; };