summaryrefslogtreecommitdiff
path: root/ui/routes/+layout.svelte
blob: 9089c7e2d93f9f63588ef6af20aaf051ec3ee2f0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
<script>
  import { setContext, onMount } from "svelte";
  import { onNavigate } from '$app/navigation';
  import { page } from '$app/state';
  import '../app.css';
  import logo from '$lib/assets/logo.png';

  /* ==================== Start subscription library-esque ==================== */
  let subscriptionJson = $state(null);

  function doSubscribe() {
    navigator.serviceWorker.ready
      .then(async(registration) => {
        const response = await fetch("/api/vapid");
        // and if we fail to get it?
        const vapidPublicKey = await response.text();
        const convertedVapidKey = vapidPublicKey;
        return registration.pushManager.subscribe({
          userVisibleOnly: true,
          applicationServerKey: convertedVapidKey
        });
      }).then((subscription) => {
        subscriptionJson = JSON.parse(JSON.stringify(subscription));
        return fetch("/api/register", {
          method: "post",
          headers: { "Content-type": "application/json" },
          body: JSON.stringify(subscriptionJson),
        });
      });
  }

  async function doUnsubscribe() {
    navigator.serviceWorker.ready
      .then((registration) => {
        return registration.pushManager.getSubscription();
      }).then((subscription) => {
        return subscription.unsubscribe()
          .then(function() {
            subscriptionJson = null;
            return fetch("/api/unregister", {
              method: "post",
              headers: { "Content-type": "application/json" },
              body: JSON.stringify({ subscription })
            });
          });
      });
  }

  function toggleSub() {
    if (subscriptionJson !== null) {
      doUnsubscribe();
    } else {
      doSubscribe();
    }
  }

  function notifyMe() {
    fetch("/api/echo", {
      method: "post",
      headers: { "Content-type": "application/json" },
      body: JSON.stringify({
        ...subscriptionJson,
        msg: "oople doople",
      })
    });
  }

  onMount(() => {
    navigator.serviceWorker.ready.then((registration) => {
      return registration.pushManager.getSubscription();
    }).then((subscription) => {
      if (subscription) {
        subscriptionJson = JSON.parse(JSON.stringify(subscription));
      }
    });
  });
  /* ==================== END ==================== */

  const session = $derived(page.data.session);
  let pageContext = $state({
    showMenu: false,
  });
  setContext('page', pageContext);

  function toggleMenu(event) {
    event.preventDefault();
    pageContext.showMenu = !pageContext.showMenu;
  }

  onNavigate(() => {
    pageContext.showMenu = false;
  });

  let { children } = $props();
</script>

<div class="app-bar">
  <div class="lead">
    <button onclick={toggleMenu}>
      <img alt="logo" src={logo} />
    </button>
  </div>
  <a href="/">pilcrow</a>
  <button onclick="{notifyMe}">
    notify
  </button>
  <button onclick="{toggleSub}">
    toggle sub
  </button>
  <div>
    hasSub: {subscriptionJson !== null}
  </div>
  <div class="trail">
    {#if session}
      <div>
        <a href="/me">@{session.currentUser.name}</a>
      </div>
    {/if}
  </div>
</div>

{@render children?.()}