chamilo/chamilo-lms

View on GitHub
public/main/my_space/admin.php

Summary

Maintainability
A
0 mins
Test Coverage
<?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 = [];
Display::page_subheader2($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();