forked from EVOgeek/Vmeda.Online
		
	
						commit
						dd5a5fc1e2
					
				| @ -570,10 +570,15 @@ export class AddonModLessonPlayerPage implements OnInit, OnDestroy { | ||||
|                 // Button to continue.
 | ||||
|                 if (this.lesson.review && !result.correctanswer && !result.noanswer && !result.isessayquestion && | ||||
|                        !result.maxattemptsreached) { | ||||
|                     this.processData.buttons.push({ | ||||
|                         label: 'addon.mod_lesson.reviewquestioncontinue', | ||||
|                         pageId: result.newpageid | ||||
|                     }); | ||||
|                     /* If both the "Yes, I'd like to try again" and "No, I just want to go on to the next question" point to the | ||||
|                        same page then don't show the "No, I just want to go on to the next question" button. It's confusing. */ | ||||
|                     if (this.pageData.page.id != result.newpageid) { | ||||
|                         // Button to continue the lesson (the page to go is configured by the teacher).
 | ||||
|                         this.processData.buttons.push({ | ||||
|                             label: 'addon.mod_lesson.reviewquestioncontinue', | ||||
|                             pageId: result.newpageid | ||||
|                         }); | ||||
|                     } | ||||
|                 } else { | ||||
|                     this.processData.buttons.push({ | ||||
|                         label: 'addon.mod_lesson.continue', | ||||
|  | ||||
| @ -156,6 +156,8 @@ export class AddonModLessonProvider { | ||||
|      */ | ||||
|     static MULTIANSWER_DELIMITER = '@^#|'; | ||||
| 
 | ||||
|     static LESSON_OTHER_ANSWERS = '@#wronganswer#@'; | ||||
| 
 | ||||
|     // Variables for database.
 | ||||
|     static PASSWORD_TABLE = 'addon_mod_lesson_password'; | ||||
|     protected siteSchema: CoreSiteSchema = { | ||||
| @ -793,6 +795,8 @@ export class AddonModLessonProvider { | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         this.checkOtherAnswers(lesson, pageData, result); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @ -907,6 +911,8 @@ export class AddonModLessonProvider { | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         this.checkOtherAnswers(lesson, pageData, result); | ||||
| 
 | ||||
|         result.userresponse = studentAnswer; | ||||
|         result.studentanswer = this.textUtils.s(studentAnswer); // Clean student answer as it goes to output.
 | ||||
|     } | ||||
| @ -945,6 +951,33 @@ export class AddonModLessonProvider { | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Check the "other answers" value. | ||||
|      * | ||||
|      * @param {any} lesson Lesson. | ||||
|      * @param {any} pageData Result of getPageData for the page to process. | ||||
|      * @param {AddonModLessonCheckAnswerResult} result Object where to store the result. | ||||
|      */ | ||||
|     protected checkOtherAnswers(lesson: any, pageData: any, result: AddonModLessonCheckAnswerResult): void { | ||||
|         // We could check here to see if we have a wrong answer jump to use.
 | ||||
|         if (result.answerid == 0) { | ||||
|             // Use the all other answers jump details if it is set up.
 | ||||
|             const lastAnswer = pageData.answers[pageData.answers.length - 1] || {}; | ||||
| 
 | ||||
|             // Double check that this is the OTHER_ANSWERS answer.
 | ||||
|             if (typeof lastAnswer.answer == 'string' && | ||||
|                     lastAnswer.answer.indexOf(AddonModLessonProvider.LESSON_OTHER_ANSWERS) != -1) { | ||||
|                 result.newpageid = lastAnswer.jumpto; | ||||
|                 result.response = lastAnswer.response; | ||||
| 
 | ||||
|                 if (lesson.custom) { | ||||
|                     result.correctanswer = lastAnswer.score > 0; | ||||
|                 } | ||||
|                 result.answerid = lastAnswer.id; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Create a list of pages indexed by page ID based on a list of pages. | ||||
|      * | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user