-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathsw.js
77 lines (66 loc) · 2.12 KB
/
sw.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
70
71
72
73
74
75
76
77
var cacheName = 'WWW-EXAMPLE-COM-V1'
var filesToCache = [
'/',
'/index.html', // index.html
'/main.js',
'/css/style.css',
'/css/tailwind.min.css',
'/images/github.svg',
'/fonts/impact.woff'
]
self.addEventListener('install', function (event) {
event.waitUntil(
caches.open(cacheName)
.then(function (cache) {
console.info('[sw.js] cached all files')
return cache.addAll(filesToCache)
})
)
})
self.addEventListener('fetch', function (event) {
event.respondWith(
caches.match(event.request)
.then(function (response) {
if (response) {
return response
} else {
// clone request stream
// as stream once consumed, can not be used again
var reqCopy = event.request.clone()
return fetch(reqCopy, { credentials: 'include' }) // reqCopy stream consumed
.then(function (response) {
// bad response
// response.type !== 'basic' means third party origin request
if (!response || response.status !== 200 || response.type !== 'basic') {
return response // response stream consumed
}
// clone response stream
// as stream once consumed, can not be used again
var resCopy = response.clone()
// ================== IN BACKGROUND ===================== //
// add response to cache and return response
caches.open(cacheName)
.then(function (cache) {
return cache.put(reqCopy, resCopy) // reqCopy, resCopy streams consumed
})
// ====================================================== //
return response // response stream consumed
})
}
})
)
})
self.addEventListener('activate', function (event) {
event.waitUntil(
caches.keys()
.then(function (cacheNames) {
return Promise.all(
cacheNames.map(function (cName) {
if (cName !== cacheName) {
return caches.delete(cName)
}
})
)
})
)
})