Added exclude list for PWA caching.
This commit is contained in:
parent
d8e45694bd
commit
0f5c2b5c9d
2 changed files with 22 additions and 5 deletions
|
@ -6,7 +6,7 @@
|
||||||
# MIT Licensed
|
# MIT Licensed
|
||||||
---
|
---
|
||||||
|
|
||||||
var cacheList = [
|
const include = [
|
||||||
|
|
||||||
/*--- CSS ---*/
|
/*--- CSS ---*/
|
||||||
|
|
||||||
|
@ -99,7 +99,6 @@ var cacheList = [
|
||||||
/*--- Others ---*/
|
/*--- Others ---*/
|
||||||
|
|
||||||
{% if site.google_analytics.pv.enabled %}
|
{% if site.google_analytics.pv.enabled %}
|
||||||
'{{ "/assets/data/pv-data.json" | relative_url }}',
|
|
||||||
'{{ "/assets/lib/countUp.min.js" | relative_url }}',
|
'{{ "/assets/lib/countUp.min.js" | relative_url }}',
|
||||||
'{{ "/assets/js/dist/pageviews.min.js" | relative_url }}',
|
'{{ "/assets/js/dist/pageviews.min.js" | relative_url }}',
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -110,3 +109,8 @@ var cacheList = [
|
||||||
'{{ "/app.js" | relative_url }}',
|
'{{ "/app.js" | relative_url }}',
|
||||||
'{{ "/sw.js" | relative_url }}'
|
'{{ "/sw.js" | relative_url }}'
|
||||||
];
|
];
|
||||||
|
|
||||||
|
const exclude = [
|
||||||
|
'/assets/data/pv-data.json',
|
||||||
|
'/img.shields.io/'
|
||||||
|
];
|
||||||
|
|
19
sw.js
19
sw.js
|
@ -10,11 +10,22 @@ self.importScripts('{{ "/assets/data/cache-list.js" | relative_url }}');
|
||||||
|
|
||||||
var cacheName = 'chirpy-{{ "now" | date: "%Y%m%d.%H%M" }}';
|
var cacheName = 'chirpy-{{ "now" | date: "%Y%m%d.%H%M" }}';
|
||||||
|
|
||||||
|
|
||||||
|
function isExcluded(url) {
|
||||||
|
for (const rule of exclude) {
|
||||||
|
if (url.indexOf(rule) != -1) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
self.addEventListener('install', (e) => {
|
self.addEventListener('install', (e) => {
|
||||||
self.skipWaiting();
|
self.skipWaiting();
|
||||||
e.waitUntil(
|
e.waitUntil(
|
||||||
caches.open(cacheName).then((cache) => {
|
caches.open(cacheName).then((cache) => {
|
||||||
return cache.addAll(cacheList);
|
return cache.addAll(include);
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
@ -26,8 +37,10 @@ self.addEventListener('fetch', (e) => {
|
||||||
/* console.log('[Service Worker] Fetching resource: ' + e.request.url); */
|
/* console.log('[Service Worker] Fetching resource: ' + e.request.url); */
|
||||||
return r || fetch(e.request).then((response) => {
|
return r || fetch(e.request).then((response) => {
|
||||||
return caches.open(cacheName).then((cache) => {
|
return caches.open(cacheName).then((cache) => {
|
||||||
/* console.log('[Service Worker] Caching new resource: ' + e.request.url); */
|
if (!isExcluded(e.request.url)) {
|
||||||
cache.put(e.request, response.clone());
|
/* console.log('[Service Worker] Caching new resource: ' + e.request.url); */
|
||||||
|
cache.put(e.request, response.clone());
|
||||||
|
}
|
||||||
return response;
|
return response;
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue