tack-up-now/app/install/EnableNotifications.tsx

59 lines
1.3 KiB
TypeScript

import React, { useState } from "react"
import { useEffect } from "react"
import { usePush } from "../usePush"
import { request } from "http"
import urlB64ToUint8Array from "../../b64ToUInt8"
import pushPublicKey from "../../pushPublicKey"
export default function EnableNotifications({
onSubscribe,
}: {
onSubscribe: () => void
}) {
return (
<div>
<h1>Allow Notifications</h1>
<div>
Tack Up Now requires your permission to send notifications in order to
function properly
</div>
<EnableButton onSubscribe={onSubscribe} />
</div>
)
}
function EnableButton({ onSubscribe }: { onSubscribe: () => void }) {
const { subscribeToPush, requestPermission, canSendPush } = usePush()
const [error, setError] = useState<Error>()
function subscribe() {
requestPermission()
}
useEffect(() => {
if (!canSendPush) return
subscribeToPush(
urlB64ToUint8Array(pushPublicKey) as any,
(subscription) => {
navigator.serviceWorker.controller?.postMessage({
type: "subscribed",
subscription,
})
onSubscribe()
},
(error) => {
setError(error)
}
)
}, [canSendPush])
return (
<>
<button onClick={subscribe}>Enable Notifications</button>
<div>{error?.toString()}</div>
</>
)
}