From 2f1f05af8bb356e9dc5cc883f2efd74ee60d7dae Mon Sep 17 00:00:00 2001 From: Viktor Govako Date: Sat, 18 May 2024 13:51:37 -0300 Subject: [PATCH] [search] Show "postal_code" string in search result UI. Signed-off-by: Viktor Govako --- .../main/cpp/app/organicmaps/SearchEngine.cpp | 5 +- .../CarPlay/MWMCarPlaySearchResultObject.mm | 5 +- .../Search/TableView/MWMSearchCommonCell.mm | 7 +-- .../TableView/MWMSearchTableViewController.mm | 3 - qt/search_panel.cpp | 57 ++++++++++++------- qt/search_panel.hpp | 7 ++- search/result.cpp | 28 +++++---- search/result.hpp | 4 +- 8 files changed, 65 insertions(+), 51 deletions(-) diff --git a/android/app/src/main/cpp/app/organicmaps/SearchEngine.cpp b/android/app/src/main/cpp/app/organicmaps/SearchEngine.cpp index 0532215dc5934..a66019d4497ca 100644 --- a/android/app/src/main/cpp/app/organicmaps/SearchEngine.cpp +++ b/android/app/src/main/cpp/app/organicmaps/SearchEngine.cpp @@ -106,12 +106,11 @@ jobject ToJavaResult(Result const & result, search::ProductInfo const & productI jni::TScopedLocalRef featureId(env, usermark_helper::CreateFeatureId(env, isFeature ? result.GetFeatureID() : kEmptyFeatureId)); - std::string const localizedType = isFeature ? result.GetLocalizedFeatureType() : ""; - jni::TScopedLocalRef featureType(env, jni::ToJavaString(env, localizedType)); + jni::TScopedLocalRef featureType(env, jni::ToJavaString(env, result.GetLocalizedFeatureType())); jni::TScopedLocalRef address(env, jni::ToJavaString(env, result.GetAddress())); jni::TScopedLocalRef dist(env, ToJavaDistance(env, distance)); - jni::TScopedLocalRef description(env, jni::ToJavaString(env, isFeature ? result.GetFeatureDescription() : "")); + jni::TScopedLocalRef description(env, jni::ToJavaString(env, result.GetFeatureDescription())); jni::TScopedLocalRef desc(env, env->NewObject(g_descriptionClass, g_descriptionConstructor, featureId.get(), featureType.get(), address.get(), diff --git a/iphone/Maps/Classes/CarPlay/MWMCarPlaySearchResultObject.mm b/iphone/Maps/Classes/CarPlay/MWMCarPlaySearchResultObject.mm index 93e39fc0d0361..05d9d172db82c 100644 --- a/iphone/Maps/Classes/CarPlay/MWMCarPlaySearchResultObject.mm +++ b/iphone/Maps/Classes/CarPlay/MWMCarPlaySearchResultObject.mm @@ -27,10 +27,7 @@ - (instancetype)initForRow:(NSInteger)row { MWMSearchItemType type = [MWMSearch resultTypeWithRow:row]; if (type == MWMSearchItemTypeRegular) { auto const & result = [MWMSearch resultWithContainerIndex:containerIndex]; - NSString *localizedTypeName = @""; - if (result.GetResultType() == search::Result::Type::Feature) - localizedTypeName = @(result.GetLocalizedFeatureType().c_str()); - + NSString *localizedTypeName = @(result.GetLocalizedFeatureType().c_str()); self.title = result.GetString().empty() ? localizedTypeName : @(result.GetString().c_str()); self.address = @(result.GetAddress().c_str()); auto const pivot = result.GetFeatureCenter(); diff --git a/iphone/Maps/UI/Search/TableView/MWMSearchCommonCell.mm b/iphone/Maps/UI/Search/TableView/MWMSearchCommonCell.mm index 987c5701ddbd7..44cdcc2e00cb9 100644 --- a/iphone/Maps/UI/Search/TableView/MWMSearchCommonCell.mm +++ b/iphone/Maps/UI/Search/TableView/MWMSearchCommonCell.mm @@ -31,11 +31,8 @@ - (void)config:(search::Result const &)result self.locationLabel.text = @(result.GetAddress().c_str()); [self.locationLabel sizeToFit]; - - if (result.GetResultType() == search::Result::Type::Feature) - self.infoLabel.text = @(result.GetFeatureDescription().c_str()); - else - self.infoLabel.text = @(""); + + self.infoLabel.text = @(result.GetFeatureDescription().c_str()); CLLocation * lastLocation = [MWMLocationManager lastLocation]; double distanceInMeters = 0.0; diff --git a/iphone/Maps/UI/Search/TableView/MWMSearchTableViewController.mm b/iphone/Maps/UI/Search/TableView/MWMSearchTableViewController.mm index d493995915179..1998f9bf02d8a 100644 --- a/iphone/Maps/UI/Search/TableView/MWMSearchTableViewController.mm +++ b/iphone/Maps/UI/Search/TableView/MWMSearchTableViewController.mm @@ -8,9 +8,6 @@ namespace { NSString *GetLocalizedTypeName(search::Result const &result) { - if (result.GetResultType() != search::Result::Type::Feature) - return @""; - return @(result.GetLocalizedFeatureType().c_str()); } } diff --git a/qt/search_panel.cpp b/qt/search_panel.cpp index 048975c1a2ad7..e8bb0c4e410c5 100644 --- a/qt/search_panel.cpp +++ b/qt/search_panel.cpp @@ -6,8 +6,6 @@ #include "map/bookmark_manager.hpp" #include "map/framework.hpp" -#include "platform/platform.hpp" - #include "base/assert.hpp" #include @@ -86,9 +84,9 @@ SearchPanel::SearchPanel(DrawWidget * drawWidget, QWidget * parent) namespace { -QTableWidgetItem * CreateItem(QString const & s) +QTableWidgetItem * CreateItem(std::string const & s) { - QTableWidgetItem * item = new QTableWidgetItem(s); + QTableWidgetItem * item = new QTableWidgetItem(QString::fromStdString(s)); item->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled); return item; } @@ -104,7 +102,7 @@ void SearchPanel::ClearResults() { ClearTable(); m_results.Clear(); - m_pDrawWidget->GetFramework().GetBookmarkManager().GetEditSession().ClearGroup(UserMark::Type::SEARCH); + GetFramework().GetBookmarkManager().GetEditSession().ClearGroup(UserMark::Type::SEARCH); } void SearchPanel::StartBusyIndicator() @@ -153,16 +151,29 @@ void SearchPanel::OnEverywhereSearchResults(uint64_t timestamp, search::Results int const rowCount = m_pTable->rowCount(); m_pTable->insertRow(rowCount); m_pTable->setCellWidget(rowCount, 1, new QLabel(strHigh)); - m_pTable->setItem(rowCount, 2, CreateItem(QString::fromStdString(res.GetAddress()))); + m_pTable->setItem(rowCount, 2, CreateItem(res.GetAddress())); - if (res.GetResultType() == search::Result::Type::Feature) + bool showDistance = true; + switch (res.GetResultType()) { - m_pTable->setItem(rowCount, 0, CreateItem(QString::fromStdString(res.GetLocalizedFeatureType()))); - m_pTable->setItem(rowCount, 3, CreateItem(QString::fromStdString(m_pDrawWidget->GetDistance(res)))); + case search::Result::Type::SuggestFromFeature: + case search::Result::Type::PureSuggest: + showDistance = false; + break; + case search::Result::Type::Feature: + case search::Result::Type::Postcode: + m_pTable->setItem(rowCount, 0, CreateItem(res.GetLocalizedFeatureType())); + break; + case search::Result::Type::LatLon: + m_pTable->setItem(rowCount, 0, CreateItem("LatLon")); + break; } + + if (showDistance) + m_pTable->setItem(rowCount, 3, CreateItem(m_pDrawWidget->GetDistance(res))); } - m_pDrawWidget->GetFramework().FillSearchResultsMarks(true /* clear */, m_results); + GetFramework().FillSearchResultsMarks(true /* clear */, m_results); if (m_results.IsEndMarker()) StopBusyIndicator(); @@ -177,8 +188,8 @@ bool SearchPanel::Try3dModeCmd(std::string const & str) if (!is3dModeOn && !is3dBuildingsOn && !is3dModeOff) return false; - m_pDrawWidget->GetFramework().Save3dMode(is3dModeOn || is3dBuildingsOn, is3dBuildingsOn); - m_pDrawWidget->GetFramework().Allow3dMode(is3dModeOn || is3dBuildingsOn, is3dBuildingsOn); + GetFramework().Save3dMode(is3dModeOn || is3dBuildingsOn, is3dBuildingsOn); + GetFramework().Allow3dMode(is3dModeOn || is3dBuildingsOn, is3dBuildingsOn); return true; } @@ -192,8 +203,8 @@ bool SearchPanel::TryTrafficSimplifiedColorsCmd(std::string const & str) return false; bool const isSimplified = simplifiedMode; - m_pDrawWidget->GetFramework().GetTrafficManager().SetSimplifiedColorScheme(isSimplified); - m_pDrawWidget->GetFramework().SaveTrafficSimplifiedColors(isSimplified); + GetFramework().GetTrafficManager().SetSimplifiedColorScheme(isSimplified); + GetFramework().SaveTrafficSimplifiedColors(isSimplified); return true; } @@ -228,7 +239,7 @@ void SearchPanel::OnSearchTextChanged(QString const & str) if (normalized.empty()) { - m_pDrawWidget->GetFramework().GetSearchAPI().CancelAllSearches(); + GetFramework().GetSearchAPI().CancelAllSearches(); // hide X button m_pClearButton->setVisible(false); @@ -251,7 +262,7 @@ void SearchPanel::OnSearchTextChanged(QString const & str) } }; - if (m_pDrawWidget->GetFramework().GetSearchAPI().SearchEverywhere(std::move(params))) + if (GetFramework().GetSearchAPI().SearchEverywhere(std::move(params))) StartBusyIndicator(); } else if (m_mode == Mode::Viewport) @@ -273,12 +284,12 @@ void SearchPanel::OnSearchTextChanged(QString const & str) // clearing the table would require additional care (or, most likely, we would need a better // API). This is similar to the Android and iOS clients where we do not show the list of // results in the viewport search mode. - m_pDrawWidget->GetFramework().FillSearchResultsMarks(true /* clear */, results); + GetFramework().FillSearchResultsMarks(true /* clear */, results); StopBusyIndicator(); } }; - m_pDrawWidget->GetFramework().GetSearchAPI().SearchInViewport(std::move(params)); + GetFramework().GetSearchAPI().SearchInViewport(std::move(params)); } } @@ -321,13 +332,13 @@ void SearchPanel::OnSearchPanelItemClicked(int row, int) else { // center viewport on clicked item - m_pDrawWidget->GetFramework().ShowSearchResult(m_results[row]); + GetFramework().ShowSearchResult(m_results[row]); } } void SearchPanel::hideEvent(QHideEvent *) { - m_pDrawWidget->GetFramework().GetSearchAPI().CancelSearch(search::Mode::Everywhere); + GetFramework().GetSearchAPI().CancelSearch(search::Mode::Everywhere); } void SearchPanel::OnAnimationTimer() @@ -347,4 +358,10 @@ void SearchPanel::OnClearButton() { m_pEditor->setText(""); } + +Framework & SearchPanel::GetFramework() const +{ + return m_pDrawWidget->GetFramework(); +} + } // namespace qt diff --git a/qt/search_panel.hpp b/qt/search_panel.hpp index 41aaa6907d9ae..6878ce9fa5bb0 100644 --- a/qt/search_panel.hpp +++ b/qt/search_panel.hpp @@ -5,8 +5,6 @@ #include "base/thread_checker.hpp" -#include - #include #include #include @@ -17,6 +15,8 @@ class QPushButton; class QTableWidget; class QTimer; +class Framework; + namespace qt { class DrawWidget; @@ -68,5 +68,8 @@ private slots: bool Try3dModeCmd(std::string const & str); bool TryTrafficSimplifiedColorsCmd(std::string const & str); + +private: + Framework & GetFramework() const; }; } // namespace qt diff --git a/search/result.cpp b/search/result.cpp index a13674b994317..80d8a115b8be9 100644 --- a/search/result.cpp +++ b/search/result.cpp @@ -87,24 +87,30 @@ std::string GetLocalizedTypeName(uint32_t type) std::string Result::GetLocalizedFeatureType() const { - ASSERT_EQUAL(m_resultType, Type::Feature, ()); - return GetLocalizedTypeName(m_mainType); + switch (m_resultType) + { + case Type::Feature: return GetLocalizedTypeName(m_mainType); + case Type::Postcode: return platform::GetLocalizedString("postal_code"); + default: return {}; + } } std::string Result::GetFeatureDescription() const { - ASSERT_EQUAL(m_resultType, Type::Feature, ()); - std::string featureDescription; + std::string res = GetLocalizedFeatureType(); + if (res.empty()) + return res; - auto const append = [&featureDescription](std::string_view sv) + auto const append = [&res](std::string_view sv) { - if (!featureDescription.empty()) - featureDescription += feature::kFieldsSeparator; - featureDescription += sv; + if (!res.empty()) + res += feature::kFieldsSeparator; + res += sv; }; - if (!m_str.empty()) - append(GetLocalizedTypeName(m_mainType)); + // Clear, because GetLocalizedFeatureType will be shown as main title. + if (m_str.empty()) + res.clear(); if (m_mainType != m_matchedType && m_matchedType != 0) append(GetLocalizedTypeName(m_matchedType)); @@ -112,7 +118,7 @@ std::string Result::GetFeatureDescription() const if (!GetDescription().empty()) append(GetDescription()); - return featureDescription; + return res; } m2::PointD Result::GetFeatureCenter() const diff --git a/search/result.hpp b/search/result.hpp index d642d50ac09fd..9b2a56b5ace88 100644 --- a/search/result.hpp +++ b/search/result.hpp @@ -91,10 +91,8 @@ class Result uint32_t GetFeatureType() const; bool IsSameType(uint32_t type) const; - // Precondition: GetResultType() == Type::Feature. std::string GetLocalizedFeatureType() const; - - // Precondition: GetResultType() == Type::Feature. + // Secondary title for the result. std::string GetFeatureDescription() const; // Center point of a feature.