2020-10-12 23:37:21 +01:00
|
|
|
// Handles browser quirks, based on
|
|
|
|
// https://developer.mozilla.org/en-US/docs/Web/API/Notifications_API/Using_the_Notifications_API
|
|
|
|
|
|
|
|
const checkNotificationPromise = () => {
|
|
|
|
try {
|
2020-11-23 16:35:14 +00:00
|
|
|
// eslint-disable-next-line promise/catch-or-return
|
2020-10-12 23:37:21 +01:00
|
|
|
Notification.requestPermission().then();
|
|
|
|
} catch(e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
const handlePermission = (permission, callback) => {
|
|
|
|
// Whatever the user answers, we make sure Chrome stores the information
|
|
|
|
if(!('permission' in Notification)) {
|
|
|
|
Notification.permission = permission;
|
|
|
|
}
|
|
|
|
|
|
|
|
callback(Notification.permission);
|
|
|
|
};
|
|
|
|
|
|
|
|
export const requestNotificationPermission = (callback) => {
|
|
|
|
if (checkNotificationPromise()) {
|
2020-11-23 16:35:14 +00:00
|
|
|
Notification.requestPermission().then((permission) => handlePermission(permission, callback)).catch(console.warn);
|
2020-10-12 23:37:21 +01:00
|
|
|
} else {
|
|
|
|
Notification.requestPermission((permission) => handlePermission(permission, callback));
|
|
|
|
}
|
|
|
|
};
|