X-Git-Url: https://git.auder.net/images/pieces/%22%20%20%20VariantRules.getPpath%28board%5Bi%5D%5Bj%5D%29%20%20%20%22.svg?a=blobdiff_plain;ds=sidebyside;f=public%2Fjavascripts%2Fassessment.js;h=95cd4d74ca5cffe0c9ca479f8206a661a1b7553d;hb=7a7dc732599b358b25b770cfc27036f4b403d1b4;hp=acce5489610e4e6684b31e25c5c73704f9f1b91e;hpb=8a2b3260841fc5c2e0d24758bf94628ac52300d3;p=qomet.git diff --git a/public/javascripts/assessment.js b/public/javascripts/assessment.js index acce548..95cd4d7 100644 --- a/public/javascripts/assessment.js +++ b/public/javascripts/assessment.js @@ -39,25 +39,53 @@ new Vue({ }, mounted: function() { $(".modal").modal(); - if (assessment.mode != "secure") - return; - window.addEventListener("keydown", e => { - // Ignore F12 (avoid accidental window resize due to devtools) - // NOTE: in Chromium at least, fullscreen mode exit with F11 cannot be prevented. - // Workaround: disable key at higher level. Possible xbindkey config: - // "false" - // m:0x10 + c:95 - // Mod2 + F11 - if (e.keyCode == 123) - e.preventDefault(); - }, false); + if (assessment.mode != "open") + { + window.addEventListener("keydown", e => { + // Ignore F12 (avoid accidental window resize due to devtools) + // NOTE: in Chromium at least, fullscreen mode exit with F11 cannot be prevented. + // Workaround: disable key at higher level. Possible xbindkey config: + // "false" + // m:0x10 + c:95 + // Mod2 + F11 + if (e.keyCode == 123) + e.preventDefault(); + }, false); + } window.addEventListener("blur", () => { - this.trySendCurrentAnswer(); - document.location.href= "/noblur"; + if (!socket) + return; + if (assessment.mode == "secure") + { + this.trySendCurrentAnswer(); + document.location.href= "/noblur"; + } + else if (assessment.mode == "exam") + socket.emit(message.studentBlur, {number:this.student.number}); }, false); + if (assessment.mode == "exam") + { + window.addEventListener("focus", () => { + if (!socket) + return; + socket.emit(message.studentFocus, {number:this.student.number}); + }, false); + } window.addEventListener("resize", e => { - this.trySendCurrentAnswer(); - document.location.href= "/fullscreen"; + if (!socket) + return; + if (assessment.mode == "secure") + { + this.trySendCurrentAnswer(); + document.location.href= "/fullscreen"; + } + else if (assessment.mode == "exam") + { + if (checkWindowSize()) + socket.emit(message.studentFullscreen, {number:this.student.number}); + else + socket.emit(message.studentResize, {number:this.student.number}); + } }, false); }, methods: { @@ -246,7 +274,6 @@ new Vue({ success: ret => { if (!!ret.errmsg) return this.showWarning(ret.errmsg); - assessment.conclusion = ret.conclusion; this.stage = 3; delete this.student["password"]; //unable to send new answers now },