72 lines
3.1 KiB
Plaintext
72 lines
3.1 KiB
Plaintext
|
#import "AppDelegate.h"
|
||
|
|
||
|
#import <React/RCTBundleURLProvider.h>
|
||
|
#import <React/RCTLinkingManager.h>
|
||
|
|
||
|
#import <TSBackgroundFetch/TSBackgroundFetch.h>
|
||
|
|
||
|
@implementation AppDelegate
|
||
|
|
||
|
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
|
||
|
{
|
||
|
self.moduleName = @"main";
|
||
|
|
||
|
// You can add your custom initial props in the dictionary below.
|
||
|
// They will be passed down to the ViewController used by React Native.
|
||
|
self.initialProps = @{};
|
||
|
|
||
|
// Register BackgroundFetch
|
||
|
[[TSBackgroundFetch sharedInstance] didFinishLaunching];
|
||
|
|
||
|
return [super application:application didFinishLaunchingWithOptions:launchOptions];
|
||
|
}
|
||
|
|
||
|
- (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
|
||
|
{
|
||
|
#if DEBUG
|
||
|
return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index"];
|
||
|
#else
|
||
|
return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
/// This method controls whether the `concurrentRoot`feature of React18 is turned on or off.
|
||
|
///
|
||
|
/// @see: https://reactjs.org/blog/2022/03/29/react-v18.html
|
||
|
/// @note: This requires to be rendering on Fabric (i.e. on the New Architecture).
|
||
|
/// @return: `true` if the `concurrentRoot` feature is enabled. Otherwise, it returns `false`.
|
||
|
- (BOOL)concurrentRootEnabled
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
// Linking API
|
||
|
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options {
|
||
|
return [super application:application openURL:url options:options] || [RCTLinkingManager application:application openURL:url options:options];
|
||
|
}
|
||
|
|
||
|
// Universal Links
|
||
|
- (BOOL)application:(UIApplication *)application continueUserActivity:(nonnull NSUserActivity *)userActivity restorationHandler:(nonnull void (^)(NSArray<id<UIUserActivityRestoring>> * _Nullable))restorationHandler {
|
||
|
BOOL result = [RCTLinkingManager application:application continueUserActivity:userActivity restorationHandler:restorationHandler];
|
||
|
return [super application:application continueUserActivity:userActivity restorationHandler:restorationHandler] || result;
|
||
|
}
|
||
|
|
||
|
// Explicitly define remote notification delegates to ensure compatibility with some third-party libraries
|
||
|
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
|
||
|
{
|
||
|
return [super application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];
|
||
|
}
|
||
|
|
||
|
// Explicitly define remote notification delegates to ensure compatibility with some third-party libraries
|
||
|
- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
|
||
|
{
|
||
|
return [super application:application didFailToRegisterForRemoteNotificationsWithError:error];
|
||
|
}
|
||
|
|
||
|
// Explicitly define remote notification delegates to ensure compatibility with some third-party libraries
|
||
|
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler
|
||
|
{
|
||
|
return [super application:application didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
|
||
|
}
|
||
|
|
||
|
@end
|