-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy path_cache_service_worker.js
95 lines (82 loc) · 3.29 KB
/
_cache_service_worker.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*
Cache Service Worker template by mrc 2019
mostly based in:
https://github.com/GoogleChrome/samples/blob/gh-pages/service-worker/basic/service-worker.js
https://github.com/chriscoyier/Simple-Offline-Site/blob/master/js/service-worker.js
https://gist.github.com/kosamari/7c5d1e8449b2fbc97d372675f16b566e
Note for GitHub Pages:
there can be an unexpected behaviour (cache not updating) when site is accessed from
https://user.github.io/repo/ (without index.html) in some browsers (Firefox)
use absolute paths if hosted in GitHub Pages in order to avoid it
also invoke sw with an absolute path:
navigator.serviceWorker.register('/repo/_cache_service_worker.js', {scope: '/repo/'})
*/
/* MOD: fix old caches for mrc */
caches.keys().then(function(cacheNames){
for(var i=0; i<cacheNames.length; i++){
if(
cacheNames[i]==='runtime' ||
/^precache-\w+$/.test(cacheNames[i]) ||
/^v?\d+\w?$/.test(cacheNames[i])
){
console.log('deleting old cache: '+cacheNames[i]);
caches.delete(cacheNames[i]);
}
}
});
var PRECACHE_ID='retroarch-playlist-editor';
var PRECACHE_VERSION='2RC1';
var PRECACHE_URLS=[
'/retroarch-playlist-editor/','/retroarch-playlist-editor/index.html',
'/retroarch-playlist-editor/app/retroarch-playlist-editor.js',
'/retroarch-playlist-editor/app/MarcDataTable.min.js',
'/retroarch-playlist-editor/app/systems.js',
'/retroarch-playlist-editor/app/style.css',
'/retroarch-playlist-editor/app/assets/favicon16.png',
'/retroarch-playlist-editor/app/assets/favicon128.png',
'/retroarch-playlist-editor/app/assets/icon_github.svg',
'/retroarch-playlist-editor/app/assets/icon_heart.svg',
'/retroarch-playlist-editor/app/assets/icon_download.svg',
'/retroarch-playlist-editor/app/assets/icon_plus.svg',
'/retroarch-playlist-editor/app/assets/icon_select_none.svg',
'/retroarch-playlist-editor/app/assets/icon_select_mixed.svg',
'/retroarch-playlist-editor/app/assets/icon_select_all.svg',
'/retroarch-playlist-editor/app/assets/icon_alert.svg',
'/retroarch-playlist-editor/app/assets/icon_pencil.svg',
'/retroarch-playlist-editor/app/assets/icon_trash.svg'
];
// install event (fired when sw is first installed): opens a new cache
self.addEventListener('install', evt => {
evt.waitUntil(
caches.open('precache-'+PRECACHE_ID+'-'+PRECACHE_VERSION)
.then(cache => cache.addAll(PRECACHE_URLS))
.then(self.skipWaiting())
);
});
// activate event (fired when sw is has been successfully installed): cleans up old outdated caches
self.addEventListener('activate', evt => {
evt.waitUntil(
caches.keys().then(cacheNames => {
return cacheNames.filter(cacheName => (cacheName.startsWith('precache-'+PRECACHE_ID+'-') && !cacheName.endsWith('-'+PRECACHE_VERSION)));
}).then(cachesToDelete => {
return Promise.all(cachesToDelete.map(cacheToDelete => {
console.log('delete '+cacheToDelete);
return caches.delete(cacheToDelete);
}));
}).then(() => self.clients.claim())
);
});
// fetch event (fired when requesting a resource): returns cached resource when possible
self.addEventListener('fetch', evt => {
if(evt.request.url.startsWith(self.location.origin)){ //skip cross-origin requests
evt.respondWith(
caches.match(evt.request).then(cachedResource => {
if (cachedResource) {
return cachedResource;
}else{
return fetch(evt.request);
}
})
);
}
});