expressCart/routes/order.js

177 lines
5.1 KiB
JavaScript
Raw Normal View History

2018-02-05 23:20:44 +10:00
const express = require('express');
const common = require('../lib/common');
2019-06-15 14:46:08 +10:00
const { restrict, checkAccess } = require('../lib/auth');
2019-06-15 15:56:51 +10:00
const { indexOrders } = require('../lib/indexing');
2018-02-05 23:20:44 +10:00
const router = express.Router();
// Show orders
2019-11-09 12:29:28 +10:00
router.get('/admin/orders', restrict, async (req, res, next) => {
2018-02-05 23:20:44 +10:00
const db = req.app.db;
// Top 10 products
2019-11-09 12:29:28 +10:00
const orders = await db.orders.find({}).sort({ orderDate: -1 }).limit(10).toArray();
2019-11-09 12:29:28 +10:00
// If API request, return json
if(req.apiAuthenticated){
res.status(200).json({
orders
2018-02-05 23:20:44 +10:00
});
2019-11-09 12:29:28 +10:00
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
2018-02-05 23:20:44 +10:00
});
});
// Admin section
2019-11-09 12:29:28 +10:00
router.get('/admin/orders/bystatus/:orderstatus', restrict, async (req, res, next) => {
2018-02-05 23:20:44 +10:00
const db = req.app.db;
if(typeof req.params.orderstatus === 'undefined'){
res.redirect('/admin/orders');
return;
}
// case insensitive search
2019-07-12 17:50:07 +10:00
const regex = new RegExp(['^', req.params.orderstatus, '$'].join(''), 'i');
2019-11-09 12:29:28 +10:00
const orders = await db.orders.find({ orderStatus: regex }).sort({ orderDate: -1 }).limit(10).toArray();
2019-11-09 12:29:28 +10:00
// If API request, return json
if(req.apiAuthenticated){
res.status(200).json({
orders
2018-02-05 23:20:44 +10:00
});
2019-11-09 12:29:28 +10:00
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
2018-02-05 23:20:44 +10:00
});
});
// render the editor
2019-11-09 12:29:28 +10:00
router.get('/admin/order/view/:id', restrict, async (req, res) => {
2018-02-05 23:20:44 +10:00
const db = req.app.db;
2019-11-09 12:29:28 +10:00
const order = await db.orders.findOne({ _id: common.getId(req.params.id) });
res.render('order', {
title: 'View order',
result: order,
config: req.app.config,
session: req.session,
message: common.clearSessionValue(req.session, 'message'),
messageType: common.clearSessionValue(req.session, 'messageType'),
editor: true,
admin: true,
helpers: req.handlebars.helpers
2018-02-05 23:20:44 +10:00
});
});
// Admin section
2019-11-09 12:29:28 +10:00
router.get('/admin/orders/filter/:search', restrict, async (req, res, next) => {
2018-02-05 23:20:44 +10:00
const db = req.app.db;
2019-07-12 17:50:07 +10:00
const searchTerm = req.params.search;
const ordersIndex = req.app.ordersIndex;
2018-02-05 23:20:44 +10:00
2019-07-12 17:50:07 +10:00
const lunrIdArray = [];
2018-02-05 23:20:44 +10:00
ordersIndex.search(searchTerm).forEach((id) => {
lunrIdArray.push(common.getId(id.ref));
});
// we search on the lunr indexes
2019-11-09 12:29:28 +10:00
const orders = await db.orders.find({ _id: { $in: lunrIdArray } }).toArray();
2019-11-09 12:29:28 +10:00
// If API request, return json
if(req.apiAuthenticated){
res.status(200).json({
orders
2018-02-05 23:20:44 +10:00
});
2019-11-09 12:29:28 +10:00
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
2018-02-05 23:20:44 +10:00
});
});
// order product
2019-11-09 12:29:28 +10:00
router.get('/admin/order/delete/:id', restrict, async(req, res) => {
2018-02-05 23:20:44 +10:00
const db = req.app.db;
// remove the order
2019-11-09 12:29:28 +10:00
try{
await db.orders.deleteOne({ _id: common.getId(req.params.id) });
2018-02-05 23:20:44 +10:00
// remove the index
2019-06-15 15:56:51 +10:00
indexOrders(req.app)
2018-02-05 23:20:44 +10:00
.then(() => {
2019-11-09 12:29:28 +10:00
if(req.apiAuthenticated){
res.status(200).json({
message: 'Order successfully deleted'
});
return;
}
2018-02-05 23:20:44 +10:00
// redirect home
req.session.message = 'Order successfully deleted';
req.session.messageType = 'success';
res.redirect('/admin/orders');
});
2019-11-09 12:29:28 +10:00
}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');
}
2018-02-05 23:20:44 +10:00
});
// update order status
2019-11-09 12:29:28 +10:00
router.post('/admin/order/statusupdate', restrict, checkAccess, async (req, res) => {
2018-02-05 23:20:44 +10:00
const db = req.app.db;
2019-11-09 12:29:28 +10:00
try{
await db.orders.updateOne({
_id: common.getId(req.body.order_id) },
{ $set: { orderStatus: req.body.status }
}, { multi: false });
return res.status(200).json({ message: 'Status successfully updated' });
2019-11-09 12:29:28 +10:00
}catch(ex){
console.info('Error updating status', ex);
return res.status(400).json({ message: 'Failed to update the order status' });
}
2018-02-05 23:20:44 +10:00
});
module.exports = router;