From fe8bdd3aee1103c95eff7de4ab2859cb4c72e409 Mon Sep 17 00:00:00 2001 From: Oliver Foster Date: Mon, 8 Jul 2024 10:30:27 +0100 Subject: [PATCH] Fix: Ensure question number is configured when restoring (fixes #200) (#201) * Fix: Ensure question number is configured when restoring (fixes #200) * Setup question number on restore last attempt also * Ensure specific subject models are set as partofassessment only --- js/adapt-assessmentArticleModel.js | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/js/adapt-assessmentArticleModel.js b/js/adapt-assessmentArticleModel.js index 54730e0..e114156 100644 --- a/js/adapt-assessmentArticleModel.js +++ b/js/adapt-assessmentArticleModel.js @@ -87,7 +87,7 @@ const AssessmentModel = { } // save original children this._originalChildModelsStore = this.getChildren().models; - this._setAssessmentOwnershipOnChildrenModels(); + this._setAssessmentOwnershipOnChildrenModels(this._originalChildModelsStore); return this._originalChildModelsStore; } }); @@ -108,7 +108,7 @@ const AssessmentModel = { }); }, - _setAssessmentOwnershipOnChildrenModels() { + _setAssessmentOwnershipOnChildrenModels(childModels) { // mark all children components as belonging to an assessment const assessmentConfig = this.get('_assessment'); const childConfig = { @@ -116,10 +116,10 @@ const AssessmentModel = { _assessmentId: assessmentConfig._id }; - for (const blockModel of this._originalChildModels) { - blockModel.set(childConfig); + for (const childModel of childModels) { + childModel.set(childConfig); // make sure components are set to _isPartOfAssessment for plp checking - blockModel.setOnChildren(childConfig); + childModel.setOnChildren(childConfig); } }, @@ -184,6 +184,7 @@ const AssessmentModel = { quizModels = quizModels.concat(outsideModels); } this.getChildren().reset(quizModels); + this._setAssessmentOwnershipOnChildrenModels(quizModels); this.setupCurrentQuestionComponents(); if (shouldResetAssessment || shouldResetQuestions) { this._resetFilter(); @@ -748,6 +749,8 @@ const AssessmentModel = { if (_isAssessmentComplete) this._checkIsPass(); + this._setAssessmentOwnershipOnChildrenModels(blocks); + Adapt.trigger('assessments:restored', this.getState(), this); },