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.
241 lines
9.7 KiB
241 lines
9.7 KiB
<?php
|
|
/* For licensing terms, see /license.txt */
|
|
/**
|
|
* @package chamilo.admin
|
|
*/
|
|
|
|
// name of the language file that needs to be included
|
|
$language_file = 'admin';
|
|
$cidReset = true;
|
|
$this_section = SECTION_PLATFORM_ADMIN;
|
|
|
|
api_protect_admin_script();
|
|
|
|
$course_table = Database::get_main_table(TABLE_MAIN_COURSE);
|
|
$course_code = isset($_GET['course_code']) ? $_GET['course_code'] : $_POST['code'];
|
|
|
|
$noPHP_SELF = true;
|
|
$tool_name = get_lang('ModifyCourseInfo');
|
|
$interbreadcrumb[] = array ("url" => 'index.php', "name" => get_lang('PlatformAdmin'));
|
|
$interbreadcrumb[] = array ("url" => "course_list.php", "name" => get_lang('CourseList'));
|
|
|
|
// Get all course categories
|
|
$table_user = Database :: get_main_table(TABLE_MAIN_USER);
|
|
|
|
//Get the course infos
|
|
$course = api_get_course_info($course_code);
|
|
if (empty($course)) {
|
|
header('Location: course_list.php');
|
|
exit;
|
|
}
|
|
|
|
// Get course teachers
|
|
$table_course_user = Database :: get_main_table(TABLE_MAIN_COURSE_USER);
|
|
$order_clause = api_sort_by_first_name() ? ' ORDER BY firstname, lastname' : ' ORDER BY lastname, firstname';
|
|
$sql = "SELECT user.user_id,lastname,firstname
|
|
FROM $table_user as user,$table_course_user as course_user
|
|
WHERE
|
|
course_user.status='1' AND
|
|
course_user.user_id=user.user_id AND
|
|
course_user.c_id ='".$course['real_id']."'".
|
|
$order_clause;
|
|
$res = Database::query($sql);
|
|
$course_teachers = array();
|
|
while ($obj = Database::fetch_object($res)) {
|
|
$course_teachers[$obj->user_id] = api_get_person_name($obj->firstname, $obj->lastname);
|
|
}
|
|
|
|
// Get all possible teachers without the course teachers
|
|
/*$sql = "SELECT u.user_id,lastname,firstname
|
|
FROM $table_user as u
|
|
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 or status = 2 ".$order_clause;*/
|
|
/** @var Doctrine\ORM\EntityManager $em */
|
|
/*$em = $this->getDoctrine()->getManager();
|
|
$userManager = $em->getRepository('ApplicationSonataUserBundle:User');
|
|
var_dump($userManager->getTeachers());*/
|
|
//$userManager->get
|
|
|
|
|
|
$teachersInPlatform = CourseManager::get_teacher_list_from_course_code($course['real_id']);
|
|
$teachers = array();
|
|
|
|
$platform_teachers[0] = '-- '.get_lang('NoManager').' --';
|
|
foreach ($teachersInPlatform as $teacher) {
|
|
$teacherId = $teacher['user_id'];
|
|
if (!array_key_exists($teacherId, $course_teachers)) {
|
|
$teachers[$teacherId] = api_get_person_name($teacher['firstname'], $teacher['lastname']);
|
|
}
|
|
|
|
if (isset($course['tutor_name']) && isset($course_teachers[$teacherId]) && $course['tutor_name'] == $course_teachers[$teacherId]) {
|
|
$course['tutor_name'] = $teacherId;
|
|
}
|
|
//We add in the array platform teachers
|
|
$platform_teachers[$teacherId] = api_get_person_name($teacher['firstname'], $teacher['lastname']);
|
|
}
|
|
|
|
//Case where there is no teacher in the course
|
|
if (count($course_teachers) ==0 ) {
|
|
$sql='SELECT tutor_name FROM '.$course_table.' WHERE code="'.$course_code.'"';
|
|
$res = Database::query($sql);
|
|
$tutor_name=Database::result($res,0,0);
|
|
$course['tutor_name']=array_search($tutor_name,$platform_teachers);
|
|
}
|
|
|
|
// Build the form
|
|
$form = new FormValidator('update_course');
|
|
$form->addElement('hidden','code',$course_code);
|
|
|
|
//title
|
|
$form->add_textfield('title', get_lang('Title'), true, array ('class' => 'span6'));
|
|
$form->applyFilter('title','html_filter');
|
|
$form->applyFilter('title','trim');
|
|
|
|
// Code
|
|
$element = $form->addElement('text', 'real_code', array(get_lang('CourseCode'), get_lang('ThisValueCantBeChanged')));
|
|
$element->freeze();
|
|
|
|
// Id
|
|
$element = $form->addElement('text', 'real_id', 'id');
|
|
$element->freeze();
|
|
|
|
// visual code
|
|
$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','html_filter');
|
|
|
|
//$form->addElement('text', tutor_name', get_lang('CourseTitular'));
|
|
|
|
//$form->addElement('select', 'tutor_name', get_lang('CourseTitular'), $platform_teachers, array('style'=>'width:350px','id'=>'tutor_name_id', 'class'=>'chzn-select'));
|
|
//$form->applyFilter('tutor_name','html_filter');
|
|
|
|
//$form->addElement('select', 'course_teachers', get_lang('CourseTeachers'), $teachers, 'multiple=multiple size="4" style="width: 150px;"');
|
|
|
|
$group = array(
|
|
$form->createElement('select', 'platform_teachers', '', $teachers, ' id="platform_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;"')
|
|
);
|
|
|
|
$multiSelectTemplate = $form->getDoubleMultipleSelectTemplate();
|
|
$renderer = $form->defaultRenderer();
|
|
$renderer->setElementTemplate($multiSelectTemplate, 'group');
|
|
$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="arrowl" style="width:30px;height:30px;padding-left:13px" type="button" onclick="moveItem(document.getElementById(\'course_teachers\'), document.getElementById(\'platform_teachers\'))" ></td><td>'
|
|
);
|
|
|
|
|
|
$categories_select = $form->addElement('select', 'category_code', get_lang('CourseFaculty'), array() , array('style'=>'width:350px','id'=>'category_code_id', 'class'=>'chzn-select'));
|
|
$categories_select->addOption('-','');
|
|
CourseManager::select_and_sort_categories($categories_select);
|
|
|
|
$form->add_textfield( 'department_name', get_lang('CourseDepartment'), false,array ('size' => '60'));
|
|
$form->applyFilter('department_name','html_filter');
|
|
$form->applyFilter('department_name','trim');
|
|
|
|
$form->add_textfield( 'department_url', get_lang('CourseDepartmentURL'),false, array ('size' => '60'));
|
|
$form->applyFilter('department_url','html_filter');
|
|
$form->applyFilter('department_url','trim');
|
|
|
|
$form->addElement('select_language', 'course_language', get_lang('CourseLanguage'));
|
|
$form->applyFilter('select_language','html_filter');
|
|
|
|
$group = array();
|
|
$group[]= $form->createElement('radio', 'visibility', get_lang("CourseAccess"), get_lang('OpenToTheWorld'), COURSE_VISIBILITY_OPEN_WORLD);
|
|
$group[]= $form->createElement('radio', 'visibility', null, get_lang('OpenToThePlatform'), COURSE_VISIBILITY_OPEN_PLATFORM);
|
|
$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('CourseVisibilityHidden'), COURSE_VISIBILITY_HIDDEN);
|
|
$form->addGroup($group,'', get_lang('CourseAccess'), '<br />');
|
|
|
|
$group = array();
|
|
$group[]= $form->createElement('radio', 'subscribe', get_lang('Subscription'), get_lang('Allowed'), 1);
|
|
$group[]= $form->createElement('radio', 'subscribe', null, get_lang('Denied'), 0);
|
|
$form->addGroup($group,'', get_lang('Subscription'), '<br />');
|
|
|
|
$group = array();
|
|
$group[]= $form->createElement('radio', 'unsubscribe', get_lang('Unsubscription'), get_lang('AllowedToUnsubscribe'), 1);
|
|
$group[]= $form->createElement('radio', 'unsubscribe', null, get_lang('NotAllowedToUnsubscribe'), 0);
|
|
$form->addGroup($group,'', get_lang('Unsubscription'), '<br />');
|
|
|
|
|
|
$form->addElement('text','disk_quota',array(get_lang('CourseQuota'), null, get_lang('MB')));
|
|
$form->addRule('disk_quota', get_lang('ThisFieldIsRequired'),'required');
|
|
$form->addRule('disk_quota',get_lang('ThisFieldShouldBeNumeric'),'numeric');
|
|
|
|
//Extra fields
|
|
$extra_field = new ExtraField('course');
|
|
$extra = $extra_field->addElements($form, $course_code);
|
|
|
|
$htmlHeadXtra[] ='
|
|
<script>
|
|
$(function() {
|
|
'.$extra['jquery_ready_content'].'
|
|
});
|
|
</script>';
|
|
|
|
$form->addElement('style_submit_button', 'button', get_lang('ModifyCourseInfo'),'onclick="valide()"; class="save"');
|
|
|
|
// Set some default values
|
|
//$course['disk_quota'] = round($course['disk_quota']/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['real_code'] = $course['code'];
|
|
|
|
$form->setDefaults($course);
|
|
|
|
// Validate form
|
|
if ($form->validate()) {
|
|
$course = $form->getSubmitValues();
|
|
$visual_code = CourseManager::generate_course_code($course['visual_code']);
|
|
// make sure to rebase the disk quota (shown in MB but stored in bytes)
|
|
$course['disk_quota'] = $course['disk_quota']*1024*1024;
|
|
CourseManager::update($course);
|
|
|
|
// Check if the visual code is already used by *another* course
|
|
$visual_code_is_used = false;
|
|
|
|
$warn = get_lang('TheFollowingCoursesAlreadyUseThisVisualCode').':';
|
|
if (!empty($visual_code)) {
|
|
$list = CourseManager::get_courses_info_from_visual_code($visual_code);
|
|
foreach ($list as $course_temp) {
|
|
if ($course_temp['code'] != $course_code) {
|
|
$visual_code_is_used = true;
|
|
$warn .= ' '.$course_temp['title'].' ('.$course_temp['code'].'),';
|
|
}
|
|
}
|
|
$warn = substr($warn,0,-1);
|
|
}
|
|
if ($visual_code_is_used) {
|
|
header('Location: course_list.php?action=show_msg&warn='.urlencode($warn));
|
|
exit;
|
|
} else {
|
|
header('Location: course_list.php');
|
|
exit;
|
|
}
|
|
}
|
|
|
|
Display::display_header($tool_name);
|
|
|
|
echo "<script>
|
|
function valide() {
|
|
var options = document.getElementById('course_teachers').options;
|
|
for (i = 0 ; i<options.length ; i++) {
|
|
options[i].selected = true;
|
|
}
|
|
document.update_course.submit();
|
|
}
|
|
</script>";
|
|
// Display the form
|
|
$form->display();
|
|
|
|
Display :: display_footer();
|
|
|