-
Notifications
You must be signed in to change notification settings - Fork 1
/
view.php
85 lines (72 loc) · 2.88 KB
/
view.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<?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/>.
/**
* My students block.
*
* @package block_mystudents
* @copyright 2018 Namur University
* @author Laurence Dumortier <laurence.dumortier@unamur.be>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once("../../config.php");
require_once($CFG->dirroot.'/user/lib.php');
require_once('./locallib.php');
require_login();
$PAGE->set_url(new moodle_url('/blocks/mystudents/view.php'));
$context = context_system::instance();
$PAGE->set_context($context);
$PAGE->set_pagelayout('admin');
$PAGE->set_heading(get_string('mystudents', 'block_mystudents'));
$PAGE->set_title(get_string('mystudents', 'block_mystudents'));
echo $OUTPUT->header();
echo $OUTPUT->box_start();
$content = '';
// Get course list.
$mycourses = enrol_get_my_courses(null, 'fullname ASC');
$students = array();
foreach ($mycourses as $course) {
$courseid = $course->id;
if (is_allowed_to_display_students($courseid)) {
// For each course get all the users.
list ($select, $from, $where, $params) = user_get_participants_sql($courseid, 0, 0, 5);
$list = $DB->get_recordset_sql("$select $from $where", $params);
foreach ($list as $student) {
$key = str_replace('', '_', $student->lastname) . '_' . str_replace('', '_', $student->firstname);
if (!array_key_exists($key, $students)) {
$students[$key] = array('lastname' => $student->lastname, 'firstname' => $student->firstname,
'email' => $student->email, 'userid' => $student->id, 'courses' => array());
}
$students[$key]['courses'][] = $course->shortname;
}
}
}
ksort($students);
$table = new html_table();
$table->head = array(get_string('lastname'), get_string('firstname'), get_string('email'), get_string('courses'));
foreach ($students as $student => $info) {
$courses = $info['courses'];
$row = new html_table_row();
$row->cells[] = $info['lastname'];
$row->cells[] = $info['firstname'];
$row->cells[] = $info['email'];
$row->cells[] = implode(', ', $courses);
$table->data[] = $row;
}
$content .= html_writer::table($table);
echo $content;
echo $OUTPUT->box_end();
// Finish the page.
echo $OUTPUT->footer();