X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=public%2Fjavascripts%2Fassessment.js;h=ad309d7cf12d98e1656d55868b788c5d1db29d6f;hb=29c8b391bcdf6ffca53545178e2ad194287a1bdc;hp=09caf12aa37e6d2106759c43769ffb87f71e4c9c;hpb=71d1ca9c594b64d959c608a2abbff926480abad5;p=qomet.git diff --git a/public/javascripts/assessment.js b/public/javascripts/assessment.js index 09caf12..ad309d7 100644 --- a/public/javascripts/assessment.js +++ b/public/javascripts/assessment.js @@ -129,7 +129,8 @@ let V = new Vue({ this.answers.indices = indices.concat( _.shuffle(remainingIndices) ); } this.answers.index = !!paper ? paper.inputs.length : 0; - Vue.nextTick(statementsLibsRefresh); + this.answers.displayAll = assessment.display == "all"; + this.answers.showSolution = false; this.stage = 2; }; if (assessment.mode == "open") @@ -156,7 +157,7 @@ let V = new Vue({ // Got password: students answers locked to this page until potential teacher // action (power failure, computer down, ...) } - socket = io.connect("/" + assessment.name, { + socket = io.connect("/", { query: "aid=" + assessment._id + "&number=" + this.student.number + "&password=" + this.student.password }); socket.on(message.allAnswers, this.setAnswers); @@ -180,7 +181,7 @@ let V = new Vue({ }, 1000); }, // stage 2 - sendAnswer: function() { + sendOneAnswer: function() { const realIndex = this.answers.indices[this.answers.index]; let gotoNext = () => { if (this.answers.index == assessment.questions.length - 1) @@ -215,6 +216,13 @@ let V = new Vue({ }, }); }, + // TODO: I don't like that + sending should not be definitive in exam mode with display = all + sendAnswer: function() { + if (assessment.display == "one") + this.sendOneAnswer(); + else + assessment.questions.forEach(this.sendOneAnswer); + }, // stage 2 --> 3 (or 4) // from a message by statements component, or time over endAssessment: function() { @@ -223,6 +231,8 @@ let V = new Vue({ if (assessment.mode == "open") { this.stage = 4; + this.answers.showSolution = true; + this.answers.displayAll = true; return; } $.ajax("/end/assessment", { @@ -239,16 +249,19 @@ let V = new Vue({ assessment.conclusion = ret.conclusion; this.stage = 3; delete this.student["password"]; //unable to send new answers now - socket.disconnect(); - socket = null; }, }); }, // stage 3 --> 4 (on socket message "feedback") setAnswers: function(m) { - for (let i=0; i