From 382a9576c74cd2ee34a51ad1a3a5af253879d64f Mon Sep 17 00:00:00 2001 From: Hadi Nategh Date: Tue, 21 Jul 2020 15:46:38 +0200 Subject: [PATCH] Implement push mechanism for popup notifications --- .../inc/class.notifications_popup.inc.php | 42 +++++++++++++++++++ notifications/js/notificationajaxpopup.js | 3 +- 2 files changed, 44 insertions(+), 1 deletion(-) diff --git a/notifications/inc/class.notifications_popup.inc.php b/notifications/inc/class.notifications_popup.inc.php index 197f3e8871..7b0e9850fc 100644 --- a/notifications/inc/class.notifications_popup.inc.php +++ b/notifications/inc/class.notifications_popup.inc.php @@ -128,6 +128,48 @@ class notifications_popup implements notifications_iface { 'notify_data' => is_array($_data) ? json_encode($_data) : NULL ), false,__LINE__,__FILE__,self::_appname); if ($result === false) throw new Exception("Can't save notification into SQL table"); + $push = new Api\Json\Push($this->recipient->account_id); + $push->call('app.notifications.append', $this->read()); + } + + + /** + * read all notification messages for current recipient + * @return type + */ + private function read() + { + $rs = $this->db->select(self::_notification_table, '*', array( + 'account_id' => $this->recipient->account_id, + 'notify_type' => self::_type + ), + __LINE__,__FILE__,0 ,'ORDER BY notify_id DESC',self::_appname, 100); + $result = array(); + if ($rs->NumRows() > 0) { + foreach ($rs as $notification) { + $actions = null; + $data = json_decode($notification['notify_data'], true); + if ($data['appname'] && $data['data']) + { + $_actions = Api\Hooks::process (array( + 'location' => 'notifications_actions', + 'data' => $data['data'] + ), $data['appname'], true); + $actions = $_actions[$data['appname']]; + } + $result[] = array( + 'id' => $notification['notify_id'], + 'message' => $notification['notify_message'], + 'status' => $notification['notify_status'], + 'created' => Api\DateTime::to($notification['notify_created']), + 'current' => new DateTime(), + 'actions' => is_array($actions)?$actions:NULL, + 'extra_data' => ($data['data'] ? $data['data'] : array()) + ); + + } + return $result; + } } /** diff --git a/notifications/js/notificationajaxpopup.js b/notifications/js/notificationajaxpopup.js index 91394e424b..cdf5c07add 100644 --- a/notifications/js/notificationajaxpopup.js +++ b/notifications/js/notificationajaxpopup.js @@ -658,6 +658,7 @@ var hasUnseen = []; notifymessages = {}; + var browser_notify = _browser_notify || this.check_browser_notify(); for (var i=0; i < _rawData.length; i++) { var data = this.getData(_rawData[i]['message'], _rawData[i]['extra_data']); @@ -690,7 +691,7 @@ }; if (_rawData[i]['actions'] && _rawData[i]['actions'].length > 0) notifymessages[_rawData[i]['id']]['data']['actions'] = _rawData[i]['actions']; // Notification API - if(_browser_notify && !_rawData[i]['status']) + if(browser_notify && !_rawData[i]['status']) { egw.notification(data.title, { tag: data.app+":"+_rawData[i]['id'],