iOS image carousel push notifications
The UNNotificationContentExtension
protocol provides the entry point for a notification content app extension, which displays a custom interface for your app’s notifications.
data:image/s3,"s3://crabby-images/dbbc0/dbbc00b4b2eefc57bf0167c388edfdbd97c93743" alt=""
1. Add Notification Content Extension
In Xcode, select File > New > Target…
data:image/s3,"s3://crabby-images/0653d/0653d4fab4dcef9f6b834eac1839b70eefa94b9f" alt=""
Choose the Notification Content Extension
data:image/s3,"s3://crabby-images/d1bdd/d1bdd4d838cd82ca3d37fb5155194faa75cc4021" alt=""
Name it NotificationContentExtension
data:image/s3,"s3://crabby-images/cb5cf/cb5cfce1c968ad68ec4fafd320be48f30cdebd4f" alt=""
2. Add code to your app
Download PWNotificationExtension from Github and replace the PWNotificationContentExtension
in your Xcode Project with the same file from Github.
data:image/s3,"s3://crabby-images/de741/de7410ec3ab9d656d44d5b019edbd1459b25c4b7" alt=""
3. Notification category
Add the code bellow to your AppDelegate.swift file
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
if #available(iOS 10.0, *) { let options: UNAuthorizationOptions = [.alert] UNUserNotificationCenter.current().requestAuthorization(options: options) { (authorized, error) in if authorized { let categoryIdentifier = "PWNotificationCarousel" let carouselNext = UNNotificationAction(identifier: "PWNotificationCarousel.next", title: "➡️ RIGHT", options: []) let carouselPrevious = UNNotificationAction(identifier: "PWNotificationCarousel.previous", title: "⬅️ LEFT", options: []) let carouselCategory = UNNotificationCategory(identifier: categoryIdentifier, actions: [carouselNext, carouselPrevious], intentIdentifiers: [], options: []) UNUserNotificationCenter.current().setNotificationCategories([carouselCategory]) } } }
return true }
4. Send a push notification
iOS Category:
Send a push notification with APS json:
data:image/s3,"s3://crabby-images/f9ce0/f9ce017f3ad0a460768a992a206c93c0ca371b33" alt="APS JSON"
{ "aps":{ "category":"PWNotificationCarousel" }}
Custom Data
You must list the Image URLs separated by a comma ,
data:image/s3,"s3://crabby-images/9f9bd/9f9bd3dcabd6e467ab91c48a632d22765de11e01" alt="Example"
{ "images":"image1.jpg, image2.jpg, image3.jpg"}
Once you receive the push, you will need to long press or swipe left and click “View” to expand the notification depending on the iOS version.