IOS Integration

πŸ“˜

Cordova Info

If your intregration is in Cordova. Then you have to skip this IOS Integration.
Now Add Notification Service Extension .
Goto the next page and Notification Service Extension on your project.

Cocoapods Install

Run this command from terminal

cd ios && pod install && cd ..

Configure info.plist

Source Code Edit

<key>NSAppTransportSecurity</key>
    <dict>
       <key>NSAllowsArbitraryLoads</key>
       <true/>
    </dict>

<key>CFBundleURLTypes</key>
     <array>
           <dict>
                <key>CFBundleURLName</key>
                <string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
                <key>CFBundleURLSchemes</key>
                <array>
                        <string>YOUR_URL_SCHEME</string>
                </array>
           </dict>
     </array>

<key>nvBrandID</key>
<integer>YOUR_BRANDID_COMES_HERE</integer>

<key>nvSecretKey</key>
<string>YOUR_SECRET_KEY_COMES_HERE</string>

<key>nvPushCategory</key>
<string>nvpush</string>

<key>nvViewAutoRedirection</key>
<true/>    <!--OR--> <!-- <false/>-->

OR Property List Edit

.1 Add a new row by going to the menu and clicking Editor > Add Item. Setup a NSAppTransportSecurity as a Dictionary.

1.2 Added a Subkey called NSAllowsArbitraryLoads as Boolean and set its value to YES as like the following image.

1.3 Add a new row again and set up a URL Types item by adding a new item. Expand the URL Types key, expand Item 0, and add a new item, URL schemes. Fill in β€œappScheme” for Item 0 of URL schemes and your company identifier for the URL Identifier. Your file should resemble the image below when done.

1.4 Add a new row again and set up a nvBrandID as Number and fill this field with your BRANDID

1.5 Add a new row again and set up a nvSecretKey as String and fill this field with your SECRET KEY

{8A991DED60F2186660EF8A337C30BDDE}

1.6 Add a new row again and set up a nvPushCategory as String and set it’s value nvpush.

1.7 Add a new row again and set up a key nvViewAutoRedirection as Boolean set it YES to enable auto redirection of your app’s ViewControllers from sdk or set it NO to handle redirections by your app.

1.9 Goto Signing & Capabilities Tab and if β€œBackground Modes” is not already added then click on the + symbol on the left corner of this tab and add Background Modes make sure to select 2 checkboxes. If it is already added then make sure to select 2 checkboxes (i.e. Background fetch, Remote notifications).

In the Signing & Capabilities Tab and click on + symbol on the left corner of this tab and add Push Notifications and if you are upgraded Xcode and Push Notifications was already added in previous version of Xcode then remove Push Notifications and add it again to configure push notification properly for the upgraded devices.

In the Signing & Capabilities Tab if β€œApp Groups” is not already added then click on + symbol on the left corner of this tab and add App Groups and click on + sign and add a new app group give the group name as group.nv.{Your App Bundle Identifier}.

Example : if Your App’s Bundle Identifier is com.example.myapp then the App Group must be named as group.nv.com.example.myapp make sure this newly created app group must be checked (Turned on)

Swift (Bridging-Header)

If your project IOS platform is in Swift language. You have to create a Bridging-Header.h file. Add a new header file and name it with the following format. PROJECT_NAME-Bridging-Header.h

Import the below statement in PROJECT_NAME-Bridging-Header.h for accessing Native SDK Classes.

#import "notifyvisitors.h"

Make sure that the path of bridge-header.h file is included in build settings under β€œSwift compiler-code generation” as:
Objective C bridging header: YOUR_PROJECT_NAME/YOUR_PROJECT_NAME-Bridging-Header.h

Import Header File

Import the below header file in your AppDelegate.m file in which SDK function is to be accessed.

#import "RNNotifyvisitors.h"
/* Objective C */
#import <flutter_notifyvisitors/NotifyvisitorsPlugin.h>
  
/* swift */
#import "NotifyvisitorsPlugin.h"
//you can import this statement on bridge-header file.
#import "notifyvisitors.h"

Initialise SDK

Initialize the SDK in the application didFinishLaunchingWithOptions function.

[RNNotifyvisitors Initialize];
[RNNotifyvisitors RegisterPushWithDelegate: self App: application launchOptions: launchOptions];

/* Example */ 
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
  RCTAppSetupPrepareApp(application);

  RCTBridge *bridge = [self.reactDelegate createBridgeWithDelegate:self launchOptions:launchOptions];
  
  // NotifyVisitors methods here
  [RNNotifyvisitors Initialize];
  [RNNotifyvisitors RegisterPushWithDelegate: self App: application launchOptions: launchOptions];
  // ----------------------------
  
  [super application:application didFinishLaunchingWithOptions:launchOptions];

  return YES;
}

 /* Objective C */
 [NotifyvisitorsPlugin Initialize];
 [NotifyvisitorsPlugin RegisterPushWithDelegate:self App:application launchOptions:launchOptions];
   
