mirror of
https://github.com/matt-fidd/stratos.git
synced 2026-01-01 22:59:28 +00:00
Added route for creating testResults
This commit is contained in:
@@ -73,7 +73,8 @@ router.get('/:id/results', async (req, res) => {
|
|||||||
testName: t.template.name,
|
testName: t.template.name,
|
||||||
userType: req.session.userType,
|
userType: req.session.userType,
|
||||||
testResults: results,
|
testResults: results,
|
||||||
linkRoot: linkRoot
|
linkRoot: linkRoot,
|
||||||
|
addLink: `${linkRoot}/add`
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -100,6 +101,54 @@ router.post('/:id/results/:resultId/edit', async (req, res) => {
|
|||||||
res.redirect(returnURL);
|
res.redirect(returnURL);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
router.get('/:id/results/add', async (req, res) => {
|
||||||
|
const t = req.test;
|
||||||
|
const linkRoot = `/admin/test/${t.id}/results`;
|
||||||
|
|
||||||
|
const existingResults = (await t.getTestResults())
|
||||||
|
.map(r => r.student.id);
|
||||||
|
|
||||||
|
const students = t.class.students
|
||||||
|
.filter(s => !existingResults.includes(s.id));
|
||||||
|
|
||||||
|
return res.render('addTestResult', {
|
||||||
|
title: `Stratos - ${t.template.name}`,
|
||||||
|
current: 'Tests',
|
||||||
|
name: req.session.fullName,
|
||||||
|
testName: t.template.name,
|
||||||
|
linkRoot: linkRoot,
|
||||||
|
students: students,
|
||||||
|
maxMark: t.template.maxMark
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
router.post('/:id/results/add', async (req, res) => {
|
||||||
|
const t = req.test;
|
||||||
|
const returnURL = `/admin/test/${t.id}/results`;
|
||||||
|
|
||||||
|
let fields;
|
||||||
|
try {
|
||||||
|
fields = validator.validate(req.body,
|
||||||
|
[
|
||||||
|
'student',
|
||||||
|
'mark'
|
||||||
|
]
|
||||||
|
).fields;
|
||||||
|
} catch (e) {
|
||||||
|
console.error(e);
|
||||||
|
return res.redirect(returnURL);
|
||||||
|
}
|
||||||
|
|
||||||
|
await t.addResult(
|
||||||
|
req.session.userId,
|
||||||
|
fields.get('student'),
|
||||||
|
fields.get('mark')
|
||||||
|
);
|
||||||
|
|
||||||
|
return res.redirect(returnURL);
|
||||||
|
});
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
priority: 50,
|
priority: 50,
|
||||||
root: '/admin/test',
|
root: '/admin/test',
|
||||||
|
|||||||
Reference in New Issue
Block a user