Repo created
This commit is contained in:
parent
4af19165ec
commit
68073add76
12458 changed files with 12350765 additions and 2 deletions
118
iphone/Maps/Core/Search/SearchResult.mm
Normal file
118
iphone/Maps/Core/Search/SearchResult.mm
Normal file
|
|
@ -0,0 +1,118 @@
|
|||
#import "SearchResult+Core.h"
|
||||
#import "CLLocation+Mercator.h"
|
||||
#import "MWMLocationManager.h"
|
||||
#import "SwiftBridge.h"
|
||||
|
||||
#import "platform/localization.hpp"
|
||||
#import "platform/distance.hpp"
|
||||
|
||||
#include "map/bookmark_helpers.hpp"
|
||||
|
||||
#import "geometry/mercator.hpp"
|
||||
|
||||
@implementation SearchResult
|
||||
|
||||
- (instancetype)initWithTitleText:(NSString *)titleText type:(SearchItemType)type suggestion:(NSString *)suggestion {
|
||||
self = [super init];
|
||||
if (self) {
|
||||
_titleText = titleText;
|
||||
_itemType = type;
|
||||
_suggestion = suggestion;
|
||||
};
|
||||
return self;
|
||||
}
|
||||
|
||||
@end
|
||||
|
||||
@implementation SearchResult(Core)
|
||||
|
||||
- (instancetype)initWithResult:(const search::Result &)result itemType:(SearchItemType)itemType index:(NSUInteger)index {
|
||||
self = [super init];
|
||||
if (self) {
|
||||
_index = index;
|
||||
_titleText = result.GetString().empty() ? @(result.GetLocalizedFeatureType().c_str()) : @(result.GetString().c_str());
|
||||
_addressText = @(result.GetAddress().c_str());
|
||||
_infoText = @(result.GetFeatureDescription().c_str());
|
||||
_branchText = result.GetBranch().empty() ? nil : @(result.GetBranch().c_str());
|
||||
if (result.IsSuggest())
|
||||
_suggestion = @(result.GetSuggestionString().c_str());
|
||||
|
||||
_distanceText = nil;
|
||||
if (result.HasPoint()) {
|
||||
auto const center = result.GetFeatureCenter();
|
||||
_point = CGPointMake(center.x, center.y);
|
||||
auto const [centerLat, centerLon] = mercator::ToLatLon(center);
|
||||
_coordinate = CLLocationCoordinate2DMake(centerLat, centerLon);
|
||||
|
||||
CLLocation * lastLocation = [MWMLocationManager lastLocation];
|
||||
if (lastLocation) {
|
||||
double const distanceM = mercator::DistanceOnEarth(lastLocation.mercator, center);
|
||||
std::string const distanceStr = platform::Distance::CreateFormatted(distanceM).ToString();
|
||||
_distanceText = @(distanceStr.c_str());
|
||||
}
|
||||
}
|
||||
|
||||
switch (result.IsOpenNow()) {
|
||||
case osm::Yes: {
|
||||
const int minutes = result.GetMinutesUntilClosed();
|
||||
if (minutes < 60) { // less than 1 hour
|
||||
_openStatusColor = [UIColor colorNamed:@"Base Colors/Yellow Color"];
|
||||
NSString * time = [NSString stringWithFormat:@"%d %@", minutes, L(@"minute")];
|
||||
_openStatusText = [NSString stringWithFormat:L(@"closes_in"), time];
|
||||
} else {
|
||||
_openStatusColor = [UIColor colorNamed:@"Base Colors/Green Color"];
|
||||
_openStatusText = L(@"editor_time_open");
|
||||
}
|
||||
break;
|
||||
}
|
||||
case osm::No: {
|
||||
const int minutes = result.GetMinutesUntilOpen();
|
||||
if (minutes < 15) { // less than 15 minutes
|
||||
_openStatusColor = [UIColor colorNamed:@"Base Colors/Yellow Color"];
|
||||
NSString * time = [NSString stringWithFormat:@"%d %@", minutes, L(@"minute")];
|
||||
_openStatusText = [NSString stringWithFormat:L(@"opens_in"), time];
|
||||
}
|
||||
else if (minutes < 60) { // less than an hour (but more than 15 mins)
|
||||
_openStatusColor = [UIColor colorNamed:@"Base Colors/Red Color"];
|
||||
NSString * time = [NSString stringWithFormat:@"%d %@", minutes, L(@"minute")];
|
||||
_openStatusText = [NSString stringWithFormat:L(@"opens_in"), time];
|
||||
}
|
||||
else { // opens later or schedule is unknown
|
||||
_openStatusColor = [UIColor colorNamed:@"Base Colors/Red Color"];
|
||||
_openStatusText = L(@"closed");
|
||||
}
|
||||
break;
|
||||
}
|
||||
case osm::Unknown: {
|
||||
_openStatusText = nil;
|
||||
_openStatusColor = UIColor.clearColor;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
_isPopularHidden = YES; // Restore logic in the future when popularity is available.
|
||||
_isPureSuggest = result.GetResultType() == search::Result::Type::PureSuggest;
|
||||
|
||||
NSMutableArray<NSValue *> * ranges = [NSMutableArray array];
|
||||
size_t const rangesCount = result.GetHighlightRangesCount();
|
||||
for (size_t i = 0; i < rangesCount; ++i) {
|
||||
auto const &range = result.GetHighlightRange(i);
|
||||
NSRange nsRange = NSMakeRange(range.first, range.second);
|
||||
[ranges addObject:[NSValue valueWithRange:nsRange]];
|
||||
}
|
||||
_highlightRanges = [ranges copy];
|
||||
|
||||
_itemType = itemType;
|
||||
|
||||
if (result.GetResultType() == search::Result::Type::Feature) {
|
||||
auto const featureType = result.GetFeatureType();
|
||||
auto const bookmarkImage = GetBookmarkIconByFeatureType(featureType);
|
||||
_iconImageName = [NSString stringWithFormat:@"%@%@",
|
||||
@"ic_bm_",
|
||||
[@(kml::ToString(bookmarkImage).c_str()) lowercaseString]];
|
||||
}
|
||||
}
|
||||
return self;
|
||||
}
|
||||
|
||||
@end
|
||||
Loading…
Add table
Add a link
Reference in a new issue