2015-01-26 07:09:22 +08:00
|
|
|
|
|
|
|
(function () {
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var
|
|
|
|
window = require('window'),
|
|
|
|
ko = require('ko'),
|
2015-01-27 05:06:00 +08:00
|
|
|
buzz = require('buzz'),
|
2015-01-26 07:09:22 +08:00
|
|
|
|
|
|
|
Enums = require('Common/Enums'),
|
2015-01-27 05:06:00 +08:00
|
|
|
Links = require('Common/Links'),
|
2015-01-26 07:09:22 +08:00
|
|
|
|
|
|
|
Settings = require('Storage/Settings')
|
|
|
|
;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @constructor
|
|
|
|
*/
|
2015-01-27 05:06:00 +08:00
|
|
|
function NotificationUserStore()
|
2015-01-26 07:09:22 +08:00
|
|
|
{
|
|
|
|
var self = this;
|
|
|
|
|
2015-01-27 05:06:00 +08:00
|
|
|
this.buzz = null;
|
|
|
|
|
2015-02-16 05:55:59 +08:00
|
|
|
this.enableSoundNotification = ko.observable(false);
|
2015-01-27 05:06:00 +08:00
|
|
|
this.soundNotificationIsSupported = ko.observable(false);
|
|
|
|
|
2015-01-26 07:09:22 +08:00
|
|
|
this.allowDesktopNotification = ko.observable(false);
|
|
|
|
|
2015-02-13 01:54:12 +08:00
|
|
|
this.desktopNotificationPermissions = ko.computed(function () {
|
2015-01-26 07:09:22 +08:00
|
|
|
|
|
|
|
this.allowDesktopNotification();
|
|
|
|
|
|
|
|
var
|
|
|
|
NotificationClass = this.notificationClass(),
|
|
|
|
iResult = Enums.DesktopNotification.NotSupported
|
|
|
|
;
|
|
|
|
|
|
|
|
if (NotificationClass && NotificationClass.permission)
|
|
|
|
{
|
|
|
|
switch (NotificationClass.permission.toLowerCase())
|
|
|
|
{
|
|
|
|
case 'granted':
|
|
|
|
iResult = Enums.DesktopNotification.Allowed;
|
|
|
|
break;
|
|
|
|
case 'denied':
|
|
|
|
iResult = Enums.DesktopNotification.Denied;
|
|
|
|
break;
|
|
|
|
case 'default':
|
|
|
|
iResult = Enums.DesktopNotification.NotAllowed;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (window.webkitNotifications && window.webkitNotifications.checkPermission)
|
|
|
|
{
|
|
|
|
iResult = window.webkitNotifications.checkPermission();
|
|
|
|
}
|
|
|
|
|
|
|
|
return iResult;
|
|
|
|
|
2015-02-02 04:46:23 +08:00
|
|
|
}, this).extend({'notify': 'always'});
|
2015-01-26 07:09:22 +08:00
|
|
|
|
|
|
|
this.enableDesktopNotification = ko.computed({
|
|
|
|
'owner': this,
|
|
|
|
'read': function () {
|
|
|
|
return this.allowDesktopNotification() &&
|
2015-02-13 01:54:12 +08:00
|
|
|
Enums.DesktopNotification.Allowed === this.desktopNotificationPermissions();
|
2015-01-26 07:09:22 +08:00
|
|
|
},
|
|
|
|
'write': function (bValue) {
|
|
|
|
if (bValue)
|
|
|
|
{
|
|
|
|
var
|
|
|
|
NotificationClass = this.notificationClass(),
|
2015-02-13 01:54:12 +08:00
|
|
|
iPermission = this.desktopNotificationPermissions()
|
2015-01-26 07:09:22 +08:00
|
|
|
;
|
|
|
|
|
|
|
|
if (NotificationClass && Enums.DesktopNotification.Allowed === iPermission)
|
|
|
|
{
|
|
|
|
this.allowDesktopNotification(true);
|
|
|
|
}
|
|
|
|
else if (NotificationClass && Enums.DesktopNotification.NotAllowed === iPermission)
|
|
|
|
{
|
|
|
|
NotificationClass.requestPermission(function () {
|
|
|
|
self.allowDesktopNotification.valueHasMutated();
|
2015-02-13 01:54:12 +08:00
|
|
|
if (Enums.DesktopNotification.Allowed === self.desktopNotificationPermissions())
|
2015-01-26 07:09:22 +08:00
|
|
|
{
|
|
|
|
if (self.allowDesktopNotification())
|
|
|
|
{
|
|
|
|
self.allowDesktopNotification.valueHasMutated();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
self.allowDesktopNotification(true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (self.allowDesktopNotification())
|
|
|
|
{
|
|
|
|
self.allowDesktopNotification(false);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
self.allowDesktopNotification.valueHasMutated();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.allowDesktopNotification(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.allowDesktopNotification(false);
|
|
|
|
}
|
|
|
|
}
|
2015-02-02 04:46:23 +08:00
|
|
|
}).extend({'notify': 'always'});
|
2015-01-26 07:09:22 +08:00
|
|
|
|
|
|
|
if (!this.enableDesktopNotification.valueHasMutated)
|
|
|
|
{
|
|
|
|
this.enableDesktopNotification.valueHasMutated = function () {
|
|
|
|
self.allowDesktopNotification.valueHasMutated();
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2015-02-19 03:52:52 +08:00
|
|
|
this.computers();
|
2015-01-27 05:06:00 +08:00
|
|
|
|
|
|
|
this.initNotificationPlayer();
|
2015-01-26 07:09:22 +08:00
|
|
|
}
|
|
|
|
|
2015-02-19 03:52:52 +08:00
|
|
|
NotificationUserStore.prototype.computers = function ()
|
2015-01-26 07:09:22 +08:00
|
|
|
{
|
|
|
|
this.isDesktopNotificationSupported = ko.computed(function () {
|
2015-02-13 01:54:12 +08:00
|
|
|
return Enums.DesktopNotification.NotSupported !== this.desktopNotificationPermissions();
|
2015-01-26 07:09:22 +08:00
|
|
|
}, this);
|
|
|
|
|
|
|
|
this.isDesktopNotificationDenied = ko.computed(function () {
|
2015-02-13 01:54:12 +08:00
|
|
|
return Enums.DesktopNotification.NotSupported === this.desktopNotificationPermissions() ||
|
|
|
|
Enums.DesktopNotification.Denied === this.desktopNotificationPermissions();
|
2015-01-26 07:09:22 +08:00
|
|
|
}, this);
|
|
|
|
};
|
|
|
|
|
2015-01-27 05:06:00 +08:00
|
|
|
NotificationUserStore.prototype.initNotificationPlayer = function ()
|
|
|
|
{
|
|
|
|
if (buzz && buzz.isSupported() && (buzz.isOGGSupported() || buzz.isMP3Supported()))
|
|
|
|
{
|
|
|
|
this.soundNotificationIsSupported(true);
|
|
|
|
|
|
|
|
this.buzz = new buzz.sound(Links.sound('new-mail'), {
|
2015-02-02 04:46:23 +08:00
|
|
|
'preload': 'none',
|
|
|
|
'formats': ['mp3', 'ogg']
|
2015-01-27 05:06:00 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.enableSoundNotification(false);
|
|
|
|
this.soundNotificationIsSupported(false);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
NotificationUserStore.prototype.playSoundNotification = function (bSkipSetting)
|
|
|
|
{
|
|
|
|
if (this.buzz && (bSkipSetting ? true : this.enableSoundNotification()))
|
|
|
|
{
|
|
|
|
this.buzz.play();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
NotificationUserStore.prototype.displayDesktopNotification = function (sImageSrc, sTitle, sText)
|
|
|
|
{
|
|
|
|
if (this.enableDesktopNotification())
|
|
|
|
{
|
|
|
|
var
|
|
|
|
NotificationClass = this.notificationClass(),
|
|
|
|
oNotification = NotificationClass ? new NotificationClass(sTitle, {
|
|
|
|
'body': sText,
|
|
|
|
'icon': sImageSrc
|
|
|
|
}) : null
|
|
|
|
;
|
|
|
|
|
|
|
|
if (oNotification)
|
|
|
|
{
|
|
|
|
if (oNotification.show)
|
|
|
|
{
|
|
|
|
oNotification.show();
|
|
|
|
}
|
|
|
|
|
|
|
|
window.setTimeout((function (oLocalNotifications) {
|
|
|
|
return function () {
|
|
|
|
if (oLocalNotifications.cancel)
|
|
|
|
{
|
|
|
|
oLocalNotifications.cancel();
|
|
|
|
}
|
|
|
|
else if (oLocalNotifications.close)
|
|
|
|
{
|
|
|
|
oLocalNotifications.close();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}(oNotification)), 7000);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
NotificationUserStore.prototype.populate = function ()
|
2015-01-26 07:09:22 +08:00
|
|
|
{
|
2015-01-27 05:06:00 +08:00
|
|
|
this.enableSoundNotification(!!Settings.settingsGet('SoundNotification'));
|
2015-01-26 07:09:22 +08:00
|
|
|
this.enableDesktopNotification(!!Settings.settingsGet('DesktopNotifications'));
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return {*|null}
|
|
|
|
*/
|
2015-01-27 05:06:00 +08:00
|
|
|
NotificationUserStore.prototype.notificationClass = function ()
|
2015-01-26 07:09:22 +08:00
|
|
|
{
|
|
|
|
return window.Notification && window.Notification.requestPermission ? window.Notification : null;
|
|
|
|
};
|
|
|
|
|
2015-01-27 05:06:00 +08:00
|
|
|
module.exports = new NotificationUserStore();
|
2015-01-26 07:09:22 +08:00
|
|
|
|
|
|
|
}());
|