- 
                Notifications
    You must be signed in to change notification settings 
- Fork 22
Home
To configure the SDK, the following has to be done in the AppDelegate of the application:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    EMSConfig *config = [EMSConfig makeWithBuilder:^(EMSConfigBuilder *builder) {
        [builder setMobileEngageApplicationCode:<applicationCode: NSString>
                            applicationPassword:<applicationPassword: NSString>];
        [builder setContactFieldId:<contactFieldId: NSNumber>];
        [builder setMerchantId:<predictMerchantId: NSString>];
    }];
    [Emarsys setupWithConfig:config];
    return YES;
}func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
    let config = EMSConfig.make { builder in
        builder.setMobileEngageApplicationCode(<applicationCode: String>, applicationPassword: <applicationPassword: String>)
        builder.setContactFieldId(<contactFieldId: Number>)
        builder.setMerchantId(<predictMerchantId: String>)
    }
    Emarsys.setup(with: config)
    return true
}After application setup is finished, you can use setContact method to identify the user with contactFieldValue.
[Emarsys setContactWithContactFieldValue:<contactFieldValue: NSString>
                         completionBlock:^(NSError *error) {
                         }];Emarsys.setContactWithContactFieldValue(<contactFieldValue: String>) { error in
}When the user signs out, the clearContact method should be used:
[Emarsys clearContactWithCompletionBlock:^(NSError *error) {
}];Emarsys.clearContact { error in
}If you want to track custom events, the trackCustomEvent method should be used, where the eventName parameter is required, but the other attributes are optional.
[Emarsys trackCustomEventWithName:<eventName: String>
                  eventAttributes:<eventAttributes: NSDictionary<String, String>
                  completionBlock:^(NSError *error) {
                  }];Emarsys.trackCustomEvent(withName: <eventName: String>, eventAttributes: <eventAttributes: NSDictionary<String, String>) { error in
}The pushToken has to be set when it arrives:
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
    [Emarsys.push setPushToken:deviceToken
               completionBlock:^(NSError *error) {
               }];
}func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
    Emarsys.push.setPushToken(deviceToken) { error in
    }
}If you want to remove pushToken for the Contact, you can use clearPushToken
[Emarsys.push clearPushTokenWithCompletionBlock:^(NSError *error) {
}];Emarsys.push.clearPushToken { error in
}If you want to track whether the push messages have been opened, the trackMessageOpen method should be used.
In the simplest case this call will be in the AppDelegate's didReceiveRemoteNotification:fetchCompletionHandler: method:
-(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
    [Emarsys.push trackMessageOpenWithUserInfo:userInfo
                               completionBlock:^(NSError *error) {
                               }];
}func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
    Emarsys.push.trackMessageOpen(userInfo: userInfo) { error in
    }
}In order to receive the inbox content, you can use the fetchNotifications method.
[Emarsys.inbox fetchNotificationsWithResultBlock:^(EMSNotificationInboxStatus *inboxStatus, NSError *error) {
    if (error) {
        NSLog(error);
    } else {
        NSLog(inboxStatus.notifications);
        NSLog(inboxStatus.badgeCount);
    }
}];Emarsys.inbox.fetchNotifications { status, error in
    if let error = error {
        print(error as Any)
    } else if let status = status {
        print("Notifications: \(status.notifications) badgeClount: \(status.badgeCount)")
    }
}When your user opened the application inbox you might want to reset the unread count (badge). To do so you can use the resetBadgeCount method.
[Emarsys.inbox resetBadgeCountWithCompletionBlock:^(NSError *error) {
}];Emarsys.inbox.resetBadgeCount { error in
}To track the notification opens in inbox, use the following trackNotificationOpen method.
[Emarsys.inbox trackNotificationOpenWithNotification:<notification: EMSNotification>
                                     completionBlock:^(NSError *error) {
}];Emarsys.inbox.trackNotificationOpen(with: <notification: EMSNotification>) { error in
}When a critical activity starts and should not be interrupted by InApp, pause InApp messages
[Emarsys.inApp pause];Emarsys.inApp.pause()In order to show inApp messages after being paused use the resume method
[Emarsys.inApp resume];Emarsys.inApp.resume()In order to react to an event, triggered from the InApp message, you can register for it using the setEventHandler method.
[Emarsys.inApp setEventHandler:<eventHandler: id<EMSEventHandler>>];Emarsys.inApp.eventHandler = <eventHandler: EMSEventHandler>We won't go into the details to introduce how Predict works, and what are the capabilities, but here we aim to explain the mapping between the Predict commands and our interface. Please visit Predict's documentation for more details.
To use Predict functionality you have to setup your merchantId during the initialization of the SDK.
In order to track Predict events you can use the methods available on our Predict interface.
When you want to track the cart items in the basket you can call the trackCart method with a list of CartItems. CartItem is an interface
which can be used in your application for your own CartItems and then simply use the same items with the SDK
[Emarsys.predict trackCartWithCartItems:<cartItems: NSArray<EMSCartItem *> *>];Emarsys.predict.trackCart(withCartItems: <cartItems: Array<EMSCartItem>>)To report a purchase event you should call trackPurchase with the items purchased and with an orderId
[Emarsys.predict trackPurchaseWithOrderId:<orderId: NSString>
                                    items:<cartItems: NSArray<EMSCartItem *> *>];Emarsys.predict.trackPurchase(withOrderId: <orderId: String>, items: <cartItems: Array<EMSCartItem>>)If an item was viewed use the trackItemView method with an itemId.
