Maxim Salnikov
@webmaxru
Push Notifications
My App
Maxim Salnikov
data:image/s3,"s3://crabby-images/3cd75/3cd752c52a1968c084a5858cb0113d728f070d89" alt=""
-
PWA Slack organizer
-
PWA Oslo / PWA London meetups organizer
-
PWA speaker and trainer
-
Google Dev Expert in Web Technologies
data:image/s3,"s3://crabby-images/df9a0/df9a0b014b81220f41c210338516a84a98adc2ce" alt=""
Azure Developer Technical Lead at Microsoft
data:image/s3,"s3://crabby-images/6ee70/6ee706809d0c6ce07660fb37596f82f2c453bab4" alt=""
Why is this important?
For user:
timely updates from websites you use
For publisher:
effectively re-engage users with customized, relevant content
Current support
data:image/s3,"s3://crabby-images/3efe1/3efe1cdb465070ec93b376980024927de05d8706" alt=""
Involved parties & flow
data:image/s3,"s3://crabby-images/e9ee7/e9ee7953e7f1edd5d6bef3f53bd5c0634d99b7fa" alt=""
Feature detection
if (!('serviceWorker' in navigator)) {
// Service Worker isn't supported on this browser
// Disable or hide UI.
return;
}
if (!('PushManager' in window)) {
// Push isn't supported on this browser
// Disable or hide UI.
return;
}
Requesting permission
Notification.requestPermission().then(function(result) {
if (result === 'denied') {
console.log('Permission wasn\'t granted');
return;
}
if (result === 'default') {
console.log('The permission request was dismissed');
return;
}
// Do something with the granted permission
// result === 'granted' in this case
});
data:image/s3,"s3://crabby-images/09000/0900016099e6adf01cb4a539d7b9ebe070bf950f" alt=""
UX patterns
-
Ask to subscribe at a time when the benefit is obvious
-
Antipattern: to show the permission dialog to users as soon as they land on your site
-
Consider how a user should unsubscribe or opt out of push messaging.
data:image/s3,"s3://crabby-images/6bdf5/6bdf5acab2978c17b5bad020dc43590ded454e69" alt=""
data:image/s3,"s3://crabby-images/14c72/14c72d7c5f9b4b90f63e95f109418818b0ecf77f" alt=""
data:image/s3,"s3://crabby-images/ca5d4/ca5d486d4d19bb30fd90e44fe9dbfa5f7a2e2fe0" alt=""
Allow users to unsubscribe.
Otherwise they'll block!
Subscribing
navigator.serviceWorker.register('/service-worker.js')
.then(function(registration) {
const subscribeOptions = {
userVisibleOnly: true,
applicationServerKey: 'key...'
};
return registration.pushManager.subscribe(subscribeOptions);
})
.then(function(pushSubscription) {
console.log(JSON.stringify(pushSubscription));
return pushSubscription;
});
{
"endpoint": "https://particular-push-service.com/long-unique-id/",
"keys": {
"p256dh": "BNcRdreALRFXTkOOUHK1EtK2wtaz5Ry4YfYCA=",
"auth": "tBHItJI5svbpez7KI4CCXg=="
}
}
Push event
self.addEventListener('push', function(event) {
notification = event.data.json()
event.waitUntil(
self.registration.showNotification(
notification.title, notification.options
)
)
})
data:image/s3,"s3://crabby-images/f129d/f129dc47651d22bd70c08a5477f1e9818ee16e01" alt=""
Notification UX
data:image/s3,"s3://crabby-images/7c09b/7c09bdf990fbbcbc9971fd50c2d385e17b636772" alt=""
const title = 'Something Has Happened'
const options = {
message: 'Something you might want to check out',
icon: '/assets/images/logo.png'
}
self.registration.showNotification(title, options)
MyAirline
Online check in is available
MyAirline
myairline.com
data:image/s3,"s3://crabby-images/b79d3/b79d3869c4efc65f0b4a7b3515b0114de3b18a93" alt=""
data:image/s3,"s3://crabby-images/b79d3/b79d3869c4efc65f0b4a7b3515b0114de3b18a93" alt=""
Flight
DY1043
Depart
21.09 13:45
OSL -> LAX
Click here to check in now
myairline.com
-
Do not Repeat Yourself
-
Provide actual information instead of notifying about it
-
Give a call to action
Notification actions
self.addEventListener('notificationclose', function(event) {
const dismissedNotification = event.notification
event.waitUntil( triggerAnalytics( dismissedNotification ) )
})
self.addEventListener('notificationclick', function(event) {
const clickedNotification = event.notification
clickedNotification.close()
event.waitUntil( performAction( clickedNotification ) );
});
-
Open a window
-
Focus an existing window
-
Message a page from a push event
Thank you!
Maxim Salnikov
@webmaxru
Questions?
Maxim Salnikov
@webmaxru
PWA: Push Notifications
By Maxim Salnikov
PWA: Push Notifications
- 4,595