read($fromExercise); } if(!($objExcercise instanceOf Exercise) && !empty($exerciseId)) { $objExercise = new Exercise(); $objExercise->read($exerciseId); } if ($is_allowedToEdit) { //Duplicating a Question if ($copy_question != 0 && isset($fromExercise)) { $origin_course_id = intval($_GET['course_id']); $origin_course_info = api_get_course_info_by_id($origin_course_id); $current_course = api_get_course_info(); $old_question_id = $copy_question; //Reading the source question $old_question_obj = Question::read($old_question_id, $origin_course_id); $old_question_obj->updateTitle($old_question_obj->selectTitle().' - '.get_lang('Copy')); //Duplicating the source question, in the current course $new_id = $old_question_obj->duplicate($current_course); //Reading new question $new_question_obj = Question::read($new_id); $new_question_obj->addToList($fromExercise); //Reading Answers obj of the current course $new_answer_obj = new Answer($old_question_id, $origin_course_id); $new_answer_obj->read(); //Duplicating the Answers in the current course $new_answer_obj->duplicate($new_id, $current_course); // destruction of the Question object unset($new_question_obj); unset($old_question_obj); if(!$objExcercise instanceOf Exercise) { $objExercise = new Exercise(); $objExercise->read($fromExercise); } // adds the question ID represented by $recup into the list of questions for the current exercise //$objExercise->addToList($new_id); api_session_register('objExercise'); header("Location: admin.php?".api_get_cidreq()."&exerciseId=$fromExercise"); exit(); } // deletes a question from the data base and all exercises if($delete) { // construction of the Question object // if the question exists if($objQuestionTmp = Question::read($delete)) { // deletes the question from all exercises $objQuestionTmp->delete(); } // destruction of the Question object unset($objQuestionTmp); } elseif($recup && $fromExercise) { // gets an existing question and copies it into a new exercise $objQuestionTmp = Question :: read($recup); // if the question exists if($objQuestionTmp = Question :: read($recup)) { // adds the exercise ID represented by $fromExercise into the list of exercises for the current question $objQuestionTmp->addToList($fromExercise); } // destruction of the Question object unset($objQuestionTmp); if(!$objExcercise instanceOf Exercise) { $objExercise = new Exercise(); $objExercise->read($fromExercise); } // adds the question ID represented by $recup into the list of questions for the current exercise $objExercise->addToList($recup); api_session_register('objExercise'); header("Location: admin.php?".api_get_cidreq()."&exerciseId=$fromExercise"); exit(); } else if( isset($_POST['recup']) && is_array($_POST['recup']) && $fromExercise) { $list_recup = $_POST['recup']; foreach ($list_recup as $recup) { $recup = intval($recup); // if the question exists if($objQuestionTmp = Question :: read($recup)) { // adds the exercise ID represented by $fromExercise into the list of exercises for the current question $objQuestionTmp->addToList($fromExercise); } // destruction of the Question object unset($objQuestionTmp); if(!$objExcercise instanceOf Exercise) { $objExercise = new Exercise(); $objExercise->read($fromExercise); } // adds the question ID represented by $recup into the list of questions for the current exercise $objExercise->addToList($recup); } api_session_register('objExercise'); header("Location: admin.php?".api_get_cidreq()."&exerciseId=$fromExercise"); exit(); } } if (isset($_SESSION['gradebook'])){ $gradebook= $_SESSION['gradebook']; } if (!empty($gradebook) && $gradebook=='view') { $interbreadcrumb[]= array ('url' => '../gradebook/'.Security::remove_XSS($_SESSION['gradebook_dest']),'name' => get_lang('ToolGradebook')); } $nameTools=get_lang('QuestionPool'); $interbreadcrumb[]=array("url" => "exercice.php","name" => get_lang('Exercices')); // if admin of course if (!$is_allowedToEdit) { api_not_allowed(true); } $htmlHeadXtra[] = ' '; Display::display_header($nameTools,'Exercise'); echo '

'.$nameTools.'

'; echo '
'; if (isset($type)) { $url = api_get_self().'?type=1'; } else { $url = api_get_self(); } echo '
'; echo ''.Display::return_icon('back.png', get_lang('GoBackToQuestionList'),'','32').''; /*if(!empty($fromExercise)) { echo ''.Display::return_icon('back.png', get_lang('GoBackToQuestionList')),get_lang('GoBackToQuestionList'),''; } else { echo ''.Display::return_icon('more.png'),get_lang('NewQu').''; }*/ if (isset($type)) { echo ''; } //echo ''; echo ''; //Session list $session_list = SessionManager::get_sessions_by_coach(api_get_user_id()); $session_select_list = array(); foreach($session_list as $item) { $session_select_list[$item['id']] = $item['name']; } echo get_lang('Session').' '; echo Display::select('session_id', $session_select_list, $session_id, array('onchange'=>'submit_form(this);')); //Course list if (!empty($session_id) && $session_id != '-1') { $course_list = SessionManager::get_course_list_by_session_id($session_id); } else { $course_list = CourseManager::get_course_list_of_user_as_course_admin(api_get_user_id()); } $course_select_list = array(); foreach ($course_list as $item) { $course_select_list[$item['id']] = $item['title']; } echo ' '.get_lang('Course').' '; echo Display::select('selected_course', $course_select_list, $selected_course, array('onchange'=>'submit_form(this);')); if (empty($selected_course) || $selected_course == '-1') { $course_info = api_get_course_info(); $db_name = $course_info['db_name']; } else { $course_info = CourseManager::get_course_information_by_id($selected_course); $db_name = $course_info['db_name']; } //Redefining table calls $TBL_EXERCICE_QUESTION = Database::get_course_table(TABLE_QUIZ_TEST_QUESTION, $db_name); $TBL_EXERCICES = Database::get_course_table(TABLE_QUIZ_TEST, $db_name); $TBL_QUESTIONS = Database::get_course_table(TABLE_QUIZ_QUESTION, $db_name); $TBL_REPONSES = Database::get_course_table(TABLE_QUIZ_ANSWER, $db_name); $exercise_list = get_all_exercises($course_info, $session_id); echo ''; echo '
'; //Exercise List echo ' '.get_lang('Exercice').' '; $my_exercise_list = array(); $my_exercise_list['0'] = get_lang('AllExercises'); $my_exercise_list['-1'] = get_lang('OrphanQuestions'); if (is_array($exercise_list)) { foreach($exercise_list as $row) { if ($row['id'] != $fromExercise) { $my_exercise_list[$row['id']] = $row['title']; } } } echo Display::select('exerciseId', $my_exercise_list, $exerciseId, array('onchange'=>'submit_form(this);'), false); echo ' '.get_lang('Difficulty').' '; //Difficulty list (only from 1 to 5) echo Display::select('exerciseLevel', array(1=>1,2=>2,3=>3,4=>4,5=>5), $exerciseLevel, array('onchange'=>'submit_form(this);')); $question_list = Question::get_types_information(); $new_question_list = array(); foreach($question_list as $key=>$item) { $new_question_list[$key] = get_lang($item[1]); } //Answer type list echo ' '.get_lang('AnswerType').' '; echo Display::select('answerType', $new_question_list, $answerType, array('onchange'=>'submit_form(this);')); ?>
'; $from=$page*$limitQuestPage; // if we have selected an exercise in the list-box 'Filter' if ($exerciseId > 0) { //$sql="SELECT id,question,type FROM $TBL_EXERCICE_QUESTION,$TBL_QUESTIONS WHERE question_id=id AND exercice_id='".Database::escape_string($exerciseId)."' ORDER BY question_order LIMIT $from, ".($limitQuestPage + 1); $where = ''; if (isset($type) && $type==1) { $where = ' type = 1 AND '; } if (isset($exerciseLevel) && $exerciseLevel != -1) { $where .= ' level='.$exerciseLevel.' AND '; } if (isset($answerType) && $answerType != -1) { $where .= ' type='.$answerType.' AND '; } $sql="SELECT id,question,type,level FROM $TBL_EXERCICE_QUESTION,$TBL_QUESTIONS WHERE $where question_id=id AND exercice_id='".Database::escape_string($exerciseId)."' ORDER BY question_order"; $result=Database::query($sql); while($row = Database::fetch_array($result, 'ASSOC')) { $main_question_list[] = $row; } } elseif($exerciseId == -1) { // if we have selected the option 'Orphan questions' in the list-box 'Filter' // 1. Old logic: When a test is deleted, the correspondent records in 'quiz' and 'quiz_rel_question' tables are deleted. //$sql='SELECT id, question, type, exercice_id FROM '.$TBL_QUESTIONS.' as questions LEFT JOIN '.$TBL_EXERCICE_QUESTION.' as quizz_questions ON questions.id=quizz_questions.question_id WHERE exercice_id IS NULL LIMIT $from, '.($limitQuestPage + 1); // 2. New logic: When a test is deleted, the field 'active' takes value -1 (it is in the correspondent record in 'quiz' table). //$sql='SELECT questions.id, questions.question, questions.type, quizz_questions.exercice_id FROM '.$TBL_QUESTIONS. // ' as questions LEFT JOIN '.$TBL_EXERCICE_QUESTION.' as quizz_questions ON questions.id=quizz_questions.question_id LEFT JOIN '.$TBL_EXERCICES. // ' as exercices ON exercice_id=exercices.id WHERE exercices.active = -1 LIMIT $from, '.($limitQuestPage + 1); // 3. This is more safe to changes, it is a mix between old and new logic. /*$sql='SELECT questions.id, questions.question, questions.type, quizz_questions.exercice_id FROM '.$TBL_QUESTIONS. ' as questions LEFT JOIN '.$TBL_EXERCICE_QUESTION.' as quizz_questions ON questions.id=quizz_questions.question_id LEFT JOIN '.$TBL_EXERCICES. ' as exercices ON exercice_id=exercices.id WHERE quizz_questions.exercice_id IS NULL OR exercices.active = -1 LIMIT '.$from.', '.($limitQuestPage + 1); */ /* 4. Query changed because of the Level feature implemented $sql='SELECT id, question, type, exercice_id,level FROM '.$TBL_QUESTIONS.' as questions LEFT JOIN '.$TBL_EXERCICE_QUESTION.' as quizz_questions ON questions.id=quizz_questions.question_id AND exercice_id IS NULL '. (!is_null($exerciseLevel) && $exerciseLevel >= 0 ? 'WHERE level=\''.$exerciseLevel.'\' ' : ''); */ // 5. this is the combination of the 3 and 4 query because of the level feature implementation // we filter the type of question, because in the DirectFeedback we can only add questions with type=1 = UNIQUE_ANSWER $type_where= ''; if (isset($type) && $type==1) { $type_where = ' AND questions.type = 1 '; } $level_where = ''; if (isset($exerciseLevel) && $exerciseLevel!= -1 ) { $level_where = ' level='.$exerciseLevel.' AND '; } $answer_where = ''; if (isset($answerType) && $answerType!= -1 ) { $answer_where = ' questions.type='.$answerType.' AND '; } $sql='SELECT questions.id, questions.question, questions.type, quizz_questions.exercice_id , level, session_id FROM '.$TBL_QUESTIONS.' as questions LEFT JOIN '.$TBL_EXERCICE_QUESTION.' as quizz_questions ON questions.id=quizz_questions.question_id LEFT JOIN '.$TBL_EXERCICES.' as exercices ON exercice_id=exercices.id WHERE '.$answer_where.' '.$level_where.' (quizz_questions.exercice_id IS NULL OR exercices.active = -1 ) '.$type_where.' LIMIT '.$from.', '.($limitQuestPage + 1); } else { // if we have not selected any option in the list-box 'Filter' //$sql="SELECT id,question,type FROM $TBL_QUESTIONS LIMIT $from, ".($limitQuestPage + 1); $filter = ''; if (isset($type) && $type==1){ $filter .= ' AND qu.type = 1 '; } if (isset($exerciseLevel) && $exerciseLevel != -1) { $filter .= ' AND level='.$exerciseLevel.' '; } if (isset($answerType) && $answerType != -1) { $filter .= ' AND qu.type='.$answerType.' '; } $new_limit_page = $limitQuestPage + 1; if ($session_id != 0) { $main_question_list = array(); if (!empty($course_list)) foreach ($course_list as $course_item) { if (!empty($selected_course) && $selected_course != '-1') { if ($selected_course != $course_item['id']) { continue; } } $exercise_list = get_all_exercises($course_item, $session_id); //var_dump($exercise_list ); if (!empty($exercise_list)) { foreach ($exercise_list as $exercise) { $my_exercise = new Exercise($course_item['id']); $my_exercise->read($exercise['id']); if (!empty($my_exercise)) { if (!empty($my_exercise->questionList)) { foreach ($my_exercise->questionList as $question_id) { $question_obj = Question::read($question_id, $course_item['id']); if ($exerciseLevel != '-1') if ($exerciseLevel != $question_obj->level) { continue; } if ($answerType != '-1') if ($answerType != $question_obj->type) { continue; } $question_row = array('id'=>$question_obj->id, 'question'=>$question_obj->question, 'type'=>$question_obj->type, 'level'=>$question_obj->level, 'exercise_id'=>$exercise['id']); $main_question_list[] = $question_row; } } } } } } } else { //By default $sql="SELECT qu.id, question, qu.type, level, q.session_id FROM $TBL_QUESTIONS as qu, $TBL_EXERCICE_QUESTION as qt, $TBL_EXERCICES as q WHERE q.id=qt.exercice_id AND qu.id=qt.question_id AND qt.exercice_id<>".$fromExercise." $filter ORDER BY session_id ASC LIMIT $from, $new_limit_page"; } // forces the value to 0 //echo $sql; $exerciseId=0; } $result=Database::query($sql); //$nbrQuestions=Database::num_rows($result); $nbrQuestions=count($main_question_list); echo '', '', '', '', '', '
'; echo ''; if(!empty($page)) { echo ''; echo Display::return_icon('action_prev.png'); echo ' '.get_lang('PreviousPage'),' | '; } elseif($nbrQuestions > $limitQuestPage) { echo Display::return_icon('action_prev_na.png'); echo ' '.get_lang('PreviousPage'),' | '; } if($nbrQuestions > $limitQuestPage) { echo '',get_lang('NextPage').' '; echo Display::return_icon('action_next.png'); echo ''; } elseif($page) { echo get_lang('NextPage'); echo ' '.Display::return_icon('action_next_na.png'); } echo '
'; if(!empty($fromExercise)) { if (api_get_session_id() == 0 ){ echo ' '; } echo '',get_lang('Question'),'', '',get_lang('Level'),'', '',get_lang('Reuse'),''; } else { echo '',get_lang('Question'),'', '',get_lang('Modify'),'', '',get_lang('Delete'),''; } echo ''; $i=1; $session_id = api_get_session_id(); if (!empty($main_question_list)) foreach ($main_question_list as $row) { // if we come from the exercise administration to get a question, // don't show the questions already used by that exercise /*if (!$fromExercise) {echo '1'; } if (!isset($objExercise)){echo '2';} if (!($objExercise instanceOf Exercise)){echo '3';} if (!$objExercise->isInList($row['id'])) {echo '4';} */ // original recipe - //if (!$fromExercise || !isset($objExercise) || !($objExercise instanceOf Exercise) || (!$objExercise->isInList($row['id']))) if (!$fromExercise || !isset($objExercise) || !($objExercise instanceOf Exercise) || (is_array($objExercise->questionList)) ) { echo ''; if (api_get_session_id() == 0 ){ echo ' '; } echo ' ',$row['question'],''; echo ' '; if (empty($fromExercise)) { echo '',get_lang('Modify'),'', '', '', '',get_lang('Delete'),''; //'',get_lang('Delete'),''; } else { echo $row['level'],'', ''; echo ''; echo ' '.Display::return_icon('cd.gif', get_lang('ReUseACopyInCurrentTest')); echo ' '; if ($row['session_id'] == $session_id) { if ($selected_course == api_get_course_int_id()) { echo ''.get_lang('InsertALinkToThisQuestionInTheExercise').''; } } } echo ''; echo ''; // skips the last question, that is only used to know if we have or not to create a link "Next page" if($i == $limitQuestPage) { break; } $i++; } } if (!$nbrQuestions) { echo '', '',get_lang('NoQuestion'),'', ''; } echo ''; if (api_get_session_id() == 0 ){ echo '
'; } Display::display_footer();