aboutsummaryrefslogtreecommitdiffstats
path: root/clients/www/src/lib/offlineToast.ts
diff options
context:
space:
mode:
Diffstat (limited to 'clients/www/src/lib/offlineToast.ts')
-rw-r--r--clients/www/src/lib/offlineToast.ts33
1 files changed, 33 insertions, 0 deletions
diff --git a/clients/www/src/lib/offlineToast.ts b/clients/www/src/lib/offlineToast.ts
new file mode 100644
index 0000000..3ae943e
--- /dev/null
+++ b/clients/www/src/lib/offlineToast.ts
@@ -0,0 +1,33 @@
+import { getToastStore, type ToastSettings } from '@skeletonlabs/skeleton';
+
+const toastStore = getToastStore();
+
+const offline: ToastSettings = {
+ message: 'You are currently offline.',
+ background: 'variant-filled-error',
+ autohide: false
+};
+
+const online: ToastSettings = {
+ message: 'You are back online.',
+ background: 'variant-filled-success',
+ autohide: true,
+ timeout: 3000
+};
+
+/**
+ * Make a toast for if the PWA is ever brought offline for whatever reason.
+ */
+export default function offlineToast() {
+ window.addEventListener('offline', () => {
+ toastStore.clear();
+ toastStore.trigger(offline);
+ });
+
+ window.addEventListener('online', () => {
+ toastStore.clear();
+ setTimeout(() => {
+ toastStore.trigger(online);
+ }, 300);
+ });
+}