Version 8.3.0 adds support for iOS's WKWebView. UIWebView support for Urban Airship's default message center and overlay views will be removed in iOS SDK 9.0.
useWKWebView key
By including the "useWKWebView" key in AirshipConfig.plist and setting the value to "YES", you can enable WKWebView support for messages in the default message center (UADefaultMessageCenter) and for landing pages (UALandingPageOverlayController).
UAWKWebViewNativeBridge is the interface for integrating Urban Airship features into your own WKWebViews. Please see the iOS Message Center Customization Topic Guide or the Custom Events Guide for more information
WKWebView by default scales the content to fit the view. This is different than UIWebView. The following is an example of the rendering of simple message center message with a body containing only an image tag: <img src="https://www.urbanairship.com/images/[email protected]">
WKWebView | UIWebView |
---|
Fully styled content, such as that contained in messages created in the Rich Content Editor of the Message Composer, will render identically using either type of web view.
A new application integration point has been added to UAAppIntegration. If your application disables automatic integration, it will need to be updated to call the new method:
func application(application: UIApplication, didFailToRegisterForRemoteNotificationsWithError error: Error)
+ (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error;
This version supports iOS 8, 9 and 10. Xcode 8 is required.
With iOS 10 and SDK 8 you have the ability to send Rich Notifications. To configure rich notification support, please visit iOS Notification Service Extensions.
All application integration points have been moved to UAAppIntegration. If your application disables automatic integration, it will need to be updated to call the new methods:
func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData)
func application(application: UIApplication, didReceiveRemoteNotification userInfo: [NSObject : AnyObject], fetchCompletionHandler completionHandler: (UIBackgroundFetchResult) -> Void)
func application(application: UIApplication, didRegisterUserNotificationSettings notificationSettings: UIUserNotificationSettings)
func application(application: UIApplication, handleActionWithIdentifier identifier: String?, forRemoteNotification userInfo: [NSObject : AnyObject], completionHandler: () -> Void)
func application(application: UIApplication, handleActionWithIdentifier identifier: String?, forRemoteNotification userInfo: [NSObject : AnyObject], withResponseInfo responseInfo: [NSObject : AnyObject], completionHandler: () -> Void)
+ (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken;
+ (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler;
+ (void)application:(UIApplication *)application didRegisterUserNotificationSettings:(UIUserNotificationSettings *)notificationSettings;
+ (void)application:(UIApplication *)application handleActionWithIdentifier:(NSString *)identifier forRemoteNotification:(NSDictionary *)userInfo completionHandler:(void (^)())handler;
+ (void)application:(UIApplication *)application handleActionWithIdentifier:(NSString *)identifier forRemoteNotification:(NSDictionary *)userInfo withResponseInfo:(nullable NSDictionary *)responseInfo completionHandler:(void (^)())handler;
func userNotificationCenter(center: UNUserNotificationCenter, didReceiveNotificationResponse response: UNNotificationResponse, withCompletionHandler completionHandler: () -> Void)
func userNotificationCenter(center: UNUserNotificationCenter, willPresentNotification notification: UNNotification, withCompletionHandler completionHandler: (_ options: UNNotificationPresentationOptions) -> Void)
+ (void)userNotificationCenter:(UNUserNotificationCenter *)center
didReceiveNotificationResponse:(UNNotificationResponse *)response
withCompletionHandler:(void(^)())completionHandler;
+ (void)userNotificationCenter:(UNUserNotificationCenter *)center
willPresentNotification:(UNNotification *)notification
withCompletionHandler:(void (^)(UNNotificationPresentationOptions options))completionHandler;
The property launchNotification
has been replaced with launchNotificationResponse
and will contain a UANotificationResponse
.
Notification categories and types have been removed. Instead you can set UANotificationOptions and UANotificationCategory and the SDK will automatically convert the properties to the appropriate types depending on the OS version.
// Old
func currentEnabledNotificationTypes() -> UIUserNotificationType
var userNotificationTypes: UIUserNotificationType
var userNotificationCategories = Set<NSObject>()
// New
var notificationOptions: UANotificationOptions
var authorizedNotificationOptions: UANotificationOptions
var customCategories: Set<UANotificationCategory>
// Old
- (UIUserNotificationType)currentEnabledNotificationTypes;
@property (nonatomic, assign) UIUserNotificationType userNotificationTypes;
@property (nonatomic, strong) NSSet *userNotificationCategories;
// New
@property (nonatomic, assign) UANotificationOptions notificationOptions;
@property (nonatomic, assign, readonly) UANotificationOptions authorizedNotificationOptions;
@property (nonatomic, strong) NSSet <UANotificationCategory *>customCategories;
The UAPushNotificationDelegate has been rewritten to be more aligned with iOS 10. The following methods are provided:
func receivedForegroundNotification(_ notificationContent: UANotificationContent, completionHandler: () -> Void)
func receivedBackgroundNotification(_ notificationContent: UANotificationContent, completionHandler: (UIBackgroundFetchResult) -> Void)
func receivedNotificationResponse(_ notificationResponse: UANotificationResponse, completionHandler: () -> Void)
func presentationOptions(for notification: UNNotification) -> UNNotificationPresentationOptions
-(void)receivedForegroundNotification:(UANotificationContent *)notificationContent completionHandler:(void (^)())completionHandler;
-(void)receivedBackgroundNotification:(UANotificationContent *)notificationContent completionHandler:(void (^)(UIBackgroundFetchResult))completionHandler;
-(void)receivedNotificationResponse:(UANotificationResponse *)notificationResponse completionHandler:(void (^)())completionHandler;
- (UNNotificationPresentationOptions)presentationOptionsForNotification:(UNNotification *)notification;
The isBackgroundPush
method has been replaced with isSilentPush
.
UANamedUser access has been moved to UAirship.
Added
UAirship.namedUser().identifier = "NamedUserID"
[UAirship namedUser].identifier = @"NamedUserID";
Deprecated
UAirship.push().namedUser.identifier = "NamedUserID"
[UAirship push].namedUser.identifier = @"NamedUserID";
UALocationService and UALocationServiceDelegate has been deprecated and replaced with UALocation and UALocationDelegate. See iOS Platform Guide on how to use the new location APIs.
The Urban Airship library no longer references the Passkit framework for the wallet action. This is to work around the App Store incorrectly showing an app "Supports Wallet" when it does not contain wallet capabilities (Radar #24942020). The wallet action now behaves exactly like the open URL external action. If the old wallet action behavior is desired, please see Apple Wallet extension.
See legacy migration guide for older migrations