I am trying to make my PWA respond with offline.html page when device is offline, and I'm considering failure in fetching homepage as offline but as my service worker caches text/html requests my PWA uses cache to fetch homepage every time.
I am using workbox to generate my PWA, and I have tried removing document from workbox-config.js file.
Code
workbox-config.js
module.exports = {
globDirectory: 'build/',
globPatterns: [
'**/*.{png,ico,css,js}',
],
swDest: 'build\\sw.js',
swSrc: 'src/sw.js',
injectionPointRegexp: /(const precacheManifest = )\[\](;)/,
};
Fetch handler in service worker
self.addEventListener('fetch', (event) => {
console.log('fetch event', event.request.url);
// request.mode = navigate isn't supported in all browsers
// so include a check for Accept: text/html header.
// if (event.request.method === 'GET') {
// console.log(event.request.url, event.request.headers.get('accept'));
// }
if (event.request.mode === 'navigate' || (event.request.method === 'GET' && event.request.headers.get('accept').includes('text/html'))) {
event.respondWith(
fetch(event.request.url).catch((error) => {
console.log(123, error);
// Return the offline page
return caches.match('/offline.html');
}),
);
}
else {
event.respondWith(
caches.match(event.request)
.then((response) => {
if (response) {
console.log('Found ', event.request.url, ' in cache');
return response;
}
return fetch(event.request);
}),
);
}
});
I expect that my PWA fetches homepage from my server everytime but instead this is what I'm getting.

here's the url: https://smartcopy-195fd.firebaseapp.com