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.
245 lines
7.5 KiB
245 lines
7.5 KiB
<?php
|
|
|
|
/* For licensing terms, see /license.txt */
|
|
|
|
use Chamilo\CoreBundle\Framework\Container;
|
|
use Chamilo\CourseBundle\Entity\CSurvey;
|
|
|
|
require_once __DIR__.'/../inc/global.inc.php';
|
|
|
|
$this_section = SECTION_COURSES;
|
|
|
|
if (!api_is_allowed_to_edit()) {
|
|
api_not_allowed(true);
|
|
}
|
|
|
|
if (!api_is_allowed_to_edit()) {
|
|
if (!api_is_session_general_coach() ||
|
|
(!empty($_GET['survey_id']) &&
|
|
!api_is_element_in_the_session(TOOL_SURVEY, $_GET['survey_id']))
|
|
) {
|
|
api_not_allowed(true);
|
|
}
|
|
}
|
|
|
|
$interbreadcrumb[] = [
|
|
'url' => api_get_path(WEB_CODE_PATH).'survey/survey_list.php?'.api_get_cidreq(),
|
|
'name' => get_lang('Survey list'),
|
|
];
|
|
|
|
$surveyId = isset($_GET['survey_id']) ? (int) $_GET['survey_id'] : null;
|
|
$surveyRepo = Container::getSurveyRepository();
|
|
/** @var CSurvey $survey */
|
|
$survey = $surveyRepo->find($surveyId);
|
|
$surveyData = SurveyManager::get_survey($surveyId);
|
|
|
|
if (null === $survey) {
|
|
api_not_allowed(true);
|
|
}
|
|
|
|
$courseInfo = api_get_course_info();
|
|
|
|
$tool_name = get_lang('Edit');
|
|
|
|
$form = new FormValidator(
|
|
'survey',
|
|
'post',
|
|
api_get_self().'?action=edit&'.api_get_cidreq().'&survey_id='.$surveyId
|
|
);
|
|
|
|
$form->addHeader($tool_name);
|
|
$form->addHidden('anonymous', 0);
|
|
$form->addHidden('survey_language', $courseInfo['language']);
|
|
$form->addHidden('survey_subtitle', '');
|
|
$form->addHidden('survey_thanks', '');
|
|
$form->addHidden('visible_results', '0');
|
|
$form->addHidden('survey_type', 3);
|
|
$text = $form->addText('survey_title', get_lang('Title'));
|
|
|
|
$allowSurveyAvailabilityDatetime = ('true' === api_get_setting('survey.allow_survey_availability_datetime'));
|
|
|
|
if ($allowSurveyAvailabilityDatetime) {
|
|
$form->addDateTimePicker('start_date', get_lang('Start Date'));
|
|
$form->addDateTimePicker('end_date', get_lang('End Date'));
|
|
$form->addRule('start_date', get_lang('Invalid date'), 'datetime');
|
|
$form->addRule('end_date', get_lang('Invalid date'), 'datetime');
|
|
} else {
|
|
$form->addDatePicker('start_date', get_lang('Start Date'));
|
|
$form->addDatePicker('end_date', get_lang('End Date'));
|
|
$form->addRule('start_date', get_lang('Invalid date'), 'date');
|
|
$form->addRule('end_date', get_lang('Invalid date'), 'date');
|
|
}
|
|
|
|
$form->addRule(
|
|
['start_date', 'end_date'],
|
|
get_lang('Start DateShouldBeBeforeEnd Date'),
|
|
'date_compare',
|
|
'lte'
|
|
);
|
|
|
|
$form->addHtmlEditor('survey_introduction', get_lang('Description'), false);
|
|
$form->setRequired($text);
|
|
|
|
$questions = $survey->getQuestions();
|
|
$currentQuestionsCount = count($questions);
|
|
$counter = 1;
|
|
foreach ($questions as $question) {
|
|
$name = 'time_'.$counter;
|
|
$parts = explode('@@', $question->getSurveyQuestion());
|
|
$surveyData[$name] = api_get_local_time($parts[0]).'@@'.api_get_local_time($parts[1]);
|
|
|
|
$form->addDateTimeRangePicker($name, get_lang('Date'));
|
|
$form->addHidden($name.'_question_id', $question->getIid());
|
|
$counter++;
|
|
}
|
|
$currentQuestionsCount++;
|
|
|
|
$hideList = '';
|
|
$maxEvents = $currentQuestionsCount + 10;
|
|
for ($i = $currentQuestionsCount; $i <= $maxEvents; $i++) {
|
|
$name = 'time_'.$i;
|
|
$form->addDateTimeRangePicker($name, get_lang('Date'));
|
|
$hideList .= "$('#".$name."_date_time_wrapper').hide();";
|
|
}
|
|
|
|
$form->addHtml('<script>
|
|
$(function() {
|
|
'.$hideList.'
|
|
var number = "'.--$currentQuestionsCount.'";
|
|
$("#add_button").on("click", function() {
|
|
number++;
|
|
$("#time_" + number + "_date_time_wrapper").show();
|
|
$("#time_" + number + "_time_range_start").val("");
|
|
$("#time_" + number + "_time_range_end").val("");
|
|
$("#time_" + number + "_alt").val("");
|
|
});
|
|
|
|
$("#remove_button").on("click", function() {
|
|
if (number > 1) {
|
|
console.log("#time_" + number + "_time_range_start");
|
|
$("#time_" + number + "_date_time_wrapper").hide();
|
|
$("#time_" + number).val("delete");
|
|
|
|
$("#time_" + number + "_alt").val("delete");
|
|
$("#time_" + number + "_time_range_start").val("delete");
|
|
number--;
|
|
}
|
|
});
|
|
});
|
|
</script>');
|
|
|
|
$form->addLabel(
|
|
'',
|
|
Display::url(get_lang('Add'), 'javascript:void(0)', ['id' => 'add_button', 'class' => 'btn btn--plain'])
|
|
.' '.
|
|
Display::url(
|
|
get_lang('Remove'),
|
|
'javascript:void(0)',
|
|
['id' => 'remove_button', 'class' => 'btn btn--danger']
|
|
)
|
|
);
|
|
|
|
$form->addButtonUpdate(get_lang('Edit'), 'submit_survey');
|
|
$surveyData['start_date'] = api_get_local_time($surveyData['start_date']);
|
|
$surveyData['end_date'] = api_get_local_time($surveyData['end_date']);
|
|
$form->setDefaults($surveyData);
|
|
|
|
// The validation or display
|
|
if ($form->validate()) {
|
|
// Exporting the values
|
|
$values = $form->getSubmitValues();
|
|
|
|
$values['survey_id'] = $surveyId;
|
|
$values['survey_code'] = SurveyManager::generateSurveyCode($values['survey_title']);
|
|
// Storing the survey
|
|
SurveyManager::store_survey($values);
|
|
|
|
$dates = [];
|
|
$deleteItems = [];
|
|
|
|
for ($i = 1; $i <= $maxEvents; $i++) {
|
|
$name = 'time_'.$i;
|
|
|
|
if (isset($values[$name]) && !empty($values[$name])) {
|
|
$id = '';
|
|
if (isset($values[$name.'_question_id'])) {
|
|
$id = $values[$name.'_question_id'];
|
|
}
|
|
|
|
$date = $values[$name];
|
|
|
|
if ('delete' === $date && !empty($id)) {
|
|
$deleteItems[] = $id;
|
|
}
|
|
|
|
if (empty($date)) {
|
|
continue;
|
|
}
|
|
|
|
$start = $name.'_time_range_start';
|
|
$end = $name.'_time_range_end';
|
|
|
|
$start = $values[$start];
|
|
$end = $values[$end];
|
|
|
|
$part = explode('@@', $values[$name]);
|
|
$firstDate = substr($part[0], 0, 10);
|
|
|
|
$start = api_get_utc_datetime($firstDate.' '.$start);
|
|
$end = api_get_utc_datetime($firstDate.' '.$end);
|
|
|
|
if (!empty($start) && !empty($start)) {
|
|
$row = [
|
|
'id' => $id,
|
|
'start' => $start,
|
|
'end' => $end,
|
|
];
|
|
$dates[] = $row;
|
|
}
|
|
}
|
|
}
|
|
|
|
$questionTable = Database::get_course_table(TABLE_SURVEY_QUESTION);
|
|
$counter = 1;
|
|
if (!empty($surveyData['iid'])) {
|
|
foreach ($dates as $date) {
|
|
$formattedDate = $date['start'].'@@'.$date['end'];
|
|
if (!empty($date['id'])) {
|
|
$questionId = $date['id'];
|
|
$sql = "UPDATE $questionTable SET survey_question = '$formattedDate'
|
|
WHERE iid = $questionId";
|
|
Database::query($sql);
|
|
} else {
|
|
$params = [
|
|
'survey_id' => $surveyData['iid'],
|
|
'survey_question' => $formattedDate,
|
|
'survey_question_comment' => '',
|
|
'type' => 'doodle',
|
|
'display' => 'horizontal',
|
|
'sort' => $counter,
|
|
'shared_question_id' => '0',
|
|
'survey_group_pri' => 0,
|
|
'survey_group_sec1' => 0,
|
|
'survey_group_sec2' => 0,
|
|
'max_value' => 0,
|
|
];
|
|
Database::insert($questionTable, $params);
|
|
$counter++;
|
|
}
|
|
}
|
|
|
|
foreach ($deleteItems as $deleteId) {
|
|
SurveyManager::deleteQuestion($deleteId);
|
|
}
|
|
}
|
|
|
|
// Redirecting to the survey page (whilst showing the return message)
|
|
header('Location: '.api_get_path(WEB_CODE_PATH).'survey/survey_list.php?'.api_get_cidreq());
|
|
exit;
|
|
} else {
|
|
// Displaying the header
|
|
Display::display_header($tool_name);
|
|
$form->display();
|
|
}
|
|
|
|
Display::display_footer();
|
|
|