-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathservice-worker-manual-version.js
82 lines (74 loc) · 2.1 KB
/
service-worker-manual-version.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
const CACHE_NAME = 'weatherPWA-v22';
const CACHE_DATA_NAME = 'weatherPWA-data-v22';
const FILES_TO_CACHE = [
'index.html',
'js/app.js',
'css/style.css',
'images/clear.png',
'images/cloudy-scattered-showers.png',
'images/cloudy.png',
'images/fog.png',
'images/ic_add_white_24px.svg',
'images/ic_refresh_white_24px.svg',
'images/partly-cloudy.png',
'images/rain.png',
'images/scattered-showers.png',
'images/sleet.png',
'images/snow.png',
'images/thunderstorm.png',
'images/wind.png'
];
const WEATHER_API_URL = 'https://publicdata-weather.firebaseio.com/';
// Install Service Worker
// Cashes the resources required for the app shell
self.addEventListener('install', function (e) {
console.log('[ServiceWorker] Install');
e.waitUntil(
caches.open(CACHE_NAME).then(function (cache) {
console.log('[ServiceWorker] Caching app shell');
return cache.addAll(FILES_TO_CACHE);
})
);
});
// Activate event
// Removed old resources form the cache
self.addEventListener('activate', function (e) {
console.log('[ServiceWorker] Activate');
e.waitUntil(
caches.keys().then(function (keyList) {
return Promise.all(keyList.map(function (key) {
if (key !== CACHE_NAME && key !== CACHE_DATA_NAME) {
console.log('[ServiceWorker] Removing old cache', key);
return caches.delete(key);
}
}));
})
);
});
// Fetch event
// Attempt return files form cache,
// fallbacks to the network if it`s not available
self.addEventListener('fetch', function (e) {
let request = e.request;
console.log('[ServiceWorker] Fetch', request.url);
console.log(request.url);
console.log(request.url.startsWith(WEATHER_API_URL));
if (request.url.startsWith(WEATHER_API_URL)) {
e.respondWith(
fetch(request)
.then(function (response) {
return caches.open(CACHE_DATA_NAME).then(function (cache) {
cache.put(request.url, response.clone());
console.log('[ServiceWorker] Fetch&Cached Data');
return response;
})
})
)
} else {
e.respondWith(
caches.match(request).then(function (response) {
return response || fetch(request);
})
);
}
});