. /** * Helper functions for course_overview block * * @package block_course_overview * @copyright 2012 Adam Olley * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ /** * Display overview for courses * * @param array $courses courses for which overview needs to be shown * @return array html overview */ function block_course_overview_get_overviews($courses) { $htmlarray = array(); if ($modules = get_plugin_list_with_function('mod', 'print_overview')) { // Split courses list into batches with no more than MAX_MODINFO_CACHE_SIZE courses in one batch. // Otherwise we exceed the cache limit in get_fast_modinfo() and rebuild it too often. if (defined('MAX_MODINFO_CACHE_SIZE') && MAX_MODINFO_CACHE_SIZE > 0 && count($courses) > MAX_MODINFO_CACHE_SIZE) { $batches = array_chunk($courses, MAX_MODINFO_CACHE_SIZE, true); } else { $batches = array($courses); } foreach ($batches as $courses) { foreach ($modules as $fname) { $fname($courses, $htmlarray); } } } return $htmlarray; } /** * Sets user preference for maximum courses to be displayed in course_overview block * * @param int $number maximum courses which should be visible */ function block_course_overview_update_mynumber($number) { set_user_preference('course_overview_number_of_courses', $number); } /** * Sets user course sorting preference in course_overview block * * @param array $sortorder sort order of course */ function block_course_overview_update_myorder($sortorder) { set_user_preference('course_overview_course_order', serialize($sortorder)); } /** * Returns shortname of activities in course * * @param int $courseid id of course for which activity shortname is needed * @return string|bool list of child shortname */ function block_course_overview_get_child_shortnames($courseid) { global $DB; $ctxselect = context_helper::get_preload_record_columns_sql('ctx'); $sql = "SELECT c.id, c.shortname, $ctxselect FROM {enrol} e JOIN {course} c ON (c.id = e.customint1) JOIN {context} ctx ON (ctx.instanceid = e.customint1) WHERE e.courseid = :courseid AND e.enrol = :method AND ctx.contextlevel = :contextlevel ORDER BY e.sortorder"; $params = array('method' => 'meta', 'courseid' => $courseid, 'contextlevel' => CONTEXT_COURSE); if ($results = $DB->get_records_sql($sql, $params)) { $shortnames = array(); // Preload the context we will need it to format the category name shortly. foreach ($results as $res) { context_helper::preload_from_record($res); $context = context_course::instance($res->id); $shortnames[] = format_string($res->shortname, true, $context); } $total = count($shortnames); $suffix = ''; if ($total > 10) { $shortnames = array_slice($shortnames, 0, 10); $diff = $total - count($shortnames); if ($diff > 1) { $suffix = get_string('shortnamesufixprural', 'block_course_overview', $diff); } else { $suffix = get_string('shortnamesufixsingular', 'block_course_overview', $diff); } } $shortnames = get_string('shortnameprefix', 'block_course_overview', implode('; ', $shortnames)); $shortnames .= $suffix; } return isset($shortnames) ? $shortnames : false; } /** * Returns maximum number of courses which will be displayed in course_overview block * * @return int maximum number of courses */ function block_course_overview_get_max_user_courses() { // Get block configuration $config = get_config('block_course_overview'); $limit = $config->defaultmaxcourses; // If max course is not set then try get user preference if (empty($config->forcedefaultmaxcourses)) { $limit = get_user_preferences('course_overview_number_of_courses', $limit); } return $limit; } /** * Return sorted list of user courses * * @return array list of sorted courses and count of courses. */ function block_course_overview_get_sorted_courses() { global $USER; $limit = block_course_overview_get_max_user_courses(); $courses = enrol_get_my_courses(); $site = get_site(); if (array_key_exists($site->id,$courses)) { unset($courses[$site->id]); } foreach ($courses as $c) { if (isset($USER->lastcourseaccess[$c->id])) { $courses[$c->id]->lastaccess = $USER->lastcourseaccess[$c->id]; } else { $courses[$c->id]->lastaccess = 0; } } // Get remote courses. $remotecourses = array(); if (is_enabled_auth('mnet')) { $remotecourses = get_my_remotecourses(); } // Remote courses will have -ve remoteid as key, so it can be differentiated from normal courses foreach ($remotecourses as $id => $val) { $remoteid = $val->remoteid * -1; $val->id = $remoteid; $courses[$remoteid] = $val; } $order = array(); if (!is_null($usersortorder = get_user_preferences('course_overview_course_order'))) { $order = unserialize($usersortorder); } $sortedcourses = array(); $counter = 0; // Get courses in sort order into list. foreach ($order as $key => $cid) { if (($counter >= $limit) && ($limit != 0)) { break; } // Make sure user is still enroled. if (isset($courses[$cid])) { $sortedcourses[$cid] = $courses[$cid]; $counter++; } } // Append unsorted courses if limit allows foreach ($courses as $c) { if (($limit != 0) && ($counter >= $limit)) { break; } if (!in_array($c->id, $order)) { $sortedcourses[$c->id] = $c; $counter++; } } // From list extract site courses for overview $sitecourses = array(); foreach ($sortedcourses as $key => $course) { if ($course->id > 0) { $sitecourses[$key] = $course; } } return array($sortedcourses, $sitecourses, count($courses)); }