|
const CACHE_NAME = 'piclets-v4'; |
|
const urlsToCache = [ |
|
'/', |
|
'/manifest.json', |
|
'/assets/logo.PNG' |
|
]; |
|
|
|
|
|
self.addEventListener('install', event => { |
|
event.waitUntil( |
|
caches.open(CACHE_NAME) |
|
.then(cache => { |
|
console.log('Opened cache'); |
|
return cache.addAll(urlsToCache); |
|
}) |
|
); |
|
}); |
|
|
|
|
|
self.addEventListener('activate', event => { |
|
event.waitUntil( |
|
caches.keys().then(cacheNames => { |
|
return Promise.all( |
|
cacheNames.map(cacheName => { |
|
if (cacheName !== CACHE_NAME) { |
|
console.log('Deleting old cache:', cacheName); |
|
return caches.delete(cacheName); |
|
} |
|
}) |
|
); |
|
}) |
|
); |
|
}); |
|
|
|
|
|
self.addEventListener('fetch', event => { |
|
event.respondWith( |
|
caches.match(event.request) |
|
.then(response => { |
|
|
|
if (response) { |
|
return response; |
|
} |
|
|
|
|
|
const fetchRequest = event.request.clone(); |
|
|
|
return fetch(fetchRequest).then(response => { |
|
|
|
if (!response || response.status !== 200 || response.type !== 'basic') { |
|
return response; |
|
} |
|
|
|
|
|
const responseToCache = response.clone(); |
|
|
|
|
|
caches.open(CACHE_NAME) |
|
.then(cache => { |
|
|
|
if (event.request.url.startsWith(self.location.origin)) { |
|
cache.put(event.request, responseToCache); |
|
} |
|
}); |
|
|
|
return response; |
|
}); |
|
}) |
|
.catch(() => { |
|
|
|
if (event.request.mode === 'navigate') { |
|
return caches.match('/'); |
|
} |
|
}) |
|
); |
|
}); |