You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
119 lines
4.0 KiB
119 lines
4.0 KiB
<?php
|
|
|
|
/* For licensing terms, see /license.txt */
|
|
|
|
/**
|
|
* Special reporting page for admins.
|
|
*/
|
|
ob_start();
|
|
$cidReset = true;
|
|
|
|
require_once __DIR__.'/../inc/global.inc.php';
|
|
|
|
$this_section = SECTION_TRACKING;
|
|
$nameTools = get_lang('Administrators');
|
|
|
|
api_block_anonymous_users();
|
|
$interbreadcrumb[] = ["url" => "index.php", "name" => get_lang('Reporting')];
|
|
Display::display_header($nameTools);
|
|
$data = [];
|
|
api_display_tool_title($nameTools);
|
|
|
|
// Database Table Definitions
|
|
$tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
|
|
$tbl_user = Database::get_main_table(TABLE_MAIN_USER);
|
|
$tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
|
|
$tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
|
|
$tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
|
|
$tbl_admin = Database::get_main_table(TABLE_MAIN_ADMIN);
|
|
|
|
if (isset($_POST['export'])) {
|
|
$order_clause = api_is_western_name_order(PERSON_NAME_DATA_EXPORT) ? ' ORDER BY firstname, lastname' : ' ORDER BY lastname, firstname';
|
|
} else {
|
|
$order_clause = api_sort_by_first_name() ? ' ORDER BY firstname, lastname' : ' ORDER BY lastname, firstname';
|
|
}
|
|
$sql = "SELECT user.id as user_id,lastname,firstname,email
|
|
FROM $tbl_user as user, $tbl_admin as admin
|
|
WHERE admin.user_id=user.id".$order_clause;
|
|
$result_admins = Database::query($sql);
|
|
|
|
if (api_is_western_name_order()) {
|
|
echo '<table class="table table-hover table-striped data_table">
|
|
<tr>
|
|
<th>'.get_lang('FirstName').'</th>
|
|
<th>'.get_lang('LastName').'</th>
|
|
<th>'.get_lang('Email').'</th></tr>';
|
|
} else {
|
|
echo '<table class="table table-hover table-striped data_table">
|
|
<tr>
|
|
<th>'.get_lang('LastName').'</th>
|
|
<th>'.get_lang('FirstName').'</th>
|
|
<th>'.get_lang('Email').'</th></tr>';
|
|
}
|
|
|
|
if (api_is_western_name_order(PERSON_NAME_DATA_EXPORT)) {
|
|
$header[] = get_lang('First name');
|
|
$header[] = get_lang('Last name');
|
|
} else {
|
|
$header[] = get_lang('Last name');
|
|
$header[] = get_lang('First name');
|
|
}
|
|
$header[] = get_lang('e-mail');
|
|
|
|
if (Database::num_rows($result_admins) > 0) {
|
|
while ($admins = Database::fetch_array($result_admins)) {
|
|
$user_id = $admins["user_id"];
|
|
$lastname = $admins["lastname"];
|
|
$firstname = $admins["firstname"];
|
|
$email = $admins["email"];
|
|
|
|
if (0 == $i % 2) {
|
|
$css_class = "row_odd";
|
|
if (0 == $i % 20 && 0 != $i) {
|
|
if (api_is_western_name_order()) {
|
|
echo '<tr><th>'.get_lang('First name').'</th><th>'.get_lang('Last name').'</th><th>'.get_lang('e-mail').'</th></tr>';
|
|
} else {
|
|
echo '<tr><th>'.get_lang('Last name').'</th><th>'.get_lang('First name').'</th><th>'.get_lang('e-mail').'</th></tr>';
|
|
}
|
|
}
|
|
} else {
|
|
$css_class = "row_even";
|
|
}
|
|
|
|
$i++;
|
|
|
|
if (api_is_western_name_order()) {
|
|
echo "<tr class=".$css_class."><td>$firstname</td><td>$lastname</td><td><a href='mailto:".$email."'>$email</a></td></tr>";
|
|
} else {
|
|
echo "<tr class=".$css_class."><td>$lastname</td><td>$firstname</td><td><a href='mailto:".$email."'>$email</a></td></tr>";
|
|
}
|
|
|
|
if (api_is_western_name_order(PERSON_NAME_DATA_EXPORT)) {
|
|
$data[$user_id]["firstname"] = $firstname;
|
|
$data[$user_id]["lastname"] = $lastname;
|
|
} else {
|
|
$data[$user_id]["lastname"] = $lastname;
|
|
$data[$user_id]["firstname"] = $firstname;
|
|
}
|
|
$data[$user_id]["email"] = $email;
|
|
}
|
|
} else {
|
|
// No results
|
|
echo '<tr><td colspan="3">'.get_lang('No results found').'</td></tr>';
|
|
}
|
|
echo '</table>';
|
|
|
|
if (isset($_POST['export'])) {
|
|
Export::arrayToCsv($header + $data, 'administrators.csv');
|
|
}
|
|
|
|
echo "
|
|
<br /><br />
|
|
<form method='post' action='admin.php'>
|
|
<button type='submit' class='save' name='export' value='".get_lang('Excel export')."'>
|
|
".get_lang('Excel export')."
|
|
</button>
|
|
<form>
|
|
";
|
|
|
|
Display::display_footer();
|
|
|