Refactoring order route

master
Mark Moffat 2019-11-09 12:59:28 +10:30
parent f6ab6207eb
commit 87a722d03e
1 changed files with 105 additions and 95 deletions

View File

@ -5,37 +5,34 @@ const { indexOrders } = require('../lib/indexing');
const router = express.Router(); const router = express.Router();
// Show orders // Show orders
router.get('/admin/orders', restrict, (req, res, next) => { router.get('/admin/orders', restrict, async (req, res, next) => {
const db = req.app.db; const db = req.app.db;
// Top 10 products // Top 10 products
db.orders.find({}).sort({ orderDate: -1 }).limit(10).toArray((err, orders) => { const orders = await db.orders.find({}).sort({ orderDate: -1 }).limit(10).toArray();
if(err){
console.info(err.stack);
}
// If API request, return json // If API request, return json
if(req.apiAuthenticated){ if(req.apiAuthenticated){
return res.status(200).json({ res.status(200).json({
orders orders
});
}
return res.render('orders', {
title: 'Cart',
orders: orders,
admin: true,
config: req.app.config,
session: req.session,
message: common.clearSessionValue(req.session, 'message'),
messageType: common.clearSessionValue(req.session, 'messageType'),
helpers: req.handlebars.helpers
}); });
return;
}
res.render('orders', {
title: 'Cart',
orders: orders,
admin: true,
config: req.app.config,
session: req.session,
message: common.clearSessionValue(req.session, 'message'),
messageType: common.clearSessionValue(req.session, 'messageType'),
helpers: req.handlebars.helpers
}); });
}); });
// Admin section // Admin section
router.get('/admin/orders/bystatus/:orderstatus', restrict, (req, res, next) => { router.get('/admin/orders/bystatus/:orderstatus', restrict, async (req, res, next) => {
const db = req.app.db; const db = req.app.db;
if(typeof req.params.orderstatus === 'undefined'){ if(typeof req.params.orderstatus === 'undefined'){
@ -45,56 +42,50 @@ router.get('/admin/orders/bystatus/:orderstatus', restrict, (req, res, next) =>
// case insensitive search // case insensitive search
const regex = new RegExp(['^', req.params.orderstatus, '$'].join(''), 'i'); const regex = new RegExp(['^', req.params.orderstatus, '$'].join(''), 'i');
db.orders.find({ orderStatus: regex }).sort({ orderDate: -1 }).limit(10).toArray((err, orders) => { const orders = await db.orders.find({ orderStatus: regex }).sort({ orderDate: -1 }).limit(10).toArray();
if(err){
console.info(err.stack);
}
// If API request, return json // If API request, return json
if(req.apiAuthenticated){ if(req.apiAuthenticated){
return res.status(200).json({ res.status(200).json({
orders orders
});
}
return res.render('orders', {
title: 'Cart',
orders: orders,
admin: true,
filteredOrders: true,
filteredStatus: req.params.orderstatus,
config: req.app.config,
session: req.session,
message: common.clearSessionValue(req.session, 'message'),
messageType: common.clearSessionValue(req.session, 'messageType'),
helpers: req.handlebars.helpers
}); });
return;
}
res.render('orders', {
title: 'Cart',
orders: orders,
admin: true,
filteredOrders: true,
filteredStatus: req.params.orderstatus,
config: req.app.config,
session: req.session,
message: common.clearSessionValue(req.session, 'message'),
messageType: common.clearSessionValue(req.session, 'messageType'),
helpers: req.handlebars.helpers
}); });
}); });
// render the editor // render the editor
router.get('/admin/order/view/:id', restrict, (req, res) => { router.get('/admin/order/view/:id', restrict, async (req, res) => {
const db = req.app.db; const db = req.app.db;
db.orders.findOne({ _id: common.getId(req.params.id) }, (err, result) => { const order = await db.orders.findOne({ _id: common.getId(req.params.id) });
if(err){
console.info(err.stack); res.render('order', {
} title: 'View order',
res.render('order', { result: order,
title: 'View order', config: req.app.config,
result: result, session: req.session,
config: req.app.config, message: common.clearSessionValue(req.session, 'message'),
session: req.session, messageType: common.clearSessionValue(req.session, 'messageType'),
message: common.clearSessionValue(req.session, 'message'), editor: true,
messageType: common.clearSessionValue(req.session, 'messageType'), admin: true,
editor: true, helpers: req.handlebars.helpers
admin: true,
helpers: req.handlebars.helpers
});
}); });
}); });
// Admin section // Admin section
router.get('/admin/orders/filter/:search', restrict, (req, res, next) => { router.get('/admin/orders/filter/:search', restrict, async (req, res, next) => {
const db = req.app.db; const db = req.app.db;
const searchTerm = req.params.search; const searchTerm = req.params.search;
const ordersIndex = req.app.ordersIndex; const ordersIndex = req.app.ordersIndex;
@ -105,62 +96,81 @@ router.get('/admin/orders/filter/:search', restrict, (req, res, next) => {
}); });
// we search on the lunr indexes // we search on the lunr indexes
db.orders.find({ _id: { $in: lunrIdArray } }).toArray((err, orders) => { const orders = await db.orders.find({ _id: { $in: lunrIdArray } }).toArray();
if(err){
console.info(err.stack);
}
// If API request, return json // If API request, return json
if(req.apiAuthenticated){ if(req.apiAuthenticated){
return res.status(200).json({ res.status(200).json({
orders orders
});
}
return res.render('orders', {
title: 'Order results',
orders: orders,
admin: true,
config: req.app.config,
session: req.session,
searchTerm: searchTerm,
message: common.clearSessionValue(req.session, 'message'),
messageType: common.clearSessionValue(req.session, 'messageType'),
helpers: req.handlebars.helpers
}); });
return;
}
res.render('orders', {
title: 'Order results',
orders: orders,
admin: true,
config: req.app.config,
session: req.session,
searchTerm: searchTerm,
message: common.clearSessionValue(req.session, 'message'),
messageType: common.clearSessionValue(req.session, 'messageType'),
helpers: req.handlebars.helpers
}); });
}); });
// order product // order product
router.get('/admin/order/delete/:id', restrict, (req, res) => { router.get('/admin/order/delete/:id', restrict, async(req, res) => {
const db = req.app.db; const db = req.app.db;
// remove the order // remove the order
db.orders.deleteOne({ _id: common.getId(req.params.id) }, {}, (err, numRemoved) => { try{
if(err){ await db.orders.deleteOne({ _id: common.getId(req.params.id) });
console.info(err.stack);
}
// remove the index // remove the index
indexOrders(req.app) indexOrders(req.app)
.then(() => { .then(() => {
if(req.apiAuthenticated){
res.status(200).json({
message: 'Order successfully deleted'
});
return;
}
// redirect home // redirect home
req.session.message = 'Order successfully deleted'; req.session.message = 'Order successfully deleted';
req.session.messageType = 'success'; req.session.messageType = 'success';
res.redirect('/admin/orders'); res.redirect('/admin/orders');
}); });
}); }catch(ex){
console.log('Cannot delete order', ex);
if(req.apiAuthenticated){
res.status(200).json({
message: 'Error deleting order'
});
return;
}
// redirect home
req.session.message = 'Error deleting order';
req.session.messageType = 'danger';
res.redirect('/admin/orders');
}
}); });
// update order status // update order status
router.post('/admin/order/statusupdate', restrict, checkAccess, (req, res) => { router.post('/admin/order/statusupdate', restrict, checkAccess, async (req, res) => {
const db = req.app.db; const db = req.app.db;
db.orders.updateOne({ _id: common.getId(req.body.order_id) }, { $set: { orderStatus: req.body.status } }, { multi: false }, (err, numReplaced) => { try{
if(err){ await db.orders.updateOne({
console.info(err.stack); _id: common.getId(req.body.order_id) },
return res.status(400).json({ message: 'Failed to update the order status' }); { $set: { orderStatus: req.body.status }
} }, { multi: false });
return res.status(200).json({ message: 'Status successfully updated' }); return res.status(200).json({ message: 'Status successfully updated' });
}); }catch(ex){
console.info('Error updating status', ex);
return res.status(400).json({ message: 'Failed to update the order status' });
}
}); });
module.exports = router; module.exports = router;