[Emarsys.predict trackItemViewWithItemId:<itemId: NSString>];Emarsys.predict.trackItemView(withItemId: <itemId: String>)When the user navigates between the categories you should call trackCategoryView in every navigation. Be aware to send categoryPath
in the required format. Please visit Predict's documentation for more information.
[Emarsys.predict trackCategoryViewWithCategoryPath:<categoryPath: NSString>];Emarsys.predict.trackCategoryView(withCategoryPath:<categoryPath: String>)To report search terms entered by the contact use trackSearchTerm method.
[Emarsys.predict trackSearchWithSearchTerm:<searchTerm: NSString>];Emarsys.predict.trackSearch(withSearchTerm: <searchTerm: String>)If you want to track custom events, the trackCustomEvent method should be used, where the eventName parameter is required, but the other attributes are optional.
[Emarsys trackCustomEventWithName:<eventName: NSString>
                  eventAttributes:<eventAttributes: NSDictionary<NSString, NSString>
                  completionBlock:^(NSError *error) {
                  }];Emarsys.trackCustomEvent(withName: <eventName: String>, eventAttributes: <eventAttributes: NSDictionary<String, String>) { error in
}
NoteFor further information please check our DeepLink page.
In order to track email link clicks that opens the application directly with the Emarsys SDK, you need to call trackDeepLink in your AppDelegate's application:continueUserActivity:restorationHandler: method.
-  (BOOL)application:(UIApplication *)application
continueUserActivity:(NSUserActivity *)userActivity
  restorationHandler:(void (^)(NSArray *__nullable restorableObjects))restorationHandler {
    return [Emarsys trackDeepLinkWith:userActivity sourceHandler:^(NSString *source) {
        NSLog([NSString stringWithFormat:@"Source url: %@", source]);
    }];
}func application(_ application: UIApplication, continue userActivity: NSUserActivity, restorationHandler: @escaping ([Any]?) -> Void) -> Bool {
    return Emarsys.trackDeepLink(with: userActivity, sourceHandler: { url in
        if let source = url {
            print(source)
        }
    })
}The (BOOL) return value of Emarsys.trackDeepLink indicates whether the UserActivity contained a Mobile Engage email deeplink and whether it was handled by the SDK.
The first parameter is the UserActivity that comes from the AppDelegate’s application:continueUserActivity:restorationHandler: method.
The second parameter is optional, it is a closure/block that provides the source Url that was extracted from the UserActivity.
For more information, read the relevant iOS documentation.