Add basic functionality
This commit is contained in:
88
server/router/library/index.js
Normal file
88
server/router/library/index.js
Normal file
@@ -0,0 +1,88 @@
|
||||
const express = require('express');
|
||||
const req = require('express/lib/request');
|
||||
|
||||
module.exports = function (options) {
|
||||
const db = options.db;
|
||||
var router = express.Router();
|
||||
|
||||
router.route('/')
|
||||
.get(function(request, response, next) {
|
||||
db.Entry.findAll({
|
||||
|
||||
}).then(entries => {
|
||||
response.display("library", {
|
||||
user: request.user,
|
||||
pageTitle: "Library - Mantra",
|
||||
entries: entries
|
||||
})
|
||||
}).catch(error => {
|
||||
next(error)
|
||||
})
|
||||
})
|
||||
|
||||
router.route('/add')
|
||||
.get(function(request, response, next) {
|
||||
if (request.user) {
|
||||
response.display("library-form", {
|
||||
user: request.user,
|
||||
pageTitle: "Add Library - Mantra",
|
||||
entry: { }
|
||||
})
|
||||
} else {
|
||||
next()
|
||||
}
|
||||
})
|
||||
.post(function(request, response, next) {
|
||||
if (request.user) {
|
||||
db.Dialect.findOne({
|
||||
where: {
|
||||
languageId: "en",
|
||||
countryId: "int"
|
||||
}
|
||||
}).then(dialect => {
|
||||
if (dialect) {
|
||||
return db.Entry.create({
|
||||
name: request.body.name,
|
||||
url: request.body.url,
|
||||
dialectId: dialect.id,
|
||||
licenseId: "copyright"
|
||||
})
|
||||
} else {
|
||||
response.redirect("/library/add") // TODO: Show error message on missing dialect...
|
||||
}
|
||||
|
||||
}).then(entry => {
|
||||
if (entry) {
|
||||
response.redirect(`/library/${entry.id}`)
|
||||
} else {
|
||||
next()
|
||||
}
|
||||
}).catch(error => {
|
||||
next(error)
|
||||
})
|
||||
} else {
|
||||
next()
|
||||
}
|
||||
})
|
||||
|
||||
|
||||
router.route('/:id')
|
||||
.get(function(request, response, next) {
|
||||
db.Entry.findByPk(request.params.id, {
|
||||
include: [
|
||||
{
|
||||
association: db.Entry.EntryApproval
|
||||
}
|
||||
]
|
||||
}).then(entry => {
|
||||
response.display("entry", {
|
||||
user: request.user,
|
||||
pageTitle: "Library - Mantra",
|
||||
entry: entry
|
||||
})
|
||||
}).catch(error => {
|
||||
next(error)
|
||||
})
|
||||
})
|
||||
return router;
|
||||
};
|
||||
Reference in New Issue
Block a user