Adding course coaches in the admin/course_edit.php page see BT#6449 (available for admin only)

1.9.x
Julio Montoya 12 years ago
parent f339330cae
commit 599734e411
  1. 199
      main/admin/course_edit.php
  2. 37
      main/inc/lib/sessionmanager.lib.php

@ -3,7 +3,7 @@
/** /**
* @package chamilo.admin * @package chamilo.admin
*/ */
/* Initialization section */
// name of the language file that needs to be included // name of the language file that needs to be included
$language_file = 'admin'; $language_file = 'admin';
$cidReset = true; $cidReset = true;
@ -46,21 +46,25 @@ while ($obj = Database::fetch_object($res)) {
} }
// Get all possible teachers without the course teachers // Get all possible teachers without the course teachers
if ($_configuration['multiple_access_urls']) { if (api_is_multiple_url_enabled()) {
$access_url_rel_user_table= Database :: get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER); $access_url_rel_user_table= Database :: get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
$sql = "SELECT u.user_id,lastname,firstname FROM $table_user as u $sql = "SELECT u.user_id,lastname,firstname
FROM $table_user as u
INNER JOIN $access_url_rel_user_table url_rel_user INNER JOIN $access_url_rel_user_table url_rel_user
ON (u.user_id=url_rel_user.user_id) WHERE url_rel_user.access_url_id=".api_get_current_access_url_id()." AND status=1".$order_clause; ON (u.user_id=url_rel_user.user_id)
WHERE url_rel_user.access_url_id=".api_get_current_access_url_id()." AND status=1".$order_clause;
} else { } else {
$sql = "SELECT user_id,lastname,firstname FROM $table_user WHERE status='1'".$order_clause; $sql = "SELECT user_id, lastname, firstname
FROM $table_user WHERE status='1'".$order_clause;
} }
$res = Database::query($sql); $res = Database::query($sql);
$teachers = array(); $teachers = array();
$allTeachers = array();
$platform_teachers[0] = '-- '.get_lang('NoManager').' --'; $platform_teachers[0] = '-- '.get_lang('NoManager').' --';
while ($obj = Database::fetch_object($res)) { while ($obj = Database::fetch_object($res)) {
$allTeachers[$obj->user_id] = api_get_person_name($obj->firstname, $obj->lastname);
if (!array_key_exists($obj->user_id, $course_teachers)) { if (!array_key_exists($obj->user_id, $course_teachers)) {
$teachers[$obj->user_id] = api_get_person_name($obj->firstname, $obj->lastname); $teachers[$obj->user_id] = api_get_person_name($obj->firstname, $obj->lastname);
} }
@ -72,7 +76,7 @@ while ($obj = Database::fetch_object($res)) {
$platform_teachers[$obj->user_id] = api_get_person_name($obj->firstname, $obj->lastname); $platform_teachers[$obj->user_id] = api_get_person_name($obj->firstname, $obj->lastname);
} }
//Case where there is no teacher in the course // Case where there is no teacher in the course
if (count($course_teachers) == 0) { if (count($course_teachers) == 0) {
$sql='SELECT tutor_name FROM '.$course_table.' WHERE code="'.$course_code.'"'; $sql='SELECT tutor_name FROM '.$course_table.' WHERE code="'.$course_code.'"';
$res = Database::query($sql); $res = Database::query($sql);
@ -82,26 +86,27 @@ if (count($course_teachers) == 0) {
// Build the form // Build the form
$form = new FormValidator('update_course'); $form = new FormValidator('update_course');
$form->addElement('hidden','code',$course_code); $form->addElement('hidden', 'code', $course_code);
//title //title
$form->add_textfield('title', get_lang('Title'), true, array ('class' => 'span6')); $form->add_textfield('title', get_lang('Title'), true, array ('class' => 'span6'));
$form->applyFilter('title','html_filter'); $form->applyFilter('title', 'html_filter');
$form->applyFilter('title','trim'); $form->applyFilter('title', 'trim');
// Code // Code
$element = $form->addElement('text', 'real_code', array(get_lang('CourseCode'), get_lang('ThisValueCantBeChanged'))); $element = $form->addElement('text', 'real_code', array(get_lang('CourseCode'), get_lang('ThisValueCantBeChanged')));
$element->freeze(); $element->freeze();
// visual code // Visual code
$form->add_textfield('visual_code', array(get_lang('VisualCode'), get_lang('OnlyLettersAndNumbers'), get_lang('ThisValueIsUsedInTheCourseURL')), true, array('class' => 'span4')); $form->add_textfield('visual_code', array(get_lang('VisualCode'), get_lang('OnlyLettersAndNumbers'), get_lang('ThisValueIsUsedInTheCourseURL')), true, array('class' => 'span4'));
$form->applyFilter('visual_code','strtoupper'); $form->applyFilter('visual_code', 'strtoupper');
$form->applyFilter('visual_code','html_filter'); $form->applyFilter('visual_code', 'html_filter');
$group=array(); $group = array(
$group[] = $form->createElement('select', 'platform_teachers', '', $teachers, ' id="platform_teachers" multiple=multiple size="4" style="width:300px;"'); $form->createElement('select', 'platform_teachers', '', $teachers, ' id="platform_teachers" multiple=multiple size="4" style="width:300px;"'),
$group[] = $form->createElement('select', 'course_teachers', '', $course_teachers, ' id="course_teachers" multiple=multiple size="4" style="width:300px;"'); $form->createElement('select', 'course_teachers', '', $course_teachers, ' id="course_teachers" multiple=multiple size="4" style="width:300px;"')
);
$element_template = <<<EOT $element_template = <<<EOT
<div class="control-group"> <div class="control-group">
@ -120,28 +125,86 @@ EOT;
$renderer = $form->defaultRenderer(); $renderer = $form->defaultRenderer();
$renderer->setElementTemplate($element_template, 'group'); $renderer->setElementTemplate($element_template, 'group');
$form->addGroup($group,'group',get_lang('CourseTeachers'),'</td><td width="80" align="center">'. $form->addGroup($group, 'group', get_lang('CourseTeachers'), '</td><td width="80" align="center">'.
'<input class="arrowr" style="width:30px;height:30px;padding-right:12px" type="button" onclick="moveItem(document.getElementById(\'platform_teachers\'), document.getElementById(\'course_teachers\'))" ><br><br>' . '<input class="arrowr" style="width:30px;height:30px;padding-right:12px" type="button" onclick="moveItem(document.getElementById(\'platform_teachers\'), document.getElementById(\'course_teachers\'))"><br><br>'.
'<input class="arrowl" style="width:30px;height:30px;padding-left:13px" type="button" onclick="moveItem(document.getElementById(\'course_teachers\'), document.getElementById(\'platform_teachers\'))" ></td><td>'); '<input class="arrowl" style="width:30px;height:30px;padding-left:13px" type="button" onclick="moveItem(document.getElementById(\'course_teachers\'), document.getElementById(\'platform_teachers\'))"></td><td>'
);
if (array_key_exists('add_teachers_to_sessions_courses', $course)) { if (array_key_exists('add_teachers_to_sessions_courses', $course)) {
$form->addElement('checkbox', 'add_teachers_to_sessions_courses', null, get_lang('TeachersWillBeAddedAsCoachInAllCourseSessions')); $form->addElement('checkbox', 'add_teachers_to_sessions_courses', null, get_lang('TeachersWillBeAddedAsCoachInAllCourseSessions'));
} }
$categories_select = $form->addElement('select', 'category_code', get_lang('CourseFaculty'), $categories , array('style'=>'width:350px','id'=>'category_code_id', 'class'=>'chzn-select')); $coursesInSession = SessionManager::get_session_by_course($course['code']);
if (!empty($coursesInSession)) {
foreach ($coursesInSession as $session) {
$sessionId = $session['id'];
$coaches = SessionManager::getCoachesByCourseSession($sessionId, $course['code']);
$teachers = $allTeachers;
$sessionTeachers = array();
foreach ($coaches as $coachId) {
$userInfo = api_get_user_info($coachId);
$sessionTeachers[$coachId] = $userInfo['complete_name'];
if (isset($teachers[$coachId])) {
unset($teachers[$coachId]);
}
}
$groupName = 'session_coaches['.$sessionId.']';
$platformTeacherId = 'platform_teachers_by_session_'.$sessionId;
$coachId = 'coaches_by_session_'.$sessionId;
$platformTeacherName = 'platform_teachers_by_session';
$coachName = 'coaches_by_session';
$group = array(
$form->createElement('select', $platformTeacherName, '', $teachers, ' id="'.$platformTeacherId.'" multiple=multiple size="4" style="width:300px;"'),
$form->createElement('select', $coachName, '', $sessionTeachers, ' id="'.$coachId.'" multiple=multiple size="4" style="width:300px;"')
);
$renderer = $form->defaultRenderer();
$element_template = <<<EOT
<div class="control-group">
<label>
<!-- BEGIN required --><span class="form_required">*</span> <!-- END required -->{label}
</label>
<div class="controls">
<table cellpadding="0" cellspacing="0">
<tr>
<!-- BEGIN error --><span class="form_error">{error}</span><br /><!-- END error --> <td>{element}</td>
</tr>
</table>
</div>
</div>
EOT;
$renderer->setElementTemplate($element_template, $groupName);
$form->addGroup($group, $groupName, $session['name'].' - '.get_lang('Coaches'), '</td>
<td width="80" align="center">
<input class="arrowr" style="width:30px;height:30px;padding-right:12px" type="button" onclick="moveItem(document.getElementById(\''.$platformTeacherId.'\'), document.getElementById(\''.$coachId.'\'));">
<br><br>
<input class="arrowl" style="width:30px;height:30px;padding-left:13px" type="button" onclick="moveItem(document.getElementById(\''.$coachId.'\'), document.getElementById(\''.$platformTeacherId.'\'));">
</td><td>'
);
}
}
$categories_select = $form->addElement('select', 'category_code', get_lang('CourseFaculty'), $categories, array('style'=>'width:350px','id'=>'category_code_id', 'class'=>'chzn-select'));
$categories_select->addOption('-', ''); $categories_select->addOption('-', '');
CourseManager::select_and_sort_categories($categories_select); CourseManager::select_and_sort_categories($categories_select);
$form->add_textfield('department_name', get_lang('CourseDepartment'), false, array('size' => '60')); $form->add_textfield('department_name', get_lang('CourseDepartment'), false, array('size' => '60'));
$form->applyFilter('department_name','html_filter'); $form->applyFilter('department_name', 'html_filter');
$form->applyFilter('department_name','trim'); $form->applyFilter('department_name', 'trim');
$form->add_textfield('department_url', get_lang('CourseDepartmentURL'), false, array('size' => '60')); $form->add_textfield('department_url', get_lang('CourseDepartmentURL'), false, array('size' => '60'));
$form->applyFilter('department_url','html_filter'); $form->applyFilter('department_url', 'html_filter');
$form->applyFilter('department_url','trim'); $form->applyFilter('department_url', 'trim');
$form->addElement('select_language', 'course_language', get_lang('CourseLanguage')); $form->addElement('select_language', 'course_language', get_lang('CourseLanguage'));
$form->applyFilter('select_language','html_filter'); $form->applyFilter('select_language', 'html_filter');
$group = array(); $group = array();
$group[]= $form->createElement('radio', 'visibility', get_lang("CourseAccess"), get_lang('OpenToTheWorld'), COURSE_VISIBILITY_OPEN_WORLD); $group[]= $form->createElement('radio', 'visibility', get_lang("CourseAccess"), get_lang('OpenToTheWorld'), COURSE_VISIBILITY_OPEN_WORLD);
@ -149,7 +212,7 @@ $group[]= $form->createElement('radio', 'visibility', null, get_lang('OpenToTheP
$group[]= $form->createElement('radio', 'visibility', null, get_lang('Private'), COURSE_VISIBILITY_REGISTERED); $group[]= $form->createElement('radio', 'visibility', null, get_lang('Private'), COURSE_VISIBILITY_REGISTERED);
$group[]= $form->createElement('radio', 'visibility', null, get_lang('CourseVisibilityClosed'), COURSE_VISIBILITY_CLOSED); $group[]= $form->createElement('radio', 'visibility', null, get_lang('CourseVisibilityClosed'), COURSE_VISIBILITY_CLOSED);
$group[]= $form->createElement('radio', 'visibility', null, get_lang('CourseVisibilityHidden'), COURSE_VISIBILITY_HIDDEN); $group[]= $form->createElement('radio', 'visibility', null, get_lang('CourseVisibilityHidden'), COURSE_VISIBILITY_HIDDEN);
$form->addGroup($group,'', get_lang('CourseAccess'), '<br />'); $form->addGroup($group, '', get_lang('CourseAccess'), '<br />');
$group = array(); $group = array();
$group[]= $form->createElement('radio', 'subscribe', get_lang('Subscription'), get_lang('Allowed'), 1); $group[]= $form->createElement('radio', 'subscribe', get_lang('Subscription'), get_lang('Allowed'), 1);
@ -166,25 +229,24 @@ $form->addRule('disk_quota', get_lang('ThisFieldIsRequired'), 'required');
$form->addRule('disk_quota', get_lang('ThisFieldShouldBeNumeric'), 'numeric'); $form->addRule('disk_quota', get_lang('ThisFieldShouldBeNumeric'), 'numeric');
$list_course_extra_field = CourseManager::get_course_extra_field_list($course_code); $list_course_extra_field = CourseManager::get_course_extra_field_list($course_code);
//@todo this is wrong //@todo this is wrong
foreach ($list_course_extra_field as $extra_field) { foreach ($list_course_extra_field as $extra_field) {
switch ($extra_field['field_type']) { switch ($extra_field['field_type']) {
case CourseManager::COURSE_FIELD_TYPE_CHECKBOX: case CourseManager::COURSE_FIELD_TYPE_CHECKBOX:
$checked = (array_key_exists('extra_field_value', $extra_field) && $extra_field['extra_field_value'] == 1)? array('checked'=>'checked'): ''; $checked = (array_key_exists('extra_field_value', $extra_field) && $extra_field['extra_field_value'] == 1)? array('checked'=>'checked'): '';
$form->addElement('hidden', '_extra_'.$extra_field['field_variable'], 0); $form->addElement('hidden', '_extra_'.$extra_field['field_variable'], 0);
$field_display_text=$extra_field['field_display_text']; $field_display_text = $extra_field['field_display_text'];
//$form->addElement('checkbox', 'extra_'.$extra_field['field_variable'], array(get_lang('SpecialCourse'), get_lang('AllUsersAreAutomaticallyRegistered')) , get_lang($extra_field['field_default_value']), $checked); $form->addElement('checkbox', 'extra_'.$extra_field['field_variable'], array(null, get_lang('AllUsersAreAutomaticallyRegistered')), get_lang('SpecialCourse'), $checked);
$form->addElement('checkbox', 'extra_'.$extra_field['field_variable'], array(null, get_lang('AllUsersAreAutomaticallyRegistered')) , get_lang('SpecialCourse'), $checked);
break; break;
} }
} }
$form->addElement('style_submit_button', 'button', get_lang('ModifyCourseInfo'),'onclick="valide()"; class="save"'); $form->addElement('style_submit_button', 'button', get_lang('ModifyCourseInfo'), 'onclick="valide()"; class="save"');
// Set some default values // Set some default values
$course['disk_quota'] = round(DocumentManager::get_course_quota($course_code) /1024/1024, 1); $course['disk_quota'] = round(DocumentManager::get_course_quota($course_code) /1024/1024, 1);
$course['title'] = api_html_entity_decode($course['title'], ENT_QUOTES, $charset); $course['title'] = api_html_entity_decode($course['title'], ENT_QUOTES, $charset);
$course['real_code'] = $course['code']; $course['real_code'] = $course['code'];
$course['add_teachers_to_sessions_courses'] = isset($course['add_teachers_to_sessions_courses']) ? $course['add_teachers_to_sessions_courses'] : 0; $course['add_teachers_to_sessions_courses'] = isset($course['add_teachers_to_sessions_courses']) ? $course['add_teachers_to_sessions_courses'] : 0;
$form->setDefaults($course); $form->setDefaults($course);
@ -192,6 +254,7 @@ $form->setDefaults($course);
// Validate form // Validate form
if ($form->validate()) { if ($form->validate()) {
$course = $form->getSubmitValues(); $course = $form->getSubmitValues();
$dbName = $_POST['dbName']; $dbName = $_POST['dbName'];
$course_code = $course['code']; $course_code = $course['code'];
$visual_code = $course['visual_code']; $visual_code = $course['visual_code'];
@ -204,24 +267,26 @@ if ($form->validate()) {
if (!empty($visual_code)) { if (!empty($visual_code)) {
$list = CourseManager::get_courses_info_from_visual_code($visual_code); $list = CourseManager::get_courses_info_from_visual_code($visual_code);
foreach ($list as $course_temp) { foreach ($list as $course_temp) {
if ($course_temp['code'] != $course_code) { if ($course_temp['code'] != $course_code) {
$visual_code_is_used = true; $visual_code_is_used = true;
$warn .= ' '.$course_temp['title'].' ('.$course_temp['code'].'),'; $warn .= ' '.$course_temp['title'].' ('.$course_temp['code'].'),';
} }
} }
$warn = substr($warn,0,-1); $warn = substr($warn, 0, -1);
} }
// an extra field // an extra field
$extras = array(); $extras = array();
foreach ($course as $key => $value) { foreach ($course as $key => $value) {
if (substr($key,0,6)=='extra_') { if (substr($key, 0, 6) == 'extra_') {
$extras[substr($key,6)] = $value; $extras[substr($key, 6)] = $value;
} }
if (substr($key,0,7)=='_extra_') {
if (!array_key_exists(substr($key,7), $extras)) { if (substr($key, 0, 7) == '_extra_') {
$extras[substr($key,7)] = $value; if (!array_key_exists(substr($key, 7), $extras)) {
$extras[substr($key, 7)] = $value;
} }
} }
} }
$tutor_id = $course['tutor_name']; $tutor_id = $course['tutor_name'];
@ -233,17 +298,17 @@ if ($form->validate()) {
$department_name = $course['department_name']; $department_name = $course['department_name'];
$department_url = $course['department_url']; $department_url = $course['department_url'];
$course_language = $course['course_language']; $course_language = $course['course_language'];
$course['disk_quota'] = $course['disk_quota']*1024*1024; $course['disk_quota'] = $course['disk_quota']*1024*1024;
$disk_quota = $course['disk_quota']; $disk_quota = $course['disk_quota'];
$visibility = $course['visibility']; $visibility = $course['visibility'];
$subscribe = $course['subscribe']; $subscribe = $course['subscribe'];
$unsubscribe = $course['unsubscribe']; $unsubscribe = $course['unsubscribe'];
if (!stristr($department_url, 'http://')) { if (!stristr($department_url, 'http://')) {
$department_url = 'http://'.$department_url; $department_url = 'http://'.$department_url;
} }
$sql = "UPDATE $course_table SET course_language='".Database::escape_string($course_language)."',
$sql = "UPDATE $course_table SET course_language='".Database::escape_string($course_language)."',
title='".Database::escape_string($title)."', title='".Database::escape_string($title)."',
category_code='".Database::escape_string($category_code)."', category_code='".Database::escape_string($category_code)."',
tutor_name='".Database::escape_string($tutor_name)."', tutor_name='".Database::escape_string($tutor_name)."',
@ -266,13 +331,39 @@ if ($form->validate()) {
$addTeacherToSessionCourses = isset($course['add_teachers_to_sessions_courses']) && !empty($course['add_teachers_to_sessions_courses']) ? 1 : 0; $addTeacherToSessionCourses = isset($course['add_teachers_to_sessions_courses']) && !empty($course['add_teachers_to_sessions_courses']) ? 1 : 0;
// Updating teachers
if ($addTeacherToSessionCourses) { if ($addTeacherToSessionCourses) {
// Updating session coaches
$sessionCoaches = $course['session_coaches'];
if (!empty($sessionCoaches)) {
foreach ($sessionCoaches as $sessionId => $teacherInfo) {
$coachesToSubscribe = $teacherInfo['coaches_by_session'];
SessionManager::updateCoaches($sessionId, $course['code'], $coachesToSubscribe, true);
}
}
CourseManager::updateTeachers($course_code, $teachers, false, true, false); CourseManager::updateTeachers($course_code, $teachers, false, true, false);
} else { } else {
// Normal behaviour // Normal behaviour
CourseManager::updateTeachers($course_code, $teachers, true, false); CourseManager::updateTeachers($course_code, $teachers, true, false);
// Updating session coaches
$sessionCoaches = $course['session_coaches'];
if (!empty($sessionCoaches)) {
foreach ($sessionCoaches as $sessionId => $teacherInfo) {
$coachesToSubscribe = $teacherInfo['coaches_by_session'];
SessionManager::updateCoaches($sessionId, $course['code'], $coachesToSubscribe, true);
}
}
} }
$sql = "INSERT IGNORE INTO ".$course_user_table . " SET $sql = "INSERT IGNORE INTO ".$course_user_table . " SET
course_code = '".Database::escape_string($course_code). "', course_code = '".Database::escape_string($course_code). "',
user_id = '".$tutor_id . "', user_id = '".$tutor_id . "',
@ -306,8 +397,7 @@ if ($form->validate()) {
Display::display_header($tool_name); Display::display_header($tool_name);
echo "<script> echo "<script>
function moveItem(origin , destination){ function moveItem(origin , destination) {
for (var i = 0 ; i<origin.options.length ; i++) { for (var i = 0 ; i<origin.options.length ; i++) {
if (origin.options[i].selected) { if (origin.options[i].selected) {
destination.options[destination.length] = new Option(origin.options[i].text,origin.options[i].value); destination.options[destination.length] = new Option(origin.options[i].text,origin.options[i].value);
@ -317,7 +407,6 @@ function moveItem(origin , destination){
} }
destination.selectedIndex = -1; destination.selectedIndex = -1;
sortOptions(destination.options); sortOptions(destination.options);
} }
function sortOptions(options) { function sortOptions(options) {
@ -344,13 +433,19 @@ function mysort(a, b) {
} }
function valide() { function valide() {
var options = document.getElementById('course_teachers').options; // Checking all multiple
for (i = 0 ; i<options.length ; i++) {
options[i].selected = true; $('select').filter(function() {
} if ($(this).attr('multiple')) {
document.update_course.submit(); $(this).find('option').each(function() {
$(this).attr('selected', true);
});
}
});
//document.update_course.submit();
} }
</script>"; </script>";
// Display the form // Display the form
$form->display(); $form->display();

@ -2003,9 +2003,9 @@ class SessionManager
} }
$tbl_session = Database::get_main_table(TABLE_MAIN_SESSION); $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
$tbl_session_user = Database::get_main_table(TABLE_MAIN_SESSION_USER); $tbl_session_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
$tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE); $tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
$tbl_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER); $tbl_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
$sessions = array(); $sessions = array();
@ -2236,6 +2236,7 @@ class SessionManager
if ($debug) { if ($debug) {
$logger->addInfo("Sessions - Adding course '$course_code' to session #$session_id"); $logger->addInfo("Sessions - Adding course '$course_code' to session #$session_id");
} }
$course_counter++; $course_counter++;
$pattern = "/\[(.*?)\]/"; $pattern = "/\[(.*?)\]/";
@ -2282,9 +2283,6 @@ class SessionManager
$error_message .= get_lang('UserDoesNotExist').' : '.$course_coach.$eol; $error_message .= get_lang('UserDoesNotExist').' : '.$course_coach.$eol;
} }
} }
} }
$users_in_course_counter = 0; $users_in_course_counter = 0;
@ -2310,7 +2308,7 @@ class SessionManager
} }
} }
$sql = "UPDATE $tbl_session_course SET nbr_users='$users_in_course_counter' WHERE course_code='$course_code'"; $sql = "UPDATE $tbl_session_course SET nbr_users = '$users_in_course_counter' WHERE course_code = '$course_code'";
Database::query($sql); Database::query($sql);
$course_info = CourseManager::get_course_information($course_code); $course_info = CourseManager::get_course_information($course_code);
@ -2319,7 +2317,7 @@ class SessionManager
} }
$access_url_id = api_get_current_access_url_id(); $access_url_id = api_get_current_access_url_id();
UrlManager::add_session_to_url($session_id, $access_url_id); UrlManager::add_session_to_url($session_id, $access_url_id);
$sql_update_users = "UPDATE $tbl_session SET nbr_users='$user_counter', nbr_courses='$course_counter' WHERE id='$session_id'"; $sql_update_users = "UPDATE $tbl_session SET nbr_users = '$user_counter', nbr_courses = '$course_counter' WHERE id = '$session_id'";
Database::query($sql_update_users); Database::query($sql_update_users);
} }
} }
@ -2393,4 +2391,27 @@ class SessionManager
} }
return $userList; return $userList;
} }
/**
* @param $sessionId
* @param $coachList
* @param $deleteCoachesNotInList
*/
public static function updateCoaches($sessionId, $courseCode, $coachList, $deleteCoachesNotInList = false)
{
$currentCoaches = SessionManager::getCoachesByCourseSession($sessionId, $courseCode);
foreach ($coachList as $userId) {
SessionManager::set_coach_to_course_session($userId, $sessionId, $courseCode);
}
if ($deleteCoachesNotInList) {
$coachesToDelete = array_diff($currentCoaches, $coachList);
if (!empty($coachesToDelete)) {
foreach ($coachesToDelete as $userId) {
SessionManager::set_coach_to_course_session($userId, $sessionId, $courseCode, true);
}
}
}
}
} }

Loading…
Cancel
Save