2
0
mirror of https://github.com/jfmcbrayer/brutaldon synced 2025-01-24 12:51:09 +01:00
brutaldon-interfaccia-web-m.../brutaldon/templates/pwabuilder-sw.js

36 lines
1.4 KiB
JavaScript
Raw Normal View History

2018-09-19 15:55:48 +02:00
//This is the "Offline page" service worker
2018-09-19 16:19:34 +02:00
{% load static %}
2018-09-19 15:55:48 +02:00
//Install stage sets up the offline page in the cache and opens a new cache
self.addEventListener('install', function(event) {
2018-09-19 16:19:34 +02:00
var offlinePage = new Request('{% static "offline.html" %}');
2018-09-19 15:55:48 +02:00
event.waitUntil(
fetch(offlinePage).then(function(response) {
return caches.open('pwabuilder-offline').then(function(cache) {
console.log('[PWA Builder] Cached offline page during Install'+ response.url);
return cache.put(offlinePage, response);
});
}));
});
//If any fetch fails, it will show the offline page.
//Maybe this should be limited to HTML documents?
self.addEventListener('fetch', function(event) {
event.respondWith(
fetch(event.request).catch(function(error) {
console.error( '[PWA Builder] Network request Failed. Serving offline page ' + error );
return caches.open('pwabuilder-offline').then(function(cache) {
2018-09-19 16:19:34 +02:00
return cache.match('{% static "offline.html" %}');
2018-09-19 15:55:48 +02:00
});
}
));
});
//This is a event that can be fired from your page to tell the SW to update the offline page
self.addEventListener('refreshOffline', function(response) {
return caches.open('pwabuilder-offline').then(function(cache) {
console.log('[PWA Builder] Offline page updated from refreshOffline event: '+ response.url);
return cache.put(offlinePage, response);
});
});