123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268 |
- <?php
- /**
- * This file is part of course block plugin for dashboard,
- * it should be required inside dashboard controller for showing it into dashboard interface from plattform
- * @package chamilo.dashboard
- * @author Marco Sousa original code
- * @author Julio Montoya class named was changed of name, and some minor changes
- */
- /**
- * required files for getting data
- */
- require_once api_get_path(LIBRARY_PATH) . 'attendance.lib.php';
- require_once api_get_path(SYS_CODE_PATH) . 'gradebook/lib/be.inc.php';
- /**
- * This class is used like controller for this course block plugin,
- * the class name must be registered inside path.info file (e.g: controller = "BlockDiario"), so dashboard controller will be instantiate it
- * @package chamilo.dashboard
- */
- class BlockDaily extends Block
- {
- private $user_id;
- private $courses;
- private $path;
- private $permission = array(DRH);
- /**
- * Constructor
- */
- public function __construct($user_id)
- {
- $this->user_id = $user_id;
- $this->path = 'block_daily';
- if ($this->is_block_visible_for_user($user_id)) {
- $this->courses = CourseManager::get_courses_followed_by_drh(
- $user_id
- );
- }
- }
- /**
- * This method check if a user is allowed to see the block inside dashboard interface
- * @param int User id
- * @return bool Is block visible for user
- */
- public function is_block_visible_for_user($user_id)
- {
- $user_info = api_get_user_info($user_id);
- $user_status = $user_info['status'];
- $is_block_visible_for_user = false;
- if (UserManager::is_admin($user_id) || in_array(
- $user_status,
- $this->permission
- )
- ) {
- $is_block_visible_for_user = true;
- }
- return $is_block_visible_for_user;
- }
- /**
- * This method return content html containing information about courses and its position for showing it inside dashboard interface
- * it's important to use the name 'get_block' for beeing used from dashboard controller
- * @return array column and content html
- */
- public function get_block()
- {
- global $charset;
- $column = 2;
- $data = array();
- $content = $this->get_content_html();
- $html = '<li class="widget color-green" id="intro">
- <div class="widget-head">
- <h3>' . get_lang('GradebookAndAttendances') . '</h3>
- <div class="widget-actions"><a onclick="javascript:if(!confirm(\'' . addslashes(
- api_htmlentities(
- get_lang('ConfirmYourChoice'),
- ENT_QUOTES,
- $charset
- )
- ) . '\')) return false;" href="index.php?action=disable_block&path=' . $this->path . '">' . Display::return_icon(
- 'close.gif',
- get_lang('Close')
- ) . '</a></div>
- </div>
- <div class="widget-content">
- ' . $content . '
- </div>
- </li>
- ';
- $data['column'] = $column;
- $data['content_html'] = $html;
- return $data;
- }
- /**
- * This method return a content html, it's used inside get_block method for showing it inside dashboard interface
- * @return string content html
- */
- public function get_content_html()
- {
- $course_data = $this->get_course_information_data();
- $content = '<div style="margin:10px;">';
- $content .= '<h3><font color="#000">' . get_lang(
- 'YourCourseList'
- ) . '</font></h3>';
- $data_table = null;
- if (!empty($course_data)) {
- $data_table .= '<table class="data_table" width:"95%">';
- $data_table .= '<tr>
- <th>' . get_lang('CourseTitle') . '</th>
- <th width="20%">' . get_lang('NbStudents') . '</th>
- <th width="20%">' . get_lang('Evaluation') . '</th>
- <th width="20%">' . get_lang('ToolAttendance') . '</th>
- </tr>';
- $i = 1;
- foreach ($course_data as $course) {
- if ($i % 2 == 0) {
- $class_tr = 'row_odd';
- } else {
- $class_tr = 'row_even';
- }
- $data_table .= '<tr class="' . $class_tr . '">';
- if (!isset($course[3])) {
- $course[3] = get_lang('NotAvailable');
- }
- foreach ($course as $cell) {
- $data_table .= '<td align="right">' . $cell . '</td>';
- }
- $data_table .= '</tr>';
- $i++;
- }
- $data_table .= '</table>';
- } else {
- $data_table .= get_lang('ThereIsNoInformationAboutYourCourses');
- }
- $content .= $data_table;
- if (!empty($course_data)) {
- $content .= '<div style="text-align:right;margin-top:10px;">
- <a href="' . api_get_path(WEB_CODE_PATH) . 'mySpace/course.php">' . get_lang('SeeMore') . '</a></div>';
- }
- $content .= '</div>';
- return $content;
- }
- /**
- * Get number of courses
- * @return int
- */
- function get_number_of_courses()
- {
- return count($this->courses);
- }
- /**
- * Get course information data
- * @return array
- */
- function get_course_information_data()
- {
- $tbl_course_user = Database::get_main_table(TABLE_MAIN_COURSE_USER);
- $course_data = array();
- $courses = $this->courses;
- foreach ($courses as $row_course) {
- $score = null;
- $course_code = $row_course['code'];
- $course_info = api_get_course_info($course_code);
- if (empty($course_info)) {
- continue;
- }
- // Attendance table
- $table_course = Database::get_course_table(TABLE_ATTENDANCE);
- $sql = "SELECT id, name, attendance_qualify_max FROM $table_course
- WHERE c_id = " . $course_info['real_id'] . " AND active = 1 AND session_id = 0";
- $rs = Database::query($sql);
- $attendance = array();
- $attendances = array();
- $param_gradebook = '';
- if (isset($_SESSION['gradebook'])) {
- $param_gradebook = '&gradebook=' . $_SESSION['gradebook'];
- }
- while ($row = Database::fetch_array($rs, 'ASSOC')) {
- $attendance['done'] = $row['attendance_qualify_max'];
- $attendance['id'] = $row['id'];
- //$attendance['name'] = $row['name'];
- $attendance['course_code'] = $course_code;
- if ($attendance['done'] != '0') {
- $attendances[] = '<a href="' . api_get_path(WEB_PATH).'main/attendance/index.php?cidReq=' . $attendance['course_code'] . '&action=attendance_sheet_print&attendance_id=' . $attendance['id'] . $param_gradebook . '">' . Display::return_icon('printmgr.gif', get_lang('Print')).'</a>';
- } else {
- $attendances[] = get_lang("NotAvailable");
- }
- }
- // quantidade de alunos
- $sql = "SELECT user_id FROM $tbl_course_user as course_rel_user
- WHERE course_rel_user.status=" . STUDENT . " AND course_rel_user.course_code='$course_code'";
- $rs = Database::query($sql);
- $users = array();
- while ($row = Database::fetch_array($rs)) {
- $users[] = $row['user_id'];
- }
- if (count($users) > 0) {
- $nb_students_in_course = count($users);
- }
- if (!empty($tematic_advance)) {
- $tematic_advance_progress = '<a title="' . get_lang(
- 'GoToThematicAdvance'
- ) . '" href="' . api_get_path(
- WEB_CODE_PATH
- ) . 'attendance/index.php?cidReq=' . $course_code . '&action=attendance_sheet_print&attendance_id=">' . $tematic_advance . '%</a>';
- } else {
- $tematic_advance_progress = '0%';
- }
- // Score
- $tbl_grade_categories = Database :: get_main_table(
- TABLE_MAIN_GRADEBOOK_CATEGORY
- );
- $sql = "SELECT id from " . $tbl_grade_categories . "
- WHERE course_code ='" . $course_code . "'";
- $rs = Database::query($sql);
- $category = null;
- while ($row = Database::fetch_array($rs)) {
- $category = $row['id'];
- }
- if (!empty($category)) {
- $cat = Category::load($category);
- $eval = $cat[0]->get_evaluations();
- if (count($eval) > 0) {
- $i = 0;
- foreach ($eval as $item) {
- $score .= '<a href="' . api_get_path(WEB_PATH).'main/gradebook/gradebook_view_result.php?export=pdf&cat_code=' . $cat[0]->get_id() . '&official_code=' . $cat[0]->get_course_code() . '&selecteval=' . $item->get_id().$param_gradebook . '">' . $item->get_name() . '</a>';
- if (count($eval) - 1 != $i) {
- $score .= ', ';
- }
- $i++;
- }
- } else {
- $score = get_lang("NotAvailable");
- }
- } else {
- $score = get_lang("NotAvailable");
- }
- $table_row = array();
- $table_row[] = $row_course['title'];
- $table_row[] = $nb_students_in_course;
- $table_row[] = $score;
- $table_row[] = $attendances[0];
- $course_data[] = $table_row;
- }
- return $course_data;
- }
- }
|