Service-worker updates
This commit is contained in:
@@ -27,22 +27,45 @@ self.addEventListener("install", event => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
self.addEventListener("fetch", event => {
|
self.addEventListener("fetch", event => {
|
||||||
event.respondWith(
|
if (event.request.url.includes("/api/")) {
|
||||||
fetch(event.request)
|
event.respondWith(
|
||||||
.then(response => cache(event.request, response))
|
fetch(event.request)
|
||||||
.catch(function() {
|
.then(response => cache(event.request, response))
|
||||||
return caches.match(event.request);
|
.catch(function() {
|
||||||
})
|
return caches.match(event.request);
|
||||||
);
|
})
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
event.respondWith(
|
||||||
|
caches
|
||||||
|
.match(event.request) // check if the request has already been cached
|
||||||
|
.then(cached => cached || fetch(event.request)) // otherwise request network
|
||||||
|
.then(
|
||||||
|
response =>
|
||||||
|
staticCache(event.request, response) // put response in cache
|
||||||
|
.then(() => response) // resolve promise with the network response
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function staticCache(request, response) {
|
||||||
|
if (response.type === "error" || response.type === "opaque") {
|
||||||
|
return Promise.resolve(); // do not put in cache network errors
|
||||||
|
}
|
||||||
|
|
||||||
|
return caches
|
||||||
|
.open(CACHE_NAME)
|
||||||
|
.then(cache => cache.put(request, response.clone()));
|
||||||
|
}
|
||||||
|
|
||||||
function cache(request, response) {
|
function cache(request, response) {
|
||||||
//console.log(response.type === "error" || response.type === "opaque", request);
|
//console.log(response.type === "error" || response.type === "opaque", request);
|
||||||
if (response.type === "error" || response.type === "opaque") {
|
if (response.type === "error" || response.type === "opaque") {
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
return caches.open(CACHE_NAME).then(cache => {
|
return caches.open(CACHE_NAME_API).then(cache => {
|
||||||
cache.put(request, response.clone());
|
cache.put(request, response.clone());
|
||||||
return response;
|
return response;
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user