3 require_once('../../config.php');
4 require_once('lib.php');
6 $concept = optional_param('concept', '', PARAM_CLEAN
);
7 $courseid = optional_param('courseid', 0, PARAM_INT
);
8 $eid = optional_param('eid', 0, PARAM_INT
); // glossary entry id
9 $displayformat = optional_param('displayformat',-1, PARAM_SAFEDIR
);
11 $url = new moodle_url('/mod/glossary/showentry.php');
12 $url->param('concept', $concept);
13 $url->param('courseid', $courseid);
14 $url->param('eid', $eid);
15 $url->param('displayformat', $displayformat);
18 if ($CFG->forcelogin
) {
23 $entry = $DB->get_record('glossary_entries', array('id'=>$eid), '*', MUST_EXIST
);
24 $glossary = $DB->get_record('glossary', array('id'=>$entry->glossaryid
), '*', MUST_EXIST
);
25 $cm = get_coursemodule_from_instance('glossary', $glossary->id
, 0, false, MUST_EXIST
);
26 $course = $DB->get_record('course', array('id'=>$cm->course
), '*', MUST_EXIST
);
27 require_course_login($course, true, $cm);
28 $entry->glossaryname
= $glossary->name
;
29 $entry->cmid
= $cm->id
;
30 $entry->courseid
= $cm->course
;
31 $entries = array($entry);
33 } else if ($concept) {
34 $course = $DB->get_record('course', array('id'=>$courseid), '*', MUST_EXIST
);
35 require_course_login($course);
36 $entries = glossary_get_entries_search($concept, $courseid);
39 throw new \
moodle_exception('invalidelementid');
42 $PAGE->set_pagelayout('incourse');
43 $PAGE->activityheader
->disable();
46 foreach ($entries as $key => $entry) {
47 // Need to get the course where the entry is,
48 // in order to check for visibility/approve permissions there
49 $entrycourse = $DB->get_record('course', array('id' => $entry->courseid
), '*', MUST_EXIST
);
50 $modinfo = get_fast_modinfo($entrycourse);
51 // make sure the entry is visible
52 if (empty($modinfo->cms
[$entry->cmid
]->uservisible
)) {
53 unset($entries[$key]);
56 // make sure the entry is approved (or approvable by current user)
57 if (!$entry->approved
and ($USER->id
!= $entry->userid
)) {
58 $context = context_module
::instance($entry->cmid
);
59 if (!has_capability('mod/glossary:approve', $context)) {
60 unset($entries[$key]);
64 $entries[$key]->footer
= "<p style=\"text-align:right\">» <a href=\"$CFG->wwwroot/mod/glossary/view.php?g=$entry->glossaryid\">".format_string($entry->glossaryname
,true)."</a></p>";
65 glossary_entry_view($entry, $modinfo->cms
[$entry->cmid
]->context
);
69 if (!empty($courseid)) {
70 $strglossaries = get_string('modulenameplural', 'glossary');
71 $strsearch = get_string('search');
73 $PAGE->navbar
->add($strglossaries);
74 $PAGE->navbar
->add($strsearch);
75 $PAGE->set_title(strip_tags("$course->shortname: $strglossaries $strsearch"));
76 $PAGE->set_heading($course->fullname
);
77 echo $OUTPUT->header();
79 echo $OUTPUT->header(); // Needs to be something here to allow linking back to the whole glossary
83 $url = new moodle_url('view.php', ['id' => $cm->id
]);
84 $backlink = html_writer
::link($url, get_string('back'), ['class' => 'btn btn-secondary']);
85 echo html_writer
::tag('div', $backlink, ['class' => 'tertiary-navigation']);
89 glossary_print_dynaentry($courseid, $entries, $displayformat);
92 /// Show one reduced footer
93 echo $OUTPUT->footer();