. /** * Utility class for browsing of course section files. * * @package moodlecore * @subpackage file-browser * @copyright 2008 Petr Skoda (http://skodak.org) * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ /** * Represents a course category context in the tree navigated by @see{file_browser}. */ class file_info_coursesection extends file_info { protected $course; public function __construct($browser, $context, $course) { parent::__construct($browser, $context); $this->course = $course; } /** * Returns list of standard virtual file/directory identification. * The difference from stored_file parameters is that null values * are allowed in all fields * @return array with keys contextid, filearea, itemid, filepath and filename */ public function get_params() { return array('contextid'=>$this->context->id, 'filearea' =>'course_section', 'itemid' =>null, 'filepath' =>null, 'filename' =>null); } /** * Returns localised visible name. * @return string */ public function get_visible_name() { $format = $this->course->format; $sectionsname = get_string("coursesectionsummaries"); return $sectionsname; } /** * Can I add new files or directories? * @return bool */ public function is_writable() { return false; } /** * Is directory? * @return bool */ public function is_directory() { return true; } /** * Returns list of children. * @return array of file_info instances */ public function get_children() { global $DB; $children = array(); $course_sections = $DB->get_records('course_sections', array('course'=>$this->course->id), 'section'); foreach ($course_sections as $section) { if ($child = $this->browser->get_file_info($this->context, 'course_section', $section->id)) { $children[] = $child; } } return $children; } /** * Returns parent file_info instance * @return file_info or null for root */ public function get_parent() { return $this->browser->get_file_info($this->context); } }