123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- <?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(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)) {
- /*if (api_is_platform_admin()) {
- $this->courses = CourseManager::get_real_course_list();
- } else {*/
- $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 = '';
- $data_table = '';
- $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 = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_course_user = Database::get_main_table(TABLE_MAIN_COURSE_USER);
- $a_course_students = array();
- $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");
- }
- $sql = "SELECT user_id FROM $tbl_course_user as course_rel_user
- WHERE course_rel_user.status=".STUDENT." AND course_rel_user.c_id = ".$course_info['real_id'];
- $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;
- }
- }
|