Merge branch 'MDL-81084-main' of https://github.com/andrewnicols/moodle
[moodle.git] / availability / renderer.php
blobcffc258a0f94ad52ba0010cc0ec535b3cc2db143
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
17 /**
18 * Renderer for availability display.
20 * @package core_availability
21 * @copyright 2014 The Open University
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25 /**
26 * Renderer for availability display.
28 * @package core_availability
29 * @copyright 2014 The Open University
30 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
32 class core_availability_renderer extends plugin_renderer_base {
33 /**
34 * Renders HTML for the result of two or more availability restriction
35 * messages being combined in a list.
37 * The supplied messages should already take account of the 'not' option,
38 * e.g. an example message could be 'User profile field Department must
39 * not be set to Maths'.
41 * This function will not be called unless there are at least two messages.
43 * @deprecated since Moodle 4.0 MDL-716916 - please do not use this function any more.
44 * @param core_availability_multiple_messages $renderable Multiple messages
45 * @return string Combined HTML
47 public function render_core_availability_multiple_messages(
48 core_availability_multiple_messages $renderable) {
50 debugging(
51 'render_core_availability_multiple_messages is deprecated. Use core_availability\\output\\multiple_messages instead',
52 DEBUG_DEVELOPER
54 // Get initial message.
55 $out = get_string('list_' . ($renderable->root ? 'root_' : '') .
56 ($renderable->andoperator ? 'and' : 'or') . ($renderable->treehidden ? '_hidden' : ''),
57 'availability');
59 // Make the list.
60 $out .= html_writer::start_tag('ul');
61 foreach ($renderable->items as $item) {
62 if (is_string($item)) {
63 $str = $item;
64 } else {
65 $str = $this->render($item);
67 $out .= html_writer::tag('li', $str);
69 $out .= html_writer::end_tag('ul');
70 return $out;