[ios] Added new alert for OSM re-auth action

Signed-off-by: S. Kozyr <s.trump@gmail.com>
This commit is contained in:
Sergiy Kozyr 2024-03-17 23:12:55 +02:00 committed by Roman Tsisyk
parent b39ae99736
commit 25c548c96f
12 changed files with 252 additions and 3 deletions

View file

@ -37,6 +37,7 @@
- (void)presentDeleteFeatureAlertWithBlock:(nonnull MWMVoidBlock)block;
- (void)presentEditorViralAlert;
- (void)presentOsmAuthAlert;
- (void)presentOsmReauthAlert;
- (void)presentPersonalInfoWarningAlertWithBlock:(nonnull MWMVoidBlock)block;
- (void)presentTrackWarningAlertWithCancelBlock:(nonnull MWMVoidBlock)block;
- (void)presentMobileInternetAlertWithBlock:(nonnull MWMMobileInternetAlertCompletionBlock)block;

View file

@ -179,6 +179,10 @@ static NSString *const kAlertControllerNibIdentifier = @"MWMAlertViewController"
[self displayAlert:[MWMAlert osmAuthAlert]];
}
- (void)presentOsmReauthAlert {
[self displayAlert:[MWMAlert osmReauthAlert]];
}
- (void)presentCreateBookmarkCategoryAlertWithMaxCharacterNum:(NSUInteger)max
minCharacterNum:(NSUInteger)min
callback:(nonnull MWMCheckStringBlock)callback {

View file

@ -29,6 +29,7 @@
+ (MWMAlert *)deleteFeatureAlertWithBlock:(MWMVoidBlock)block;
+ (MWMAlert *)editorViralAlert;
+ (MWMAlert *)osmAuthAlert;
+ (MWMAlert *)osmReauthAlert;
+ (MWMAlert *)personalInfoWarningAlertWithBlock:(MWMVoidBlock)block;
+ (MWMAlert *)trackWarningAlertWithCancelBlock:(MWMVoidBlock)block;
+ (MWMAlert *)infoAlert:(NSString *)title text:(NSString *)text;

View file

@ -5,6 +5,7 @@
#import "MWMEditorViralAlert.h"
#import "MWMLocationAlert.h"
#import "MWMOsmAuthAlert.h"
#import "MWMOsmReauthAlert.h"
#import "MWMPlaceDoesntExistAlert.h"
#import "MWMRoutingDisclaimerAlert.h"
@ -158,6 +159,9 @@
+ (MWMAlert *)osmAuthAlert {
return [MWMOsmAuthAlert alert];
}
+ (MWMAlert *)osmReauthAlert {
return [MWMOsmReauthAlert alert];
}
+ (MWMAlert *)personalInfoWarningAlertWithBlock:(MWMVoidBlock)block {
return [MWMDefaultAlert personalInfoWarningAlertWithBlock:block];
}

View file

@ -0,0 +1,7 @@
#import "MWMAlert.h"
@interface MWMOsmReauthAlert : MWMAlert
+ (instancetype)alert;
@end

View file

@ -0,0 +1,31 @@
#import "MWMAlertViewController.h"
#import "MWMOsmReauthAlert.h"
#import "MWMAuthorizationCommon.h"
#include "editor/osm_auth.hpp"
static NSString * const kMap2OsmLoginSegue = @"Map2OsmLogin";
@implementation MWMOsmReauthAlert
+ (instancetype)alert
{
MWMOsmReauthAlert * alert =
[NSBundle.mainBundle loadNibNamed:[self className] owner:nil options:nil].firstObject;
return alert;
}
- (IBAction)osmTap
{
[self close:^{
[self.alertController.ownerViewController performSegueWithIdentifier:kMap2OsmLoginSegue
sender:nil];
}];
}
- (IBAction)closeTap
{
[self close:nil];
}
@end

View file

@ -0,0 +1,141 @@
<?xml version="1.0" encoding="UTF-8"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="32700.99.1234" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES">
<device id="retina6_12" orientation="portrait" appearance="light"/>
<dependencies>
<deployment identifier="iOS"/>
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="22684"/>
<capability name="Safe area layout guides" minToolsVersion="9.0"/>
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
</dependencies>
<objects>
<placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
<placeholder placeholderIdentifier="IBFirstResponder" id="-2" customClass="UIResponder"/>
<view contentMode="scaleToFill" id="OOr-tJ-QfW" customClass="MWMOsmReauthAlert" propertyAccessControl="none">
<rect key="frame" x="0.0" y="0.0" width="375" height="667"/>
<autoresizingMask key="autoresizingMask" flexibleMinX="YES" flexibleMaxX="YES" flexibleMinY="YES" flexibleMaxY="YES"/>
<subviews>
<view contentMode="scaleToFill" translatesAutoresizingMaskIntoConstraints="NO" id="pGb-Pj-lsX" userLabel="ContainerView">
<rect key="frame" x="47.666666666666657" y="169" width="280" height="329"/>
<subviews>
<button opaque="NO" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="bKJ-wq-v28" userLabel="Done" customClass="MWMButton">
<rect key="frame" x="240" y="0.0" width="40" height="40"/>
<color key="backgroundColor" red="0.0" green="0.0" blue="0.0" alpha="0.0" colorSpace="custom" customColorSpace="sRGB"/>
<constraints>
<constraint firstAttribute="width" constant="40" id="W81-6E-cNz"/>
<constraint firstAttribute="height" constant="40" id="yqF-ZS-dOn"/>
</constraints>
<fontDescription key="fontDescription" type="system" pointSize="17"/>
<state key="normal" image="ic_cancel">
<color key="titleColor" red="0.01176470588" green="0.47843137250000001" blue="1" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
<color key="titleShadowColor" red="0.5" green="0.5" blue="0.5" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
</state>
<userDefinedRuntimeAttributes>
<userDefinedRuntimeAttribute type="string" keyPath="styleName" value="MWMBlack"/>
</userDefinedRuntimeAttributes>
<connections>
<action selector="closeTap" destination="OOr-tJ-QfW" eventType="touchUpInside" id="vUN-3c-vWF"/>
</connections>
</button>
<label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" textAlignment="center" lineBreakMode="tailTruncation" numberOfLines="0" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="QTE-iO-nbf" userLabel="Title">
<rect key="frame" x="20" y="140" width="240" height="61"/>
<constraints>
<constraint firstAttribute="width" constant="240" id="Qgg-5q-c39"/>
<constraint firstAttribute="height" relation="greaterThanOrEqual" constant="30" id="uEo-89-aMI"/>
</constraints>
<string key="text">Войдите, чтобы ваши изменения увидели
другие пользователи</string>
<fontDescription key="fontDescription" type="system" weight="medium" pointSize="17"/>
<color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
<nil key="highlightedColor"/>
<userDefinedRuntimeAttributes>
<userDefinedRuntimeAttribute type="string" keyPath="styleName" value="medium17:blackPrimaryText"/>
<userDefinedRuntimeAttribute type="string" keyPath="localizedText" value="alert_reauth_message"/>
</userDefinedRuntimeAttributes>
</label>
<button opaque="NO" clipsSubviews="YES" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="33p-SN-9fc" userLabel="login_osm" customClass="MWMButton">
<rect key="frame" x="20" y="211" width="240" height="44"/>
<constraints>
<constraint firstAttribute="width" constant="240" id="6Mj-n7-paj"/>
<constraint firstAttribute="height" constant="44" id="vzZ-AA-l0W"/>
</constraints>
<state key="normal" title="Login OpenStreetMap"/>
<userDefinedRuntimeAttributes>
<userDefinedRuntimeAttribute type="string" keyPath="styleName" value="FlatNormalButtonBig"/>
<userDefinedRuntimeAttribute type="string" keyPath="localizedText" value="login_osm"/>
</userDefinedRuntimeAttributes>
<connections>
<action selector="osmTap" destination="OOr-tJ-QfW" eventType="touchUpInside" id="eEw-ZQ-bth"/>
</connections>
</button>
<button opaque="NO" clipsSubviews="YES" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="OS7-Xd-HGC" userLabel="Cancel">
<rect key="frame" x="20" y="265" width="240" height="44"/>
<constraints>
<constraint firstAttribute="width" constant="240" id="Bzd-Uh-BSU"/>
<constraint firstAttribute="height" constant="44" id="uTD-56-ZBz"/>
</constraints>
<state key="normal" title="Cancel"/>
<userDefinedRuntimeAttributes>
<userDefinedRuntimeAttribute type="string" keyPath="styleName" value="FlatNormalTransButtonBig"/>
<userDefinedRuntimeAttribute type="string" keyPath="localizedText" value="cancel"/>
</userDefinedRuntimeAttributes>
<connections>
<action selector="closeTap" destination="OOr-tJ-QfW" eventType="touchUpInside" id="Jmk-bD-kAS"/>
</connections>
</button>
<imageView userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" image="img_login" translatesAutoresizingMaskIntoConstraints="NO" id="BXR-WK-BfJ">
<rect key="frame" x="80" y="20" width="120" height="120"/>
<constraints>
<constraint firstAttribute="width" constant="120" id="n5Z-5L-UPW"/>
<constraint firstAttribute="width" secondItem="BXR-WK-BfJ" secondAttribute="height" multiplier="1:1" id="oyf-fo-zbh"/>
</constraints>
</imageView>
</subviews>
<constraints>
<constraint firstItem="33p-SN-9fc" firstAttribute="top" secondItem="QTE-iO-nbf" secondAttribute="bottom" constant="10" id="3FQ-Qm-8WE"/>
<constraint firstItem="OS7-Xd-HGC" firstAttribute="centerX" secondItem="pGb-Pj-lsX" secondAttribute="centerX" id="6ms-nM-I0P"/>
<constraint firstItem="QTE-iO-nbf" firstAttribute="top" secondItem="pGb-Pj-lsX" secondAttribute="top" constant="20" id="BZP-EH-Hf9">
<variation key="heightClass=compact" constant="32"/>
</constraint>
<constraint firstItem="OS7-Xd-HGC" firstAttribute="top" secondItem="33p-SN-9fc" secondAttribute="bottom" constant="10" id="Bui-bG-czy"/>
<constraint firstItem="BXR-WK-BfJ" firstAttribute="centerX" secondItem="pGb-Pj-lsX" secondAttribute="centerX" id="NV9-Kj-IPD"/>
<constraint firstAttribute="bottom" secondItem="OS7-Xd-HGC" secondAttribute="bottom" constant="20" id="Oum-gS-fQc"/>
<constraint firstItem="bKJ-wq-v28" firstAttribute="top" secondItem="pGb-Pj-lsX" secondAttribute="top" id="Rjm-H1-YUW"/>
<constraint firstItem="BXR-WK-BfJ" firstAttribute="top" secondItem="pGb-Pj-lsX" secondAttribute="top" constant="20" id="SMy-Y2-C3I"/>
<constraint firstItem="QTE-iO-nbf" firstAttribute="top" secondItem="BXR-WK-BfJ" secondAttribute="bottom" id="Sde-0Q-z3J"/>
<constraint firstAttribute="width" constant="280" id="coi-hW-q18"/>
<constraint firstAttribute="trailing" secondItem="bKJ-wq-v28" secondAttribute="trailing" id="gTa-Ov-TWc"/>
<constraint firstItem="QTE-iO-nbf" firstAttribute="centerX" secondItem="pGb-Pj-lsX" secondAttribute="centerX" id="icl-oF-MDW"/>
<constraint firstItem="33p-SN-9fc" firstAttribute="centerX" secondItem="pGb-Pj-lsX" secondAttribute="centerX" id="khE-QQ-4bJ"/>
</constraints>
<userDefinedRuntimeAttributes>
<userDefinedRuntimeAttribute type="string" keyPath="styleName" value="AlertView"/>
</userDefinedRuntimeAttributes>
<variation key="default">
<mask key="constraints">
<exclude reference="BZP-EH-Hf9"/>
</mask>
</variation>
<variation key="heightClass=compact">
<mask key="subviews">
<exclude reference="BXR-WK-BfJ"/>
</mask>
<mask key="constraints">
<include reference="BZP-EH-Hf9"/>
</mask>
</variation>
</view>
</subviews>
<viewLayoutGuide key="safeArea" id="Wzy-Dc-f4s"/>
<color key="backgroundColor" red="0.0" green="0.0" blue="0.0" alpha="0.0" colorSpace="custom" customColorSpace="sRGB"/>
<constraints>
<constraint firstItem="pGb-Pj-lsX" firstAttribute="centerX" secondItem="OOr-tJ-QfW" secondAttribute="centerX" id="NJE-Ru-ipu"/>
<constraint firstItem="pGb-Pj-lsX" firstAttribute="centerY" secondItem="OOr-tJ-QfW" secondAttribute="centerY" id="pMZ-fj-kFC"/>
</constraints>
<point key="canvasLocation" x="305" y="172"/>
</view>
</objects>
<resources>
<image name="ic_cancel" width="40" height="40"/>
<image name="img_login" width="120" height="120"/>
</resources>
</document>

View file

@ -12,6 +12,9 @@ enum class AuthorizationButtonType
// Deletes any stored credentials if called with empty key or secret.
void AuthorizationStoreCredentials(std::string const & oauthToken);
BOOL AuthorizationHaveOAuth1Credentials();
void AuthorizationClearOAuth1Credentials();
void AuthorizationCreateOAuth1Credentials();
BOOL AuthorizationHaveCredentials();
void AuthorizationClearCredentials();
// Returns empty key and secret if user has not beed authorized.

View file

@ -8,8 +8,8 @@
namespace osm_auth_ios
{
NSString * const kOSMRequestToken = @"OSMRequestToken";
NSString * const kOSMRequestSecret = @"OSMRequestSecret";
NSString * const kOSMRequestToken = @"OSMRequestToken"; // Unused after migration from OAuth1 to OAuth2
NSString * const kOSMRequestSecret = @"OSMRequestSecret"; // Unused after migration from OAuth1 to OAuth2
NSString * const kAuthNeedCheck = @"AuthNeedCheck";
NSString * const kOSMAuthToken = @"OSMAuthToken";
NSString * const kOSMUserName = @"UDOsmUserName";
@ -47,6 +47,31 @@ void AuthorizationStoreCredentials(std::string const & oauthToken)
[ud synchronize];
}
BOOL AuthorizationHaveOAuth1Credentials()
{
NSUserDefaults * ud = NSUserDefaults.standardUserDefaults;
NSString * requestToken = [ud stringForKey:kOSMRequestToken];
NSString * requestSecret = [ud stringForKey:kOSMRequestSecret];
return requestToken.length && requestSecret.length;
}
void AuthorizationClearOAuth1Credentials()
{
NSUserDefaults * ud = NSUserDefaults.standardUserDefaults;
[ud removeObjectForKey:kOSMRequestToken];
[ud removeObjectForKey:kOSMRequestSecret];
[ud synchronize];
}
void AuthorizationCreateOAuth1Credentials()
{
NSUserDefaults * ud = NSUserDefaults.standardUserDefaults;
[ud setObject:@"kOSMRequestToken" forKey:kOSMRequestToken];
[ud setObject:@"kOSMRequestSecret" forKey:kOSMRequestSecret];
[ud synchronize];
}
BOOL AuthorizationHaveCredentials()
{
NSUserDefaults * ud = NSUserDefaults.standardUserDefaults;

View file

@ -20,6 +20,8 @@
- (void)updateStatusBarStyle;
- (void)migrateOAuthCredentials;
- (void)performAction:(NSString *_Nonnull)action;
- (void)openMapsDownloader:(MWMMapDownloaderMode)mode;

View file

@ -363,6 +363,8 @@ NSString *const kPP2BookmarkEditingSegue = @"PP2BookmarkEditing";
// Otherwise PP container view is nil, or there is no animation/selection of the point.
if (DeepLinkHandler.shared.isLaunchedByDeeplink)
(void)[DeepLinkHandler.shared handleDeepLinkAndReset];
else
[self migrateOAuthCredentials];
}
- (void)viewDidLayoutSubviews {
@ -417,6 +419,16 @@ NSString *const kPP2BookmarkEditingSegue = @"PP2BookmarkEditing";
- (void)updateStatusBarStyle {
[self setNeedsStatusBarAppearanceUpdate];
}
- (void)migrateOAuthCredentials {
if (osm_auth_ios::AuthorizationHaveOAuth1Credentials())
{
//osm_auth_ios::AuthorizationClearOAuth1Credentials();
// TODO
[self.alertController presentOsmReauthAlert];
}
}
- (id)initWithCoder:(NSCoder *)coder {
NSLog(@"MapViewController initWithCoder Started");
self = [super initWithCoder:coder];

View file

@ -184,6 +184,8 @@
408645FC21495EB1000A4A1D /* categories_cuisines.txt in Resources */ = {isa = PBXBuildFile; fileRef = 408645FB21495EB1000A4A1D /* categories_cuisines.txt */; };
44360A0D2A7D34990016F412 /* TransportRuler.swift in Sources */ = {isa = PBXBuildFile; fileRef = 44360A0C2A7D34990016F412 /* TransportRuler.swift */; };
44360A112A7D35440016F412 /* TransportRuler.xib in Resources */ = {isa = PBXBuildFile; fileRef = 44360A102A7D35440016F412 /* TransportRuler.xib */; };
447DB4BC2BA78282000DF4C2 /* MWMOsmReauthAlert.mm in Sources */ = {isa = PBXBuildFile; fileRef = 447DB4BB2BA78282000DF4C2 /* MWMOsmReauthAlert.mm */; };
447DB4C42BA78665000DF4C2 /* MWMOsmReauthAlert.xib in Resources */ = {isa = PBXBuildFile; fileRef = 447DB4C12BA78665000DF4C2 /* MWMOsmReauthAlert.xib */; };
4501B1942077C35A001B9173 /* resources-xxxhdpi_clear in Resources */ = {isa = PBXBuildFile; fileRef = 4501B1922077C35A001B9173 /* resources-xxxhdpi_clear */; };
4501B1952077C35A001B9173 /* resources-xxxhdpi_dark in Resources */ = {isa = PBXBuildFile; fileRef = 4501B1932077C35A001B9173 /* resources-xxxhdpi_dark */; };
4554B6EC1E55F0EF0084017F /* drules_proto_vehicle_clear.bin in Resources */ = {isa = PBXBuildFile; fileRef = 4554B6E81E55F02B0084017F /* drules_proto_vehicle_clear.bin */; };
@ -1042,6 +1044,9 @@
408645FB21495EB1000A4A1D /* categories_cuisines.txt */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; name = categories_cuisines.txt; path = ../../data/categories_cuisines.txt; sourceTree = "<group>"; };
44360A0C2A7D34990016F412 /* TransportRuler.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TransportRuler.swift; sourceTree = "<group>"; };
44360A102A7D35440016F412 /* TransportRuler.xib */ = {isa = PBXFileReference; lastKnownFileType = file.xib; path = TransportRuler.xib; sourceTree = "<group>"; };
447DB4BA2BA78282000DF4C2 /* MWMOsmReauthAlert.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = MWMOsmReauthAlert.h; path = Classes/CustomAlert/MWMOsmReauthAlert.h; sourceTree = SOURCE_ROOT; };
447DB4BB2BA78282000DF4C2 /* MWMOsmReauthAlert.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = MWMOsmReauthAlert.mm; path = Classes/CustomAlert/MWMOsmReauthAlert.mm; sourceTree = SOURCE_ROOT; };
447DB4C12BA78665000DF4C2 /* MWMOsmReauthAlert.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; name = MWMOsmReauthAlert.xib; path = Classes/CustomAlert/MWMOsmReauthAlert.xib; sourceTree = SOURCE_ROOT; };
4501B1922077C35A001B9173 /* resources-xxxhdpi_clear */ = {isa = PBXFileReference; lastKnownFileType = folder; name = "resources-xxxhdpi_clear"; path = "../../data/resources-xxxhdpi_clear"; sourceTree = "<group>"; };
4501B1932077C35A001B9173 /* resources-xxxhdpi_dark */ = {isa = PBXFileReference; lastKnownFileType = folder; name = "resources-xxxhdpi_dark"; path = "../../data/resources-xxxhdpi_dark"; sourceTree = "<group>"; };
451950391B7A3E070085DA05 /* patterns.txt */ = {isa = PBXFileReference; lastKnownFileType = text; name = patterns.txt; path = ../../data/patterns.txt; sourceTree = "<group>"; };
@ -2469,6 +2474,16 @@
path = Widgets;
sourceTree = "<group>";
};
447DB4B72BA7826D000DF4C2 /* ReauthAlert */ = {
isa = PBXGroup;
children = (
447DB4C12BA78665000DF4C2 /* MWMOsmReauthAlert.xib */,
447DB4BA2BA78282000DF4C2 /* MWMOsmReauthAlert.h */,
447DB4BB2BA78282000DF4C2 /* MWMOsmReauthAlert.mm */,
);
path = ReauthAlert;
sourceTree = "<group>";
};
470F0B7B238842AD006AEC94 /* Views */ = {
isa = PBXGroup;
children = (
@ -3016,6 +3031,7 @@
F64F195F1AB8125C006EAF7E /* CustomAlert */ = {
isa = PBXGroup;
children = (
447DB4B72BA7826D000DF4C2 /* ReauthAlert */,
F62607FB207B78E300176C5A /* SpinnerAlert */,
F6D67CDA2062B9810032FD38 /* CreateBookmarkCategory */,
349B92691DF0516C007779DD /* Toast */,
@ -3126,9 +3142,9 @@
F6BD1D1D1CA412700047B8E8 /* AuthAlert */ = {
isa = PBXGroup;
children = (
F6BD1D221CA412E30047B8E8 /* MWMOsmAuthAlert.xib */,
F6BD1D1E1CA412920047B8E8 /* MWMOsmAuthAlert.h */,
F6BD1D1F1CA412920047B8E8 /* MWMOsmAuthAlert.mm */,
F6BD1D221CA412E30047B8E8 /* MWMOsmAuthAlert.xib */,
);
name = AuthAlert;
sourceTree = "<group>";
@ -3899,6 +3915,7 @@
F6E2FE2E1E097BA00083EBEC /* MWMStreetEditorEditTableViewCell.xib in Resources */,
3463BA691DE81DB90082417F /* MWMTrafficButtonViewController.xib in Resources */,
F623DA6C1C9C2731006A3436 /* opening_hours_how_to_edit.html in Resources */,
447DB4C42BA78665000DF4C2 /* MWMOsmReauthAlert.xib in Resources */,
6741A9761BF340DE002C974C /* packed_polygons.bin in Resources */,
676507601C10559800830BB3 /* patterns.txt in Resources */,
6B15907226623AE500944BBA /* 00_NotoSansThai-Regular.ttf in Resources */,
@ -4301,6 +4318,7 @@
993DF10523F6BDB100AC231A /* UINavigationItem+styleName.swift in Sources */,
9977E69C247BFB510073780C /* SearchTextField.swift in Sources */,
4726254921C27D4B00C7BAAD /* PlacePageDescriptionViewController.swift in Sources */,
447DB4BC2BA78282000DF4C2 /* MWMOsmReauthAlert.mm in Sources */,
340475711E081A4600C92850 /* MWMSettings.mm in Sources */,
33046832219C57180041F3A8 /* CategorySettingsViewController.swift in Sources */,
3404756E1E081A4600C92850 /* MWMSearch.mm in Sources */,