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 (
Allow Notifications
Tack Up Now requires your permission to send notifications in order to
function properly
)
}
function EnableButton({ onSubscribe }: { onSubscribe: () => void }) {
const { subscribeToPush, requestPermission, canSendPush } = usePush()
const [error, setError] = useState()
function subscribe() {
requestPermission()
}
useEffect(() => {
if (!canSendPush) return
subscribeToPush(
urlB64ToUint8Array(pushPublicKey) as any,
(subscription) => {
try {
navigator.serviceWorker.controller?.postMessage({
type: "subscribed",
subscription: subscription.toJSON(),
})
onSubscribe()
} catch (error) {
setError(error as Error)
}
},
(error) => {
setError(error)
}
)
}, [canSendPush])
return (
<>
{error?.toString()}
>
)
}