|
|
|
|
async function initCache() {
|
|
|
|
|
const cache = await caches.open('v1')
|
|
|
|
|
await cache.addAll([
|
|
|
|
|
'/',
|
|
|
|
|
'/index.html',
|
|
|
|
|
'/app.js',
|
|
|
|
|
'/components/page.js',
|
|
|
|
|
'/components/layout.js',
|
|
|
|
|
'/components/header.js',
|
|
|
|
|
'/components/nav-menu.js'
|
|
|
|
|
])
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
self.addEventListener("install", event => {
|
|
|
|
|
event.waitUntil(initCache())
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
async function cacheFirst(request) {
|
|
|
|
|
if (request.url.includes('/-/frame')) {
|
|
|
|
|
const url = new URL(request.url)
|
|
|
|
|
if (url.pathname === '/-/frame') {
|
|
|
|
|
const html = url.searchParams.get('html')
|
|
|
|
|
const csp = url.searchParams.get('csp')
|
|
|
|
|
return new Response(html, {
|
|
|
|
|
headers: {
|
|
|
|
|
'Content-Type': 'text/html',
|
|
|
|
|
'Content-Security-Policy': csp,
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
const resp = await caches.match(request)
|
|
|
|
|
if (resp) {
|
|
|
|
|
return resp
|
|
|
|
|
} else {
|
|
|
|
|
return fetch(request)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
self.addEventListener('fetch', event => {
|
|
|
|
|
event.respondWith(cacheFirst(event.request))
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
self.addEventListener('activate', event => {
|
|
|
|
|
event.waitUntil(clients.claim())
|
|
|
|
|
})
|