mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 17:06:53 +02:00
MDL-54708 message: add renderer for get_popup_notification
This commit is contained in:
parent
34eb5fcb60
commit
24a76780f6
2 changed files with 159 additions and 57 deletions
149
message/classes/output/popup_notification.php
Normal file
149
message/classes/output/popup_notification.php
Normal file
|
@ -0,0 +1,149 @@
|
|||
<?php
|
||||
// This file is part of Moodle - http://moodle.org/
|
||||
//
|
||||
// Moodle is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// Moodle is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
/**
|
||||
* Contains class used to prepare a popup notification for display.
|
||||
*
|
||||
* @package core_message
|
||||
* @copyright 2016 Ryan Wyllie <ryan@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
|
||||
namespace core_message\output;
|
||||
|
||||
require_once($CFG->dirroot . '/message/lib.php');
|
||||
|
||||
use renderable;
|
||||
use templatable;
|
||||
use moodle_url;
|
||||
use core_user;
|
||||
|
||||
/**
|
||||
* Class to prepare a popup notification for display.
|
||||
*
|
||||
* @package core_message
|
||||
* @copyright 2016 Ryan Wyllie <ryan@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
class popup_notification implements templatable, renderable {
|
||||
|
||||
/**
|
||||
* The notification.
|
||||
*/
|
||||
protected $notification;
|
||||
|
||||
/**
|
||||
* Indicates if the receiver of the notification should have their
|
||||
* details embedded in the output.
|
||||
*/
|
||||
protected $embeduserto;
|
||||
|
||||
/**
|
||||
* Indicates if the sender of the notification should have their
|
||||
* details embedded in the output.
|
||||
*/
|
||||
protected $embeduserfrom;
|
||||
|
||||
/**
|
||||
* Indicates if the receiver of the notification should have their
|
||||
* notification preferences embedded in the output.
|
||||
*/
|
||||
protected $embedpreference;
|
||||
|
||||
/**
|
||||
* A cache for the receiver's full name, if it's already known, so that
|
||||
* a DB lookup isn't required.
|
||||
*/
|
||||
protected $usertofullname;
|
||||
|
||||
/**
|
||||
* Constructor.
|
||||
*
|
||||
* @param \stdClass $notification
|
||||
*/
|
||||
public function __construct($notification, $embeduserto,
|
||||
$embeduserfrom, $embedpreference, $usertofullname = '') {
|
||||
|
||||
$this->notification = $notification;
|
||||
$this->embeduserto = $embeduserto;
|
||||
$this->embeduserfrom = $embeduserfrom;
|
||||
$this->embedpreference = $embedpreference;
|
||||
$this->usertofullname = $usertofullname;
|
||||
}
|
||||
|
||||
public function export_for_template(\renderer_base $output) {
|
||||
global $USER;
|
||||
|
||||
$context = clone $this->notification;
|
||||
|
||||
if ($context->useridto == $USER->id && $context->timeusertodeleted) {
|
||||
$context->deleted = true;
|
||||
} else {
|
||||
$context->deleted = false;
|
||||
}
|
||||
|
||||
// We need to get the user from the query.
|
||||
if ($this->embeduserfrom) {
|
||||
// Check for non-reply and support users.
|
||||
if (core_user::is_real_user($context->useridfrom)) {
|
||||
$user = new \stdClass();
|
||||
$user = username_load_fields_from_object($user, $context, 'userfrom');
|
||||
$profileurl = new moodle_url('/user/profile.php', array('id' => $context->useridfrom));
|
||||
$context->userfromfullname = fullname($user);
|
||||
$context->userfromprofileurl = $profileurl->out();
|
||||
} else {
|
||||
$context->userfromfullname = get_string('coresystem');
|
||||
}
|
||||
}
|
||||
|
||||
// We need to get the user from the query.
|
||||
if ($this->embeduserto) {
|
||||
if (empty($this->usertofullname)) {
|
||||
$user = new \stdClass();
|
||||
$user = username_load_fields_from_object($user, $context, 'userto');
|
||||
$context->usertofullname = fullname($user);
|
||||
} else {
|
||||
$context->usertofullname = $this->usertofullname;
|
||||
}
|
||||
}
|
||||
|
||||
$context->timecreatedpretty = get_string('ago', 'message', format_time(time() - $context->timecreated));
|
||||
$context->text = message_format_message_text($context);
|
||||
$context->read = $context->timeread ? true : false;
|
||||
|
||||
if (!empty($context->component) && substr($context->component, 0, 4) == 'mod_') {
|
||||
$iconurl = $output->pix_url('icon', $context->component);
|
||||
} else {
|
||||
$iconurl = $output->pix_url('i/marker', 'core');
|
||||
}
|
||||
|
||||
$context->iconurl = $iconurl->out();
|
||||
|
||||
// We only return the logged in user's preferences, so if it isn't the sender or receiver
|
||||
// of this notification then skip embedding the preferences.
|
||||
if ($this->embedpreference && !empty($context->component) && !empty($context->eventtype)
|
||||
&& $USER->id == $context->useridto) {
|
||||
$key = 'message_provider_' . $context->component . '_' . $context->eventtype;
|
||||
$context->preference = array(
|
||||
'key' => $key,
|
||||
'loggedin' => get_user_preferences($key . '_loggedin', $USER->id),
|
||||
'loggedoff' => get_user_preferences($key . '_loggedoff', $USER->id),
|
||||
);
|
||||
}
|
||||
|
||||
return $context;
|
||||
}
|
||||
}
|
|
@ -1238,7 +1238,7 @@ class core_message_external extends external_api {
|
|||
*/
|
||||
public static function get_popup_notifications($useridto, $status, $embedpreference,
|
||||
$embeduserto, $embeduserfrom, $newestfirst, $markasread, $limit, $offset) {
|
||||
global $CFG, $USER, $OUTPUT;
|
||||
global $CFG, $USER, $PAGE;
|
||||
|
||||
$params = self::validate_parameters(
|
||||
self::get_popup_notifications_parameters(),
|
||||
|
@ -1268,6 +1268,7 @@ class core_message_external extends external_api {
|
|||
$limit = $params['limit'];
|
||||
$offset = $params['offset'];
|
||||
$issuperuser = has_capability('moodle/site:readallmessages', $context);
|
||||
$renderer = $PAGE->get_renderer('core_message');
|
||||
|
||||
if (!empty($useridto)) {
|
||||
if (core_user::is_real_user($useridto)) {
|
||||
|
@ -1286,6 +1287,7 @@ class core_message_external extends external_api {
|
|||
|
||||
$sort = $newestfirst ? 'DESC' : 'ASC';
|
||||
$notifications = message_get_popup_notifications($useridto, $status, $embeduserto, $embeduserfrom, $sort, $limit, $offset);
|
||||
$notificationcontexts = [];
|
||||
|
||||
if ($notifications) {
|
||||
// In some cases, we don't need to get the to user objects from the sql query.
|
||||
|
@ -1298,69 +1300,20 @@ class core_message_external extends external_api {
|
|||
|
||||
foreach ($notifications as $notification) {
|
||||
|
||||
if ($useridto == $USER->id and $notification->timeusertodeleted) {
|
||||
$notification->deleted = true;
|
||||
} else {
|
||||
$notification->deleted = false;
|
||||
}
|
||||
$notificationoutput = new \core_message\output\popup_notification($notification, $embeduserto,
|
||||
$embeduserfrom, $embedpreference, $usertofullname);
|
||||
|
||||
// We need to get the user from the query.
|
||||
if ($embeduserfrom) {
|
||||
// Check for non-reply and support users.
|
||||
if (core_user::is_real_user($notification->useridfrom)) {
|
||||
$user = new stdClass();
|
||||
$user = username_load_fields_from_object($user, $notification, 'userfrom');
|
||||
$profileurl = new moodle_url('/user/profile.php', array('id' => $notification->useridfrom));
|
||||
$notification->userfromfullname = fullname($user);
|
||||
$notification->userfromprofileurl = $profileurl->out();
|
||||
} else {
|
||||
$notification->userfromfullname = get_string('coresystem');
|
||||
}
|
||||
}
|
||||
$notificationcontext = $notificationoutput->export_for_template($renderer);
|
||||
$notificationcontexts[] = $notificationcontext;
|
||||
|
||||
// We need to get the user from the query.
|
||||
if ($embeduserto) {
|
||||
if (empty($usertofullname)) {
|
||||
$user = new stdClass();
|
||||
$user = username_load_fields_from_object($user, $notification, 'userto');
|
||||
$notification->usertofullname = fullname($user);
|
||||
} else {
|
||||
$notification->usertofullname = $usertofullname;
|
||||
}
|
||||
}
|
||||
|
||||
$notification->timecreatedpretty = get_string('ago', 'message', format_time(time() - $notification->timecreated));
|
||||
$notification->text = message_format_message_text($notification);
|
||||
$notification->read = $notification->timeread ? true : false;
|
||||
|
||||
if (!empty($notification->component) && substr($notification->component, 0, 4) == 'mod_') {
|
||||
$iconurl = $OUTPUT->pix_url('icon', $notification->component);
|
||||
} else {
|
||||
$iconurl = $OUTPUT->pix_url('i/marker', 'core');
|
||||
}
|
||||
|
||||
$notification->iconurl = $iconurl->out();
|
||||
|
||||
// We only return the logged in user's preferences, so if it isn't the sender or receiver
|
||||
// of this notification then skip embedding the preferences.
|
||||
if ($embedpreference && !empty($notification->component) && !empty($notification->eventtype) && !$issuperuser) {
|
||||
$key = 'message_provider_' . $notification->component . '_' . $notification->eventtype;
|
||||
$notification->preference = array(
|
||||
'key' => $key,
|
||||
'loggedin' => get_user_preferences($key . '_loggedin', $USER->id),
|
||||
'loggedoff' => get_user_preferences($key . '_loggedoff', $USER->id),
|
||||
);
|
||||
}
|
||||
|
||||
if ($markasread && !$notification->read) {
|
||||
// Have to clone here because this function mutates the given data. Naughty, naughty...
|
||||
message_mark_message_read(clone $notification, time());
|
||||
if ($markasread && !$notificationcontext->read) {
|
||||
message_mark_message_read($notification, time());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return array(
|
||||
'notifications' => $notifications,
|
||||
'notifications' => $notificationcontexts,
|
||||
'unreadcount' => message_count_unread_popup_notifications($useridto),
|
||||
);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue