aboutsummaryrefslogtreecommitdiff
path: root/appcache.js
blob: bdcdbc0238024e4f61197e4ba7f848ef1fd50462 (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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
 * Beamer Viewer, a web-based PDF presentation viewer
 * Copyright 2018-2024 Euxane TRAN-GIRARD
 * SPDX-License-Identifier: EUPL-1.2
 */

"use strict";

// script put at the root of the app so it can intercept all requests made from the current directory.
class AppCache {
  constructor() {
    this.cacheName = "cache";
    this.filesToCache = [
      ".",
      "appcache.js",
      "favicon.ico",
      "sample/demo.pdf",

      "beamer/pdfjs/pdf.js",
      "beamer/pdfjs/pdf.worker.js",

      "beamer/viewer/viewer.css",
      "beamer/viewer/init.js",
      "beamer/viewer/viewer.js",
      "beamer/viewer/presentation.js",
      "beamer/viewer/stage/stage.js",
      "beamer/viewer/stage/actions.js",
      "beamer/viewer/screen/screen.js",
      "beamer/viewer/screen/timer.js"
    ];

    self.addEventListener("install", event => event.waitUntil(this.onInstall()));
    self.addEventListener("fetch", event => event.respondWith(this.onFetch(event.request)));
  }

  onInstall() {
    return caches.open(this.cacheName)
                 .then(cache => cache.addAll(this.filesToCache));
  }

  onFetch(request) {
    return caches.open(this.cacheName)
                 .then(cache => this._serve(cache, request));
  }

  _serve(cache, request) {
    return cache.match(request).then(cachedResponse => {
      const update = this._fetchUpdate(cache, request);
      return cachedResponse || update;
    });
  }

  _fetchUpdate(cache, request) {
    return fetch(request).then(networkResponse => {
      cache.put(request, networkResponse.clone());
      return networkResponse;
    });
  }
}

const appCache = new AppCache();