files/en-us/web/api/notificationevent/index.md
{{APIRef("Web Notifications")}}{{AvailableInWorkers("service")}}
The NotificationEvent interface of the {{domxref("Notifications API", "", "", "nocode")}} represents a notification event dispatched on the {{domxref("ServiceWorkerGlobalScope")}} of a {{domxref("ServiceWorker")}}.
This interface inherits from the {{domxref("ExtendableEvent")}} interface.
[!NOTE] Only persistent notification events, fired at the {{domxref("ServiceWorkerGlobalScope")}} object, implement the
NotificationEventinterface. Non-persistent notification events, fired at the {{domxref("Notification")}} object, implement theEventinterface.
{{InheritanceDiagram}}
NotificationEvent object.Also inherits properties from its parent interface, {{domxref("ExtendableEvent")}}.
Also inherits methods from its parent interface, {{domxref("ExtendableEvent")}}.
self.addEventListener("notificationclick", (event) => {
console.log(`On notification click: ${event.notification.tag}`);
event.notification.close();
// This looks to see if the current is already open and
// focuses if it is
event.waitUntil(
clients
.matchAll({
type: "window",
})
.then((clientList) => {
for (const client of clientList) {
if (client.url === "/" && "focus" in client) return client.focus();
}
if (clients.openWindow) return clients.openWindow("/");
}),
);
});
{{Specifications}}
[!NOTE] This interface is specified in the Notifications API, but accessed through {{domxref("ServiceWorkerGlobalScope")}}.
{{Compat}}