Refactor desktop notifications

- Remove webkitNotifications support, clean up the code
- Unify look and behaviour of notifications in Mail and in Settings
pull/5168/head
Aleksander Machniak 9 years ago
parent 348ec70f12
commit 1aa5817131

@ -26,6 +26,7 @@ CHANGELOG Roundcube Webmail
- Hide DSN option in Preferences when smtp_server is not used (#1490666) - Hide DSN option in Preferences when smtp_server is not used (#1490666)
- Fix handling of body parameter in mail compose request - Fix handling of body parameter in mail compose request
- Protect download urls against CSRF using unique request tokens (#1490642) - Protect download urls against CSRF using unique request tokens (#1490642)
- newmail_notifier: Refactor desktop notifications
RELEASE 1.2-beta RELEASE 1.2-beta
---------------- ----------------

@ -1,9 +1,9 @@
{ {
"name": "roundcube/newmail_notifier", "name": "roundcube/newmail_notifier",
"type": "roundcube-plugin", "type": "roundcube-plugin",
"description": "Supports three methods of notification: 1. Basic - focus browser window and change favicon 2. Sound - play wav file 3. Desktop - display desktop notification (using webkitNotifications feature, supported by Chrome and Firefox with 'HTML5 Notifications' plugin).", "description": "Supports three methods of notification: 1. Basic - focus browser window and change favicon 2. Sound - play wav file 3. Desktop - display desktop notification (using HTML5 Notification API feature).",
"license": "GPLv3+", "license": "GPLv3+",
"version": "0.7", "version": "0.8",
"authors": [ "authors": [
{ {
"name": "Aleksander Machniak", "name": "Aleksander Machniak",

@ -6,7 +6,7 @@
* @licstart The following is the entire license notice for the * @licstart The following is the entire license notice for the
* JavaScript code in this file. * JavaScript code in this file.
* *
* Copyright (c) 2013, The Roundcube Dev Team * Copyright (c) 2013-2016, The Roundcube Dev Team
* *
* The JavaScript code in this page is free software: you can redistribute it * The JavaScript code in this page is free software: you can redistribute it
* and/or modify it under the terms of the GNU General Public License * and/or modify it under the terms of the GNU General Public License
@ -106,77 +106,46 @@ function newmail_notifier_sound()
} }
// Desktop notification // Desktop notification
// - Require Chrome or Firefox latest version (22+) / 21.0 or older with a plugin // - Require window.Notification API support (Chrome 22+ or Firefox 22+)
function newmail_notifier_desktop(body) function newmail_notifier_desktop(body, disabled_callback)
{ {
var timeout = rcmail.env.newmail_notifier_timeout || 10, var timeout = rcmail.env.newmail_notifier_timeout || 10,
icon = rcmail.assets_path('plugins/newmail_notifier/mail.png'); icon = rcmail.assets_path('plugins/newmail_notifier/mail.png'),
success_callback = function() {
var popup = new window.Notification(rcmail.get_label('title', 'newmail_notifier'), {
// As of 17 June 2013, Chrome/Chromium does not implement Notification.permission correctly that
// it gives 'undefined' until an object has been created:
// https://code.google.com/p/chromium/issues/detail?id=163226
try {
if (Notification.permission == 'granted' || Notification.permission == undefined) {
var popup = new Notification(rcmail.get_label('title', 'newmail_notifier'), {
dir: "auto", dir: "auto",
lang: "", lang: "",
body: body, body: body,
tag: "newmail_notifier", tag: "newmail_notifier",
icon: icon icon: icon
}); });
popup.onclick = function() { popup.onclick = function() { this.close(); };
this.close();
}
setTimeout(function() { popup.close(); }, timeout * 1000); setTimeout(function() { popup.close(); }, timeout * 1000);
if (popup.permission == 'granted') return true; };
}
try {
window.Notification.requestPermission(function(perm) {
if (perm == 'granted')
success_callback();
else if (perm == 'denied' && disabled_callback)
disabled_callback();
});
return true;
} }
catch (e) { catch (e) {
var dn = window.webkitNotifications; return false;
if (dn && !dn.checkPermission()) {
if (rcmail.newmail_popup)
rcmail.newmail_popup.cancel();
var popup = window.webkitNotifications.createNotification(icon,
rcmail.get_label('title', 'newmail_notifier'), body);
popup.onclick = function() {
this.cancel();
}
popup.show();
setTimeout(function() { popup.cancel(); }, timeout * 1000);
rcmail.newmail_popup = popup;
return true;
}
} }
return false;
} }
function newmail_notifier_test_desktop() function newmail_notifier_test_desktop()
{ {
var txt = rcmail.get_label('testbody', 'newmail_notifier'); var status = newmail_notifier_desktop(rcmail.get_label('testbody', 'newmail_notifier'), function() {
rcmail.display_message(rcmail.get_label('desktopdisabled', 'newmail_notifier'), 'error');
});
// W3C draft implementation (with fix for Chrome/Chromium) if (!status) {
try { rcmail.display_message(rcmail.get_label('desktopunsupported', 'newmail_notifier'), 'error');
var testNotification = new window.Notification(txt, {tag: "newmail_notifier"}); // Try to show a test message
if (Notification.permission !== 'granted' || (testNotification.permission && testNotification.permission !== 'granted'))
newmail_notifier_desktop_authorize();
}
// webkit implementation
catch (e) {
var dn = window.webkitNotifications;
if (dn) {
if (!dn.checkPermission())
newmail_notifier_desktop(txt);
else
dn.requestPermission(function() {
if (!newmail_notifier_desktop(txt))
rcmail.display_message(rcmail.get_label('desktopdisabled', 'newmail_notifier'), 'error');
});
}
else
// Everything fails, means the browser has no support
rcmail.display_message(rcmail.get_label('desktopunsupported', 'newmail_notifier'), 'error');
} }
} }
@ -189,12 +158,3 @@ function newmail_notifier_test_sound()
{ {
newmail_notifier_sound(); newmail_notifier_sound();
} }
function newmail_notifier_desktop_authorize() {
Notification.requestPermission(function(perm) {
if (perm == 'denied')
rcmail.display_message(rcmail.get_label('desktopdisabled', 'newmail_notifier'), 'error');
if (perm == 'granted')
newmail_notifier_test_desktop(); // Test again, which should show test message
});
}

@ -4,16 +4,14 @@
* New Mail Notifier plugin * New Mail Notifier plugin
* *
* Supports three methods of notification: * Supports three methods of notification:
* 1. Basic - focus browser window and change favicon * 1. Basic - focus browser window and change favicon
* 2. Sound - play wav file * 2. Sound - play wav file
* 3. Desktop - display desktop notification (using webkitNotifications feature, * 3. Desktop - display desktop notification (using window.Notification API)
* supported by Chrome and Firefox with 'HTML5 Notifications' plugin)
* *
* @version @package_version@ * @version @package_version@
* @author Aleksander Machniak <alec@alec.pl> * @author Aleksander Machniak <alec@alec.pl>
* *
* * Copyright (C) 2011-2016, Kolab Systems AG
* Copyright (C) 2011, Kolab Systems AG
* *
* This program is free software: you can redistribute it and/or modify * This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by

Loading…
Cancel
Save