summaryrefslogtreecommitdiff
path: root/demo/sw.ts
blob: 0cdbcde298c31586990f63867b72881b46956d42 (plain)
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
/// <reference lib="webworker" />

const sw = self as unknown as ServiceWorkerGlobalScope & {
  __precacheManifest: ({ url: string, revision: string })[];
};

const precacheVersion = sw.__precacheManifest
  .map(p => p.revision)
  .join('');
const precacheFiles = sw.__precacheManifest.map(p => p.url).filter(
  u => /\.(ico)$/.test(u)
);

const ch = () => caches.open(precacheVersion);
 
sw.addEventListener('install', ev => {
  // Do not finish installing until every file in the app has been cached
  ev.waitUntil(
    ch().then(
      cache => cache.addAll(precacheFiles)
    )
  );
});
 
sw.addEventListener('activate', ev => {
  ev.waitUntil(
    caches.keys().then(keys => Promise.all(
      keys.filter(k => k !== precacheVersion).map(
        k => caches.delete(k)
      )
    )).then(() => sw.clients.claim())
  );
});

sw.addEventListener('fetch', ev => {
  ev.respondWith(
    caches.match(ev.request).then(resp => resp || ch().then(c =>
      fetch(ev.request).then(res => c.put(ev.request, res.clone()).then(
        () => res
      ))
    ))
  )
});