Progressive Web Apps
(aka PWA)
data:image/s3,"s3://crabby-images/058cb/058cbd7c16dcdc82933e013b273b010353d8bb2b" alt=""
data:image/s3,"s3://crabby-images/4f89b/4f89bc8cb57aa5f97047f5aee47f91b3d18876df" alt=""
Hi, I am Trishul
WHAT
@trishulgoel
@trishulgoel
WEBSITE
NATIVE APP
PWA
@trishulgoel
Discoverability
of
web
Retention
of
app
PWA
@trishulgoel
"they’re just websites that took all the right vitamins."
- Alex Russell
https://medium.com/@slightlylate/progressive-apps-escaping-tabs-without-losing-our-soul-3b93a8561955
WHY
@trishulgoel
bcoz JAVASCRIPT
@trishulgoel
PUSH NOTIFICATIONS
APP LIKE EXPERIENCE
@trishulgoel
WORKS OFFLINE
FASTER LOAD TIME
INSTALLABLE
@trishulgoel
data:image/s3,"s3://crabby-images/28753/28753f7a32cdbf8e1f47ca5c9d35bb90ea0deaf6" alt=""
data:image/s3,"s3://crabby-images/38b5f/38b5fb2daa40ca06f4e9526150475a9ea9220494" alt=""
data:image/s3,"s3://crabby-images/7e552/7e55248808c5f8ec18414cd2aa940b568c7b683c" alt=""
data:image/s3,"s3://crabby-images/f3ee4/f3ee4e4f264416cd33f59b64bf07c147c8f7e0a9" alt=""
HOW
@trishulgoel
Web app manifest
@trishulgoel
{
"short_name": "App",
"name": "My App",
"icons": [
{
"src": "/images/logo.png",
"type": "image/png",
"sizes": "1282x128"
}
],
"start_url": "/index.html",
"background_color": "#FF00FF",
"display": "standalone",
"theme_color": "#FF01FF"
}
<link rel="manifest" href="/manifest.json">
SERVICEWORKERS
@trishulgoel
data:image/s3,"s3://crabby-images/4bc82/4bc828305eb07deabf95728dc6c0bc2c0cda236c" alt=""
BUILDING BLOCKS OF PWA
@trishulgoel
@trishulgoel
CACHING
@trishulgoel
self.addEventListener('install', function(event) {
event.waitUntil(
caches.open('my-cahce').then(function(cache) {
return cache.addAll(
[
'/css/style.css',
'/js/script.js',
'/index.html'
]
);
})
);
});
self.addEventListener('fetch', function(event) {
event.respondWith(
caches.match(event.request).then(function(response) {
if(!response) response = fetch(event.request);
return response;
})
);
});
@trishulgoel
PUSH NOTIFICATIONS
@trishulgoel
self.addEventListener('activate', async () => {
try {
const options = {}
const subscription = await self.registration.pushManager.subscribe(options)
} catch (err) {
console.log('Error', err)
}
})
self.addEventListener('push', function(event) {
if (event.data) {
self.registration.showNotification("Here we are", event.data.text(),
}
})
PWA on STEROIDS
@trishulgoel
PREREQUISITES
@trishulgoel
- HTTPS
- Browser Compatibility
@trishulgoel
STEROIDS
@trishulgoel
SPEECH SYNTHESIS
@trishulgoel
const synth = window.speechSynthesis;
const voices = synth.getVoices();
const say = new SpeechSynthesisUtterance(text);
say.voice = voices[<selectedindex>];
say.rate = <rate>;
say.pitch = <pitch>;
synth.speak(say);
SPEECH RECOGNITION
@trishulgoel
const recognition = new webkitSpeechRecognition();
recognition.onstart = fn;
recognition.onerror = fn;
recognition.onend = fn;
recognition.onresult = fn;
recognition.start();
MEDIA CAPTURE API
@trishulgoel
const video = document.querySelector('video');
navigator.mediaDevices.getUserMedia({ video: true, audio: false })
.then(stream => {
video.srcObject = stream;
video.play();
});
VIBRATION
@trishulgoel
window.navigator.vibrate(200);
window.navigator.vibrate([300, 200, 400, 200, 300]);
NETWORK INFO
@trishulgoel
navigator.onLine
window.addEventListener('online', fn);
window.addEventListener('offline', fn);
navigator.connection.type
navigator.connection.effectiveType //bandwidth
navigator.connection.saveData
navigator.connection.downlink
navigator.connection.addEventListener('change', fn);
ORIENTATION
@trishulgoel
window.addEventListener('deviceorientation', handleOrientation);
function handleOrientation(event) {
const z = event.alpha; // Z-aixs | In degree in the range [0, 360]
const x = event.beta; // X-aixs | In degree in the range [-180, 180]
const y = event.gamma; // Y-aixs | In degree in the range [-90, 90]
}
BATTERY API*
@trishulgoel
navigator.getBattery().then(function(battery) {
// battery.charging
// battery.level
battery.addEventListener('chargingchange', listener);
battery.addEventListener('levelchange', listener);
battery.addEventListener('chargingtimechange', listener);
}
https://developer.mozilla.org/en-US/docs/Web/API/Battery_Status_API
WEB SHARE API*
@trishulgoel
navigator.share({
title: <title>
text: <text>,
url: <url>,
});
https://developer.mozilla.org/en-US/docs/Web/API/Navigator/share
BLUETOOTH
@trishulgoel
const device = await navigator.bluetooth.requestDevice({
filters: [{
namePrefix: 'Device-name',
services: ['battery_service'] }],
});
const server = await device.gatt.connect();
const service = await server.getPrimaryService('battery_service');
const characteristic = await service.getCharacteristic('battery_level');
characteristic.writeValue(new Uint8Array( .... )); // 'value' -> bytes
characteristic.addEventListener('characteristicvaluechanged', fn);
MANY MORE...
@trishulgoel
- web Audio API
- Payment Request API
- Memory API
- WebUSB API
SUCCESS STORIES
@trishulgoel
@trishulgoel
data:image/s3,"s3://crabby-images/d9baf/d9baf944b98d0d95f36f77055b31274c23d0becc" alt=""
data:image/s3,"s3://crabby-images/578f9/578f9682f3e2468914e0ddaee3d31740ca1ca8ea" alt=""
data:image/s3,"s3://crabby-images/61ef9/61ef957dfccd9a00d90837ff155edac6975f65c7" alt=""
data:image/s3,"s3://crabby-images/b7489/b7489305016ed70e58412c91a39276c7e4ea4277" alt=""
data:image/s3,"s3://crabby-images/ecb18/ecb188fdd43503e9bf36b4aef9d214b1a860815c" alt=""
https://developers.google.com/web/showcase/
data:image/s3,"s3://crabby-images/14e80/14e80e55977cf190a9c184208166814000df2911" alt=""
data:image/s3,"s3://crabby-images/e3b03/e3b03b7c464e2b0f0112ec85184c085a0cd4e6af" alt=""
data:image/s3,"s3://crabby-images/f268e/f268ef6484a63954ea5dd64f35d661e4890b3485" alt=""
FUTURE
@trishulgoel
- WEBASSEMBLY 😎
- MORE APIs
- BETTER BROWSER SUPPORT
@trishulgoel
REFERENCES
- https://serviceworke.rs
- https://developer.mozilla.org
- https://developers.google.com/
- https://github.com/tsl143/pwapower
@trishulgoel
@trishulgoel
data:image/s3,"s3://crabby-images/bb3b6/bb3b6297215e3a67e03d9ed712058ef3731d20ce" alt=""
Grazie!
PWA on Steroids
By Trishul Goel
PWA on Steroids
PWA on Steroids - JSDay Italy
- 1,169