|
|
|
@ -21,32 +21,28 @@ self.addEventListener('push', function(event) {
@@ -21,32 +21,28 @@ self.addEventListener('push', function(event) {
|
|
|
|
|
|
|
|
|
|
var hasActiveWindows = false |
|
|
|
|
var checksPromise = new Promise(function (resolve, reject) { |
|
|
|
|
if (!obj.badge) { |
|
|
|
|
return reject() |
|
|
|
|
} |
|
|
|
|
var nowTime = +(new Date()) |
|
|
|
|
Promise.all([getMuteUntil(), getLastAliveTime()]).then(function (result) { |
|
|
|
|
var muteUntil = result[0] |
|
|
|
|
var lastAliveTime = result[1] |
|
|
|
|
if (userInvisibleIsSupported() && |
|
|
|
|
muteUntil && |
|
|
|
|
nowTime < muteUntil) { |
|
|
|
|
console.log('Supress notification because mute for ', Math.ceil((muteUntil - nowTime) / 60000), 'min') |
|
|
|
|
return reject() |
|
|
|
|
} |
|
|
|
|
if (lastAliveTime && |
|
|
|
|
nowTime - lastAliveTime < 60000) { |
|
|
|
|
return clients.matchAll({type: 'window'}).then(function(clientList) { |
|
|
|
|
console.log('matched clients', clientList) |
|
|
|
|
hasActiveWindows = clientList.length > 0 |
|
|
|
|
if (hasActiveWindows) { |
|
|
|
|
console.log('Supress notification because some instance is alive') |
|
|
|
|
return reject() |
|
|
|
|
} |
|
|
|
|
return resolve() |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
return resolve() |
|
|
|
|
return clients.matchAll({type: 'window'}).then(function(clientList) { |
|
|
|
|
console.log('matched clients', clientList) |
|
|
|
|
hasActiveWindows = clientList.length > 0 |
|
|
|
|
if (hasActiveWindows) { |
|
|
|
|
console.log('Supress notification because some instance is alive') |
|
|
|
|
return reject() |
|
|
|
|
} |
|
|
|
|
if (userInvisibleIsSupported() && |
|
|
|
|
muteUntil && |
|
|
|
|
nowTime < muteUntil) { |
|
|
|
|
console.log('Supress notification because mute for ', Math.ceil((muteUntil - nowTime) / 60000), 'min') |
|
|
|
|
return reject() |
|
|
|
|
} |
|
|
|
|
if (!obj.badge) { |
|
|
|
|
return reject() |
|
|
|
|
} |
|
|
|
|
return resolve() |
|
|
|
|
}) |
|
|
|
|
}) |
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|