Slide 1

Slide 1 text

BROWSERS BEHIND YOUR BACK

Slide 2

Slide 2 text

PHIL NASH @philnash http:/ /philna.sh [email protected]

Slide 3

Slide 3 text

BROWSERS BEHIND YOUR BACK

Slide 4

Slide 4 text

EMAIL IS PRETTY COOL @philnash

Slide 5

Slide 5 text

No content

Slide 6

Slide 6 text

ON THE WEB? @philnash

Slide 7

Slide 7 text

PROGRESSIVE WEB APPS

Slide 8

Slide 8 text

@philnash

Slide 9

Slide 9 text

SENDING MESSAGES @philnash

Slide 10

Slide 10 text

LIKE OR FAVOURITE @philnash

Slide 11

Slide 11 text

ADD SHOPPING TO CART @philnash

Slide 12

Slide 12 text

LEAVING A COMMENT @philnash

Slide 13

Slide 13 text

@philnash

Slide 14

Slide 14 text

BACKGROUND SYNC API

Slide 15

Slide 15 text

BACKGROUND SYNC API • Service Worker • IndexedDB • Sync Event @philnash

Slide 16

Slide 16 text

DEMO

Slide 17

Slide 17 text

SERVICE WORKER

Slide 18

Slide 18 text

@philnash

Slide 19

Slide 19 text

@philnash

Slide 20

Slide 20 text

@philnash

Slide 21

Slide 21 text

INDEXEDDB

Slide 22

Slide 22 text

@philnash

Slide 23

Slide 23 text

OBJECT STORE @philnash

Slide 24

Slide 24 text

ASYNCHRONOUS @philnash

Slide 25

Slide 25 text

TRANSACTIONAL @philnash

Slide 26

Slide 26 text

LOW LEVEL @philnash

Slide 27

Slide 27 text

USE A LIBRARY • idb • localForage • Dexie • PouchDB @philnash

Slide 28

Slide 28 text

SERVICE WORKERS LOVE PROMISES @philnash

Slide 29

Slide 29 text

CALLBACKS var request = indexedDB.open('messages', 1) request.onupgradeneeded = function(event) { var upgradeDb = event.result.target; upgradeDb.createObjectStore('outbox', { autoIncrement : true, keyPath: 'id' }); } request.onsuccess = function(event) { window.db = event.result.target; } 01. 02. 03. 04. 05. 06. 07. 08. 09. 10. @philnash

Slide 30

Slide 30 text

PROMISES idb.open('messages', 1, function(upgradeDb) { upgradeDb.createObjectStore('outbox', { autoIncrement : true, keyPath: 'id' }); }).then(function(db) { return window.db = db; }) 01. 02. 03. 04. 05. 06. 07. @philnash

Slide 31

Slide 31 text

DEMO

Slide 32

Slide 32 text

BACKGROUND SYNC API

Slide 33

Slide 33 text

@philnash

Slide 34

Slide 34 text

@philnash

Slide 35

Slide 35 text

BACK ONLINE API

Slide 36

Slide 36 text

SUPPORT 49 5.4 devdevdev ? @philnash

Slide 37

Slide 37 text

ON THE PAGE navigator.serviceWorker.ready.then(function(reg) { reg.sync.register('back-online'); }); 01. 02. 03. @philnash

Slide 38

Slide 38 text

IN THE SERVICE WORKER self.addEventListener('sync', function(event) { if (event.tag === 'back-online') { // do something } }); 01. 02. 03. 04. 05. @philnash

Slide 39

Slide 39 text

DEMO

Slide 40

Slide 40 text

THE FUTURE

Slide 41

Slide 41 text

PERIODIC SYNC API

Slide 42

Slide 42 text

ON THE PAGE navigator.serviceWorker.ready.then(function(reg) { reg.periodicSync.register({ tag: 'get-latest-news', // default: '' minPeriod: 12 * 60 * 60 * 1000, // default: 0 powerState: 'avoid-draining', // default: 'auto' networkState: 'avoid-cellular' // default: 'online' }); }); 01. 02. 03. 04. 05. 06. 07. 08. @philnash

Slide 43

Slide 43 text

IN THE SERVICE WORKER self.addEventListener('periodicsync', function(event) { if (event.tag === 'get-latest-news') { // get the latest news! } }); 01. 02. 03. 04. 05. @philnash

Slide 44

Slide 44 text

BACKGROUND FETCH API

Slide 45

Slide 45 text

ON THE PAGE navigator.serviceWorker.ready.then(function(reg) { const url = "https://example.com/largeFile.mp3"; reg.backgroundFetch.fetch('downloads', [url], { icons: [], title: 'Downloading largeFile.mp3', totalDownloadSize: 1048576 }); }); 01. 02. 03. 04. 05. 06. 07. 08. @philnash

Slide 46

Slide 46 text

IN THE SERVICE WORKER self.addEventListener('backgroundfetched', function(event) { if (event.tag === 'downloads') { event.updateUI('largeFile.mp3 downloaded.'); } }); 01. 02. 03. 04. 05. @philnash

Slide 47

Slide 47 text

IN THE SERVICE WORKER Other events: • backgroundfetchfail • backgroundfetchabort • backgroundfetchclick @philnash

Slide 48

Slide 48 text

DEMO

Slide 49

Slide 49 text

BLOG POSTS Background sync: http:/ /bit.ly/bg-sync Background fetch: http:/ /bit.ly/bg-fetch @philnash

Slide 50

Slide 50 text

THANKS

Slide 51

Slide 51 text

ICON CREDITS • Browser by Kimmi Studio from the Noun Project • Cloud by Kimmi Studio from the Noun Project • Gears by TS Graphics from the Noun Project • Database by Yo! Baba from the Noun Project • wifi by i cons from the Noun Project @philnash

Slide 52

Slide 52 text

THANKS! @philnash http:/ /philna.sh [email protected]