/* Example */ 
- (BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    [GeneratedPluginRegistrant registerWithRegistry:self];
    // Override point for customization after application launch.
    
  // NotifyVisitors methods here  
    [NotifyvisitorsPlugin Initialize];
    [NotifyvisitorsPlugin RegisterPushWithDelegate:self App:application launchOptions:launchOptions];
  // ----------------------------
    
    return [super application:application didFinishLaunchingWithOptions:launchOptions];
}

/* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */ 

/* swift */
 NotifyvisitorsPlugin.nvInitialize()
 NotifyvisitorsPlugin.registerPush(withDelegate: self, app: application, launchOptions: launchOptions)


/* Example */
 override func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
  ) -> Bool {
    GeneratedPluginRegistrant.register(with: self)
    
    // NotifyVisitors methods here 
    NotifyvisitorsPlugin.nvInitialize()
    NotifyvisitorsPlugin.registerPush(withDelegate: self, app: application, launchOptions: launchOptions)
    // ----------------------------

    return super.application(application, didFinishLaunchingWithOptions: launchOptions)
  }

var nvMode:String? = nil
                #if DEBUG
                nvMode = "debug"
                #else
                    nvMode = "live"
                #endif
   notifyvisitors.initialize(nvMode)
   notifyvisitors.registerPush(withDelegate: self, app: application, launchOptions: launchOptions)

Add the following three functions inside your AppDelegate.m file to handle the registering and receiving events of push notification.

[RNNotifyvisitors application: application didRegisterForRemoteNotificationsWithDeviceToken: deviceToken];  
[RNNotifyvisitors application: application didReceiveRemoteNotification: userInfo];

/* Example */ 
-(void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken{
    [RNNotifyvisitors application: application didRegisterForRemoteNotificationsWithDeviceToken: deviceToken];  
}

-(void)application:(UIApplication *)application didReceiveRemoteNotification: (NSDictionary *)userInfo {
  [RNNotifyvisitors application: application didReceiveRemoteNotification: userInfo];
}


/* Objective C */
[NotifyvisitorsPlugin application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];
[NotifyvisitorsPlugin application:application didFailToRegisterForRemoteNotificationsWithError:error];

/* Example */
-(void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
    [NotifyvisitorsPlugin application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];
}

-(void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error{
    [NotifyvisitorsPlugin application:application didFailToRegisterForRemoteNotificationsWithError:error];
}

/* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */ 

/* swift */
NotifyvisitorsPlugin.application(application, didFailToRegisterForRemoteNotificationsWithError: error)
NotifyvisitorsPlugin.application(application, didReceiveRemoteNotification: userInfo)  

/* Example */
  
  override func application(_ application: UIApplication, didFailToRegisterForRemoteNotificationsWithError error: Error) {
   NotifyvisitorsPlugin.application(application, didFailToRegisterForRemoteNotificationsWithError: error)
 }

override func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any]) {
  NotifyvisitorsPlugin.application(application, didReceiveRemoteNotification: userInfo)
}
  

/* Swift */ 
notifyvisitors.didRegisteredNotification(application, deviceToken: deviceToken);
notifyvisitors.didReceiveRemoteNotification(userInfo: userInfo);

/* Example */ 
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
  notifyvisitors.didRegisteredNotification(application, deviceToken: deviceToken);
}

func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
  notifyvisitors.didReceiveRemoteNotification(userInfo: userInfo);
}

Add the following method in applicationWillTerminate In your AppDelegate.m file

[RNNotifyvisitors applicationWillTerminate];

/* Example */ 
- (void)applicationWillTerminate:(UIApplication *)application{
  [RNNotifyvisitors applicationWillTerminate];
}
/* Objective C */
[NotifyvisitorsPlugin applicationWillTerminate];

/* Example */
- (void) applicationWillTerminate:(UIApplication *)application{
    [NotifyvisitorsPlugin applicationWillTerminate];
}

/* swift */
NotifyvisitorsPlugin.applicationWillTerminate()
  
/* Example */
override func applicationWillTerminate(_ application: UIApplication) {
   NotifyvisitorsPlugin.applicationWillTerminate()
 }
/* Swift */
notifyvisitors.applicationWillTerminate();

/* Example */ 
func applicationWillTerminate(_ application: UIApplication) {
  notifyvisitors.applicationWillTerminate();
}

Rich Push Notification

Goto AppDelegate.h import UserNotifications framework and also add UNUserNotificationCenterDelegate to support Rich Push Notifications.

