@ -10,22 +10,28 @@ require_once '../global.inc.php';
$libpath = api_get_path(LIBRARY_PATH);
// 1. Setting variables needed by jqgrid
$action = $_GET['a'];
$page = intval($_REQUEST['page']); //page
$limit = intval($_REQUEST['rows']); //quantity of rows
$sidx = $_REQUEST['sidx']; //index (field) to filter
$sidx = $_REQUEST['sidx']; //index (field) to filter
$sord = $_REQUEST['sord']; //asc or desc
if (!in_array($sord, array('asc','desc'))) {
$sord = 'desc';
if (strpos(strtolower($sidx), 'asc') !== false) {
$sidx = str_replace(array('asc', ','), '', $sidx);
$sord = 'asc';
}
if (strpos(strtolower($sidx), 'desc') !== false) {
$sidx = str_replace(array('desc', ','), '', $sidx);
$sord = 'desc';
}
if (!in_array($action, array(
'get_exercise_results',
'get_hotpotatoes_exercise_results',
'get_work_user_list',
'get_timelines',
'get_exercise_results',
'get_hotpotatoes_exercise_results',
'get_work_user_list',
'get_timelines',
'get_user_skill_ranking',
'get_usergroups_teacher'))
) {
@ -57,7 +63,7 @@ function get_where_clause($col, $oper, $val) {
global $ops;
if (empty($col)){
return '';
}
}
if($oper == 'bw' || $oper == 'bn') $val .= '%';
if($oper == 'ew' || $oper == 'en' ) $val = '%'.$val;
if($oper == 'cn' || $oper == 'nc' || $oper == 'in' || $oper == 'ni') $val = '%'.$val.'%';
@ -74,32 +80,32 @@ $search_string = isset($_REQUEST['searchString']) ? $_REQUEST['searchString']
if ($_REQUEST['_search'] == 'true') {
$where_condition = ' 1 = 1 ';
$where_condition_in_form = get_where_clause($search_field, $search_oper, $search_string);
if (!empty($where_condition_in_form)) {
$where_condition .= ' AND '.$where_condition_in_form;
}
$filters = isset($_REQUEST['filters']) ? json_decode($_REQUEST['filters']) : false;
if (!empty($filters)) {
$where_condition .= ' AND ( ';
$counter = 0;
foreach ($filters->rules as $key=>$rule) {
$where_condition .= get_where_clause($rule->field,$rule->op, $rule->data);
if ($counter < count ( $ filters- > rules) -1) {
if ($counter < count ( $ filters- > rules) -1) {
$where_condition .= $filters->groupOp;
}
$counter++;
}
$where_condition .= ' ) ';
}
}
}
//var_dump($where_condition);
// get index row - i.e. user click to sort $sord = $_GET['sord'];
// get the direction
// get index row - i.e. user click to sort $sord = $_GET['sord'];
// get the direction
if (!$sidx) $sidx = 1;
//2. Selecting the count FIRST
//@todo rework this
@ -111,28 +117,28 @@ switch ($action) {
case 'get_work_user_list':
require_once api_get_path(SYS_CODE_PATH).'work/work.lib.php';
$work_id = $_REQUEST['work_id'];
$count = get_count_work($work_id);
$count = get_count_work($work_id);
break;
case 'get_exercise_results':
require_once api_get_path(SYS_CODE_PATH).'exercice/exercise.lib.php';
require_once api_get_path(SYS_CODE_PATH).'exercice/exercise.lib.php';
$exercise_id = $_REQUEST['exerciseId'];
if (isset($_GET['filter_by_user']) & & !empty($_GET['filter_by_user'])) {
if (isset($_GET['filter_by_user']) & & !empty($_GET['filter_by_user'])) {
$filter_user = intval($_GET['filter_by_user']);
if ($where_condition == "") {
$where_condition .= " te.exe_user_id = '$filter_user'" ;
} else {
$where_condition .= " AND te.exe_user_id = '$filter_user'";
}
}
$count = get_count_exam_results($exercise_id, $where_condition);
}
$count = get_count_exam_results($exercise_id, $where_condition);
break;
case 'get_hotpotatoes_exercise_results':
require_once api_get_path(SYS_CODE_PATH).'exercice/exercise.lib.php';
require_once api_get_path(SYS_CODE_PATH).'exercice/exercise.lib.php';
$hotpot_path = $_REQUEST['path'];
$count = get_count_exam_hotpotatoes_results($hotpot_path);
$count = get_count_exam_hotpotatoes_results($hotpot_path);
break;
case 'get_sessions':
case 'get_sessions':
$count = SessionManager::get_count_admin();
break;
case 'get_timelines':
@ -147,15 +153,15 @@ switch ($action) {
break;
case 'get_event_email_template':
$obj = new EventEmailTemplate();
$count = $obj->get_count();
$count = $obj->get_count();
break;
case 'get_careers':
$obj = new Career();
$count = $obj->get_count();
break;
case 'get_promotions':
case 'get_promotions':
$obj = new Promotion();
$count = $obj->get_count();
$count = $obj->get_count();
break;
case 'get_grade_models':
$obj = new GradeModel();
@ -169,34 +175,34 @@ switch ($action) {
$obj = new UserGroup();
$type = isset($_REQUEST['type']) ? $_REQUEST['type'] : 'registered';
$course_id = api_get_course_int_id();
if ($type == 'registered') {
if ($type == 'registered') {
$count = $obj->get_usergroup_by_course_with_data_count($course_id);
} else {
$count = $obj->get_count();
$count = $obj->get_count();
}
break;
default:
exit;
exit;
}
//3. Calculating first, end, etc
//3. Calculating first, end, etc
$total_pages = 0;
if ($count > 0) {
if ($count > 0) {
if (!empty($limit)) {
$total_pages = ceil($count/$limit);
}
}
if ($page > $total_pages) {
if ($page > $total_pages) {
$page = $total_pages;
}
}
$start = $limit * $page - $limit;
if ($start < 0 ) {
$start = 0;
}
}
//4. Deleting an element if the user wants to
if ($_REQUEST['oper'] == 'del') {
if (isset($_REQUEST['oper']) & & $_REQUEST['oper'] == 'del') {
$obj->delete($_REQUEST['id']);
}
@ -205,13 +211,13 @@ $is_allowedToEdit = api_is_allowed_to_edit(null,true) || api_is_allowed_to_edit(
//5. Querying the DB for the elements
$columns = array();
switch ($action) {
case 'get_user_skill_ranking':
switch ($action) {
case 'get_user_skill_ranking':
$columns = array('photo', 'firstname', 'lastname', 'skills_acquired', 'currently_learning', 'rank');
$result = $skill->get_user_list_skill_ranking($start, $limit, $sidx, $sord, $where_condition);
$result = msort($result, 'skills_acquired', 'asc');
$skills_in_course = array();
$skills_in_course = array();
if (!empty($result)) {
//$counter = 1;
foreach ($result as & $item) {
@ -219,52 +225,52 @@ switch ($action) {
$personal_course_list = UserManager::get_personal_session_course_list($item['user_id']);
$count_skill_by_course = array();
foreach ($personal_course_list as $course_item) {
if (!isset($skills_in_course[$course_item['code']])) {
if (!isset($skills_in_course[$course_item['code']])) {
$count_skill_by_course[$course_item['code']] = $skill->get_count_skills_by_course($course_item['code']);
$skills_in_course[$course_item['code']] = $count_skill_by_course[$course_item['code']];
$skills_in_course[$course_item['code']] = $count_skill_by_course[$course_item['code']];
} else {
$count_skill_by_course[$course_item['code']] = $skills_in_course[$course_item['code']];
}
}
}
$item['photo'] = Display::img($user_info['avatar_small']);
$item['currently_learning'] = !empty($count_skill_by_course) ? array_sum($count_skill_by_course) : 0;
$item['currently_learning'] = !empty($count_skill_by_course) ? array_sum($count_skill_by_course) : 0;
}
}
break;
case 'get_work_user_list':
case 'get_work_user_list':
if (isset($_GET['type']) & & $_GET['type'] == 'simple') {
$columns = array('type', 'firstname', 'lastname', 'username', 'title', 'qualification', 'sent_date', 'qualificator_id', 'actions');
} else {
$columns = array('type', 'firstname', 'lastname', 'username', 'title', 'sent_date', 'actions');
$columns = array('type', 'firstname', 'lastname', 'username', 'title', 'sent_date', 'actions');
}
$result = get_work_user_list($start, $limit, $sidx, $sord, $work_id, $where_condition);
$result = get_work_user_list($start, $limit, $sidx, $sord, $work_id, $where_condition);
break;
case 'get_exercise_results':
$course = api_get_course_info();
$course = api_get_course_info();
//used inside get_exam_results_data()
$documentPath = api_get_path(SYS_COURSE_PATH) . $course['path'] . "/document";
$documentPath = api_get_path(SYS_COURSE_PATH) . $course['path'] . "/document";
if ($is_allowedToEdit) {
$columns = array('firstname', 'lastname', 'username', 'group_name', 'exe_duration', 'start_date', 'exe_date', 'score', 'status', 'lp', 'actions');
} else {
//$columns = array('exe_duration', 'start_date', 'exe_date', 'score', 'status', 'actions');
}
$result = get_exam_results_data($start, $limit, $sidx, $sord, $exercise_id, $where_condition);
}
$result = get_exam_results_data($start, $limit, $sidx, $sord, $exercise_id, $where_condition);
break;
case 'get_hotpotatoes_exercise_results':
$course = api_get_course_info();
$course = api_get_course_info();
//used inside get_exam_results_data()
$documentPath = api_get_path(SYS_COURSE_PATH) . $course['path'] . "/document";
$documentPath = api_get_path(SYS_COURSE_PATH) . $course['path'] . "/document";
$columns = array('firstname', 'lastname', 'username', 'group_name', 'exe_date', 'score', 'actions');
$result = get_exam_results_hotpotatoes_data($start, $limit, $sidx, $sord, $hotpot_path, $where_condition); //get_exam_results_data($start, $limit, $sidx, $sord, $exercise_id, $where_condition);
$result = get_exam_results_hotpotatoes_data($start, $limit, $sidx, $sord, $hotpot_path, $where_condition); //get_exam_results_data($start, $limit, $sidx, $sord, $exercise_id, $where_condition);
break;
case 'get_sessions':
$columns = array('name', 'nbr_courses', 'nbr_users', 'category_name', 'date_start','date_end', 'coach_name', 'session_active', 'visibility');
$result = SessionManager::get_sessions_admin(array('where'=> $where_condition, 'order'=>"$sidx $sord", 'limit'=> "$start , $limit"));
break;
case 'get_timelines':
$columns = array('headline', 'actions');
$columns = array('name', 'nbr_courses', 'nbr_users', 'category_name', 'date_start','date_end', 'coach_name', 'session_active', 'visibility');
$result = SessionManager::get_sessions_admin(array('where'=> $where_condition, 'order'=>"$sidx $sord", 'limit'=> "$start , $limit"));
break;
case 'get_timelines':
$columns = array('headline', 'actions');
//$columns = array('headline', 'type', 'start_date', 'end_date', 'text', 'media', 'media_credit', 'media_caption', 'title_slide', 'parent_id');
if(!in_array($sidx, $columns)) {
$sidx = 'headline';
}
@ -273,19 +279,19 @@ switch ($action) {
$new_result = array();
foreach ($result as $item) {
if (!$item['status']) {
$item['name'] = '< font style = "color:#AAA" > '.$item['name'].'< / font > ';
$item['name'] = '< font style = "color:#AAA" > '.$item['name'].'< / font > ';
}
$item['headline'] = Display::url($item['headline'], api_get_path(WEB_CODE_PATH).'timeline/view.php?id='.$item['id']);
$item['actions'] = Display::url(Display::return_icon('add.png', get_lang('AddItems')), api_get_path(WEB_CODE_PATH).'timeline/?action=add_item&parent_id='.$item['id']);
$item['actions'] .= Display::url(Display::return_icon('edit.png', get_lang('Edit')), api_get_path(WEB_CODE_PATH).'timeline/?action=edit&id='.$item['id']);
$item['actions'] .= Display::url(Display::return_icon('delete.png', get_lang('Delete')), api_get_path(WEB_CODE_PATH).'timeline/?action=delete&id='.$item['id']);
$new_result[] = $item;
}
$result = $new_result;
}
$result = $new_result;
break;
case 'get_gradebooks':
$columns = array('name', 'certificates','skills', 'actions', 'has_certificates');
case 'get_gradebooks':
$columns = array('name', 'certificates','skills', 'actions', 'has_certificates');
if (!in_array($sidx, $columns)) {
$sidx = 'name';
}
@ -296,54 +302,54 @@ switch ($action) {
continue;
}
$skills = $obj->get_skills_by_gradebook($item['id']);
//Fixes bug when gradebook doesn't have names
if (empty($item['name'])) {
$item['name'] = $item['course_code'];
$item['name'] = $item['course_code'];
} else {
//$item['name'] = $item['name'].' ['.$item['course_code'].']';
}
$item['name'] = Display::url($item['name'], api_get_path(WEB_CODE_PATH).'gradebook/index.php?id_session=0&cidReq='.$item['course_code']);
if (!empty($item['certif_min_score']) & & !empty($item['document_id'])) {
$item['certificates'] = Display::return_icon('accept.png', get_lang('WithCertificate'), array(), ICON_SIZE_SMALL);
$item['has_certificates'] = '1';
$item['has_certificates'] = '1';
} else {
$item['certificates'] = Display::return_icon('warning.png', get_lang('NoCertificate'), array(), ICON_SIZE_SMALL);
$item['has_certificates'] = '0';
}
}
if (!empty($skills)) {
foreach($skills as $skill) {
$item['skills'] .= Display::span($skill['name'], array('class' => 'label_tag skill'));
$item['skills'] .= Display::span($skill['name'], array('class' => 'label_tag skill'));
}
}
$new_result[] = $item;
}
}
$result = $new_result;
break;
case 'get_event_email_template':
$columns = array('subject', 'event_type_name', 'language_id', 'activated', 'actions');
case 'get_event_email_template':
$columns = array('subject', 'event_type_name', 'language_id', 'activated', 'actions');
if(!in_array($sidx, $columns)) {
$sidx = 'subject';
}
$result = Database::select('*', $obj->table, array('order'=>"$sidx $sord", 'LIMIT'=> "$start , $limit"));
$result = Database::select('*', $obj->table, array('order'=>"$sidx $sord", 'LIMIT'=> "$start , $limit"));
$new_result = array();
foreach ($result as $item) {
$language_info = api_get_language_info($item['language_id']);
$item['language_id'] = $language_info['english_name'];
$item['actions'] = Display::url(Display::return_icon('edit.png', get_lang('Edit')), api_get_path(WEB_CODE_PATH).'admin/event_type.php?action=edit&event_type_name='.$item['event_type_name']);
$item['actions'] .= Display::url(Display::return_icon('delete.png', get_lang('Delete')), api_get_path(WEB_CODE_PATH).'admin/event_controller.php?action=delete&id='.$item['id']);
/*if (!$item['status']) {
$item['name'] = '< font style = "color:#AAA" > '.$item['subject'].'< / font > ';
}*/
$new_result[] = $item;
}
$result = $new_result;
break;
case 'get_careers':
$columns = array('name', 'description', 'actions');
}
$result = $new_result;
break;
case 'get_careers':
$columns = array('name', 'description', 'actions');
if(!in_array($sidx, $columns)) {
$sidx = 'name';
}
@ -354,14 +360,14 @@ switch ($action) {
$item['name'] = '< font style = "color:#AAA" > '.$item['name'].'< / font > ';
}
$new_result[] = $item;
}
$result = $new_result;
}
$result = $new_result;
break;
case 'get_promotions':
case 'get_promotions':
$columns = array('name', 'career', 'description', 'actions');
if(!in_array($sidx, $columns)) {
$sidx = 'name';
}
}
$result = Database::select('p.id,p.name, p.description, c.name as career, p.status', "$obj->table p LEFT JOIN ".Database::get_main_table(TABLE_CAREER)." c ON c.id = p.career_id ", array('order' =>"$sidx $sord", 'LIMIT'=> "$start , $limit"));
$new_result = array();
foreach($result as $item) {
@ -369,7 +375,7 @@ switch ($action) {
$item['name'] = '< font style = "color:#AAA" > '.$item['name'].'< / font > ';
}
$new_result[] = $item;
}
}
$result = $new_result;
break;
case 'get_grade_models':
@ -389,26 +395,26 @@ switch ($action) {
$result = Database::select('*', $obj->table, array('order'=>"name $sord", 'LIMIT'=> "$start , $limit"));
$new_result = array();
if (!empty($result)) {
foreach ($result as $group) {
foreach ($result as $group) {
$group['sessions'] = count($obj->get_sessions_by_usergroup($group['id']));
$group['courses'] = count($obj->get_courses_by_usergroup($group['id']));
$group['users'] = count($obj->get_users_by_usergroup($group['id']));
$new_result[] = $group;
}
$result = $new_result;
}
$columns = array('name', 'users', 'courses','sessions');
}
$columns = array('name', 'users', 'courses','sessions');
if(!in_array($sidx, $columns)) {
$sidx = 'name';
}
//Multidimensional sort
msort($result, $sidx);
break;
break;
case 'get_usergroups_teacher':
$columns = array('name', 'users', 'actions');
$options = array('order'=>"name $sord", 'LIMIT'=> "$start , $limit");
$columns = array('name', 'users', 'actions');
$options = array('order'=>"name $sord", 'LIMIT'=> "$start , $limit");
switch ($type) {
case 'not_registered':
case 'not_registered':
$options['course_id'] = $course_id;
$result = $obj->get_usergroup_not_in_course($options);
break;
@ -416,55 +422,55 @@ switch ($action) {
$options['where'] = array(" usergroup.course_id = ? " => $course_id);
$result = $obj->get_usergroup_in_course($options);
break;
}
$new_result = array();
}
$new_result = array();
if (!empty($result)) {
foreach ($result as $group) {
$group['users'] = count($obj->get_users_by_usergroup($group['id']));
$group['users'] = count($obj->get_users_by_usergroup($group['id']));
if ($obj->usergroup_was_added_in_course($group['id'], $course_id)) {
$url = 'class.php?action=remove_class_from_course&id='.$group['id'];
$icon = Display::return_icon('delete.png', get_lang('Remove'));
} else {
$url = 'class.php?action=add_class_to_course&id='.$group['id'];
$icon = Display::return_icon('add.png', get_lang('Add'));
$icon = Display::return_icon('add.png', get_lang('Add'));
}
$group['actions'] = Display::url($icon, $url);
$group['actions'] = Display::url($icon, $url);
$new_result[] = $group;
}
$result = $new_result;
$result = $new_result;
}
if (!in_array($sidx, $columns)) {
$sidx = 'name';
}
//Multidimensional sort
msort($result, $sidx);
msort($result, $sidx);
break;
default:
exit;
default:
exit;
}
//var_dump($result);
$allowed_actions = array('get_careers',
'get_promotions',
$allowed_actions = array('get_careers',
'get_promotions',
'get_usergroups',
'get_usergroups_teacher',
'get_gradebooks',
'get_sessions',
'get_exercise_results',
'get_hotpotatoes_exercise_results',
'get_work_user_list',
'get_timelines',
'get_grade_models',
'get_gradebooks',
'get_sessions',
'get_exercise_results',
'get_hotpotatoes_exercise_results',
'get_work_user_list',
'get_timelines',
'get_grade_models',
'get_event_email_template',
'get_user_skill_ranking');
//5. Creating an obj to return a json
if (in_array($action, $allowed_actions)) {
$response = new stdClass();
$response->page = $page;
$response = new stdClass();
$response->page = $page;
$response->total = $total_pages;
$response->records = $count;
$response->records = $count;
$i=0;
if (!empty($result)) {
foreach ($result as $row) {
@ -474,15 +480,15 @@ if (in_array($action, $allowed_actions)) {
$response->rows[$i]['id']=$i;
} else {
$response->rows[$i]['id']=$row['id'];
}
$array = array();
}
$array = array();
foreach ($columns as $col) {
$array[] = $row[$col];
}
$array[] = isset( $row[$col]) ? $row[$col] : null ;
}
$response->rows[$i]['cell']=$array;
$i++;
$i++;
}
}
}
echo json_encode($response);
}