Safari push notifications for mobile
Learn how to send push notifications to iOS and iPadOS users using Safari v16.4 or later.
Prerequisites
Before you can set up Safari push notifications on mobile, you’ll need to set up push notifications for the Braze Web SDK.
Setting up Safari push for mobile
Step 1: Create a manifest file
A Web Application Manifest is a JSON file that controls how your website is presented when installed to a user’s home screen.
For example, you can set the background theme color and icon that the App Switcher uses, whether it renders as full screen to resemble a native app, or whether the app should open in landscape or portrait mode.
Create a new manifest.json
file in your website’s root directory, with the following mandatory fields.
1
2
3
4
5
6
7
8
9
{
"name": "your app name",
"short_name": "your app name",
"display": "fullscreen",
"icons": [{
"src": "favicon.ico",
"sizes": "128x128",
}]
}
The full list of supported fields can be found here.
Step 2: Link the manifest file
Add the following <link>
tag to your website’s <head>
element pointing to where your manifest file is hosted.
1
<link rel="manifest" href="/manifest.json" />
Step 3: Add a service worker
Your website must have a service worker file that imports the Braze service-worker library, as described in our web push integration guide.
Step 4: Add to home screen
Popular browsers (such as Safari, Chrome, FireFox, and Edge) all support web push notifications in their later versions. To request push permission on iOS or iPadOS, your website must be added to the user’s home screen by selecting Share To > Add to Home Screen. Add to Homescreen lets users bookmark your website, adding your icon to their valuable home screen real estate.
Step 5: Show the native push prompt
After the app has been added to your home screen you can now request push permission when the user takes an action (such as clicking a button). This can be done using the requestPushPermission
method, or with a no-code push primer in-app message.
After you accept or decline the prompt, you need to delete and reinstall the website to your home screen to be able to show the prompt again.
For example:
1
2
3
4
5
6
7
8
9
import { requestPushPermission } from "@braze/web-sdk";
button.onclick = function(){
requestPushPermission(() => {
console.log(`User accepted push prompt`);
}, (temporary) => {
console.log(`User ${temporary ? "temporarily dismissed" : "permanently denied"} push prompt`);
});
};
Next steps
Next, send yourself a test message to validate the integration. After your integration is complete, you can use our no-code push primer messages to optimize your push opt-in rates.