-
Notifications
You must be signed in to change notification settings - Fork 890
/
sw.js
130 lines (110 loc) · 4.25 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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
global
offlineFallbackPage, divInstall
*/
// This is the "Offline page" service worker
const CACHE = "pwabuilder-precache";
const precacheFiles = [
/* Add an array of files to precache for your app */
"./index.html"
];
self.addEventListener("install", function (event) {
// eslint-disable-next-line no-console
console.log("[PWA Builder] Install Event processing");
// eslint-disable-next-line no-console
console.log("[PWA Builder] Skip waiting on install");
self.skipWaiting();
event.waitUntil(
caches.open(CACHE).then(function (cache) {
// eslint-disable-next-line no-console
console.log("[PWA Builder] Caching pages during install");
return cache.addAll(precacheFiles);
})
);
});
// Allow sw to control of current page
self.addEventListener("activate", function (event) {
// eslint-disable-next-line no-console
console.log("[PWA Builder] Claiming clients for current page");
event.waitUntil(self.clients.claim());
});
function updateCache(request, response) {
if (response.status === 206) {
console.log("Partial response is unsupported for caching.");
return Promise.resolve();
}
return caches.open(CACHE).then(function (cache) {
return cache.put(request, response);
});
}
function fromCache(request) {
// Check to see if you have it in the cache
// Return response
// If not in the cache, then return
return caches.open(CACHE).then(function (cache) {
return cache.match(request).then(function (matching) {
if (!matching || matching.status === 404) {
return Promise.reject("no-match");
}
return matching;
});
});
}
// If any fetch fails, it will look for the request in the cache and
// serve it from there first
self.addEventListener("fetch", function (event) {
if (event.request.method !== "GET") return;
event.respondWith(
fromCache(event.request).then(
function (response) {
// The response was found in the cache so we responde
// with it and update the entry
// This is where we call the server to get the newest
// version of the file to use the next time we show view
event.waitUntil(
fetch(event.request).then(function (response) {
if (response.ok) {
return updateCache(event.request, response);
}
})
);
return response;
},
async function () {
// The response was not found in the cache so we look
// for it on the server
try {
const response = await fetch(event.request);
// If request was success, add or update it in the cache
if (response.ok) {
event.waitUntil(updateCache(event.request, response.clone()));
}
return response;
} catch (error) {
// eslint-disable-next-line no-console
console.log("[PWA Builder] Network request failed and no cache." + error);
}
}
)
);
});
self.addEventListener("beforeinstallprompt", (event) => {
// eslint-disable-next-line no-console
console.log("done", "beforeinstallprompt", event);
// Stash the event so it can be triggered later.
window.deferredPrompt = event;
// Remove the "hidden" class from the install button container
divInstall.classList.toggle("hidden", false);
});
// This is an event that can be fired from your page to tell the SW to
// update the offline page
self.addEventListener("refreshOffline", function () {
const offlinePageRequest = new Request(offlineFallbackPage);
return fetch(offlineFallbackPage).then(function (response) {
return caches.open(CACHE).then(function (cache) {
// eslint-disable-next-line no-console
console.log("[PWA Builder] Offline page updated from refreshOffline event: " + response.url);
return cache.put(offlinePageRequest, response);
});
});
});