'; $htmlHeadXtra[] = ''; //jQuery $htmlHeadXtra[] = ''; //Grid js $htmlHeadXtra[] = ''; $htmlHeadXtra[] = ''; $htmlHeadXtra[] = ''; Display :: display_header($nameTools); $session_id = intval($_GET['session_id']); $session_info = SessionManager::fetch($session_id); $session_list = SessionManager::get_sessions_by_coach(api_get_user_id()); $course_list = SessionManager::get_course_list_by_session_id($session_id); $course_select = array(); $session_select = array(); foreach ($session_list as $item) { $session_select[$item['id']] = $item['name']; } /* foreach ($course_list as $course_item) { $course_select[$course_item['id']] = $course_item['title']; }*/ // Session list form if (count($session_select) > 1) { $form = new FormValidator('exercise_admin', 'get', api_get_self().'?session_id='.$session_id); $form->addElement('select', 'session_id', get_lang('SessionList'), $session_select, 'onchange="javascript:change_session()"'); $defaults['session_id'] = $session_id; $form->setDefaults($defaults); $form->display(); if ($form->validate()) { } } echo Display::tag('h1', $session_info['name']); //Listing LPs from all courses $lps = array(); foreach ($course_list as $item) { $list = new LearnpathList(api_get_user_id(),$item['code']); $flat_list = $list->get_flat_list(); $lps[$item['code']] = $flat_list; foreach ($flat_list as $item) { //var_dump(get_week_from_day($item['publicated_on'])); } } //Getting all sessions where I'm subscribed $new_session_list = UserManager::get_personal_session_course_list(api_get_user_id()); //echo '
'; $my_session_list = array(); $final_array = array(); if (!empty($new_session_list)) { foreach($new_session_list as $item) { $my_session_id = $item['id_session']; if (isset($my_session_id) && !in_array($my_session_id, $my_session_list) && $session_id == $my_session_id) { $final_array[$my_session_id]['name'] = $item['session_name']; //Get all courses by session where I'm subscribed $my_course_list = UserManager::get_courses_list_by_session(api_get_user_id(), $my_session_id ); $course = array(); foreach ($my_course_list as $my_course) { $course_info = api_get_course_info($my_course['code']); //Getting all exercises from the current course $exercise_list = get_all_exercises($course_info); //Exercises we skip /*if (empty($exercise_list)) { continue; } */ $exercise_course_list = array(); $course['name'] = $course_info['name']; if (!empty($exercise_list)) { foreach($exercise_list as $exercise_item) { $exercise = new Exercise($course_info['real_id']); $exercise->read($exercise_item['id']); $exercise_course_list[$exercise_item['id']] = $exercise; //Reading all Exercise results by user, exercise_id, code, and session $user_results = get_all_exercise_results_by_user(api_get_user_id(), $exercise_item['id'], $my_course['code'], $my_session_id); //print_r($user_results); $course['exercises'][$exercise_item['id']]['name'] = $exercise->exercise; $course['exercises'][$exercise_item['id']]['data'] = $user_results; //print_r($user_results); } $final_array[$my_session_id]['data'][$my_course['code']] = $course; } } } $my_session_list[] = $my_session_id; } } //print_r($final_array); exit; require_once api_get_path(LIBRARY_PATH).'pear/HTML/Table.php'; $html = ''; //Final data to be show $my_real_array =array(); foreach($final_array as $session_data) { //Session name $html .=Display::tag('h1',$session_data['name']); $course_list = $session_data['data']; if (!empty($course_list)) foreach ($course_list as $my_course_code=>$course_data) { //Course table $table = new HTML_Table(array('class' => 'data_table')); $row = 0; $column = 0; //Course headers /*$header_names = array(get_lang('Course'),get_lang('Exercise'),get_lang('Attempt'),get_lang('Results'),get_lang('Score'), get_lang('Ranking')); foreach ($header_names as $item) { $table->setHeaderContents($row, $column, $item); $column++; } $row = 1; $column = 0; $table->setCellContents($row, $column, $course_data['name']); $column++;*/ if (!empty($course_data['exercises'])) { //Exercises foreach ($course_data['exercises'] as $my_exercise_id => $exercise_data) { //Exercise results $counter = 1; foreach ($exercise_data['data'] as $exercise_result) { $my_exercise_result = array($exercise_data['name'], $exercise_result['exe_id']); $column = 1; //$exercise_result['exe_id'] /*print_r($exercise_result); exe_weighting exe_result exe_id*/ $score = $exercise_result['exe_result'].' / '.$exercise_result['exe_weighting']; $platform_score = show_score($exercise_result['exe_result'], $exercise_result['exe_weighting'], false); if (!empty($exercise_result['exe_weighting']) && intval($exercise_result['exe_weighting']) != 0 ) { $my_score = $exercise_result['exe_result']/$exercise_result['exe_weighting']; } else { $my_score = 0; } $position = get_exercise_result_ranking($my_score, $exercise_result['exe_id'], $my_exercise_id, $my_course_code,$session_id); $my_real_array[]= array('course'=>$course_data['name'], 'exercise'=>$exercise_data['name'],'attempt'=>$counter,'result'=>$score,'note'=>$platform_score,'position'=>$position); $counter++; foreach ($my_exercise_result as $data) { //$my_real_array[]= array('session'=>$session_data['name'],'course'=>$course_data['name'], 'exercise'=>$exercise_data['name'],'result'=>$exercise_result['exe_id']) ; $table->setCellContents($row, $column, $data); //$table->updateCellAttributes($row, $column, 'align="center"'); $column++; } $row++; } } } $html .=$table->toHtml(); } } //echo '';print_r($my_real_array) ; //All Learnpaths grid settings (First tab, first subtab) $url = api_get_path(WEB_AJAX_PATH).'course_home.ajax.php?a=session_courses_lp_default&session_id='.$session_id; $columns = array('Date','Course', 'LP'); $column_model = array(array('name'=>'date', 'index'=>'date', 'width'=>'80', 'align'=>'left'), array('name'=>'course', 'index'=>'course', 'width'=>'500', 'align'=>'left'), array('name'=>'lp', 'index'=>'lp', 'width'=>'200', 'align'=>'center')); $extra_params['autowidth'] = 'true'; //use the width of the parent //$extra_params['forceFit'] = 'true'; //use the width of the parent //$extra_params['altRows'] = 'true'; //zebra style //Per course grid settings $url_course = api_get_path(WEB_AJAX_PATH).'course_home.ajax.php?a=session_courses_lp_by_course&session_id='.$session_id; $extra_params_course['grouping'] = 'true'; $extra_params_course['groupingView'] = array('groupField'=>array('course'), 'groupColumnShow'=>array('false'), 'groupText' => array('Course {0} - {1} Item(s)')); $extra_params_course['autowidth'] = 'true'; //use the width of the parent //Per Week grid $url_week = api_get_path(WEB_AJAX_PATH).'course_home.ajax.php?a=session_courses_lp_by_week&session_id='.$session_id; $column_week = array('Week','Date','Course', 'LP'); $column_week_model =array(array('name'=>'week', 'index'=>'week', 'width'=>'80', 'align'=>'left'), array('name'=>'date', 'index'=>'date', 'width'=>'80', 'align'=>'right'), array('name'=>'course', 'index'=>'course', 'width'=>'500', 'align'=>'left'), array('name'=>'lp', 'index'=>'lp', 'width'=>'200', 'align'=>'center')); $extra_params_week['grouping'] = 'true'; $extra_params_week['groupingView'] = array('groupField'=>array('week'), 'groupColumnShow'=>'false', 'groupText' => array('Week {0} - {1} Item(s)')); $extra_params_week['autowidth'] = 'true'; //use the width of the parent //MyQCM grid $column_exercise = array(get_lang('Course'),get_lang('Exercise'), get_lang('Attempt').' #', get_lang('Result'), get_lang('Note'), get_lang('Position')); $column_exercise_model = array(array('name'=>'course', 'index'=>'course', 'width'=>'450', 'align'=>'left','sortable'=>'false'), array('name'=>'exercise', 'index'=>'exercise', 'width'=>'250', 'align'=>'left', 'sortable'=>'false'), array('name'=>'attempt', 'index'=>'attempt', 'width'=>'50', 'align'=>'center', 'sortable'=>'false'), array('name'=>'result', 'index'=>'result', 'width'=>'50', 'align'=>'center', 'sortable'=>'false'), array('name'=>'note', 'index'=>'note', 'width'=>'50', 'align'=>'center', 'sortable'=>'false'), array('name'=>'position', 'index'=>'position', 'width'=>'50', 'align'=>'center', 'sortable'=>'false') ); $extra_params_exercise['grouping'] = 'true'; $extra_params_exercise['groupingView'] = array('groupField'=>array('course'),'groupColumnShow'=>'false','groupText' => array('Course {0} - {1} Item(s)')); //$extra_params_exercise['altRows'] = 'true'; ?>
'.Tracking::show_course_detail(api_get_user_id(), $_GET['course'], $_GET['session_id']); //Main headers $headers = array(get_lang('LearningPaths'), get_lang('MyQCM'), get_lang('MyResults')); //Subheaders $sub_header = array(get_lang('AllLearningPaths'), get_lang('PerWeek'), get_lang('ByCourse')); //Sub header tab $tabs = Display::tabs($sub_header, array(Display::grid_html('list_default'), Display::grid_html('list_week'), Display::grid_html('list_course')),'sub_tab'); //Main tabs echo Display::tabs($headers, array($tabs, Display::grid_html('exercises'),$my_reporting)); Display :: display_footer();