aboutsummaryrefslogtreecommitdiff
path: root/static/sw.js
diff options
context:
space:
mode:
Diffstat (limited to 'static/sw.js')
-rw-r--r--static/sw.js33
1 files changed, 15 insertions, 18 deletions
diff --git a/static/sw.js b/static/sw.js
index 0402a220..d51870d5 100644
--- a/static/sw.js
+++ b/static/sw.js
@@ -1,32 +1,29 @@
/* eslint-env serviceworker */
-self.addEventListener('push', function (event) {
- if (event.data) {
- const data = event.data.json()
- const promiseChain = clients.matchAll({
- includeUncontrolled: true
- }).then(function (clientList) {
- const list = clientList.filter((item) => item.type === 'window')
- if (list.length) return
- return self.registration.showNotification(data.title, data)
- })
+function getWindowClients () {
+ return clients.matchAll({ includeUncontrolled: true })
+ .then((clientList) => clientList.filter(({ type }) => type === 'window'))
+}
+
+self.addEventListener('push', (event) => {
+ if (event.data) {
+ event.waitUntil(getWindowClients().then((list) => {
+ const data = event.data.json()
- event.waitUntil(promiseChain)
+ if (list.length === 0) return self.registration.showNotification(data.title, data)
+ }))
}
})
-self.addEventListener('notificationclick', function (event) {
+self.addEventListener('notificationclick', (event) => {
event.notification.close()
- event.waitUntil(clients.matchAll({
- includeUncontrolled: true
- }).then(function (clientList) {
- const list = clientList.filter((item) => item.type === 'window')
-
+ event.waitUntil(getWindowClients().then((list) => {
for (var i = 0; i < list.length; i++) {
var client = list[i]
if (client.url === '/' && 'focus' in client) { return client.focus() }
}
- if (clients.openWindow) { return clients.openWindow('/') }
+
+ if (clients.openWindow) return clients.openWindow('/')
}))
})