Mikey Oz
3 years ago
5 changed files with 77 additions and 15 deletions
@ -1,12 +1,18 @@ |
|||
<html lang="en"> |
|||
<head> |
|||
<title>fuzzyhome</title> |
|||
<meta charset="UTF-8"> |
|||
<meta name="viewport" content="width=device-width, initial-scale=1"> |
|||
<link href="https://fonts.googleapis.com/css2?family=Open+Sans:wght@300&display=swap" rel="stylesheet"> |
|||
<style src='*'></style> |
|||
</head> |
|||
<body> |
|||
<script type="module" src="./client.imba"></script> |
|||
</body> |
|||
<head> |
|||
<title>fuzzyhome</title> |
|||
<meta charset="UTF-8"> |
|||
<meta name="viewport" content="width=device-width, initial-scale=1"> |
|||
<style src='*'></style> |
|||
</head> |
|||
<body> |
|||
<script type="module"> |
|||
if ('serviceWorker' in navigator) { |
|||
navigator.serviceWorker.register('./sw.js').then(function(reg){ |
|||
reg.update() |
|||
}) |
|||
} |
|||
</script> |
|||
<script type="module" src="./client.imba"></script> |
|||
</body> |
|||
</html> |
|||
|
@ -0,0 +1,50 @@ |
|||
let p = console.log |
|||
|
|||
const app_prefix = "fuzzyhome_cache" |
|||
const version = "0.0.5" |
|||
|
|||
const cache_name = "{app_prefix}-{version}" |
|||
|
|||
let urls = [ |
|||
'./', |
|||
'./__assets__/all.css' |
|||
'./__assets__/app/client.js' |
|||
'./__assets__/app/client.css' |
|||
] |
|||
|
|||
self.addEventListener('fetch', &) do |e| |
|||
|
|||
def intercept request |
|||
if request |
|||
p `{cache_name} responding with cache : {e.request.url}` |
|||
request |
|||
else |
|||
p `{cache_name} not cached, fetching : {e.request.url}` |
|||
fetch e.request |
|||
|
|||
e.respondWith(caches.match(e.request.url).then(intercept)) |
|||
|
|||
self.addEventListener('install', &) do |e| |
|||
p `{cache_name} install` |
|||
|
|||
def add_urls_to_cache cache |
|||
p `{cache_name} installing cache : {cache_name}` |
|||
cache.addAll urls |
|||
skipWaiting! # [TODO]: Export this and import to settings component and have manual update button |
|||
|
|||
e.waitUntil(caches.open(cache_name).then(add_urls_to_cache)) |
|||
|
|||
|
|||
self.addEventListener('activate', &) do |e| |
|||
p `{cache_name} activate` |
|||
|
|||
def delete_cached keys |
|||
|
|||
let temp = keys.map(&) do |key, i| |
|||
if key !== cache_name |
|||
p `{cache_name} deleting cache : {keys[i]}` |
|||
caches.delete keys[i] |
|||
|
|||
Promise.all(temp) |
|||
|
|||
e.waitUntil(caches.keys().then(delete_cached)) |
Loading…
Reference in new issue