Maxim Salnikov
@webmaxru
App Manifest
Add to Home Screen
My App
Fundamentals
Codelabs
Today's slidedecks
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?
data:image/s3,"s3://crabby-images/873ef/873efa4233541e3f545c908b10c7f383a1e4a495" alt=""
-
Most engaged audience
-
More repeat visits
-
Longer time on site
-
Higher conversion rates
Current support
data:image/s3,"s3://crabby-images/dd07a/dd07af84dc3e8cf0cff74102720cffd5afc15a6e" alt=""
Installation criteria
- Includes a web app manifest with at least:
-
-
icons must include a 192px and a 512px sized icons
-
display must be one of: fullscreen, standalone, or minimal-ui
-
Has registered a service worker with a fetch event handler
-
As a consequence of above point: served over HTTPS
-
The web app is not already installed
-
Manifest's prefer_related_applications is not true
-
Meets a user engagement heuristic (Engagement Score?)
Web App Manifest
{
"short_name": "Maps",
"name": "Google Maps",
"icons": [
{
"src": "/images/icons-192.png",
"type": "image/png",
"sizes": "192x192"
},
{
"src": "/images/icons-512.png",
"type": "image/png",
"sizes": "512x512"
}
],
"start_url": "/maps/?utm_source=pwa",
"background_color": "#3367D6",
"display": "standalone",
"scope": "/maps/",
"theme_color": "#3367D6"
}
Connect with your app
<link rel="manifest" href="/manifest.json">
Validate and test
data:image/s3,"s3://crabby-images/cd3fe/cd3fe3e690942c531cb031da823042181dec0a06" alt=""
Generate
Native install options
data:image/s3,"s3://crabby-images/c2e9e/c2e9e233ce22f569a74e1a66d1314cb79b1405e6" alt=""
data:image/s3,"s3://crabby-images/58a0f/58a0f17fa4be7a23b48db37e11e2f7d92c2231de" alt=""
data:image/s3,"s3://crabby-images/05c67/05c67b7c9ea7a930f957ac549dafafa49d0b50a5" alt=""
data:image/s3,"s3://crabby-images/cc696/cc6968d869f1b773ba90330e4beec6d26d1e4dfe" alt=""
Custom install options
-
Listen for the beforeinstallprompt event
-
Notify the user your app can be installed with a button or other element
-
Wait for the explicit user event
-
Show the prompt by calling prompt() on the saved beforeinstallprompt event
-
[Optional] Track the successful installation using appinstalled event
window.addEventListener('beforeinstallprompt', (e) => {
// Prevent Chrome 67 and earlier from auto-showing the prompt
e.preventDefault();
// Stash the event so it can be triggered later.
deferredPrompt = e;
// Update UI notify the user they can add to home screen
btnAdd.style.display = 'block';
});
btnAdd.addEventListener('click', (e) => {
// hide our user interface that shows our A2HS button
btnAdd.style.display = 'none';
// Show the prompt
deferredPrompt.prompt();
// Wait for the user to respond to the prompt
deferredPrompt.userChoice
.then((choiceResult) => {
if (choiceResult.outcome === 'accepted') {
console.log('User accepted the A2HS prompt');
} else {
console.log('User dismissed the A2HS prompt');
}
deferredPrompt = null;
});
});
window.addEventListener('appinstalled', (e) => {
// Installed
});
Tracking installations from all sources
UX patterns
-
Header
-
Menu
-
Landing page
-
Banner
-
Inline (contextual)
data:image/s3,"s3://crabby-images/386d4/386d41eae4144921fddf0f6a56c19f3ea9cf32ae" alt=""
data:image/s3,"s3://crabby-images/460a5/460a5cc2acc5d5a03c1e724216b5cb607cbbfbf1" alt=""
-
Keep promo outside of the flow of your user journeys
-
Include the ability to dismiss or decline the promotion
-
Combine more than one of these techniques in different parts of your PWA
-
Only show the promotion after beforeinstallprompt event
Thank you!
Maxim Salnikov
@webmaxru
Questions?
Maxim Salnikov
@webmaxru
PWA: App Manifest, Add to Home Screen
By Maxim Salnikov
PWA: App Manifest, Add to Home Screen
- 5,039