. /** * Contains standard functions for message_popup. * * @package message_popup * @copyright 2016 Ryan Wyllie * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); /** * Renders the popup. * * @param renderer_base $renderer * @return string The HTML */ function message_popup_render_navbar_output(\renderer_base $renderer) { global $USER, $CFG; // Early bail out conditions. if (!isloggedin() || isguestuser() || user_not_fully_set_up($USER) || get_user_preferences('auth_forcepasswordchange') || (!$USER->policyagreed && !is_siteadmin() && ($manager = new \core_privacy\local\sitepolicy\manager()) && $manager->is_defined())) { return ''; } $output = ''; // Add the notifications popover. $enabled = \core_message\api::is_processor_enabled("popup"); if ($enabled) { $unreadcount = \message_popup\api::count_unread_popup_notifications($USER->id); $context = [ 'userid' => $USER->id, 'unreadcount' => $unreadcount, 'urls' => [ 'seeall' => (new moodle_url('/message/output/popup/notifications.php'))->out(), 'preferences' => (new moodle_url('/message/notificationpreferences.php', ['userid' => $USER->id]))->out(), ], ]; $output .= $renderer->render_from_template('message_popup/notification_popover', $context); } return $output; }