-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathservice-worker.js
69 lines (62 loc) · 1.34 KB
/
service-worker.js
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
61
62
63
64
65
66
67
68
69
const CACHE_NAME = 'redditjson';
const CACHED_FILES = [
'/'
];
self.addEventListener('install', (evt) => {
evt.waitUntil(
Promise.resolve()
.then(() => {
return caches.open(CACHE_NAME);
})
.then((cache) => {
return cache.addAll(CACHED_FILES);
})
.then(() => {
self.skipWaiting();
})
);
});
self.addEventListener('activate', (event) => {
event.waitUntil(
caches.keys()
.then((keys) => {
return Promise.all(keys
.filter((key) => {
return key !== CACHE_NAME;
})
.map((key) => {
return caches.delete(key);
})
);
})
);
});
function isForeignRequest(request) {
return (/youtube|google|gstatic|twitter|codepen|cdn-cgi|disqus|github|twimg/).test(request.url);
}
function fetchAndCache(request, cache) {
return fetch(request)
.then((response) => {
cache.put(request, response.clone());
// console.log('fetch (online)', request.url);
return response;
})
.catch(() => {
// console.log('fetch (cache)', request.url);
return cache.match(request);
});
}
function networkFirst(evt) {
evt.respondWith(
caches.open(CACHE_NAME)
.then((cache) => {
return fetchAndCache(evt.request, cache);
})
);
}
self.addEventListener('fetch', (evt) => {
if (isForeignRequest(evt.request)) {
return;
}
networkFirst(evt);
});