mirror of
https://github.com/matt-fidd/stratos.git
synced 2026-01-02 05:59:30 +00:00
Split class routes into two files
This commit is contained in:
@@ -79,88 +79,6 @@ router.all(/class\/(.{36})(\/.*)?/, async (req, res, next) => {
|
|||||||
next();
|
next();
|
||||||
});
|
});
|
||||||
|
|
||||||
router.get('/class/:id', async (req, res) => {
|
|
||||||
const c = await new Class(req.db, req.params.id);
|
|
||||||
const linkRoot = `/admin/class/${c.id}`;
|
|
||||||
const upcomingTests = await c.getTests({ range: 'after' });
|
|
||||||
const recentTests = await c.getTests({ range: 'before' });
|
|
||||||
const testCount = recentTests.length + upcomingTests.length;
|
|
||||||
|
|
||||||
return res.render('class', {
|
|
||||||
title: `Stratos - ${c.name}`,
|
|
||||||
current: 'Classes',
|
|
||||||
name: req.session.fullName,
|
|
||||||
className: c.name,
|
|
||||||
teachers: c.teachers,
|
|
||||||
members: c.students,
|
|
||||||
recentTests: recentTests,
|
|
||||||
upcomingTests: upcomingTests,
|
|
||||||
contactLink: `${linkRoot}/contact`,
|
|
||||||
testsLink: `${linkRoot}/tests`,
|
|
||||||
reportsLink: `${linkRoot}/reports`,
|
|
||||||
deleteLink: `${linkRoot}/delete`,
|
|
||||||
membersLink: `${linkRoot}/members`,
|
|
||||||
teachersLink: `${linkRoot}/teachers`,
|
|
||||||
userType: req.session.userType,
|
|
||||||
stats: [
|
|
||||||
{
|
|
||||||
value: testCount,
|
|
||||||
text: 'Test' + (testCount !== 1 ? 's' : '')
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: recentTests.length,
|
|
||||||
text: 'Completed test' +
|
|
||||||
(recentTests.length !== 1 ? 's' : '')
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: upcomingTests.length,
|
|
||||||
text: 'Upcoming test' +
|
|
||||||
(upcomingTests.length !== 1 ? 's' : '')
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: '72%',
|
|
||||||
text: 'Average percentage'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: '50%',
|
|
||||||
text: 'Last percentage'
|
|
||||||
},
|
|
||||||
]
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
router.get('/class/:id/teachers', async (req, res) => {
|
|
||||||
const c = await new Class(req.db, req.params.id);
|
|
||||||
|
|
||||||
return res.render('classUsers', {
|
|
||||||
title: `Stratos - ${c.name}`,
|
|
||||||
current: 'Classes',
|
|
||||||
name: req.session.fullName,
|
|
||||||
userType: req.session.userType,
|
|
||||||
className: c.name,
|
|
||||||
users: c.teachers,
|
|
||||||
addLink: `/admin/class/${c.id}/teachers/add`,
|
|
||||||
addContent: 'Add new teachers',
|
|
||||||
pageTitle: 'Teachers'
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
router.get('/class/:id/members', async (req, res) => {
|
|
||||||
const c = await new Class(req.db, req.params.id);
|
|
||||||
|
|
||||||
return res.render('classUsers', {
|
|
||||||
title: `Stratos - ${c.name}`,
|
|
||||||
current: 'Classes',
|
|
||||||
name: req.session.fullName,
|
|
||||||
userType: req.session.userType,
|
|
||||||
className: c.name,
|
|
||||||
users: c.students,
|
|
||||||
addLink: `/admin/class/${c.id}/members/add`,
|
|
||||||
addContent: 'Add new students',
|
|
||||||
pageTitle: 'Students'
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
root: '/admin',
|
root: '/admin',
|
||||||
router: router
|
router: router
|
||||||
|
|||||||
95
routes/singleClass.js
Normal file
95
routes/singleClass.js
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
const crypto = require('crypto');
|
||||||
|
const express = require('express');
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
const validator = require('../lib/validator');
|
||||||
|
|
||||||
|
const Class = require('../lib/Class');
|
||||||
|
const User = require('../lib/User');
|
||||||
|
|
||||||
|
router.get('/:id', async (req, res) => {
|
||||||
|
const c = await new Class(req.db, req.params.id);
|
||||||
|
const linkRoot = `/admin/class/${c.id}`;
|
||||||
|
const upcomingTests = await c.getTests({ range: 'after' });
|
||||||
|
const recentTests = await c.getTests({ range: 'before' });
|
||||||
|
const testCount = recentTests.length + upcomingTests.length;
|
||||||
|
|
||||||
|
return res.render('class', {
|
||||||
|
title: `Stratos - ${c.name}`,
|
||||||
|
current: 'Classes',
|
||||||
|
name: req.session.fullName,
|
||||||
|
className: c.name,
|
||||||
|
teachers: c.teachers,
|
||||||
|
members: c.students,
|
||||||
|
recentTests: recentTests,
|
||||||
|
upcomingTests: upcomingTests,
|
||||||
|
contactLink: `${linkRoot}/contact`,
|
||||||
|
testsLink: `${linkRoot}/tests`,
|
||||||
|
reportsLink: `${linkRoot}/reports`,
|
||||||
|
deleteLink: `${linkRoot}/delete`,
|
||||||
|
membersLink: `${linkRoot}/members`,
|
||||||
|
teachersLink: `${linkRoot}/teachers`,
|
||||||
|
userType: req.session.userType,
|
||||||
|
stats: [
|
||||||
|
{
|
||||||
|
value: testCount,
|
||||||
|
text: 'Test' + (testCount !== 1 ? 's' : '')
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: recentTests.length,
|
||||||
|
text: 'Completed test' +
|
||||||
|
(recentTests.length !== 1 ? 's' : '')
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: upcomingTests.length,
|
||||||
|
text: 'Upcoming test' +
|
||||||
|
(upcomingTests.length !== 1 ? 's' : '')
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: '72%',
|
||||||
|
text: 'Average percentage'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: '50%',
|
||||||
|
text: 'Last percentage'
|
||||||
|
},
|
||||||
|
]
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
router.get('/:id/:memberType(members|teachers)', async (req, res) => {
|
||||||
|
const c = await new Class(req.db, req.params.id);
|
||||||
|
const linkRoot = `/admin/class/${c.id}`;
|
||||||
|
|
||||||
|
let users, addLink, addContent, pageTitle;
|
||||||
|
if (req.params.memberType === 'members') {
|
||||||
|
users = c.students;
|
||||||
|
addLink = `${linkRoot}/members/add`;
|
||||||
|
addContent = 'Add new students';
|
||||||
|
pageTitle = 'Students';
|
||||||
|
} else {
|
||||||
|
users = c.teachers;
|
||||||
|
addLink = `${linkRoot}/teachers/add`;
|
||||||
|
addContent = 'Add new teachers';
|
||||||
|
pageTitle = 'Teachers';
|
||||||
|
}
|
||||||
|
|
||||||
|
return res.render('classUsers', {
|
||||||
|
title: `Stratos - ${c.name}`,
|
||||||
|
current: 'Classes',
|
||||||
|
name: req.session.fullName,
|
||||||
|
userType: req.session.userType,
|
||||||
|
className: c.name,
|
||||||
|
users: users,
|
||||||
|
addLink: addLink,
|
||||||
|
addContent: addContent,
|
||||||
|
pageTitle: pageTitle
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
root: '/admin/class',
|
||||||
|
router: router
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user