From 800468c5e28c6f0493f66605d83b5f7d629a0b8c Mon Sep 17 00:00:00 2001 From: -k Date: Thu, 28 Mar 2024 11:40:20 -0700 Subject: [PATCH] feat(pwa): revalidate current cache --- static/sw.js | 51 ++++++++++++++------------------------------------- 1 file changed, 14 insertions(+), 37 deletions(-) diff --git a/static/sw.js b/static/sw.js index 18439a6..015e467 100644 --- a/static/sw.js +++ b/static/sw.js @@ -12,45 +12,22 @@ oninstall = (event) => { onfetch = (event) => { console.log("Service worker fetching", event.request.url); - event.respondWith( - caches.open(cacheName).then((cache) => { - return cache - .match(event.request) - .then((response) => { - if (response) { - console.log("Service worker found response in cache:", response); - return response; - } - - console.log( - "No response for %s found in service worker cache. Fetching " + - "from network", - event.request.url, - ); - - return fetch(event.request.clone()).then((response) => { - console.log( - "Service worker got response for %s from network: %O", - event.request.url, - response, - ); + event.respondWith(caches.open(cacheName).then((cache) => { + return cache.match(event.request).then((cachedResponse) => { + const fetchedResponse = fetch(event.request).then((networkResponse) => { + if (networkResponse.status < 400) { + console.log("Caching the response to", event.request.url); + cache.put(event.request, networkResponse.clone()); + } else { + console.log("Service worker not caching the response to", event.request.url); + } - if (response.status < 400) { - console.log("Caching the response to", event.request.url); - cache.put(event.request, response.clone()); - } else { - console.log("Service worker not caching the response to", event.request.url); - } + return networkResponse; + }).catch(() => caches.match("/offline/")); - return response; - }).catch(() => caches.match("/offline/")); - }) - .catch((error) => { - console.error("Error in service worker fetch handler:", error); - throw error; - }); - }), - ); + return cachedResponse || fetchedResponse; + }); + })); }; self.onactivate = (event) => {