owlboard-svelte/src/service-worker.js

49 lines
1.2 KiB
JavaScript
Raw Normal View History

2023-06-21 14:56:12 +01:00
/// <reference types="@sveltejs/kit" />
2024-04-30 11:17:06 +01:00
import { build, files, version } from "$service-worker";
2023-06-21 14:56:12 +01:00
const cacheName = `ob-${version}`;
2024-04-30 11:17:06 +01:00
const assets = [...build, ...files, "/service-worker.js"];
2023-06-21 14:56:12 +01:00
2024-04-30 11:17:06 +01:00
self.addEventListener("install", (event) => {
async function addToCache() {
const cache = await caches.open(cacheName);
await cache.addAll(assets);
}
2023-06-21 14:56:12 +01:00
2024-04-30 11:17:06 +01:00
event.waitUntil(addToCache());
2023-07-07 11:27:28 +01:00
});
2023-06-21 14:56:12 +01:00
2024-04-30 11:17:06 +01:00
self.addEventListener("activate", (event) => {
async function deleteOldCache() {
for (const key of await caches.keys()) {
if (key !== cacheName) {
await caches.delete(key);
}
}
2023-06-21 14:56:12 +01:00
}
2024-04-30 11:17:06 +01:00
event.waitUntil(deleteOldCache());
2023-07-07 11:27:28 +01:00
});
2023-06-21 14:56:12 +01:00
2024-04-30 11:17:06 +01:00
self.addEventListener("fetch", (event) => {
if (event.request.method !== "GET") {
return;
2023-07-07 11:27:28 +01:00
}
2024-04-30 11:17:06 +01:00
async function respond() {
const cacheRes = await caches.match(event.request, { ignoreSearch: true });
if (cacheRes) {
return cacheRes;
}
try {
return await fetch(event.request);
} catch (err) {
return { error: "OFFLINE", errorMsg: "You are offline" };
}
2023-06-21 14:56:12 +01:00
}
2024-04-30 11:17:06 +01:00
event.respondWith(respond());
2023-07-07 11:27:28 +01:00
});