2016-08-17 06:01:20 +08:00
|
|
|
import ko from 'ko';
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2020-08-14 04:58:41 +08:00
|
|
|
import { DesktopNotification } from 'Common/Enums';
|
2016-08-17 06:01:20 +08:00
|
|
|
import Audio from 'Common/Audio';
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
import * as Settings from 'Storage/Settings';
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
class NotificationUserStore {
|
2016-08-17 06:01:20 +08:00
|
|
|
constructor() {
|
|
|
|
this.enableSoundNotification = ko.observable(false);
|
|
|
|
this.soundNotificationIsSupported = ko.observable(false);
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.allowDesktopNotification = ko.observable(false);
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
this.desktopNotificationPermissions = ko
|
|
|
|
.computed(() => {
|
|
|
|
this.allowDesktopNotification();
|
|
|
|
|
|
|
|
let result = DesktopNotification.NotSupported;
|
|
|
|
|
|
|
|
const NotificationClass = this.notificationClass();
|
|
|
|
if (NotificationClass && NotificationClass.permission) {
|
|
|
|
switch (NotificationClass.permission.toLowerCase()) {
|
|
|
|
case 'granted':
|
|
|
|
result = DesktopNotification.Allowed;
|
|
|
|
break;
|
|
|
|
case 'denied':
|
|
|
|
result = DesktopNotification.Denied;
|
|
|
|
break;
|
|
|
|
case 'default':
|
|
|
|
result = DesktopNotification.NotAllowed;
|
|
|
|
break;
|
|
|
|
// no default
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2019-07-05 03:19:24 +08:00
|
|
|
} else if (window.webkitNotifications && window.webkitNotifications.checkPermission) {
|
|
|
|
result = window.webkitNotifications.checkPermission();
|
|
|
|
}
|
2016-08-17 06:01:20 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
return result;
|
|
|
|
})
|
|
|
|
.extend({ notify: 'always' });
|
|
|
|
|
|
|
|
this.enableDesktopNotification = ko
|
|
|
|
.computed({
|
|
|
|
read: () =>
|
|
|
|
this.allowDesktopNotification() && DesktopNotification.Allowed === this.desktopNotificationPermissions(),
|
|
|
|
write: (value) => {
|
|
|
|
if (value) {
|
|
|
|
const NotificationClass = this.notificationClass(),
|
|
|
|
permission = this.desktopNotificationPermissions();
|
|
|
|
|
|
|
|
if (NotificationClass && DesktopNotification.Allowed === permission) {
|
|
|
|
this.allowDesktopNotification(true);
|
|
|
|
} else if (NotificationClass && DesktopNotification.NotAllowed === permission) {
|
|
|
|
NotificationClass.requestPermission(() => {
|
|
|
|
this.allowDesktopNotification.valueHasMutated();
|
|
|
|
|
|
|
|
if (DesktopNotification.Allowed === this.desktopNotificationPermissions()) {
|
|
|
|
if (this.allowDesktopNotification()) {
|
|
|
|
this.allowDesktopNotification.valueHasMutated();
|
|
|
|
} else {
|
|
|
|
this.allowDesktopNotification(true);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (this.allowDesktopNotification()) {
|
|
|
|
this.allowDesktopNotification(false);
|
|
|
|
} else {
|
|
|
|
this.allowDesktopNotification.valueHasMutated();
|
|
|
|
}
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2019-07-05 03:19:24 +08:00
|
|
|
});
|
|
|
|
} else {
|
|
|
|
this.allowDesktopNotification(false);
|
|
|
|
}
|
|
|
|
} else {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.allowDesktopNotification(false);
|
|
|
|
}
|
2015-01-26 07:09:22 +08:00
|
|
|
}
|
2019-07-05 03:19:24 +08:00
|
|
|
})
|
|
|
|
.extend({ notify: 'always' });
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2019-07-05 03:19:24 +08:00
|
|
|
if (!this.enableDesktopNotification.valueHasMutated) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.enableDesktopNotification.valueHasMutated = () => {
|
|
|
|
this.allowDesktopNotification.valueHasMutated();
|
|
|
|
};
|
|
|
|
}
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.computers();
|
2015-01-26 07:09:22 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.initNotificationPlayer();
|
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
computers() {
|
|
|
|
this.isDesktopNotificationSupported = ko.computed(
|
|
|
|
() => DesktopNotification.NotSupported !== this.desktopNotificationPermissions()
|
|
|
|
);
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
this.isDesktopNotificationDenied = ko.computed(
|
2019-07-05 03:19:24 +08:00
|
|
|
() =>
|
|
|
|
DesktopNotification.NotSupported === this.desktopNotificationPermissions() ||
|
2016-08-17 06:01:20 +08:00
|
|
|
DesktopNotification.Denied === this.desktopNotificationPermissions()
|
|
|
|
);
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2016-08-17 06:01:20 +08:00
|
|
|
|
|
|
|
initNotificationPlayer() {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (Audio && Audio.supportedNotification) {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.soundNotificationIsSupported(true);
|
2019-07-05 03:19:24 +08:00
|
|
|
} else {
|
2016-08-17 06:01:20 +08:00
|
|
|
this.enableSoundNotification(false);
|
|
|
|
this.soundNotificationIsSupported(false);
|
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2015-01-27 05:06:00 +08:00
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
playSoundNotification(skipSetting) {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (Audio && Audio.supportedNotification && (skipSetting ? true : this.enableSoundNotification())) {
|
2016-08-17 06:01:20 +08:00
|
|
|
Audio.playNotification();
|
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
2015-01-27 05:06:00 +08:00
|
|
|
|
2020-08-15 02:35:39 +08:00
|
|
|
displayDesktopNotification(imageSrc, title, text, messageData) {
|
2019-07-05 03:19:24 +08:00
|
|
|
if (this.enableDesktopNotification()) {
|
|
|
|
const NotificationClass = this.notificationClass(),
|
|
|
|
notification = NotificationClass
|
|
|
|
? new NotificationClass(title, {
|
|
|
|
body: text,
|
|
|
|
icon: imageSrc
|
|
|
|
})
|
|
|
|
: null;
|
|
|
|
|
|
|
|
if (notification) {
|
|
|
|
if (notification.show) {
|
2016-08-17 06:01:20 +08:00
|
|
|
notification.show();
|
|
|
|
}
|
2015-07-07 02:46:44 +08:00
|
|
|
|
2020-08-15 02:35:39 +08:00
|
|
|
if (messageData) {
|
2016-08-17 06:01:20 +08:00
|
|
|
notification.onclick = () => {
|
2020-08-12 06:25:36 +08:00
|
|
|
focus();
|
2015-07-07 02:46:44 +08:00
|
|
|
|
2020-08-15 02:35:39 +08:00
|
|
|
if (messageData.Folder && messageData.Uid) {
|
|
|
|
dispatchEvent(new CustomEvent('mailbox.message.show', {detail:messageData}));
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
2015-01-27 05:06:00 +08:00
|
|
|
|
2020-08-12 06:25:36 +08:00
|
|
|
setTimeout(
|
2019-07-05 03:19:24 +08:00
|
|
|
(function(localNotifications) {
|
|
|
|
return () => {
|
|
|
|
if (localNotifications.cancel) {
|
|
|
|
localNotifications.cancel();
|
|
|
|
} else if (localNotifications.close) {
|
|
|
|
localNotifications.close();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
})(notification),
|
2020-08-14 04:58:41 +08:00
|
|
|
7000
|
2019-07-05 03:19:24 +08:00
|
|
|
);
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-17 06:01:20 +08:00
|
|
|
populate() {
|
|
|
|
this.enableSoundNotification(!!Settings.settingsGet('SoundNotification'));
|
|
|
|
this.enableDesktopNotification(!!Settings.settingsGet('DesktopNotifications'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @returns {*|null}
|
|
|
|
*/
|
|
|
|
notificationClass() {
|
2020-08-12 06:25:36 +08:00
|
|
|
return window.Notification && Notification.requestPermission ? Notification : null;
|
2016-08-17 06:01:20 +08:00
|
|
|
}
|
|
|
|
}
|
2016-06-30 08:02:45 +08:00
|
|
|
|
2016-09-13 04:50:21 +08:00
|
|
|
export default new NotificationUserStore();
|