2016-02-22 22:04:42 +00: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 15:14:40 +00:00
|
|
|
#import <asl.h>
|
2017-08-09 15:30:08 +00:00
|
|
|
#import "ReactNativeConfig.h"
|
2017-09-08 08:13:26 +00:00
|
|
|
#import "React/RCTLog.h"
|
2016-07-20 09:03:05 +00:00
|
|
|
#import "RCTBundleURLProvider.h"
|
2016-02-22 22:04:42 +00:00
|
|
|
#import "RCTRootView.h"
|
2016-11-15 11:43:48 +00:00
|
|
|
#import "SplashScreen.h"
|
2017-08-09 15:30:08 +00:00
|
|
|
#import "TestFairy.h"
|
2017-08-30 09:34:30 +00:00
|
|
|
#import "RNFIRMessaging.h"
|
|
|
|
|
2017-05-19 10:30:09 +00:00
|
|
|
@import Instabug;
|
2016-02-22 22:04:42 +00:00
|
|
|
|
|
|
|
@implementation AppDelegate
|
|
|
|
|
2017-09-09 15:14:40 +00: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-22 22:04:42 +00:00
|
|
|
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
|
|
|
|
{
|
2016-12-11 11:09:12 +00:00
|
|
|
signal(SIGPIPE, SIG_IGN);
|
2016-02-22 22:04:42 +00:00
|
|
|
NSURL *jsCodeLocation;
|
|
|
|
|
2017-12-22 21:49:58 +00: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 15:14:40 +00:00
|
|
|
RCTSetLogFunction(RCTTestFairyLogFunction);
|
2017-09-08 08:13:26 +00:00
|
|
|
}
|
|
|
|
|
2016-07-20 09:03:05 +00:00
|
|
|
jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];
|
2016-07-22 08:53:12 +00:00
|
|
|
|
2016-02-22 22:04:42 +00:00
|
|
|
RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
|
2016-05-19 16:32:38 +00:00
|
|
|
moduleName:@"StatusIm"
|
2016-02-22 22:04:42 +00:00
|
|
|
initialProperties:nil
|
|
|
|
launchOptions:launchOptions];
|
2016-07-20 09:03:05 +00:00
|
|
|
rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
|
2017-08-30 09:34:30 +00:00
|
|
|
|
2016-02-22 22:04:42 +00:00
|
|
|
self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
|
|
|
|
UIViewController *rootViewController = [UIViewController new];
|
|
|
|
rootViewController.view = rootView;
|
|
|
|
self.window.rootViewController = rootViewController;
|
|
|
|
[self.window makeKeyAndVisible];
|
2016-11-15 11:43:48 +00:00
|
|
|
[SplashScreen show];
|
2017-08-09 15:30:08 +00:00
|
|
|
NSString *testfairyEnabled = [ReactNativeConfig envFor:@"TESTFAIRY_ENABLED"];
|
2017-08-11 07:10:11 +00:00
|
|
|
if([testfairyEnabled isEqualToString:@"1"]){
|
2017-08-09 15:30:08 +00:00
|
|
|
[TestFairy begin:@"969f6c921cb435cea1d41d1ea3f5b247d6026d55"];
|
|
|
|
}
|
2017-08-11 07:10:11 +00:00
|
|
|
[Instabug startWithToken:@"5534212f4a44f477c9ab270ab5cd2062" invocationEvent:IBGInvocationEventShake];
|
2017-08-30 09:34:30 +00:00
|
|
|
|
|
|
|
[FIRApp configure];
|
|
|
|
[[UNUserNotificationCenter currentNotificationCenter] setDelegate:self];
|
|
|
|
|
2016-02-22 22:04:42 +00:00
|
|
|
return YES;
|
|
|
|
}
|
|
|
|
|
2017-08-30 09:34:30 +00:00
|
|
|
|
|
|
|
- (void)userNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(UNNotificationPresentationOptions))completionHandler
|
|
|
|
{
|
|
|
|
[RNFIRMessaging willPresentNotification:notification withCompletionHandler:completionHandler];
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler
|
|
|
|
{
|
|
|
|
[RNFIRMessaging didReceiveNotificationResponse:response withCompletionHandler:completionHandler];
|
|
|
|
}
|
|
|
|
|
|
|
|
-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification {
|
|
|
|
[RNFIRMessaging didReceiveLocalNotification:notification];
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(nonnull NSDictionary *)userInfo fetchCompletionHandler:(nonnull void (^)(UIBackgroundFetchResult))completionHandler{
|
|
|
|
[RNFIRMessaging didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
|
|
|
|
}
|
|
|
|
|
2016-02-22 22:04:42 +00:00
|
|
|
@end
|