#import <UserNotifications/UserNotifications.h>
@interface AppDelegate : UIResponder <UIApplicationDelegate, UNUserNotificationCenterDelegate>
@end

Now open AppDelegate.m file and add the following delegate methods to handle rich push notifications.

# pragma mark UNNotificationCenter Delegate Methods

[RNNotifyvisitors  willPresentNotification: notification withCompletionHandler: completionHandler];
[RNNotifyvisitors application:application didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
[RNNotifyvisitors didReceiveNotificationResponse: response];

/* Example */ 
- (void)userNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(UNNotificationPresentationOptions options))completionHandler {
   [RNNotifyvisitors  willPresentNotification: notification withCompletionHandler: completionHandler];
}

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler{
  [RNNotifyvisitors application:application didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
}

-(void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)(void))completionHandler {
  [RNNotifyvisitors didReceiveNotificationResponse: response];
}
/* Objective C */
[NotifyvisitorsPlugin willPresentNotification:notification withCompletionHandler:completionHandler];
[NotifyvisitorsPlugin application:application didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
[NotifyvisitorsPlugin didReceiveNotificationResponse:response];

/* Example */ 
- (void)userNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(UNNotificationPresentationOptions options))completionHandler {
    [NotifyvisitorsPlugin willPresentNotification:notification withCompletionHandler:completionHandler];  
}

- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)(void))completionHandler {
    [NotifyvisitorsPlugin didReceiveNotificationResponse:response];
}

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
    [NotifyvisitorsPlugin application:application didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
}


/* swift */
NotifyvisitorsPlugin.willPresent(notification, withCompletionHandler: completionHandler)
NotifyvisitorsPlugin.application(application, didReceiveRemoteNotification: userInfo)
NotifyvisitorsPlugin.didReceive(response)
  
/* Example */ 
override func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
   NotifyvisitorsPlugin.willPresent(notification, withCompletionHandler: completionHandler)
}

override func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
   NotifyvisitorsPlugin.application(application, didReceiveRemoteNotification: userInfo)
}

override func userNotificationCenter(_ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse, withCompletionHandler completionHandler: @escaping () -> Void) {
     NotifyvisitorsPlugin.didReceive(response)
}


/* Swift */
notifyvisitors.willPresent( notification, withCompletionHandler: completionHandler)
notifyvisitors.didReceiveRemoteNotification(userInfo: userInfo);
notifyvisitors.pushNotificationActionData(from: response, autoRedirectOtherApps: true) { (pushData: NSMutableDictionary?) in
    let userInfo: [AnyHashable : Any]?
      if pushData!.count > 0 {
        userInfo = (pushData as! [AnyHashable : Any])
        } else {
        userInfo = [:]
 }

/* Example */ 
func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
  notifyvisitors.willPresent( notification, withCompletionHandler: completionHandler)
}

func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
  notifyvisitors.didReceiveRemoteNotification(userInfo: userInfo);
}

func userNotificationCenter(_ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse) async {
  notifyvisitors.pushNotificationActionData(from: response, autoRedirectOtherApps: true) { (pushData: NSMutableDictionary?) in
    let userInfo: [AnyHashable : Any]?
      if pushData!.count > 0 {
        userInfo = (pushData as! [AnyHashable : Any])
        } else {
        userInfo = [:]
        }
                                                                                          NotificationCenter.default.post(name: Notification.Name.init("didReceiveResponse"), object: nil, userInfo: userInfo) ;                                                                                       }
}

Call the below method in your AppDelegate.m that will check the deep linking and open your app from URL Scheme.

  [RNNotifyvisitors openUrl:application openURL:url];

/* Example */ 
-(BOOL)application:(UIApplication*)application openURL:(NSURL*)url sourceApplication:(NSString*)sourceApplication annotation:(id)annotation {
  [RNNotifyvisitors openUrl:application openURL:url];
  return YES;
}
/* Objective C */
[NotifyvisitorsPlugin openUrl:application openURL:url];

/* Example */  
-(BOOL)application:(UIApplication*)application openURL:(NSURL*)url sourceApplication:(NSString*)sourceApplication annotation:(id)annotation {
    [NotifyvisitorsPlugin openUrl:application openURL:url];
    return YES;
}

/* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */ 
/* swift */
NotifyvisitorsPlugin.openUrl(app, open: url)
  
/* Example */  
override func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]) -> Bool {
     NotifyvisitorsPlugin.openUrl(app, open: url)
     return true
 }
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) -> Bool {
  notifyvisitors.openUrl(with: app, url: url);
  return ApplicationDelegateProxy.shared.application(app, open: url, options: options)
}

Notification Service Extension

Add [Notification Service Extension] to support Rich media Attachments from iOS 10 push notifications. Kindly refer to our [Notification Service Extension] creation guide on the Next Page.