summaryrefslogtreecommitdiff
path: root/ui
diff options
context:
space:
mode:
authorKit La Touche <kit@transneptune.net>2024-11-05 22:22:22 -0500
committerKit La Touche <kit@transneptune.net>2024-11-05 22:22:22 -0500
commitc68ebc39096d93867058f011b4e6313f53128819 (patch)
tree41eb253d6d9d81dcb6c7f244ab4c65a6023b87e4 /ui
parent2f67205b83009c874f4254a4789b1945668b3056 (diff)
Start to make this a PWA
Diffstat (limited to 'ui')
-rw-r--r--ui/app.html1
-rw-r--r--ui/routes/(app)/+layout.svelte2
-rw-r--r--ui/routes/+layout.svelte2
-rw-r--r--ui/service-worker.js35
-rw-r--r--ui/static/manifest.json43
5 files changed, 81 insertions, 2 deletions
diff --git a/ui/app.html b/ui/app.html
index 51a6780..4dc66f4 100644
--- a/ui/app.html
+++ b/ui/app.html
@@ -4,6 +4,7 @@
<meta charset="utf-8" />
<link rel="icon" href="%sveltekit.assets%/favicon.png" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
+ <link rel="manifest" href="%sveltekit.assets%/manifest.json" />
%sveltekit.head%
</head>
<body data-sveltekit-preload-data="hover" data-theme="skeleton">
diff --git a/ui/routes/(app)/+layout.svelte b/ui/routes/(app)/+layout.svelte
index ae3dc6a..2725c65 100644
--- a/ui/routes/(app)/+layout.svelte
+++ b/ui/routes/(app)/+layout.svelte
@@ -55,7 +55,7 @@
</script>
<svelte:head>
- <title>understory</title>
+ <title>pilcrow</title>
</svelte:head>
{#if loading}
diff --git a/ui/routes/+layout.svelte b/ui/routes/+layout.svelte
index d786389..da5bbe0 100644
--- a/ui/routes/+layout.svelte
+++ b/ui/routes/+layout.svelte
@@ -28,7 +28,7 @@
<img class="w-8 h-8" alt="logo" src={logo} />
</button>
</svelte:fragment>
- <a href="/">understory</a>
+ <a href="/">pilcrow</a>
<svelte:fragment slot="trail">
{#if $currentUser}
<CurrentUser />
diff --git a/ui/service-worker.js b/ui/service-worker.js
new file mode 100644
index 0000000..e29fab3
--- /dev/null
+++ b/ui/service-worker.js
@@ -0,0 +1,35 @@
+/// <reference types="@sveltejs/kit" />
+/// <reference no-default-lib="true"/>
+/// <reference lib="esnext" />
+/// <reference lib="webworker" />
+
+import { build, files, version } from '$service-worker';
+
+// Create a unique cache name for this deployment
+const CACHE = `cache-${version}`;
+
+const ASSETS = [
+ ...build, // the app itself
+ ...files // everything in `static`
+];
+
+self.addEventListener('install', (event) => {
+ // Create a new cache and add all files to it
+ async function addFilesToCache() {
+ const cache = await caches.open(CACHE);
+ await cache.addAll(ASSETS);
+ }
+
+ event.waitUntil(addFilesToCache());
+});
+
+self.addEventListener('activate', (event) => {
+ // Remove previous cached data from disk
+ async function deleteOldCaches() {
+ for (const key of await caches.keys()) {
+ if (key !== CACHE) await caches.delete(key);
+ }
+ }
+
+ event.waitUntil(deleteOldCaches());
+});
diff --git a/ui/static/manifest.json b/ui/static/manifest.json
new file mode 100644
index 0000000..2d4cf39
--- /dev/null
+++ b/ui/static/manifest.json
@@ -0,0 +1,43 @@
+{
+ "name": "Pilcrow",
+ "short_name": "Pilcrow",
+ "start_url": "index.html",
+ "display": "standalone",
+ "background_color": "#fdfdfd",
+ "theme_color": "#db4938",
+ "orientation": "portrait-primary",
+ "icons": [
+ {
+ "src": "/favicon.png",
+ "type": "image/png", "sizes": "72x72"
+ },
+ {
+ "src": "/favicon.png",
+ "type": "image/png", "sizes": "96x96"
+ },
+ {
+ "src": "/favicon.png",
+ "type": "image/png","sizes": "128x128"
+ },
+ {
+ "src": "/favicon.png",
+ "type": "image/png", "sizes": "144x144"
+ },
+ {
+ "src": "/favicon.png",
+ "type": "image/png", "sizes": "152x152"
+ },
+ {
+ "src": "/favicon.png",
+ "type": "image/png", "sizes": "192x192"
+ },
+ {
+ "src": "/favicon.png",
+ "type": "image/png", "sizes": "384x384"
+ },
+ {
+ "src": "/favicon.png",
+ "type": "image/png", "sizes": "512x512"
+ }
+ ]
+}