Skip to content

Commit

Permalink
MDL-33774 filter_activitynames removed hardcoded label module type
Browse files Browse the repository at this point in the history
  • Loading branch information
marinaglancy committed Feb 14, 2013
1 parent 9ecb50e commit 173115e
Showing 1 changed file with 11 additions and 23 deletions.
34 changes: 11 additions & 23 deletions filter/activitynames/filter.php
Expand Up @@ -36,8 +36,6 @@ class filter_activitynames extends moodle_text_filter {
static $cachedcourseid; static $cachedcourseid;


function filter($text, array $options = array()) { function filter($text, array $options = array()) {
global $CFG, $COURSE, $DB;

if (!$courseid = get_courseid_from_context($this->context)) { if (!$courseid = get_courseid_from_context($this->context)) {
return $text; return $text;
} }
Expand All @@ -53,35 +51,25 @@ function filter($text, array $options = array()) {
if (is_null(self::$activitylist)) { if (is_null(self::$activitylist)) {
self::$activitylist = array(); self::$activitylist = array();


if ($COURSE->id == $courseid) { $modinfo = get_fast_modinfo($courseid);
$course = $COURSE; if (!empty($modinfo->cms)) {
} else {
$course = $DB->get_record("course", array("id"=>$courseid));
}

if (!isset($course->modinfo)) {
return $text;
}

/// Casting $course->modinfo to string prevents one notice when the field is null
$modinfo = unserialize((string)$course->modinfo);

if (!empty($modinfo)) {

self::$activitylist = array(); /// We will store all the activities here self::$activitylist = array(); /// We will store all the activities here


//Sort modinfo by name length //Sort modinfo by name length
usort($modinfo, 'filter_activitynames_comparemodulenamesbylength'); $sortedactivities = fullclone($modinfo->cms);
usort($sortedactivities, 'filter_activitynames_comparemodulenamesbylength');


foreach ($modinfo as $activity) { foreach ($sortedactivities as $cm) {
//Exclude labels, hidden activities and activities for group members only //Exclude labels, hidden activities and activities for group members only
if ($activity->mod != "label" and $activity->visible and empty($activity->groupmembersonly)) { if ($cm->visible and empty($cm->groupmembersonly) and $cm->has_view()) {
$title = s(trim(strip_tags($activity->name))); $title = s(trim(strip_tags($cm->name)));
$currentname = trim($activity->name); $currentname = trim($cm->name);
$entitisedname = s($currentname); $entitisedname = s($currentname);
/// Avoid empty or unlinkable activity names /// Avoid empty or unlinkable activity names
if (!empty($title)) { if (!empty($title)) {
$href_tag_begin = "<a class=\"autolink\" title=\"$title\" href=\"$CFG->wwwroot/mod/$activity->mod/view.php?id=$activity->cm\">"; $href_tag_begin = html_writer::start_tag('a',
array('class' => 'autolink', 'title' => $title,
'href' => $cm->get_url()));
self::$activitylist[] = new filterobject($currentname, $href_tag_begin, '</a>', false, true); self::$activitylist[] = new filterobject($currentname, $href_tag_begin, '</a>', false, true);
if ($currentname != $entitisedname) { /// If name has some entity (&amp; &quot; &lt; &gt;) add that filter too. MDL-17545 if ($currentname != $entitisedname) { /// If name has some entity (&amp; &quot; &lt; &gt;) add that filter too. MDL-17545
self::$activitylist[] = new filterobject($entitisedname, $href_tag_begin, '</a>', false, true); self::$activitylist[] = new filterobject($entitisedname, $href_tag_begin, '</a>', false, true);
Expand Down

0 comments on commit 173115e

Please sign in to comment.