From d6d9a076ae39fe364e6f57adb971e9f390fad9fd Mon Sep 17 00:00:00 2001 From: Hadi Nategh Date: Wed, 4 May 2016 13:04:55 +0000 Subject: [PATCH] Check Notification API is supported by browser before using it --- api/js/jsapi/egw_notification.js | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/api/js/jsapi/egw_notification.js b/api/js/jsapi/egw_notification.js index dcbc32bcab..46cd4f15a8 100644 --- a/api/js/jsapi/egw_notification.js +++ b/api/js/jsapi/egw_notification.js @@ -19,14 +19,20 @@ * @augments Class * @param {string} _app application name object is instanciated for * @param {object} _wnd window object is instanciated for + * + * @return {object} defined functions of module */ egw.extend('notification', egw.MODULE_WND_LOCAL, function(_app, _wnd) { "use strict"; // Notification permission, the default value is 'default' which is equivalent to 'denied' - var permission = Notification.permission || 'default'; - + var permission = 'default'; + + if (typeof Notification != 'undefined') + { + permission = Notification.permission; + } return { @@ -45,10 +51,12 @@ egw.extend('notification', egw.MODULE_WND_LOCAL, function(_app, _wnd) * onclose: // Callback function dispateches on notification close * onerror: // Callback function dispatches on error, default is a egw.debug log * } - * @return {boolean} true if the permission is granted otherwise false + * @return {boolean} false if Notification is not supported by browser */ notification: function (_title, _options) { + // Check if the notification is supported by browser + if (typeof Notification == 'undefined') return false; var self = this; // Check and ask for permission