Merge pull request #240 from mebjas/develop-notif

Save a preference in local settings to record when the user has hidden the notifications warning bar.
pull/21833/head
Richard van der Hoff 2016-03-29 10:48:12 +01:00
commit d7f8017b91
1 changed files with 27 additions and 21 deletions

View File

@ -132,30 +132,26 @@ var Notifier = {
}
}
if(enable) {
if (!this.havePermission()) {
global.Notification.requestPermission(function() {
if (callback) {
callback();
dis.dispatch({
action: "notifier_enabled",
value: true
});
}
});
}
if (enable) {
// Attempt to get permission from user
global.Notification.requestPermission(function(result) {
if (result !== 'granted') {
// The permission request was dismissed or denied
return;
}
if (!global.localStorage) return;
global.localStorage.setItem('notifications_enabled', 'true');
if (global.localStorage) {
global.localStorage.setItem('notifications_enabled', 'true');
}
if (this.havePermission) {
if (callback) callback();
dis.dispatch({
action: "notifier_enabled",
value: true
});
}
}
else {
});
this.setToolbarHidden(false);
} else {
if (!global.localStorage) return;
global.localStorage.setItem('notifications_enabled', 'false');
dis.dispatch({
@ -163,8 +159,6 @@ var Notifier = {
value: false
});
}
this.setToolbarHidden(false);
},
isEnabled: function() {
@ -192,15 +186,27 @@ var Notifier = {
return enabled === 'true';
},
setToolbarHidden: function(hidden) {
setToolbarHidden: function(hidden, persistent = true) {
this.toolbarHidden = hidden;
dis.dispatch({
action: "notifier_enabled",
value: this.isEnabled()
});
// update the info to localStorage for persistent settings
if (persistent && global.localStorage) {
global.localStorage.setItem('notifications_hidden', hidden);
}
},
isToolbarHidden: function() {
// Check localStorage for any such meta data
if (global.localStorage) {
if (global.localStorage.getItem('notifications_hidden') === 'true') {
return true;
}
}
return this.toolbarHidden;
},