return window.innerWidth >= screen.width-3 && window.innerHeight >= screen.height-3;
};
+function libsRefresh()
+{
+ // Run Prism + MathJax on questions text
+ $("#statements").find("code[class^=language-]").each( (i,elem) => {
+ Prism.highlightElement(elem);
+ });
+ MathJax.Hub.Queue(["Typeset",MathJax.Hub,"statements"]);
+}
+
new Vue({
el: "#assessment",
data: {
document.location.href= "/fullscreen";
}, false);
},
+ updated: function() {
+ libsRefresh(); //TODO: shouldn't be required: "MathJax" strings on start and assign them to assessment.questions. ...
+ },
methods: {
inputId: function(i,j) {
return "q" + i + "_" + "input" + j;
{
// Resuming
let indices = paper.inputs.map( input => { return input.index; });
- let remainingIndices = _.difference(_.range(assessment.questions.length), indices);
+ let remainingIndices = _.difference( _.range(assessment.questions.length).map(String), indices );
assessment.indices = indices.concat( _.shuffle(remainingIndices) );
}
assessment.index = !!paper ? paper.inputs.length : 0;
+ Vue.nextTick(libsRefresh);
this.stage = 2;
- Vue.nextTick( () => {
- // Run Prism + MathJax on questions text
- $("#statements").find("code[class^=language-]").each( (i,elem) => {
- Prism.highlightElement(elem);
- });
- MathJax.Hub.Queue(["Typeset",MathJax.Hub,"statements"]);
- });
};
if (assessment.mode == "open")
return initializeStage2();
const validator = require("../public/javascripts/utils/validation");
const ObjectId = require("bson-objectid");
const sanitizeHtml = require('sanitize-html');
+const sanitizeOpts = {
+ allowedTags: sanitizeHtml.defaults.allowedTags.concat([ 'img' ]),
+ allowedAttributes: { code: [ 'class' ] },
+};
router.get("/add/assessment", access.ajax, access.logged, (req,res) => {
const name = req.query["name"];
let error = validator(assessment, "Assessment");
if (error.length > 0)
return res.json({errmsg:error});
- const sanitizeOpts = {allowedTags: sanitizeHtml.defaults.allowedTags.concat([ 'img' ]) };
assessment.introduction = sanitizeHtml(assessment.introduction, sanitizeOpts);
assessment.conclusion = sanitizeHtml(assessment.conclusion, sanitizeOpts);
assessment.questions.forEach( q => {