Skip to content

Commit

Permalink
[search] Show "postal_code" string in search result UI.
Browse files Browse the repository at this point in the history
Signed-off-by: Viktor Govako <[email protected]>
  • Loading branch information
vng committed May 22, 2024
1 parent 734d239 commit 2f1f05a
Show file tree
Hide file tree
Showing 8 changed files with 65 additions and 51 deletions.
5 changes: 2 additions & 3 deletions android/app/src/main/cpp/app/organicmaps/SearchEngine.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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(),
Expand Down
5 changes: 1 addition & 4 deletions iphone/Maps/Classes/CarPlay/MWMCarPlaySearchResultObject.mm
Original file line number Diff line number Diff line change
Expand Up @@ -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();
Expand Down
7 changes: 2 additions & 5 deletions iphone/Maps/UI/Search/TableView/MWMSearchCommonCell.mm
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,6 @@

namespace {
NSString *GetLocalizedTypeName(search::Result const &result) {
if (result.GetResultType() != search::Result::Type::Feature)
return @"";

return @(result.GetLocalizedFeatureType().c_str());
}
}
Expand Down
57 changes: 37 additions & 20 deletions qt/search_panel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@
#include "map/bookmark_manager.hpp"
#include "map/framework.hpp"

#include "platform/platform.hpp"

#include "base/assert.hpp"

#include <QtCore/QTimer>
Expand Down Expand Up @@ -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;
}
Expand All @@ -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()
Expand Down Expand Up @@ -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();
Expand All @@ -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;
}
Expand All @@ -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;
}
Expand Down Expand Up @@ -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);
Expand All @@ -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)
Expand All @@ -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));
}
}

Expand Down Expand Up @@ -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()
Expand All @@ -347,4 +358,10 @@ void SearchPanel::OnClearButton()
{
m_pEditor->setText("");
}

Framework & SearchPanel::GetFramework() const
{
return m_pDrawWidget->GetFramework();
}

} // namespace qt
7 changes: 5 additions & 2 deletions qt/search_panel.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,6 @@

#include "base/thread_checker.hpp"

#include <vector>

#include <QtGui/QIcon>
#include <QtGui/QPixmap>
#include <QtWidgets/QWidget>
Expand All @@ -17,6 +15,8 @@ class QPushButton;
class QTableWidget;
class QTimer;

class Framework;

namespace qt
{
class DrawWidget;
Expand Down Expand Up @@ -68,5 +68,8 @@ private slots:

bool Try3dModeCmd(std::string const & str);
bool TryTrafficSimplifiedColorsCmd(std::string const & str);

private:
Framework & GetFramework() const;
};
} // namespace qt
28 changes: 17 additions & 11 deletions search/result.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -87,32 +87,38 @@ 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));

if (!GetDescription().empty())
append(GetDescription());

return featureDescription;
return res;
}

m2::PointD Result::GetFeatureCenter() const
Expand Down
4 changes: 1 addition & 3 deletions search/result.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -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.
Expand Down

0 comments on commit 2f1f05a

Please sign in to comment.