12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391 |
- <?php
- /* For licensing terms, see /license.txt */
- use ChamiloSession as Session;
- /**
- * @package chamilo.survey
- *
- * @author unknown, the initial survey that did not make it in 1.8 because of bad code
- * @author Patrick Cool <patrick.cool@UGent.be>, Ghent University: cleanup,
- * refactoring and rewriting large parts of the code
- * @author Julio Montoya <gugli100@gmail.com>, Chamilo: Personality Test
- * modification and rewriting large parts of the code as well
- *
- * @todo check if the user already filled the survey and if this
- * is the case then the answers have to be updated and not stored again.
- * @todo performance could be improved if not the survey_id was
- * stored with the invitation but the survey_code
- */
- // Unsetting the course id (because it is in the URL)
- if (!isset($_GET['cidReq'])) {
- $cidReset = true;
- } else {
- $_cid = $_GET['cidReq'];
- }
- require_once __DIR__.'/../inc/global.inc.php';
- // Database table definitions
- $table_survey = Database::get_course_table(TABLE_SURVEY);
- $table_survey_answer = Database::get_course_table(TABLE_SURVEY_ANSWER);
- $table_survey_question = Database::get_course_table(TABLE_SURVEY_QUESTION);
- $table_survey_question_option = Database::get_course_table(TABLE_SURVEY_QUESTION_OPTION);
- $table_survey_invitation = Database::get_course_table(TABLE_SURVEY_INVITATION);
- $table_user = Database::get_main_table(TABLE_MAIN_USER);
- $allowRequiredSurveyQuestions = api_get_configuration_value('allow_required_survey_questions');
- // Check if user is anonymous or not
- $isAnonymous = false;
- if (api_is_anonymous(api_get_user_id(), true)) {
- $isAnonymous = true;
- }
- // getting all the course information
- if (isset($_GET['course'])) {
- $courseInfo = api_get_course_info($_GET['course']);
- } else {
- $courseInfo = api_get_course_info();
- }
- if (empty($courseInfo)) {
- api_not_allowed(true);
- }
- $userInfo = api_get_user_info();
- $sessionId = isset($_GET['id_session']) ? (int) $_GET['id_session'] : api_get_session_id();
- // Breadcrumbs
- if (!empty($userInfo)) {
- $interbreadcrumb[] = [
- 'url' => api_get_path(WEB_CODE_PATH).'survey/survey_list.php?cidReq='.$courseInfo['code'].'&id_session='.$sessionId,
- 'name' => get_lang('Survey list'),
- ];
- }
- $course_id = $courseInfo['real_id'];
- $surveyCode = isset($_GET['scode']) ? Database::escape_string($_GET['scode']) : '';
- if ($surveyCode != '') {
- // Firstly we check if this survey is ready for anonymous use:
- $sql = "SELECT anonymous FROM $table_survey
- WHERE c_id = $course_id AND code ='".$surveyCode."'";
- $resultAnonymous = Database::query($sql);
- $rowAnonymous = Database::fetch_array($resultAnonymous, 'ASSOC');
- // If is anonymous and is not allowed to take the survey to anonymous users, forbid access:
- if (!isset($rowAnonymous['anonymous']) ||
- ($rowAnonymous['anonymous'] == 0 && api_is_anonymous()) ||
- count($rowAnonymous) == 0
- ) {
- api_not_allowed(true);
- }
- // If is anonymous and it is allowed to take the survey as anonymous, mark survey as anonymous.
- }
- // First we check if the needed parameters are present
- if ((!isset($_GET['course']) || !isset($_GET['invitationcode'])) && !isset($_GET['user_id'])) {
- api_not_allowed(true, get_lang('There is a parameter missing in the link. Please use copy and past'));
- }
- $invitationcode = $_GET['invitationcode'];
- // Start auto-invitation feature FS#3403 (all-users-can-do-the-survey-URL handling)
- if ($invitationcode == 'auto' && isset($_GET['scode'])) {
- $userid = api_get_user_id();
- // Survey_code of the survey
- $surveyCode = $_GET['scode'];
- if ($isAnonymous) {
- $autoInvitationcode = 'auto-ANONY_'.md5(time())."-$surveyCode";
- } else {
- $invitations = SurveyManager::getUserInvitationsForSurveyInCourse(
- $userid,
- $surveyCode,
- $courseInfo['real_id'],
- $sessionId
- );
- $lastInvitation = current($invitations);
- if (!$lastInvitation) {
- // New invitation code from userid
- $autoInvitationcode = "auto-$userid-$surveyCode";
- } else {
- $autoInvitationcode = $lastInvitation->getInvitationCode();
- }
- }
- // The survey code must exist in this course, or the URL is invalid
- $sql = "SELECT * FROM $table_survey
- WHERE c_id = $course_id AND code = '".Database::escape_string($surveyCode)."'";
- $result = Database::query($sql);
- if (Database :: num_rows($result) > 0) {
- // Check availability
- $row = Database::fetch_array($result, 'ASSOC');
- $tempdata = SurveyManager::get_survey($row['survey_id']);
- SurveyManager::checkTimeAvailability($tempdata);
- // Check for double invitation records (insert should be done once)
- $sql = "SELECT user
- FROM $table_survey_invitation
- WHERE
- c_id = $course_id AND
- invitation_code = '".Database::escape_string($autoInvitationcode)."'";
- $result = Database::query($sql);
- $now = api_get_utc_datetime();
- if (Database :: num_rows($result) == 0) {
- $params = [
- 'c_id' => $course_id,
- 'survey_code' => $surveyCode,
- 'user' => $userid,
- 'invitation_code' => $autoInvitationcode,
- 'invitation_date' => $now,
- ];
- Database::insert($table_survey_invitation, $params);
- }
- // From here we use the new invitationcode auto-userid-surveycode string
- $_GET['invitationcode'] = $autoInvitationcode;
- $invitationcode = $autoInvitationcode;
- }
- }
- // Now we check if the invitation code is valid
- $sql = "SELECT * FROM $table_survey_invitation
- WHERE
- c_id = $course_id AND
- invitation_code = '".Database::escape_string($invitationcode)."'";
- $result = Database::query($sql);
- if (Database::num_rows($result) < 1) {
- api_not_allowed(true, get_lang('Wrong invitation code'));
- }
- $survey_invitation = Database::fetch_array($result, 'ASSOC');
- $surveyUserFromSession = Session::read('surveyuser');
- // Now we check if the user already filled the survey
- if (!isset($_POST['finish_survey']) &&
- (
- $isAnonymous &&
- !empty($surveyUserFromSession) &&
- SurveyUtil::isSurveyAnsweredFlagged($survey_invitation['survey_code'], $survey_invitation['c_id'])
- ) ||
- ($survey_invitation['answered'] == 1 && !isset($_GET['user_id']))
- ) {
- api_not_allowed(true, Display::return_message(get_lang('You already filled this survey')));
- }
- $logInfo = [
- 'tool' => TOOL_SURVEY,
- 'tool_id' => $survey_invitation['survey_invitation_id'],
- 'tool_id_detail' => 0,
- 'action' => 'invitationcode',
- 'action_details' => $invitationcode,
- ];
- Event::registerLog($logInfo);
- // Checking if there is another survey with this code.
- // If this is the case there will be a language choice
- $sql = "SELECT * FROM $table_survey
- WHERE
- c_id = $course_id AND
- code = '".Database::escape_string($survey_invitation['survey_code'])."'";
- $sql .= api_get_session_condition($sessionId);
- $result = Database::query($sql);
- if (Database::num_rows($result) > 1) {
- if ($_POST['language']) {
- $survey_invitation['survey_id'] = $_POST['language'];
- } else {
- Display::display_header(get_lang('Surveys'));
- $frmLangUrl = api_get_self().'?'.api_get_cidreq().'&'
- .http_build_query([
- 'course' => Security::remove_XSS($_GET['course']),
- 'invitationcode' => Security::remove_XSS($_GET['invitationcode']),
- ]);
- echo '<form id="language" name="language" method="POST" action="'.$frmLangUrl.'">';
- echo '<select name="language">';
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- echo '<option value="'.$row['survey_id'].'">'.$row['lang'].'</option>';
- }
- echo '</select>';
- echo '<button type="submit" name="Submit" class="next">'.get_lang('Validate').'</button>';
- echo '</form>';
- Display::display_footer();
- exit();
- }
- } else {
- $row = Database::fetch_array($result, 'ASSOC');
- $survey_invitation['survey_id'] = $row['survey_id'];
- }
- // Getting the survey information
- $survey_data = SurveyManager::get_survey($survey_invitation['survey_id']);
- if (empty($survey_data)) {
- api_not_allowed(true);
- }
- // Checking time availability
- SurveyManager::checkTimeAvailability($survey_data);
- $survey_data['survey_id'] = $survey_invitation['survey_id'];
- if ($survey_data['survey_type'] == '3') {
- header('Location: '.
- api_get_path(WEB_CODE_PATH).
- 'survey/meeting.php?cidReq='.$courseInfo['code'].'&id_session='.$sessionId.'&invitationcode='.Security::remove_XSS($invitationcode)
- );
- exit;
- }
- if (!empty($survey_data['anonymous'])) {
- define('USER_IN_ANON_SURVEY', true);
- }
- // Storing the answers
- if (count($_POST) > 0) {
- if ($survey_data['survey_type'] === '0') {
- $types = [];
- $required = [];
- // Getting all the types of the question
- // (because of the special treatment of the score question type
- $sql = "SELECT * FROM $table_survey_question
- WHERE
- c_id = $course_id AND
- survey_id = '".intval($survey_invitation['survey_id'])."'";
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $types[$row['question_id']] = $row['type'];
- $required[$row['question_id']] = $allowRequiredSurveyQuestions && $row['is_required'];
- }
- // Looping through all the post values
- foreach ($_POST as $key => &$value) {
- // If the post value key contains the string 'question' then it is an answer on a question
- if (strpos($key, 'question') !== false && ($key != '_qf__question')) {
- // Finding the question id by removing 'question'
- $survey_question_id = str_replace('question', '', $key);
- // If not question ID was defined, we're on the start
- // screen or something else that doesn't require
- // saving an answer
- if (empty($survey_question_id)) {
- continue;
- }
- /* If the post value is an array then we have a multiple response question or a scoring question type
- remark: when it is a multiple response then the value of the array is the option_id
- when it is a scoring question then the key of the array is the option_id and the value is the value
- */
- if (is_array($value)) {
- SurveyUtil::remove_answer(
- $survey_invitation['user'],
- $survey_invitation['survey_id'],
- $survey_question_id,
- $course_id
- );
- foreach ($value as $answer_key => &$answer_value) {
- if ($types[$survey_question_id] == 'score') {
- $option_id = $answer_key;
- $option_value = $answer_value;
- } else {
- $option_id = $answer_value;
- $option_value = '';
- }
- SurveyUtil::store_answer(
- $survey_invitation['user'],
- $survey_invitation['survey_id'],
- $survey_question_id,
- $option_id,
- $option_value,
- $survey_data
- );
- }
- } else {
- // All the other question types (open question, multiple choice, percentage, ...)
- if (isset($types[$survey_question_id]) &&
- $types[$survey_question_id] == 'percentage') {
- $sql = "SELECT * FROM $table_survey_question_option
- WHERE
- c_id = $course_id AND
- question_option_id='".intval($value)."'";
- $result = Database::query($sql);
- $row = Database::fetch_array($result, 'ASSOC');
- $option_value = $row['option_text'];
- } else {
- $option_value = 0;
- if (isset($types[$survey_question_id]) &&
- $types[$survey_question_id] == 'open'
- ) {
- $option_value = $value;
- }
- }
- $survey_question_answer = $value;
- SurveyUtil::remove_answer(
- $survey_invitation['user'],
- $survey_invitation['survey_id'],
- $survey_question_id,
- $course_id
- );
- SurveyUtil::store_answer(
- $survey_invitation['user'],
- $survey_invitation['survey_id'],
- $survey_question_id,
- $value,
- $option_value,
- $survey_data
- );
- }
- }
- }
- } elseif ($survey_data['survey_type'] === '1') {
- //conditional/personality-test type surveys
- // Getting all the types of the question (because of the special treatment of the score question type
- $shuffle = '';
- if ($survey_data['shuffle'] == '1') {
- $shuffle = ' ORDER BY RAND() ';
- }
- $sql = "SELECT * FROM $table_survey_question
- WHERE
- c_id = $course_id AND
- survey_id = '".intval($survey_invitation['survey_id'])."' AND
- survey_group_pri = '0' $shuffle";
- $result = Database::query($sql);
- // There is only one question type for conditional surveys
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $types[$row['question_id']] = $row['type'];
- }
- // Looping through all the post values
- foreach ($_POST as $key => &$value) {
- // If the post value key contains the string 'question' then it is an answer to a question
- if (strpos($key, 'question') !== false) {
- // Finding the question id by removing 'question'
- $survey_question_id = str_replace('question', '', $key);
- // If not question ID was defined, we're on the start
- // screen or something else that doesn't require
- // saving an answer
- if (empty($survey_question_id)) {
- continue;
- }
- // We select the correct answer and the puntuacion
- $sql = "SELECT value FROM $table_survey_question_option
- WHERE c_id = $course_id AND question_option_id='".intval($value)."'";
- $result = Database::query($sql);
- $row = Database::fetch_array($result, 'ASSOC');
- $option_value = $row['value'];
- //$option_value = 0;
- $survey_question_answer = $value;
- // We save the answer after making sure that a possible previous attempt is deleted
- SurveyUtil::remove_answer(
- $survey_invitation['user'],
- $survey_invitation['survey_id'],
- $survey_question_id,
- $course_id
- );
- SurveyUtil::store_answer(
- $survey_invitation['user'],
- $survey_invitation['survey_id'],
- $survey_question_id,
- $value,
- $option_value,
- $survey_data
- );
- }
- }
- } else {
- // In case it's another type than 0 or 1
- api_not_allowed(true, get_lang('Survey type unknown'));
- }
- }
- $user_id = api_get_user_id();
- if ($user_id == 0) {
- $user_id = $survey_invitation['user'];
- }
- $user_data = api_get_user_info($user_id);
- if ($survey_data['form_fields'] != '' &&
- $survey_data['anonymous'] == 0 &&
- is_array($user_data)
- ) {
- $form_fields = explode('@', $survey_data['form_fields']);
- $list = [];
- foreach ($form_fields as $field) {
- $field_value = explode(':', $field);
- if (isset($field_value[1]) && $field_value[1] == 1) {
- if ($field_value[0] != '') {
- $val = api_substr($field_value[0], 8, api_strlen($field_value[0]));
- $list[$val] = 1;
- }
- }
- }
- $url = api_get_self().
- '?cidReq='.$courseInfo['code'].
- '&id_session='.$sessionId;
- $listQueryParams = preg_split('/&/', $_SERVER['QUERY_STRING']);
- foreach ($listQueryParams as $param) {
- $url .= '&'.Security::remove_XSS($param);
- }
- // We use the same form as in auth/profile.php
- $form = new FormValidator('profile', 'post', $url);
- if (api_is_western_name_order()) {
- if (isset($list['firstname']) && $list['firstname'] == 1) {
- //FIRST NAME
- $form->addElement('text', 'firstname', get_lang('First name'), ['size' => 40]);
- if (api_get_setting('profile', 'name') !== 'true') {
- $form->freeze(['firstname']);
- }
- $form->applyFilter(['firstname'], 'stripslashes');
- $form->applyFilter(['firstname'], 'trim');
- $form->addRule('firstname', get_lang('Required field'), 'required');
- }
- if (isset($list['lastname']) && $list['lastname'] == 1) {
- // LAST NAME
- $form->addElement('text', 'lastname', get_lang('Last name'), ['size' => 40]);
- if (api_get_setting('profile', 'name') !== 'true') {
- $form->freeze(['lastname']);
- }
- $form->applyFilter(['lastname'], 'stripslashes');
- $form->applyFilter(['lastname'], 'trim');
- $form->addRule('lastname', get_lang('Required field'), 'required');
- }
- } else {
- if (isset($list['lastname']) && $list['lastname'] == 1) {
- // LAST NAME
- $form->addElement('text', 'lastname', get_lang('Last name'), ['size' => 40]);
- if (api_get_setting('profile', 'name') !== 'true') {
- $form->freeze(['lastname']);
- }
- $form->applyFilter(['lastname'], 'stripslashes');
- $form->applyFilter(['lastname'], 'trim');
- $form->addRule('lastname', get_lang('Required field'), 'required');
- }
- if (isset($list['firstname']) && $list['firstname'] == 1) {
- //FIRST NAME
- $form->addElement('text', 'firstname', get_lang('First name'), ['size' => 40]);
- if (api_get_setting('profile', 'name') !== 'true') {
- $form->freeze(['firstname']);
- }
- $form->applyFilter(['firstname'], 'stripslashes');
- $form->applyFilter(['firstname'], 'trim');
- $form->addRule('firstname', get_lang('Required field'), 'required');
- }
- }
- if (isset($list['official_code']) && $list['official_code'] == 1) {
- // OFFICIAL CODE
- $form->addElement('text', 'official_code', get_lang('Code'), ['size' => 40]);
- if (api_get_setting('profile', 'officialcode') !== 'true') {
- $form->freeze('official_code');
- }
- $form->applyFilter('official_code', 'stripslashes');
- $form->applyFilter('official_code', 'trim');
- if (api_get_setting('registration', 'officialcode') == 'true' &&
- api_get_setting('profile', 'officialcode') == 'true'
- ) {
- $form->addRule('official_code', get_lang('Required field'), 'required');
- }
- }
- if (isset($list['email']) && $list['email'] == 1) {
- // EMAIL
- $form->addElement('text', 'email', get_lang('e-mail'), ['size' => 40]);
- if (api_get_setting('profile', 'email') !== 'true') {
- $form->freeze('email');
- }
- $form->applyFilter('email', 'stripslashes');
- $form->applyFilter('email', 'trim');
- if (api_get_setting('registration', 'email') == 'true') {
- $form->addRule('email', get_lang('Required field'), 'required');
- }
- $form->addRule('email', get_lang('e-mailWrong'), 'email');
- }
- if (isset($list['phone']) && $list['phone'] == 1) {
- // PHONE
- $form->addElement('text', 'phone', get_lang('Phone'), ['size' => 20]);
- if (api_get_setting('profile', 'phone') !== 'true') {
- $form->freeze('phone');
- }
- $form->applyFilter('phone', 'stripslashes');
- $form->applyFilter('phone', 'trim');
- if (api_get_setting('profile', 'phone') == 'true') {
- $form->addRule('phone', get_lang('Required field'), 'required');
- }
- }
- if (isset($list['language']) && $list['language'] == 1) {
- // LANGUAGE
- $form->addSelectLanguage('language', get_lang('Language'));
- if (api_get_setting('profile', 'language') !== 'true') {
- $form->freeze('language');
- }
- if (api_get_setting('profile', 'language') == 'true') {
- $form->addRule('language', get_lang('Required field'), 'required');
- }
- }
- // EXTRA FIELDS
- $extraField = new ExtraField('user');
- $returnParams = $extraField->addElements($form, api_get_user_id());
- $jquery_ready_content = $returnParams['jquery_ready_content'];
- // the $jquery_ready_content variable collects all functions
- // that will be load in the $(document).ready javascript function
- $htmlHeadXtra[] = '<script>
- $(function() {
- '.$jquery_ready_content.'
- });
- </script>';
- $form->addButtonNext(get_lang('Next'));
- $form->setDefaults($user_data);
- }
- Display::display_header(get_lang('Surveys'));
- // Displaying the survey title and subtitle (appears on every page)
- echo '<div class="survey-block">';
- echo '<div class="page-header">';
- echo '<h2>';
- echo strip_tags($survey_data['survey_title']).'</h2></div>';
- if (!empty($survey_data['survey_subtitle'])) {
- echo '<div class="survey_subtitle"><p>'.strip_tags($survey_data['survey_subtitle']).'</p></div>';
- }
- // Displaying the survey introduction
- if (
- !isset($_GET['show']) ||
- (isset($_GET['show'])) && $_GET['show'] == '') {
- // The first thing we do is delete the session
- Session::erase('paged_questions');
- Session::erase('page_questions_sec');
- $paged_questions_sec = [];
- if (!empty($survey_data['survey_introduction'])) {
- echo '<div class="survey_content">'.$survey_data['survey_introduction'].'</div>';
- }
- $limit = 0;
- }
- if ($survey_data['form_fields'] &&
- $survey_data['anonymous'] == 0 &&
- is_array($user_data) &&
- !isset($_GET['show'])
- ) {
- if ($form->validate()) {
- $user_data = $form->exportValues();
- if (is_array($user_data)) {
- if (count($user_data) > 0) {
- $extras = [];
- // Build SQL query
- $sql = "UPDATE $table_user SET";
- $update = false;
- $allowedFields = [
- 'firstname',
- 'lastname',
- 'official_code',
- 'email',
- 'phone',
- 'language',
- ];
- foreach ($user_data as $key => $value) {
- if (in_array($key, $allowedFields)) {
- $sql .= " $key = '".Database :: escape_string($value)."',";
- $update = true;
- }
- }
- // Remove trailing , from the query we have so far
- $sql = rtrim($sql, ',');
- $sql .= " WHERE id = $user_id";
- if ($update) {
- Database::query($sql);
- }
- $extraFieldValue = new ExtraFieldValue('user');
- $extraFieldValue->saveFieldValues($user_data);
- echo '<div id="survey_content" class="survey_content">'.
- get_lang('Information updated').' '.get_lang('Please fill survey').'</div>';
- }
- }
- $_GET['show'] = 0;
- $show = 0;
- // We unset the sessions
- Session::erase('paged_questions');
- Session::erase('page_questions_sec');
- $paged_questions_sec = [];
- } else {
- echo '<div id="survey_content" class="survey_content">'.get_lang('Update information').'</div>';
- // We unset the sessions
- Session::erase('paged_questions');
- Session::erase('page_questions_sec');
- $paged_questions_sec = [];
- $form->display();
- }
- }
- // Displaying the survey thanks message
- if (isset($_POST['finish_survey'])) {
- echo Display::return_message(get_lang('You have finished this survey.'), 'confirm');
- echo $survey_data['survey_thanks'];
- SurveyManager::update_survey_answered(
- $survey_data,
- $survey_invitation['user'],
- $survey_invitation['survey_code']
- );
- SurveyUtil::flagSurveyAsAnswered(
- $survey_invitation['survey_code'],
- $survey_invitation['c_id']
- );
- if ($courseInfo && !api_is_anonymous()) {
- echo Display::toolbarButton(
- get_lang('Return to Course Homepage'),
- api_get_course_url($courseInfo['code']),
- 'home'
- );
- }
- Session::erase('paged_questions');
- Session::erase('page_questions_sec');
- Display::display_footer();
- exit();
- }
- // Sets the random questions
- $shuffle = '';
- if ($survey_data['shuffle'] == 1) {
- $shuffle = ' BY RAND() ';
- }
- if ((isset($_GET['show']) && $_GET['show'] != '') ||
- isset($_POST['personality'])
- ) {
- // Getting all the questions for this page and add them to a
- // multidimensional array where the first index is the page.
- // As long as there is no pagebreak fount we keep adding questions to the page
- $questions_displayed = [];
- $counter = 0;
- //$paged_questions = Session::read('paged_questions');
- $paged_questions = [];
- // If non-conditional survey
- if ($survey_data['survey_type'] == '0') {
- if (empty($paged_questions)) {
- $sql = "SELECT * FROM $table_survey_question
- WHERE
- survey_question NOT LIKE '%{{%' AND
- c_id = $course_id AND
- survey_id = '".intval($survey_invitation['survey_id'])."'
- ORDER BY sort ASC";
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if ($survey_data['one_question_per_page'] == 1) {
- if ($row['type'] != 'pagebreak') {
- $paged_questions[$counter][] = $row['question_id'];
- $counter++;
- continue;
- }
- } else {
- if ($row['type'] == 'pagebreak') {
- $counter++;
- } else {
- $paged_questions[$counter][] = $row['question_id'];
- }
- }
- }
- Session::write('paged_questions', $paged_questions);
- }
- // Redefinition of variables and session ids to fix issue of survey not
- // showing questions - see support.chamilo.org #5529
- $course_id = $survey_invitation['c_id'];
- Session::write('_cid', $course_id);
- Session::write('_real_cid', $course_id);
- if (array_key_exists($_GET['show'], $paged_questions)) {
- if (isset($_GET['user_id'])) {
- // Get the user into survey answer table (user or anonymus)
- $my_user_id = $survey_data['anonymous'] == 1 ? $surveyUserFromSession : api_get_user_id();
- $sql = "SELECT
- survey_question.survey_group_sec1,
- survey_question.survey_group_sec2,
- survey_question.survey_group_pri,
- survey_question.question_id,
- survey_question.survey_id,
- survey_question.survey_question,
- survey_question.display,
- survey_question.sort,
- survey_question.type,
- survey_question.max_value,
- survey_question_option.question_option_id,
- survey_question_option.option_text,
- survey_question_option.sort as option_sort
- FROM $table_survey_question survey_question
- LEFT JOIN $table_survey_question_option survey_question_option
- ON survey_question.question_id = survey_question_option.question_id AND
- survey_question_option.c_id = $course_id
- WHERE
- survey_question.survey_id = '".Database::escape_string($survey_invitation['survey_id'])."' AND
- survey_question.question_id NOT IN (
- SELECT sa.question_id
- FROM ".$table_survey_answer." sa
- WHERE
- sa.user='".$my_user_id."') AND
- survey_question.c_id = $course_id
- ORDER BY survey_question.sort, survey_question_option.sort ASC";
- } else {
- $sql = "SELECT
- survey_question.survey_group_sec1,
- survey_question.survey_group_sec2,
- survey_question.survey_group_pri,
- survey_question.question_id,
- survey_question.survey_id,
- survey_question.survey_question,
- survey_question.display,
- survey_question.sort,
- survey_question.type,
- survey_question.max_value,
- survey_question_option.question_option_id,
- survey_question_option.option_text,
- survey_question_option.sort as option_sort
- ".($allowRequiredSurveyQuestions ? ', survey_question.is_required' : '')."
- FROM $table_survey_question survey_question
- LEFT JOIN $table_survey_question_option survey_question_option
- ON survey_question.question_id = survey_question_option.question_id AND
- survey_question_option.c_id = $course_id
- WHERE
- survey_question NOT LIKE '%{{%' AND
- survey_question.survey_id = '".intval($survey_invitation['survey_id'])."' AND
- survey_question.question_id IN (".implode(',', $paged_questions[$_GET['show']]).") AND
- survey_question.c_id = $course_id
- ORDER BY survey_question.sort, survey_question_option.sort ASC";
- }
- $result = Database::query($sql);
- $question_counter_max = Database::num_rows($result);
- $counter = 0;
- $limit = 0;
- $questions = [];
- while ($row = Database :: fetch_array($result, 'ASSOC')) {
- // If the type is not a pagebreak we store it in the $questions array
- if ($row['type'] != 'pagebreak') {
- $questions[$row['sort']]['question_id'] = $row['question_id'];
- $questions[$row['sort']]['survey_id'] = $row['survey_id'];
- $questions[$row['sort']]['survey_question'] = $row['survey_question'];
- $questions[$row['sort']]['display'] = $row['display'];
- $questions[$row['sort']]['type'] = $row['type'];
- $questions[$row['sort']]['options'][$row['question_option_id']] = $row['option_text'];
- $questions[$row['sort']]['maximum_score'] = $row['max_value'];
- $questions[$row['sort']]['sort'] = $row['sort'];
- $questions[$row['sort']]['is_required'] = $allowRequiredSurveyQuestions && $row['is_required'];
- }
- $counter++;
- }
- }
- } elseif ($survey_data['survey_type'] === '1') {
- $my_survey_id = (int) $survey_invitation['survey_id'];
- $current_user = Database::escape_string($survey_invitation['user']);
- if (isset($_POST['personality'])) {
- // Compute the results to get the 3 groups nearest to the user's personality
- if ($shuffle == '') {
- $order = 'BY sort ASC ';
- } else {
- $order = $shuffle;
- }
- $answer_list = [];
- // Get current user results
- $results = [];
- $sql = "SELECT
- survey_group_pri,
- user,
- SUM(value) as value
- FROM $table_survey_answer as survey_answer
- INNER JOIN $table_survey_question as survey_question
- ON (survey_question.question_id = survey_answer.question_id)
- WHERE
- survey_answer.survey_id='".$my_survey_id."' AND
- survey_answer.user='".$current_user."' AND
- survey_answer.c_id = $course_id AND
- survey_question.c_id = $course_id AND
- GROUP BY survey_group_pri
- ORDER BY survey_group_pri
- ";
- $result = Database::query($sql);
- while ($row = Database :: fetch_array($result)) {
- $answer_list['value'] = $row['value'];
- $answer_list['group'] = $row['survey_group_pri'];
- $results[] = $answer_list;
- }
- // Get the total score for each group of questions
- $totals = [];
- $sql = "SELECT SUM(temp.value) as value, temp.survey_group_pri FROM
- (
- SELECT
- MAX(value) as value,
- survey_group_pri,
- survey_question.question_id
- FROM $table_survey_question as survey_question
- INNER JOIN $table_survey_question_option as survey_question_option
- ON (survey_question.question_id = survey_question_option.question_id)
- WHERE
- survey_question.survey_id='".$my_survey_id."' AND
- survey_question.c_id = $course_id AND
- survey_question_option.c_id = $course_id AND
- survey_group_sec1='0' AND
- survey_group_sec2='0'
- GROUP BY survey_group_pri, survey_question.question_id
- ) as temp
- GROUP BY temp.survey_group_pri
- ORDER BY temp.survey_group_pri";
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- $list['value'] = $row['value'];
- $list['group'] = $row['survey_group_pri'];
- $totals[] = $list;
- }
- $final_results = [];
- // Get a percentage score for each group
- for ($i = 0; $i < count($totals); $i++) {
- for ($j = 0; $j < count($results); $j++) {
- if ($totals[$i]['group'] == $results[$j]['group']) {
- $group = $totals[$i]['group'];
- $porcen = ($results[$j]['value'] / $totals[$i]['value']);
- $final_results[$group] = $porcen;
- }
- }
- }
- // Sort the results by score (getting a list of group IDs by score into $groups)
- arsort($final_results);
- $groups = array_keys($final_results);
- $result = [];
- $count_result = 0;
- foreach ($final_results as $key => &$sub_result) {
- $result[] = ['group' => $key, 'value' => $sub_result];
- $count_result++;
- }
- // i.e 70% - 70% -70% 70% $equal_count =3
- $i = 0;
- $group_cant = 0;
- $equal_count = 0;
- // This is the case if the user does not select any question
- if ($count_result > 0) {
- // Count the number of scores equal to the first
- while (1) {
- if ($result[$i]['value'] == $result[$i + 1]['value']) {
- $equal_count++;
- } else {
- break;
- }
- $i++;
- }
- } else {
- // We force the exit of the survey undeterminated
- $equal_count = 10;
- }
- // If we have only 3 or less equal scores (i.e. 0,1 or 2 equalities), then we can use the three first groups
- if ($equal_count < 4) {
- // If there is one or less score equalities
- if ($equal_count === 0 || $equal_count === 1) {
- // i.e 70% - 70% -60% - 60% $equal_count = 1 we only get the first 2 options
- if (($result[0]['value'] == $result[1]['value']) &&
- ($result[2]['value'] == $result[3]['value'])
- ) {
- $group_cant = 1;
- } elseif (($result[0]['value'] != $result[1]['value']) &&
- ($result[1]['value'] == $result[2]['value']) && ($result[2]['value'] == $result[3]['value'])
- ) {
- // i.e 70% - 70% -0% - 0% - $equal_count = 0 we only get the first 2 options
- /* elseif (($result[0]['value'] == $result[1]['value']) && ($result[1]['value'] != $result[2]['value'])) {
- $group_cant = 0;
- } */
- /*
- // i.e 70% - 70% -60% - 60% $equal_count = 0 we only get the first 2 options
- elseif (($result[0]['value'] == $result[1]['value']) && ($result[2]['value'] == $result[3]['value'])) {
- $group_cant = 0;
- } */
- // i.e. 80% - 70% - 70% - 70%
- $group_cant = 0;
- } else {
- // i.e. 80% - 70% - 70% - 50
- // i.e. 80% - 80% - 70% - 50
- // By default we choose the highest 3
- $group_cant = 2;
- }
- } else {
- // If there are two score equalities
- $group_cant = $equal_count;
- }
- //@todo Translate these comments.
- // conditional_status
- // 0 no determinado
- // 1 determinado
- // 2 un solo valor
- // 3 valores iguales
- if ($group_cant > 0) {
- //echo '$equal_count'.$group_cant;
- // We only get highest 3
- $secondary = '';
- $combi = '';
- for ($i = 0; $i <= $group_cant; $i++) {
- $group1 = $groups[$i];
- $group2 = $groups[$i + 1];
- // Here we made all the posibilities with the 3 groups
- if ($group_cant == 2 && $i == $group_cant) {
- $group2 = $groups[0];
- $secondary .= " OR ( survey_group_sec1 = '$group1' AND survey_group_sec2 = '$group2') ";
- $secondary .= " OR ( survey_group_sec1 = '$group2' AND survey_group_sec2 = '$group1' ) ";
- $combi .= $group1.' - '.$group2." or ".$group2.' - '.$group1.'<br />';
- } else {
- if ($i != 0) {
- $secondary .= " OR ( survey_group_sec1 = '$group1' AND survey_group_sec2 = '$group2') ";
- $secondary .= " OR ( survey_group_sec1 = '$group2' AND survey_group_sec2 = '$group1' ) ";
- $combi .= $group1.' - '.$group2." or ".$group2.' - '.$group1.'<br />';
- } else {
- $secondary .= " ( survey_group_sec1 = '$group1' AND survey_group_sec2 = '$group2') ";
- $secondary .= " OR ( survey_group_sec1 = '$group2' AND survey_group_sec2 = '$group1' ) ";
- $combi .= $group1.' - '.$group2." or ".$group2.' - '.$group1.'<br />';
- }
- }
- }
- // Create the new select with the questions from the secondary phase
- if (empty($_SESSION['page_questions_sec']) &&
- !is_array($_SESSION['page_questions_sec']) &&
- count($_SESSION['page_questions_sec'] == 0)
- ) {
- $sql = "SELECT * FROM $table_survey_question
- WHERE
- c_id = $course_id AND
- survey_id = '".$my_survey_id."' AND
- ($secondary )
- ORDER BY sort ASC";
- $result = Database::query($sql);
- $counter = 0;
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if ($survey_data['one_question_per_page'] == 1) {
- $paged_questions_sec[$counter][] = $row['question_id'];
- $counter++;
- } elseif ($row['type'] == 'pagebreak') {
- $counter++;
- } else {
- // ids from question of the current survey
- $paged_questions_sec[$counter][] = $row['question_id'];
- }
- }
- Session::write('page_questions_sec', $paged_questions_sec);
- } else {
- $paged_questions_sec = Session::read('page_questions_sec');
- }
- $paged_questions = Session::read('paged_questions'); // For the sake of pages counting
- if ($shuffle == '') {
- $shuffle = ' BY survey_question.sort, survey_question_option.sort ASC ';
- }
- $val = (int) $_POST['personality'];
- if (is_array($paged_questions_sec)) {
- $sql = "SELECT
- survey_question.survey_group_sec1,
- survey_question.survey_group_sec2,
- survey_question.survey_group_pri,
- survey_question.question_id,
- survey_question.survey_id,
- survey_question.survey_question,
- survey_question.display,
- survey_question.sort,
- survey_question.type,
- survey_question.max_value,
- survey_question_option.question_option_id,
- survey_question_option.option_text,
- survey_question_option.sort as option_sort
- FROM $table_survey_question survey_question
- LEFT JOIN $table_survey_question_option survey_question_option
- ON survey_question.question_id = survey_question_option.question_id AND
- survey_question_option.c_id = $course_id
- WHERE
- survey_question NOT LIKE '%{{%' AND
- survey_question.survey_id = '".$my_survey_id."' AND
- survey_question.c_id = $course_id AND
- survey_question.question_id IN (".implode(',', $paged_questions_sec[$val]).")
- ORDER $shuffle ";
- $result = Database::query($sql);
- $question_counter_max = Database::num_rows($result);
- $counter = 0;
- $limit = 0;
- $questions = [];
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- // If the type is not a pagebreak we store it in the $questions array
- if ($row['type'] != 'pagebreak') {
- $questions[$row['sort']]['question_id'] = $row['question_id'];
- $questions[$row['sort']]['survey_id'] = $row['survey_id'];
- $questions[$row['sort']]['survey_question'] = $row['survey_question'];
- $questions[$row['sort']]['display'] = $row['display'];
- $questions[$row['sort']]['type'] = $row['type'];
- $questions[$row['sort']]['options'][$row['question_option_id']] = $row['option_text'];
- $questions[$row['sort']]['maximum_score'] = $row['max_value'];
- // Personality params
- $questions[$row['sort']]['survey_group_sec1'] = $row['survey_group_sec1'];
- $questions[$row['sort']]['survey_group_sec2'] = $row['survey_group_sec2'];
- $questions[$row['sort']]['survey_group_pri'] = $row['survey_group_pri'];
- $questions[$row['sort']]['sort'] = $row['sort'];
- } else {
- // If the type is a pagebreak we are finished loading the questions for this page
- break;
- }
- $counter++;
- }
- } else {
- echo get_lang('Survey undefined');
- }
- } else {
- echo get_lang('Survey undefined');
- }
- } else {
- echo get_lang('Survey undefined');
- }
- } else {
- // We need this variable only in the 2nd set of questions when personality is set.
- Session::erase('page_questions_sec');
- $paged_questions_sec = [];
- // Only the questions from the basic group
- // the 50 questions A B C D E F G
- $order_sql = $shuffle;
- if ($shuffle == '') {
- $order_sql = ' BY question_id ';
- }
- if (empty($_SESSION['paged_questions'])) {
- $sql = "SELECT * FROM $table_survey_question
- WHERE
- c_id = $course_id AND
- survey_id = '".intval($survey_invitation['survey_id'])."' AND
- survey_group_sec1='0' AND
- survey_group_sec2='0'
- ORDER ".$order_sql." ";
- $result = Database::query($sql);
- $counter = 0;
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if ($survey_data['one_question_per_page'] == 1) {
- $paged_questions[$counter][] = $row['question_id'];
- $counter++;
- } else {
- if ($row['type'] == 'pagebreak') {
- $counter++;
- } else {
- // ids from question of the current survey
- $paged_questions[$counter][] = $row['question_id'];
- }
- }
- }
- Session::write('paged_questions', $paged_questions);
- } else {
- $paged_questions = Session::read('paged_questions');
- }
- $order_sql = $shuffle;
- if ($shuffle == '') {
- $order_sql = ' BY survey_question.sort, survey_question_option.sort ASC ';
- }
- $val = $_GET['show'];
- $result = null;
- if ($val != '') {
- $imploded = Database::escape_string(implode(',', $paged_questions[$val]));
- if ($imploded != '') {
- // The answers are always in the same order NO shuffle
- $order_sql = ' BY survey_question.sort, survey_question_option.sort ASC ';
- $sql = "SELECT
- survey_question.survey_group_sec1,
- survey_question.survey_group_sec2,
- survey_question.survey_group_pri,
- survey_question.question_id,
- survey_question.survey_id,
- survey_question.survey_question,
- survey_question.display,
- survey_question.sort,
- survey_question.type,
- survey_question.max_value,
- survey_question_option.question_option_id,
- survey_question_option.option_text,
- survey_question_option.sort as option_sort
- ".($allowRequiredSurveyQuestions ? ', survey_question.is_required' : '')."
- FROM $table_survey_question survey_question
- LEFT JOIN $table_survey_question_option survey_question_option
- ON survey_question.question_id = survey_question_option.question_id AND
- survey_question_option.c_id = $course_id
- WHERE
- survey_question NOT LIKE '%{{%' AND
- survey_question.survey_id = '".intval($survey_invitation['survey_id'])."' AND
- survey_question.c_id = $course_id AND
- survey_question.question_id IN (".$imploded.")
- ORDER $order_sql ";
- $result = Database::query($sql);
- $question_counter_max = Database :: num_rows($result);
- }
- }
- if (!is_null($result)) {
- $counter = 0;
- $limit = 0;
- $questions = [];
- while ($row = Database :: fetch_array($result, 'ASSOC')) {
- // If the type is not a pagebreak we store it in the $questions array
- if ($row['type'] != 'pagebreak') {
- $questions[$row['sort']]['question_id'] = $row['question_id'];
- $questions[$row['sort']]['survey_id'] = $row['survey_id'];
- $questions[$row['sort']]['survey_question'] = $row['survey_question'];
- $questions[$row['sort']]['display'] = $row['display'];
- $questions[$row['sort']]['type'] = $row['type'];
- $questions[$row['sort']]['options'][$row['question_option_id']] = $row['option_text'];
- $questions[$row['sort']]['maximum_score'] = $row['max_value'];
- $questions[$row['sort']]['is_required'] = $allowRequiredSurveyQuestions && $row['is_required'];
- // Personality params
- $questions[$row['sort']]['survey_group_sec1'] = $row['survey_group_sec1'];
- $questions[$row['sort']]['survey_group_sec2'] = $row['survey_group_sec2'];
- $questions[$row['sort']]['survey_group_pri'] = $row['survey_group_pri'];
- $questions[$row['sort']]['sort'] = $row['sort'];
- } else {
- // If the type is a page break we are finished loading the questions for this page
- //break;
- }
- $counter++;
- }
- }
- }
- } else { // In case it's another type than 0 or 1
- echo get_lang('Survey type unknown');
- }
- }
- $numberOfPages = SurveyManager::getCountPages($survey_data);
- // Displaying the form with the questions
- $show = 0;
- if (isset($_GET['show']) && $_GET['show'] != '') {
- $show = (int) $_GET['show'] + 1;
- }
- $displayFinishButton = true;
- if (isset($_GET['show']) && $_GET['show'] != '') {
- $pagesIndexes = array_keys($paged_questions);
- $pagesIndexes[] = count($pagesIndexes);
- if (end($pagesIndexes) <= $show - 1 && empty($_POST)) {
- $displayFinishButton = false;
- }
- }
- // Displaying the form with the questions
- $personality = 0;
- if (isset($_POST['personality'])) {
- $personality = (int) $_POST['personality'] + 1;
- }
- // Displaying the form with the questions
- $g_c = isset($_GET['course']) ? Security::remove_XSS($_GET['course']) : '';
- $g_ic = isset($_GET['invitationcode']) ? Security::remove_XSS($_GET['invitationcode']) : '';
- $g_cr = isset($_GET['cidReq']) ? Security::remove_XSS($_GET['cidReq']) : '';
- $p_l = isset($_POST['language']) ? Security::remove_XSS($_POST['language']) : '';
- $add_parameters = isset($_GET['user_id']) ? '&user_id='.intval($_GET['user_id']) : '';
- $url = api_get_self().'?cidReq='.$courseInfo['code'].
- '&id_session='.$sessionId.
- $add_parameters.
- '&course='.$g_c.
- '&invitationcode='.$g_ic.
- '&show='.$show;
- $form = new FormValidator(
- 'question',
- 'post',
- $url,
- null,
- null,
- FormValidator::LAYOUT_INLINE
- );
- $form->addHidden('language', $p_l);
- if (isset($questions) && is_array($questions)) {
- $originalShow = isset($_GET['show']) ? (int) $_GET['show'] : 0;
- $questionCounter = 1;
- if (!empty($originalShow)) {
- $before = 0;
- foreach ($paged_questions as $keyQuestion => $list) {
- if ($originalShow > $keyQuestion) {
- $before += count($list);
- }
- }
- $questionCounter = $before + 1;
- }
- foreach ($questions as $key => &$question) {
- $ch_type = 'ch_'.$question['type'];
- $questionNumber = $questionCounter;
- $display = survey_question::createQuestion($question['type']);
- // @todo move this in a function.
- $form->addHtml('<div class="survey_question '.$ch_type.'">');
- $form->addHtml('<div style="float:left; font-weight: bold; margin-right: 5px;"> '.$questionNumber.'. </div>');
- $form->addHtml('<div>'.Security::remove_XSS($question['survey_question']).'</div> ');
- $userAnswerData = SurveyUtil::get_answers_of_question_by_user($question['survey_id'], $question['question_id']);
- $finalAnswer = null;
- if (!empty($userAnswerData[$user_id])) {
- $userAnswer = $userAnswerData[$user_id];
- switch ($question['type']) {
- case 'score':
- $finalAnswer = [];
- foreach ($userAnswer as $userChoice) {
- list($choiceId, $choiceValue) = explode('*', $userChoice);
- $finalAnswer[$choiceId] = $choiceValue;
- }
- break;
- case 'percentage':
- list($choiceId, $choiceValue) = explode('*', current($userAnswer));
- $finalAnswer = $choiceId;
- break;
- default:
- $finalAnswer = $userAnswer;
- break;
- }
- }
- $display->render($form, $question, $finalAnswer);
- $form->addHtml('</div>');
- $questionCounter++;
- }
- }
- $form->addHtml('<div class="start-survey">');
- if ($survey_data['survey_type'] == '0') {
- if ($survey_data['show_form_profile'] == 0) {
- // The normal survey as always
- if ($show < $numberOfPages) {
- if ($show == 0) {
- $form->addButton(
- 'next_survey_page',
- get_lang('Start the Survey'),
- 'arrow-right',
- 'success'
- );
- } else {
- $form->addButton(
- 'next_survey_page',
- get_lang('Next'),
- 'arrow-right',
- 'success'
- );
- }
- }
- if ($show >= $numberOfPages && $displayFinishButton) {
- $form->addButton(
- 'finish_survey',
- get_lang('Finish survey'),
- 'arrow-right',
- 'success'
- );
- }
- } else {
- // The normal survey as always but with the form profile
- if (isset($_GET['show'])) {
- $numberOfPages = count($paged_questions);
- if ($show < $numberOfPages) {
- if ($show == 0) {
- $form->addButton(
- 'next_survey_page',
- get_lang('Start the Survey'),
- 'arrow-right',
- 'success'
- );
- } else {
- $form->addButton(
- 'next_survey_page',
- get_lang('Next'),
- 'arrow-right',
- 'success'
- );
- }
- }
- if ($show >= $numberOfPages && $displayFinishButton) {
- $form->addButton(
- 'finish_survey',
- get_lang('Finish survey'),
- 'arrow-right',
- 'success'
- );
- }
- }
- }
- } elseif ($survey_data['survey_type'] == '1') {
- // Conditional/personality-test type survey
- if (isset($_GET['show']) || isset($_POST['personality'])) {
- $numberOfPages = count($paged_questions);
- if (!empty($paged_questions_sec) && count($paged_questions_sec) > 0) {
- // In case we're in the second phase, also sum the second group questions
- $numberOfPages += count($paged_questions_sec);
- } else {
- // We need this variable only if personality == 1
- Session::erase('page_questions_sec');
- $paged_questions_sec = [];
- }
- if ($personality == 0) {
- if (($show <= $numberOfPages) || !$_GET['show']) {
- $form->addButton('next_survey_page', get_lang('Next'), 'arrow-right', 'success');
- if ($survey_data['one_question_per_page'] == 0) {
- if ($personality >= 0) {
- $form->addHidden('personality', $personality);
- }
- } else {
- if ($personality > 0) {
- $form->addHidden('personality', $personality);
- }
- }
- if ($numberOfPages == $show) {
- $form->addHidden('personality', $personality);
- }
- }
- }
- if ($show > $numberOfPages && $_GET['show'] && $personality == 0) {
- $form->addHidden('personality', $personality);
- } elseif ($personality > 0) {
- if ($survey_data['one_question_per_page'] == 1) {
- if ($show >= $numberOfPages) {
- $form->addButton('finish_survey', get_lang('Finish survey'), 'arrow-right', 'success');
- } else {
- $form->addHidden('personality', $personality);
- $form->addButton('next_survey_page', get_lang('Next'), 'arrow-right', 'success');
- }
- } else {
- // if the personality test hidden input was set.
- $form->addButton('finish_survey', get_lang('Finish survey'), 'arrow-right');
- }
- }
- } elseif ($survey_data['form_fields'] == '') {
- // This is the case when the show_profile_form is true but there are not form_fields
- $form->addButton('next_survey_page', get_lang('Next'), 'arrow-right', 'success');
- } elseif (!is_array($user_data)) {
- // If the user is not registered in the platform we do not show the form to update his information
- $form->addButton('next_survey_page', get_lang('Next'), 'arrow-right', 'success');
- }
- }
- $form->addHtml('</div>');
- $form->display();
- Display::display_footer();
|