See Release Notes
Long Term Support Release
Differences Between: [Versions 401 and 402] [Versions 401 and 403]
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. 13 // 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/>. 16 17 namespace mod_data\output; 18 19 use action_link; 20 use core\output\sticky_footer; 21 use html_writer; 22 use mod_data\manager; 23 use mod_data\template; 24 use moodle_url; 25 use renderer_base; 26 27 /** 28 * Renderable class for sticky footer in the view pages of the database activity. 29 * 30 * @package mod_data 31 * @copyright 2022 Ferran Recio <ferran@moodle.com> 32 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 33 */ 34 class view_footer extends sticky_footer { 35 36 /** @var int $totalcount the total records count. */ 37 private $totalcount; 38 39 /** @var int $currentpage the current page */ 40 private $currentpage; 41 42 /** @var int $nowperpage the number of elements per page */ 43 private $nowperpage; 44 45 /** @var moodle_url $baseurl the page base url */ 46 private $baseurl; 47 48 /** @var template $parser the template name */ 49 private $parser; 50 51 /** @var manager $manager if the user can manage capabilities or not */ 52 private $manager; 53 54 /** 55 * The class constructor. 56 * 57 * @param manager $manager the activity manager 58 * @param int $totalcount the total records count 59 * @param int $currentpage the current page 60 * @param int $nowperpage the number of elements per page 61 * @param moodle_url $baseurl the page base url 62 * @param template $parser the current template name 63 */ 64 public function __construct( 65 manager $manager, 66 int $totalcount, 67 int $currentpage, 68 int $nowperpage, 69 moodle_url $baseurl, 70 template $parser 71 ) { 72 $this->manager = $manager; 73 $this->totalcount = $totalcount; 74 $this->currentpage = $currentpage; 75 $this->nowperpage = $nowperpage; 76 $this->baseurl = $baseurl; 77 $this->parser = $parser; 78 } 79 80 /** 81 * Export this data so it can be used as the context for a mustache template (core/inplace_editable). 82 * 83 * @param renderer_base $output typically, the renderer that's calling this function 84 * @return array data context for a mustache template 85 */ 86 public function export_for_template(renderer_base $output) { 87 $this->set_content( 88 $this->get_footer_output($output) 89 ); 90 return parent::export_for_template($output); 91 } 92 93 /** 94 * Generate the pre-rendered footer content. 95 * 96 * @param \renderer_base $output The renderer to be used to render the action bar elements. 97 * @return string the rendered content 98 */ 99 public function get_footer_output(renderer_base $output): string { 100 $data = []; 101 102 $cm = $this->manager->get_coursemodule(); 103 $instance = $this->manager->get_instance(); 104 $currentgroup = groups_get_activity_group($cm); 105 $groupmode = groups_get_activity_groupmode($cm); 106 $context = $this->manager->get_context(); 107 $canmanageentries = has_capability('mod/data:manageentries', $context); 108 $parser = $this->parser; 109 110 // Sticky footer content. 111 $data['pagination'] = $output->paging_bar( 112 $this->totalcount, 113 $this->currentpage, 114 $this->nowperpage, 115 $this->baseurl 116 ); 117 118 if ($parser->get_template_name() != 'singletemplate' && $parser->has_tag('delcheck') && $canmanageentries) { 119 // Build the select/deselect all control. 120 $selectallid = 'selectall-listview-entries'; 121 $togglegroup = 'listview-entries'; 122 $mastercheckbox = new \core\output\checkbox_toggleall($togglegroup, true, [ 123 'id' => $selectallid, 124 'name' => $selectallid, 125 'value' => 1, 126 'label' => get_string('selectall'), 127 'classes' => 'btn-secondary mr-1', 128 ], true); 129 $data['selectall'] = $output->render($mastercheckbox); 130 131 $data['deleteselected'] = html_writer::empty_tag('input', [ 132 'class' => 'btn btn-secondary', 133 'type' => 'submit', 134 'value' => get_string('deleteselected'), 135 'disabled' => true, 136 'data-action' => 'toggle', 137 'data-togglegroup' => $togglegroup, 138 'data-toggle' => 'action', 139 ]); 140 } 141 if (data_user_can_add_entry($instance, $currentgroup, $groupmode, $context)) { 142 $addentrylink = new moodle_url( 143 '/mod/data/edit.php', 144 ['id' => $cm->id, 'backto' => $this->baseurl] 145 ); 146 $addentrybutton = new action_link( 147 $addentrylink, 148 get_string('add', 'mod_data'), 149 null, 150 ['class' => 'btn btn-primary', 'role' => 'button'] 151 ); 152 $data['addentrybutton'] = $addentrybutton->export_for_template($output); 153 } 154 return $output->render_from_template('mod_data/view_footer', $data); 155 } 156 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body