You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							214 lines
						
					
					
						
							7.9 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							214 lines
						
					
					
						
							7.9 KiB
						
					
					
				| <?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/>. | |
|  | |
| /** | |
|  * Renderable class for manage rules page. | |
|  * | |
|  * @package    tool_monitor | |
|  * @copyright  2014 onwards Ankit Agarwal <ankit.agrr@gmail.com> | |
|  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
|  */ | |
| 
 | |
| namespace tool_monitor\output\managerules; | |
| 
 | |
| defined('MOODLE_INTERNAL') || die; | |
| 
 | |
| require_once($CFG->libdir . '/tablelib.php'); | |
| 
 | |
| /** | |
|  * Renderable class for manage rules page. | |
|  * | |
|  * @since      Moodle 2.8 | |
|  * @package    tool_monitor | |
|  * @copyright  2014 onwards Ankit Agarwal <ankit.agrr@gmail.com> | |
|  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
|  */ | |
| class renderable extends \table_sql implements \renderable { | |
| 
 | |
|     /** | |
|      * @var int course id. | |
|      */ | |
|     public $courseid; | |
| 
 | |
|     /** | |
|      * @var \context_course|\context_system context of the page to be rendered. | |
|      */ | |
|     protected $context; | |
| 
 | |
|     /** | |
|      * @var bool Does the user have capability to manage rules at site context. | |
|      */ | |
|     protected $hassystemcap; | |
| 
 | |
|     /** | |
|      * Sets up the table_log parameters. | |
|      * | |
|      * @param string $uniqueid unique id of form. | |
|      * @param \moodle_url $url url where this table is displayed. | |
|      * @param int $courseid course id. | |
|      * @param int $perpage Number of rules to display per page. | |
|      */ | |
|     public function __construct($uniqueid, \moodle_url $url, $courseid = 0, $perpage = 100) { | |
|         parent::__construct($uniqueid); | |
| 
 | |
|         $this->set_attribute('id', 'toolmonitorrules_table'); | |
|         $this->set_attribute('class', 'toolmonitor managerules generaltable generalbox'); | |
|         $this->define_columns(array('name', 'description', 'course', 'plugin', 'eventname', 'filters', 'manage')); | |
|         $this->define_headers(array( | |
|                 get_string('rulename', 'tool_monitor'), | |
|                 get_string('description'), | |
|                 get_string('course'), | |
|                 get_string('area', 'tool_monitor'), | |
|                 get_string('event', 'tool_monitor'), | |
|                 get_string('frequency', 'tool_monitor'), | |
|                 get_string('manage', 'tool_monitor'), | |
|             ) | |
|         ); | |
|         $this->courseid = $courseid; | |
|         $this->pagesize = $perpage; | |
|         $systemcontext = \context_system::instance(); | |
|         $this->context = empty($courseid) ? $systemcontext : \context_course::instance($courseid); | |
|         $this->hassystemcap = has_capability('tool/monitor:managerules', $systemcontext); | |
|         $this->collapsible(false); | |
|         $this->sortable(false); | |
|         $this->pageable(true); | |
|         $this->is_downloadable(false); | |
|         $this->define_baseurl($url); | |
|     } | |
| 
 | |
|     /** | |
|      * Generate content for name column. | |
|      * | |
|      * @param \tool_monitor\rule $rule rule object | |
|      * @return string html used to display the column field. | |
|      */ | |
|     public function col_name(\tool_monitor\rule $rule) { | |
|         return $rule->get_name($this->context); | |
|     } | |
| 
 | |
|     /** | |
|      * Generate content for description column. | |
|      * | |
|      * @param \tool_monitor\rule $rule rule object | |
|      * @return string html used to display the column field. | |
|      */ | |
|     public function col_description(\tool_monitor\rule $rule) { | |
|         return $rule->get_description($this->context); | |
|     } | |
| 
 | |
|     /** | |
|      * Generate content for course column. | |
|      * | |
|      * @param \tool_monitor\rule $rule rule object | |
|      * @return string html used to display the context column field. | |
|      */ | |
|     public function col_course(\tool_monitor\rule $rule) { | |
|         $coursename = $rule->get_course_name($this->context); | |
| 
 | |
|         $courseid = $rule->courseid; | |
|         if (empty($courseid)) { | |
|             return $coursename; | |
|         } else { | |
|             return \html_writer::link(new \moodle_url('/course/view.php', array('id' => $courseid)), $coursename); | |
|         } | |
|     } | |
| 
 | |
|     /** | |
|      * Generate content for plugin column. | |
|      * | |
|      * @param \tool_monitor\rule $rule rule object | |
|      * @return string html used to display the column field. | |
|      */ | |
|     public function col_plugin(\tool_monitor\rule $rule) { | |
|         return $rule->get_plugin_name(); | |
|     } | |
| 
 | |
|     /** | |
|      * Generate content for eventname column. | |
|      * | |
|      * @param \tool_monitor\rule $rule rule object | |
|      * @return string html used to display the column field. | |
|      */ | |
|     public function col_eventname(\tool_monitor\rule $rule) { | |
|         return $rule->get_event_name(); | |
|     } | |
| 
 | |
|     /** | |
|      * Generate content for filters column. | |
|      * | |
|      * @param \tool_monitor\rule $rule rule object | |
|      * @return string html used to display the filters column field. | |
|      */ | |
|     public function col_filters(\tool_monitor\rule $rule) { | |
|         return $rule->get_filters_description(); | |
|     } | |
| 
 | |
|     /** | |
|      * Generate content for manage column. | |
|      * | |
|      * @param \tool_monitor\rule $rule rule object | |
|      * @return string html used to display the manage column field. | |
|      */ | |
|     public function col_manage(\tool_monitor\rule $rule) { | |
|         global $OUTPUT, $CFG; | |
| 
 | |
|         $manage = ''; | |
| 
 | |
|         // Do not allow the user to edit the rule unless they have the system capability, or we are viewing the rules | |
|         // for a course, and not the site. Note - we don't need to check for the capability at a course level since | |
|         // the user is never shown this page otherwise. | |
|         if ($this->hassystemcap || ($rule->courseid != 0)) { | |
|             $editurl = new \moodle_url($CFG->wwwroot. '/admin/tool/monitor/edit.php', array('ruleid' => $rule->id, | |
|                     'courseid' => $rule->courseid, 'sesskey' => sesskey())); | |
|             $icon = $OUTPUT->render(new \pix_icon('t/edit', get_string('editrule', 'tool_monitor'))); | |
|             $manage .= \html_writer::link($editurl, $icon, array('class' => 'action-icon')); | |
|         } | |
| 
 | |
|         // The user should always be able to copy the rule if they are able to view the page. | |
|         $copyurl = new \moodle_url($CFG->wwwroot. '/admin/tool/monitor/managerules.php', | |
|                 array('ruleid' => $rule->id, 'action' => 'copy', 'courseid' => $this->courseid, 'sesskey' => sesskey())); | |
|         $icon = $OUTPUT->render(new \pix_icon('t/copy', get_string('duplicaterule', 'tool_monitor'))); | |
|         $manage .= \html_writer::link($copyurl, $icon, array('class' => 'action-icon')); | |
| 
 | |
|         if ($this->hassystemcap || ($rule->courseid != 0)) { | |
|             $deleteurl = new \moodle_url($CFG->wwwroot. '/admin/tool/monitor/managerules.php', array('ruleid' => $rule->id, | |
|                     'action' => 'delete', 'courseid' => $rule->courseid, 'sesskey' => sesskey())); | |
|             $icon = $OUTPUT->render(new \pix_icon('t/delete', get_string('deleterule', 'tool_monitor'))); | |
|             $manage .= \html_writer::link($deleteurl, $icon, array('class' => 'action-icon')); | |
|         } | |
| 
 | |
|         return $manage; | |
|     } | |
| 
 | |
|     /** | |
|      * Query the reader. Store results in the object for use by build_table. | |
|      * | |
|      * @param int $pagesize size of page for paginated displayed table. | |
|      * @param bool $useinitialsbar do you want to use the initials bar. | |
|      */ | |
|     public function query_db($pagesize, $useinitialsbar = true) { | |
| 
 | |
|         $total = \tool_monitor\rule_manager::count_rules_by_courseid($this->courseid); | |
|         $this->pagesize($pagesize, $total); | |
|         $rules = \tool_monitor\rule_manager::get_rules_by_courseid($this->courseid, $this->get_page_start(), | |
|                 $this->get_page_size()); | |
|         $this->rawdata = $rules; | |
|         // Set initial bars. | |
|         if ($useinitialsbar) { | |
|             $this->initialbars($total > $pagesize); | |
|         } | |
|     } | |
| }
 | |
| 
 |