diff --git a/kolibri/plugins/coach/assets/src/composables/quizCreationSpecs.js b/kolibri/plugins/coach/assets/src/composables/quizCreationSpecs.js
index bcd20b216d..f827b4be6e 100644
--- a/kolibri/plugins/coach/assets/src/composables/quizCreationSpecs.js
+++ b/kolibri/plugins/coach/assets/src/composables/quizCreationSpecs.js
@@ -180,4 +180,9 @@ export const Quiz = {
type: Number,
default: getRandomInt(),
},
+ // Default to sections being shown in a fixed order
+ learners_see_fixed_order: {
+ type: Boolean,
+ default: true,
+ },
};
diff --git a/kolibri/plugins/coach/assets/src/composables/useQuizCreation.js b/kolibri/plugins/coach/assets/src/composables/useQuizCreation.js
index 5f6bcc7866..d04574820b 100644
--- a/kolibri/plugins/coach/assets/src/composables/useQuizCreation.js
+++ b/kolibri/plugins/coach/assets/src/composables/useQuizCreation.js
@@ -25,6 +25,17 @@ function validateQuiz(quiz) {
return validateObject(quiz, Quiz);
}
+const fieldsToSave = [
+ 'title',
+ 'assignments',
+ 'learner_ids',
+ 'collection',
+ 'learners_see_fixed_order',
+ 'draft',
+ 'active',
+ 'archive',
+];
+
/**
* Composable function presenting primary interface for Quiz Creation
*/
@@ -299,16 +310,17 @@ export default function useQuizCreation() {
return Promise.reject(`Quiz is not valid: ${JSON.stringify(get(_quiz))}`);
}
- const id = get(_quiz).id;
+ const quizData = get(_quiz);
+
+ const id = quizData.id;
- const finalQuiz = {
- title: get(_quiz).title,
- assignments: get(_quiz).assignments,
- learner_ids: get(_quiz).learner_ids,
- collection: get(_quiz).collection,
- };
+ const finalQuiz = {};
+
+ for (const field of fieldsToSave) {
+ finalQuiz[field] = quizData[field];
+ }
- if (get(_quiz).draft) {
+ if (finalQuiz.draft) {
// Here we update each section's `resource_pool` to only be the IDs of the resources
const questionSourcesWithoutResourcePool = get(allSections).map(section => {
const sectionToSave = { ...section };
diff --git a/kolibri/plugins/coach/assets/src/views/common/QuizStatus.vue b/kolibri/plugins/coach/assets/src/views/common/QuizStatus.vue
index 577a8df71b..7cc4653cfb 100644
--- a/kolibri/plugins/coach/assets/src/views/common/QuizStatus.vue
+++ b/kolibri/plugins/coach/assets/src/views/common/QuizStatus.vue
@@ -162,7 +162,7 @@
:layout8="{ span: 4 }"
:layout12="{ span: 12 }"
>
- {{ $tr('questionOrderLabel') }}
+ {{ sectionOrderLabel$() }}
@@ -101,7 +101,7 @@
diff --git a/kolibri/plugins/coach/assets/src/views/plan/CreateExamPage/index.vue b/kolibri/plugins/coach/assets/src/views/plan/CreateExamPage/index.vue
index a875e96290..5bcad89b70 100644
--- a/kolibri/plugins/coach/assets/src/views/plan/CreateExamPage/index.vue
+++ b/kolibri/plugins/coach/assets/src/views/plan/CreateExamPage/index.vue
@@ -27,6 +27,40 @@
@update="updateQuiz"
/>
+
+
+
+
+ updateQuiz({ learners_see_fixed_order: value })"
+ />
+
+
+ updateQuiz({ learners_see_fixed_order: value })"
+ />
+
+
+
+
@@ -92,7 +126,15 @@
const showError = ref(false);
const quizInitialized = ref(false);
- const { saveAndClose$, allSectionsEmptyWarning$ } = enhancedQuizManagementStrings;
+ const {
+ saveAndClose$,
+ allSectionsEmptyWarning$,
+ sectionOrderLabel$,
+ randomizedLabel$,
+ fixedLabel$,
+ randomizedSectionOptionDescription$,
+ fixedSectionOptionDescription$,
+ } = enhancedQuizManagementStrings;
return {
classId,
@@ -106,6 +148,11 @@
allSectionsEmpty,
allSectionsEmptyWarning$,
saveAndClose$,
+ sectionOrderLabel$,
+ randomizedLabel$,
+ fixedLabel$,
+ randomizedSectionOptionDescription$,
+ fixedSectionOptionDescription$,
};
},
provide() {
@@ -212,4 +259,9 @@
margin-right: 8px;
}
+ .section-order-header {
+ margin-top: 0;
+ margin-bottom: 0.5em;
+ }
+
diff --git a/kolibri/plugins/coach/assets/src/views/plan/QuizSummaryPage/index.vue b/kolibri/plugins/coach/assets/src/views/plan/QuizSummaryPage/index.vue
index a088c4b259..1dd9cb40cf 100644
--- a/kolibri/plugins/coach/assets/src/views/plan/QuizSummaryPage/index.vue
+++ b/kolibri/plugins/coach/assets/src/views/plan/QuizSummaryPage/index.vue
@@ -74,6 +74,7 @@
import CatchErrors from 'kolibri.utils.CatchErrors';
import commonCoreStrings from 'kolibri.coreVue.mixins.commonCoreStrings';
import { ExamResource } from 'kolibri.resources';
+ import { enhancedQuizManagementStrings } from 'kolibri-common/strings/enhancedQuizManagementStrings';
import { PageNames } from '../../../constants';
import commonCoach from '../../common';
import CoachAppBarPage from '../../CoachAppBarPage';
@@ -97,6 +98,16 @@
QuizOptionsDropdownMenu,
},
mixins: [commonCoach, coachStringsMixin, commonCoreStrings],
+ setup() {
+ const {
+ randomizedSectionOptionDescription$,
+ fixedSectionOptionDescription$,
+ } = enhancedQuizManagementStrings;
+ return {
+ randomizedSectionOptionDescription$,
+ fixedSectionOptionDescription$,
+ };
+ },
data() {
return {
quiz: {
@@ -133,8 +144,8 @@
},
orderDescriptionString() {
return this.quizIsRandomized
- ? this.coachString('orderRandomDescription')
- : this.coachString('orderFixedDescription');
+ ? this.randomizedSectionOptionDescription$()
+ : this.fixedSectionOptionDescription$();
},
classId() {
return this.$route.params.classId;
diff --git a/kolibri/plugins/coach/assets/src/views/reports/ReportsQuizPreviewPage.vue b/kolibri/plugins/coach/assets/src/views/reports/ReportsQuizPreviewPage.vue
index 991cb2fd97..c99dfa3a38 100644
--- a/kolibri/plugins/coach/assets/src/views/reports/ReportsQuizPreviewPage.vue
+++ b/kolibri/plugins/coach/assets/src/views/reports/ReportsQuizPreviewPage.vue
@@ -34,6 +34,7 @@