Beeznest
*/
$cidReset = true;
require_once __DIR__.'/../inc/global.inc.php';
$session_id = isset($_GET['session_id']) ? (int) $_GET['session_id'] : 0;
if (empty($session_id)) {
api_not_allowed(true);
}
$sessionField = new ExtraFieldValue('session');
$valueAllowVisitors = $sessionField->get_values_by_handler_and_field_variable(
$session_id,
'allow_visitors'
);
$allowVisitors = $valueAllowVisitors != false;
if (!$allowVisitors) {
// Only users who are logged in can proceed.
api_block_anonymous_users();
}
$this_section = SECTION_COURSES;
$htmlHeadXtra[] = api_get_jqgrid_js();
$course_id = isset($_GET['course_id']) ? (int) $_GET['course_id'] : null;
Session::write('id_session', $session_id);
// Clear the exercise session just in case
Session::erase('objExercise');
Session::erase('duration_time_previous');
Session::erase('duration_time');
$userId = api_get_user_id();
$session_info = SessionManager::fetch($session_id);
$session_list = SessionManager::get_sessions_by_coach(api_get_user_id());
$courseList = SessionManager::get_course_list_by_session_id($session_id);
$userIsGeneralCoach = SessionManager::user_is_general_coach($userId, $session_id);
$user_course_list = [];
$exerciseListPerCourse = [];
foreach ($courseList as $course) {
$status = SessionManager::get_user_status_in_course_session(
$userId,
$course['real_id'],
$session_id
);
if ($status !== false || api_is_platform_admin() || $userIsGeneralCoach) {
$user_course_list[] = $course['real_id'];
}
$exerciseList = ExerciseLib::get_all_exercises_for_course_id(
$course,
$session_id,
$course['real_id'],
true
);
$exerciseListNew = [];
if (!empty($exerciseList)) {
// Exercises
foreach ($exerciseList as $exerciseInfo) {
$exerciseId = $exerciseInfo['id'];
$visibility = api_get_item_visibility(
$course,
TOOL_QUIZ,
$exerciseId,
$session_id
);
if ($visibility == 0) {
continue;
}
$exerciseListNew[] = $exerciseInfo;
}
}
$exerciseListPerCourse[$course['real_id']] = $exerciseListNew;
}
if (empty($user_course_list)) {
api_not_allowed(true);
}
$my_session_list = [];
$final_array = [];
$new_course_list = [];
if (!empty($courseList)) {
foreach ($courseList as $course_data) {
if (api_is_platform_admin()) {
$course_data['title'] = Display::url(
$course_data['title'],
api_get_course_url($course_data['code'], $session_id)
);
} else {
if (in_array($course_data['real_id'], $user_course_list) || api_is_anonymous()) {
$course_data['title'] = Display::url(
$course_data['title'],
api_get_course_url($course_data['code'], $session_id)
);
} else {
continue;
}
}
$list = new LearnpathList(
api_get_user_id(),
api_get_course_info($course_data['code']),
$session_id,
'lp.publicatedOn ASC',
true,
null,
true
);
$lp_list = $list->get_flat_list();
$lp_count = 0;
if (!empty($lp_list)) {
foreach ($lp_list as $valLp) {
if ($valLp['lp_visibility']) {
$lp_count++;
}
}
}
$course_info = api_get_course_info($course_data['code']);
$exerciseCount = count($exerciseListPerCourse[$course_info['real_id']]);
$max_mutation_date = '';
$last_date = Tracking::get_last_connection_date_on_the_course(
api_get_user_id(),
$course_info,
$session_id,
false
);
$icons = '';
foreach ($lp_list as $item) {
if (empty($item['modified_on'])) {
$lp_date_original = $item['created_on'];
$image = 'new.gif';
$label = get_lang('LearnpathAdded');
} else {
$lp_date_original = $item['modified_on'];
$image = 'moderator_star.png';
$label = get_lang('LearnpathUpdated');
}
$mutation_date = api_strtotime($item['publicated_on']) > api_strtotime($lp_date_original) ? $item['publicated_on'] : $lp_date_original;
if (api_strtotime($mutation_date) > api_strtotime($max_mutation_date)) {
$max_mutation_date = $mutation_date;
}
if (strtotime($last_date) < strtotime($lp_date_original)) {
if (empty($icons)) {
$icons .= ' '.Display::return_icon(
$image,
get_lang('TitleNotification').': '.$label.' - '.$lp_date_original
).' ';
}
}
}
$new_course_list[] = [
'title' => $course_data['title'].$icons,
// 'recent_lps' => $icons,
//'max_mutation_date' => substr(api_get_local_time($max_mutation_date),0,10),
'exercise_count' => $exerciseCount,
'lp_count' => $lp_count,
];
}
}
//If session is not active we stop de script
if (api_is_coach_of_course_in_session($session_id) == false) {
//If session is not active we stop de script
if (!api_is_allowed_to_session_edit()) {
api_not_allowed(true);
}
}
$entityManager = Database::getManager();
$session = $entityManager->find('ChamiloCoreBundle:Session', $session_id);
$sessionTitleLink = api_get_configuration_value('courses_list_session_title_link');
if ($sessionTitleLink == 2 && $session->getNbrCourses() === 1) {
$sessionCourses = $session->getCourses();
$sessionCourse = $sessionCourses[0]->getCourse();
$courseUrl = $sessionCourse->getDirectory().'/index.php?';
$courseUrl .= http_build_query([
'id_session' => $session->getId(),
]);
header('Location: '.api_get_path(WEB_COURSE_PATH).$courseUrl);
exit;
}
Display::display_header(get_lang('Session'));
$session_select = [];
foreach ($session_list as $item) {
$session_select[$item['id']] = $item['name'];
}
// 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 (empty($session_id)) {
$user_list = UserManager::get_user_list();
} else {
$user_list = SessionManager::get_users_by_session($session_id);
}
//Final data to be show
$my_real_array = $new_exercises = [];
$now = time();
if (!empty($courseList)) {
foreach ($courseList as $courseInfo) {
$courseCode = $courseInfo['code'];
$courseId = $courseInfo['real_id'];
$isSubscribed = CourseManager::is_user_subscribed_in_course(
api_get_user_id(),
$courseCode,
true,
$session_id
);
$exerciseList = $exerciseListPerCourse[$courseId];
if (!empty($exerciseList)) {
// Exercises
foreach ($exerciseList as $exerciseInfo) {
if ($exerciseInfo['start_time'] == '0000-00-00 00:00:00') {
$start_date = '-';
} else {
$start_date = $exerciseInfo['start_time'];
}
$best_score_data = ExerciseLib::get_best_attempt_in_course(
$exerciseInfo['id'],
$courseInfo['real_id'],
$session_id
);
$best_score = '';
if (!empty($best_score_data)) {
$best_score = ExerciseLib::show_score(
$best_score_data['exe_result'],
$best_score_data['exe_weighting']
);
}
$exerciseResultInfo = Event::getExerciseResultsByUser(
$userId,
$exerciseId,
$courseId,
$session_id
);
if (empty($exerciseResultInfo)) {
// We check the date validation of the exercise if the user can make it
if ($exerciseInfo['start_time'] != '0000-00-00 00:00:00') {
$allowed_time = api_strtotime($exerciseInfo['start_time'], 'UTC');
if ($now < $allowed_time) {
continue;
}
}
$name = Display::url(
$exerciseInfo['title'],
api_get_path(WEB_CODE_PATH)."exercise/overview.php?cidReq=$courseCode&exerciseId={$exerciseId}&id_session=$session_id",
['target' => SESSION_LINK_TARGET]
);
$new_exercises[] = [
'status' => Display::return_icon(
'star.png',
get_lang('New'),
['width' => ICON_SIZE_SMALL]
),
'date' => $exerciseInfo['start_time'],
'course' => $courseInfo['title'],
'exercise' => $name,
'attempt' => '-',
'result' => '-',
'best_result' => '-',
'position' => '-',
];
continue;
}
// Exercise results
$counter = 1;
foreach ($exerciseResultInfo as $result) {
$platform_score = ExerciseLib::show_score(
$result['exe_result'],
$result['exe_weighting']
);
$my_score = 0;
if (!empty($result['exe_weighting']) &&
intval($result['exe_weighting']) != 0
) {
$my_score = $result['exe_result'] / $result['exe_weighting'];
}
$position = ExerciseLib::get_exercise_result_ranking(
$my_score,
$result['exe_id'],
$exerciseId,
$courseCode,
$session_id,
$user_list
);
$name = Display::url(
$exerciseInfo['title'],
api_get_path(WEB_CODE_PATH)."exercise/result.php?cidReq=$courseCode&id={$result['exe_id']}&id_session=$session_id&show_headers=1",
['target' => SESSION_LINK_TARGET, 'class' => 'exercise-result-link']
);
$my_real_array[] = [
'status' => Display::return_icon(
'quiz.png',
get_lang('Attempted'),
'',
ICON_SIZE_SMALL
),
'date' => $start_date,
'course' => $courseInfo['title'],
'exercise' => $name,
'attempt' => $counter,
'result' => $platform_score,
'best_result' => $best_score,
'position' => $position,
];
$counter++;
}
}
}
}
}
$my_real_array = msort($my_real_array, 'date', 'asc');
if (!empty($new_exercises)) {
$my_real_array = array_merge($new_exercises, $my_real_array);
}
$start = $end = $start_only = $end_only = '';
if (!empty($session_info['access_start_date'])) {
$start = api_convert_and_format_date($session_info['access_start_date'], DATE_FORMAT_SHORT);
$start_only = get_lang('From').' '.$session_info['access_start_date'];
}
if (!empty($session_info['access_start_date'])) {
$end = api_convert_and_format_date($session_info['access_end_date'], DATE_FORMAT_SHORT);
$end_only = get_lang('Until').' '.$session_info['access_end_date'];
}
if (!empty($start) && !empty($end)) {
$dates = Display::tag('i', sprintf(get_lang('FromDateXToDateY'), $start, $end));
} else {
$dates = Display::tag('i', $start_only.' '.$end_only);
}
$editLink = '';
if (api_is_platform_admin()) {
$editLink = ' '.Display::url(
Display::return_icon('edit.png', get_lang('Edit')),
api_get_path(WEB_CODE_PATH).'session/session_edit.php?page=resume_session.php&id='.$session_id
);
}
echo Display::tag('h1', $session_info['name'].$editLink);
echo $dates.'
';
$allow = api_get_setting('show_session_description') === 'true';
if ($session_info['show_description'] == 1 && $allow) {
?>