2016-02-23 01:04:42 +03:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#import "AppDelegate.h"
|
|
|
|
|
2017-09-09 17:14:40 +02:00
|
|
|
#import <asl.h>
|
2017-08-09 18:30:08 +03:00
|
|
|
#import "ReactNativeConfig.h"
|
2017-09-08 10:13:26 +02:00
|
|
|
#import "React/RCTLog.h"
|
2016-07-20 12:03:05 +03:00
|
|
|
#import "RCTBundleURLProvider.h"
|
2016-02-23 01:04:42 +03:00
|
|
|
#import "RCTRootView.h"
|
2018-08-23 03:54:29 +02:00
|
|
|
#import "RNSplashScreen.h"
|
2017-08-09 18:30:08 +03:00
|
|
|
#import "TestFairy.h"
|
2018-06-28 21:31:31 +02:00
|
|
|
#import "RCTLinkingManager.h"
|
2018-06-29 15:28:46 +03:00
|
|
|
#import <Firebase.h>
|
|
|
|
#import "RNFirebaseNotifications.h"
|
|
|
|
#import "RNFirebaseMessaging.h"
|
2017-08-30 11:34:30 +02:00
|
|
|
|
2016-02-23 01:04:42 +03:00
|
|
|
@implementation AppDelegate
|
|
|
|
|
2017-09-09 17:14:40 +02:00
|
|
|
/* Modified version of RCTDefaultLogFunction that also directs all app logs to TestFairy. */
|
|
|
|
RCTLogFunction RCTTestFairyLogFunction = ^(
|
|
|
|
RCTLogLevel level,
|
|
|
|
__unused RCTLogSource source,
|
|
|
|
NSString *fileName,
|
|
|
|
NSNumber *lineNumber,
|
|
|
|
NSString *message
|
|
|
|
)
|
|
|
|
{
|
|
|
|
NSString *log = RCTFormatLog([NSDate date], level, fileName, lineNumber, message);
|
|
|
|
fprintf(stderr, "%s\n", log.UTF8String);
|
|
|
|
fflush(stderr);
|
|
|
|
|
|
|
|
/* Only custom part */
|
|
|
|
TFLog(log);
|
|
|
|
|
|
|
|
int aslLevel;
|
|
|
|
switch(level) {
|
|
|
|
case RCTLogLevelTrace:
|
|
|
|
aslLevel = ASL_LEVEL_DEBUG;
|
|
|
|
break;
|
|
|
|
case RCTLogLevelInfo:
|
|
|
|
aslLevel = ASL_LEVEL_NOTICE;
|
|
|
|
break;
|
|
|
|
case RCTLogLevelWarning:
|
|
|
|
aslLevel = ASL_LEVEL_WARNING;
|
|
|
|
break;
|
|
|
|
case RCTLogLevelError:
|
|
|
|
aslLevel = ASL_LEVEL_ERR;
|
|
|
|
break;
|
|
|
|
case RCTLogLevelFatal:
|
|
|
|
aslLevel = ASL_LEVEL_CRIT;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
asl_log(NULL, NULL, aslLevel, "%s", message.UTF8String);
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2016-02-23 01:04:42 +03:00
|
|
|
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
|
|
|
|
{
|
2016-12-11 13:09:12 +02:00
|
|
|
signal(SIGPIPE, SIG_IGN);
|
2016-02-23 01:04:42 +03:00
|
|
|
NSURL *jsCodeLocation;
|
|
|
|
|
2018-06-29 15:28:46 +03:00
|
|
|
[FIRApp configure];
|
|
|
|
[RNFirebaseNotifications configure];
|
|
|
|
[application registerForRemoteNotifications];
|
|
|
|
|
|
|
|
|
2017-12-22 22:49:58 +01:00
|
|
|
/* Set logging level from React Native */
|
|
|
|
NSString *logLevel = [ReactNativeConfig envFor:@"LOG_LEVEL"];
|
|
|
|
if([logLevel isEqualToString:@"error"]){
|
|
|
|
RCTSetLogThreshold(RCTLogLevelError);
|
|
|
|
}
|
|
|
|
else if([logLevel isEqualToString:@"warn"]){
|
|
|
|
RCTSetLogThreshold(RCTLogLevelWarning);
|
|
|
|
}
|
|
|
|
else if([logLevel isEqualToString:@"info"]){
|
|
|
|
RCTSetLogThreshold(RCTLogLevelInfo);
|
|
|
|
}
|
|
|
|
else if([logLevel isEqualToString:@"debug"]){
|
|
|
|
RCTSetLogThreshold(RCTLogLevelTrace);
|
2017-09-09 17:14:40 +02:00
|
|
|
RCTSetLogFunction(RCTTestFairyLogFunction);
|
2017-09-08 10:13:26 +02:00
|
|
|
}
|
|
|
|
|
2016-07-20 12:03:05 +03:00
|
|
|
jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];
|
2016-07-22 11:53:12 +03:00
|
|
|
|
2016-02-23 01:04:42 +03:00
|
|
|
RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
|
2016-05-19 18:32:38 +02:00
|
|
|
moduleName:@"StatusIm"
|
2016-02-23 01:04:42 +03:00
|
|
|
initialProperties:nil
|
|
|
|
launchOptions:launchOptions];
|
2016-07-20 12:03:05 +03:00
|
|
|
rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
|
2017-08-30 11:34:30 +02:00
|
|
|
|
2016-02-23 01:04:42 +03:00
|
|
|
self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
|
|
|
|
UIViewController *rootViewController = [UIViewController new];
|
|
|
|
rootViewController.view = rootView;
|
|
|
|
self.window.rootViewController = rootViewController;
|
|
|
|
[self.window makeKeyAndVisible];
|
2018-08-23 03:54:29 +02:00
|
|
|
[RNSplashScreen show];
|
2017-08-30 11:34:30 +02:00
|
|
|
|
2016-02-23 01:04:42 +03:00
|
|
|
return YES;
|
|
|
|
}
|
|
|
|
|
2018-06-29 15:28:46 +03:00
|
|
|
- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification {
|
|
|
|
[[RNFirebaseNotifications instance] didReceiveLocalNotification:notification];
|
2017-08-30 11:34:30 +02:00
|
|
|
}
|
|
|
|
|
2018-06-29 15:28:46 +03:00
|
|
|
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(nonnull NSDictionary *)userInfo
|
|
|
|
fetchCompletionHandler:(nonnull void (^)(UIBackgroundFetchResult))completionHandler{
|
|
|
|
[[RNFirebaseNotifications instance] didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
|
2017-08-30 11:34:30 +02:00
|
|
|
}
|
|
|
|
|
2018-06-29 15:28:46 +03:00
|
|
|
- (void)application:(UIApplication *)application didRegisterUserNotificationSettings:(UIUserNotificationSettings *)notificationSettings {
|
|
|
|
[[RNFirebaseMessaging instance] didRegisterUserNotificationSettings:notificationSettings];
|
2017-08-30 11:34:30 +02:00
|
|
|
}
|
|
|
|
|
2018-06-28 21:31:31 +02:00
|
|
|
- (BOOL)application:(UIApplication *)application
|
|
|
|
openURL:(NSURL *)url
|
|
|
|
options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options
|
|
|
|
{
|
|
|
|
return [RCTLinkingManager application:application openURL:url options:options];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity
|
|
|
|
restorationHandler:(void (^)(NSArray * _Nullable))restorationHandler
|
|
|
|
{
|
|
|
|
return [RCTLinkingManager application:application
|
|
|
|
continueUserActivity:userActivity
|
|
|
|
restorationHandler:restorationHandler];
|
|
|
|
}
|
|
|
|
|
2016-02-23 01:04:42 +03:00
|
|
|
@end
|