I have a service worker that creates a Websocket to listen for notifications, and it works fine. My problem is that when I am trying to display the notification I can't. here is the code
function displayNotification(title, body, tag, url, actions) {
if (Notification.permission == "granted") {
if (title == undefined || title == null || title == "") title = "My site"
if (body == undefined || body == null) body = ""
if (tag == undefined || tag == "") tag = null
if (url == undefined || url == null || url == "") url = "https://example.com/"
if (actions == undefined || actions == null || actions == "") actions = []
actions.push({ action: "close", title: "Close" })
self.ServiceWorkerRegistration.showNotification(//self.ServiceWorkerRegistration.showNotification is not a function
title,
body,
lang: "en-US",
icon: "https://example.com/images/logo.png",
badge: "https://example.com/images/logo.png",
vibrate: [100, 50, 100],
data: {
dateOfArrival: Date.now(),
url
},
timestamp: Date.now(),
actions,
tag
})
}
}
I have also tried self.showNotification()
and this.showNotification()
both of which are null
I found the answer, it is
self.registration.showNotification()
. Hope this helps anyone else who finds this!