forked from MapComplete/MapComplete
Refactoring: move all code files into a src directory
This commit is contained in:
parent
de99f56ca8
commit
e75d2789d2
389 changed files with 0 additions and 12 deletions
72
src/service-worker.ts
Normal file
72
src/service-worker.ts
Normal file
|
@ -0,0 +1,72 @@
|
|||
const version = "0.0.8-GITHUB-COMMIT"
|
||||
|
||||
interface ServiceWorkerFetchEvent extends Event {
|
||||
request: RequestInfo & { url: string }
|
||||
respondWith: (response: any | PromiseLike<Response>) => Promise<void>
|
||||
}
|
||||
|
||||
async function install() {
|
||||
console.log("Installing service worker!")
|
||||
}
|
||||
|
||||
addEventListener("install", (e) => (<any>e).waitUntil(install()))
|
||||
addEventListener("activate", (e) => (<any>e).waitUntil(activate()))
|
||||
|
||||
async function activate() {
|
||||
console.log("Activating service worker")
|
||||
caches
|
||||
.keys()
|
||||
.then((keys) => {
|
||||
// Remove all old caches
|
||||
Promise.all(keys.map((key) => key !== version && caches.delete(key)))
|
||||
})
|
||||
.catch(console.error)
|
||||
}
|
||||
|
||||
const cacheFirst = async (event) => {
|
||||
await event.respondWith(
|
||||
caches.match(event.request, { ignoreSearch: true }).then((cacheResponse) => {
|
||||
if (cacheResponse !== undefined) {
|
||||
console.log("Loaded from cache: ", event.request)
|
||||
return cacheResponse
|
||||
}
|
||||
return fetch(event.request).then((networkResponse) => {
|
||||
return caches.open(version).then((cache) => {
|
||||
cache.put(event.request, networkResponse.clone())
|
||||
console.log("Cached", event.request)
|
||||
return networkResponse
|
||||
})
|
||||
})
|
||||
})
|
||||
)
|
||||
}
|
||||
|
||||
self.addEventListener("fetch", async (e) => {
|
||||
// Important: this lambda must run synchronously, as the browser will otherwise handle the request
|
||||
const event = <ServiceWorkerFetchEvent>e
|
||||
try {
|
||||
const origin = new URL(self.origin)
|
||||
const requestUrl = new URL(event.request.url)
|
||||
if (requestUrl.pathname.endsWith("service-worker-version")) {
|
||||
console.log("Sending version number...")
|
||||
await event.respondWith(
|
||||
new Response(JSON.stringify({ "service-worker-version": version }))
|
||||
)
|
||||
return
|
||||
}
|
||||
const shouldBeCached =
|
||||
origin.host === requestUrl.host &&
|
||||
origin.hostname !== "127.0.0.1" &&
|
||||
origin.hostname !== "localhost" &&
|
||||
!origin.host.endsWith(".gitpod.io")
|
||||
if (!shouldBeCached) {
|
||||
console.log("Not intercepting ", requestUrl.toString(), origin.host, requestUrl.host)
|
||||
// We return _without_ calling event.respondWith, which signals the browser that it'll have to handle it himself
|
||||
return
|
||||
}
|
||||
await cacheFirst(event)
|
||||
} catch (e) {
|
||||
console.error("CRASH IN SW:", e)
|
||||
await event.respondWith(fetch(event.request.url))
|
||||
}
|
||||
})
|
Loading…
Add table
Add a link
Reference in a new issue