summaryrefslogtreecommitdiff
path: root/ui/lib/components/NotificationSettings.svelte
blob: 81c370804c1aa5b06b546e3314ed0421e0e86e65 (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
<script>
  import { onMount } from "svelte";
  import Toggle from '$lib/components/Toggle.svelte';

  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) => {
        const subJson = subscription.toJSON();
        subscriptionJson = {
          endpoint: subJson.endpoint,
          p256dh: subJson.keys.p256dh,
          auth: subJson.keys.auth,
        };
        return fetch("/api/push", {
          method: "post",
          headers: { "Content-type": "application/json" },
          body: JSON.stringify(subscriptionJson),
        });
      });
  }

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

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

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

<h2>Enable notifications</h2>

<p>
  {#if subscriptionJson === null}
    Notifications are currently disabled.
  {:else}
    Notifications are currently enabled.
  {/if}
</p>
<button class="btn" onclick="{toggleSub}">
  {#if subscriptionJson === null}
    Enable notifications
  {:else}
    Disable notifications
  {/if}
</button>

<h2>Notify me when:</h2>

<Toggle
    name="channel_created"
    text="A new channel is created"
    onclick={async () => {}}
/>
<Toggle
    name="message_arrives"
    text="A new message arrives in a channel"
    onclick={async () => {}}
/>
<Toggle
    name="message_arrives_username"
    text="A new message containing your username arrives in a channel"
    onclick={async () => {}}
/>
<Toggle
    name="message_arrives_keyword"
    text="A new message containing a keyword you have configured arrives in a channel"
    onclick={async () => {}}
/>
<Toggle
    name="own_message_stitched"
    text="A message you wrote is stitched"
    onclick={async () => {}}
/>
<Toggle
    name="flagged_message_stitched"
    text="A message you have flagged is stitched"
    onclick={async () => {}}
/>