const CACHE_NAME = "espj-upst-pwa-v1"; const OFFLINE_URL = "/driver/offline.html"; const PRECACHE_URLS = [ "/upst", "/upst/kosong", "/driver/manifest.json", "/driver/favicon.ico", "/driver/images/pwa_192.png", "/driver/images/pwa_512.png", OFFLINE_URL ]; self.addEventListener("install", (event) => { event.waitUntil( caches.open(CACHE_NAME).then((cache) => cache.addAll(PRECACHE_URLS)) ); self.skipWaiting(); }); self.addEventListener("activate", (event) => { event.waitUntil( caches.keys().then((keys) => Promise.all( keys .filter((key) => key !== CACHE_NAME) .map((key) => caches.delete(key)) ) ) ); self.clients.claim(); }); self.addEventListener("fetch", (event) => { const { request } = event; const url = new URL(request.url); if (request.method !== "GET") { return; } if (request.mode === "navigate") { event.respondWith( fetch(request) .then((response) => { const responseClone = response.clone(); caches.open(CACHE_NAME).then((cache) => cache.put(request, responseClone)); return response; }) .catch(async () => { const cachedPage = await caches.match(request); return cachedPage || caches.match(OFFLINE_URL); }) ); return; } if (url.origin !== self.location.origin) { return; } event.respondWith( caches.match(request).then((cachedResponse) => { const networkFetch = fetch(request) .then((response) => { if (response && response.ok) { const responseClone = response.clone(); caches.open(CACHE_NAME).then((cache) => cache.put(request, responseClone)); } return response; }) .catch(() => cachedResponse); return cachedResponse || networkFetch; }) ); });