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);
|
|
|
|
});
|
|
|
|
});
|