-
Notifications
You must be signed in to change notification settings - Fork 22
Expand file tree
/
Copy pathserviceworker.js
More file actions
60 lines (51 loc) · 1.98 KB
/
serviceworker.js
File metadata and controls
60 lines (51 loc) · 1.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
// collection of all the static files which form the the shell of your app
const staticAssets = [
'./',
'./style.css',
'./app.js'
];
var mode; //used to keep a check whether we are online at this point of time or offline
// install event is called the very first time we register a servic worker
self.addEventListener('install', async event => {
// #caches are http caches provided by service worker check Application >Cache > Cache Storage
const cache = await caches.open('static-def'); // stores the shell part
cache.addAll(staticAssets);
});
// called whenever fetxh function is called in the client side
self.addEventListener('fetch', event => {
console.log(event);
const {request} = event;
const url = new URL(request.url);
if(mode==false) //check if online or offline
event.respondWith(cacheData(request)); // if offline we have to check cache
else{
if(url.origin === location.origin) { // if the url that we are searching for is in the domain check cache first
event.respondWith(cacheData(request));
} else {
event.respondWith(networkFirst(request)); // for outside urls do not check cache
}
}
});
self.addEventListener('message', function(event){
if(event.data=="offline")
mode=false
else
mode=true
console.log("message: "+mode);
});
async function cacheData(request)
{
const cachedResponse = await caches.match(request); // check for request object for a match else returns nothing
return cachedResponse || fetch(request);
}
async function networkFirst(request)
{
const cache = await caches.open('dynamic-def'); // stores the dynamic part of the pwa
try {
const response = await fetch(request);
cache.put(request, response.clone()); // map new request objects to the result object
return response;
} catch (error){
return await cache.match(request); // if theres an error in making network first request it will check the caches
}
}