mirror of
https://github.com/matt-fidd/stratos.git
synced 2026-01-01 20:39:28 +00:00
Split out singleTest route and fix priorities for routes
This commit is contained in:
@@ -81,6 +81,7 @@ router.all(/class\/(.{36})(\/.*)?/, async (req, res, next) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
priority: 30,
|
||||||
root: '/admin',
|
root: '/admin',
|
||||||
router: router
|
router: router
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -256,6 +256,7 @@ router.post('/:id/:userType(members|teachers)/:userId/remove',
|
|||||||
);
|
);
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
priority: 50,
|
||||||
root: '/admin/class',
|
root: '/admin/class',
|
||||||
router: router
|
router: router
|
||||||
};
|
};
|
||||||
|
|||||||
59
routes/singleTest.js
Normal file
59
routes/singleTest.js
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
const express = require('express');
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
router.get('/:id', async (req, res) => {
|
||||||
|
const t = req.test;
|
||||||
|
const linkRoot = `/admin/test/${t.id}`;
|
||||||
|
|
||||||
|
let results = await t.getTestResults();
|
||||||
|
|
||||||
|
if (req.session.userType === 'student') {
|
||||||
|
results = results.filter(r =>
|
||||||
|
r.student.id === req.session.userId
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return res.render('test', {
|
||||||
|
title: `Stratos - ${t.template.name}`,
|
||||||
|
current: 'Tests',
|
||||||
|
name: req.session.fullName,
|
||||||
|
testName: t.template.name,
|
||||||
|
class: t.class,
|
||||||
|
subject: t.class.subject.name,
|
||||||
|
maxMark: t.template.maxMark,
|
||||||
|
reportsLink: `${linkRoot}/reports`,
|
||||||
|
deleteLink: `${linkRoot}/delete`,
|
||||||
|
userType: req.session.userType,
|
||||||
|
testResults: results,
|
||||||
|
stats: [
|
||||||
|
{
|
||||||
|
value: 19,
|
||||||
|
text: 'Results submitted'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: '30%',
|
||||||
|
text: 'Average score'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: 1,
|
||||||
|
text: 'Placeholder'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: '2',
|
||||||
|
text: 'Placeholder'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: '3',
|
||||||
|
text: 'Placeholder'
|
||||||
|
},
|
||||||
|
]
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
priority: 50,
|
||||||
|
root: '/admin/test',
|
||||||
|
router: router
|
||||||
|
};
|
||||||
@@ -137,56 +137,9 @@ router.all(/test\/(.{36})(\/.*)?/, async (req, res, next) => {
|
|||||||
next();
|
next();
|
||||||
});
|
});
|
||||||
|
|
||||||
router.get('/test/:id', async (req, res) => {
|
|
||||||
const t = req.test;
|
|
||||||
const linkRoot = `/admin/test/${t.id}`;
|
|
||||||
|
|
||||||
let results = await t.getTestResults();
|
|
||||||
|
|
||||||
if (req.session.userType === 'student') {
|
|
||||||
results = results.filter(r =>
|
|
||||||
r.student.id === req.session.userId
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return res.render('test', {
|
|
||||||
title: `Stratos - ${t.template.name}`,
|
|
||||||
current: 'Tests',
|
|
||||||
name: req.session.fullName,
|
|
||||||
testName: t.template.name,
|
|
||||||
class: t.class,
|
|
||||||
subject: t.class.subject.name,
|
|
||||||
maxMark: t.template.maxMark,
|
|
||||||
reportsLink: `${linkRoot}/reports`,
|
|
||||||
deleteLink: `${linkRoot}/delete`,
|
|
||||||
userType: req.session.userType,
|
|
||||||
testResults: results,
|
|
||||||
stats: [
|
|
||||||
{
|
|
||||||
value: 19,
|
|
||||||
text: 'Results submitted'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: '30%',
|
|
||||||
text: 'Average score'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: 1,
|
|
||||||
text: 'Placeholder'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: '2',
|
|
||||||
text: 'Placeholder'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: '3',
|
|
||||||
text: 'Placeholder'
|
|
||||||
},
|
|
||||||
]
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
priority: 30,
|
||||||
root: '/admin',
|
root: '/admin',
|
||||||
router: router
|
router: router
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user