From c9ce1ba9a28d5cc96a04ed9523c4e4c1f3482da6 Mon Sep 17 00:00:00 2001 From: Patrick Brosset Date: Mon, 4 Nov 2024 15:53:15 +0100 Subject: [PATCH] adding SW to ICN --- incoming-call-notifications/index.html | 2 +- incoming-call-notifications/sw.js | 86 ++++++++++++++++++++++++++ 2 files changed, 87 insertions(+), 1 deletion(-) create mode 100644 incoming-call-notifications/sw.js diff --git a/incoming-call-notifications/index.html b/incoming-call-notifications/index.html index 256ca0f..65fb344 100644 --- a/incoming-call-notifications/index.html +++ b/incoming-call-notifications/index.html @@ -96,7 +96,7 @@ }; } - navigator.serviceWorker.register("service-worker.js", { scope: '/repro_pages/notifications/' }) + navigator.serviceWorker.register("sw.js", { scope: './' }) .then((result) => { registration = result; log("register() succeeded"); diff --git a/incoming-call-notifications/sw.js b/incoming-call-notifications/sw.js new file mode 100644 index 0000000..316ac08 --- /dev/null +++ b/incoming-call-notifications/sw.js @@ -0,0 +1,86 @@ +"use strict"; + +skipWaiting(); + +onactivate = () => { + return clients.claim(); +}; + +onmessage = (messageEvent) => { + registration + .showNotification(`ServiceWorkerGlobalScope Title ${messageEvent.data}`, { + body: `ServiceWorkerGlobalScope Body ${messageEvent.data}`, + icon: "../resources/happy.jpg", + }) + .then(() => { + messageEvent.source.postMessage( + "ServiceWorkerGlobalScope showNotification() succeeded." + ); + }) + .catch((error) => { + messageEvent.source.postMessage( + `ServiceWorkerGlobalScope showNotification() failed: ${error}.` + ); + }); +}; + +onnotificationclick = (event) => { + const notification = event.notification; + + clients.matchAll().then((resultList) => { + resultList.forEach((client) => { + client.postMessage( + `ServiceWorkerGlobalScope 'click' event for: ${ + notification.title + } , timestamp: ${new Date( + notification.timestamp + )}, requireInteraction: ${notification.requireInteraction}, silent: ${ + notification.silent + }` + ); + notification.close(); + }); + }); + + if (event.action === "open_window") { + event.waitUntil( + new Promise((resolve) => { + setTimeout(() => { + clients.openWindow("on-click.html"); + resolve(); + }, 0); + }) + ); + } else { + // Focus existing client. + event.waitUntil( + clients.matchAll().then((resultList) => { + if (resultList.length > 0) { + return resultList[0].focus(); + } + }) + ); + } +}; + +onnotificationclose = (event) => { + clients.matchAll().then((resultList) => { + resultList.forEach((client) => { + const notification = event.notification; + client.postMessage( + `ServiceWorkerGlobalScope 'close' event for: ${ + notification.title + } , timestamp: ${new Date( + notification.timestamp + )}, requireInteraction: ${notification.requireInteraction}, silent: ${ + notification.silent + }` + ); + }); + }); +}; + +onfetch = (fetchEvent) => { + console.log(fetchEvent.request.url); + fetchEvent.respondWith(fetch(fetchEvent.request)); +};