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.
248 lines
8.9 KiB
248 lines
8.9 KiB
<?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).'course.lib.php';
|
|
require_once api_get_path(LIBRARY_PATH).'usermanager.lib.php';
|
|
require_once api_get_path(LIBRARY_PATH).'tracking.lib.php';
|
|
require_once api_get_path(LIBRARY_PATH).'thematic.lib.php';
|
|
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_course';
|
|
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>';
|
|
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, $course_info['db_name']);
|
|
|
|
$sql = "SELECT id, name, attendance_qualify_max FROM $table_course WHERE 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;
|
|
}
|
|
} |