const express = require('express'); const common = require('./common'); const router = express.Router(); // Show orders router.get('/orders', common.restrict, (req, res, next) => { const db = req.app.db; // Top 10 products db.orders.find({}).sort({'orderDate': -1}).limit(10).toArray((err, orders) => { if(err){ console.info(err.stack); } res.render('orders', { title: 'Cart', orders: orders, admin: true, config: common.getConfig(), session: req.session, message: common.clearSessionValue(req.session, 'message'), messageType: common.clearSessionValue(req.session, 'messageType'), helpers: req.handlebars.helpers }); }); }); // Admin section router.get('/orders/bystatus/:orderstatus', common.restrict, (req, res, next) => { const db = req.app.db; if(typeof req.params.orderstatus === 'undefined'){ res.redirect('/admin/orders'); return; } // case insensitive search let regex = new RegExp(['^', req.params.orderstatus, '$'].join(''), 'i'); db.orders.find({orderStatus: regex}).sort({'orderDate': -1}).limit(10).toArray((err, orders) => { if(err){ console.info(err.stack); } res.render('orders', { title: 'Cart', orders: orders, admin: true, filteredOrders: true, filteredStatus: req.params.orderstatus, config: common.getConfig(), session: req.session, message: common.clearSessionValue(req.session, 'message'), messageType: common.clearSessionValue(req.session, 'messageType'), helpers: req.handlebars.helpers }); }); }); // render the editor router.get('/order/view/:id', common.restrict, (req, res) => { const db = req.app.db; db.orders.findOne({_id: common.getId(req.params.id)}, (err, result) => { if(err){ console.info(err.stack); } let productOptions = ''; if(result.options !== {}){ productOptions = result.options; } res.render('order', { title: 'View order', result: result, productOptions: productOptions, config: common.getConfig(), session: req.session, message: common.clearSessionValue(req.session, 'message'), messageType: common.clearSessionValue(req.session, 'messageType'), editor: true, admin: true, helpers: req.handlebars.helpers }); }); }); // Admin section router.get('/orders/filter/:search', common.restrict, (req, res, next) => { const db = req.app.db; let searchTerm = req.params.search; let ordersIndex = req.app.ordersIndex; let lunrIdArray = []; ordersIndex.search(searchTerm).forEach((id) => { lunrIdArray.push(common.getId(id.ref)); }); // we search on the lunr indexes db.orders.find({_id: {$in: lunrIdArray}}).toArray((err, orders) => { if(err){ console.info(err.stack); } res.render('orders', { title: 'Order results', orders: orders, admin: true, config: common.getConfig(), session: req.session, searchTerm: searchTerm, message: common.clearSessionValue(req.session, 'message'), messageType: common.clearSessionValue(req.session, 'messageType'), helpers: req.handlebars.helpers }); }); }); // order product router.get('/order/delete/:id', common.restrict, (req, res) => { const db = req.app.db; // remove the article db.orders.remove({_id: common.getId(req.params.id)}, {}, (err, numRemoved) => { if(err){ console.info(err.stack); } // remove the index common.indexOrders(req.app) .then(() => { // redirect home req.session.message = 'Order successfully deleted'; req.session.messageType = 'success'; res.redirect('/admin/orders'); }); }); }); // update order status router.post('/order/statusupdate', common.restrict, (req, res) => { const db = req.app.db; db.orders.update({_id: common.getId(req.body.order_id)}, {$set: {orderStatus: req.body.status}}, {multi: false}, (err, numReplaced) => { if(err){ console.info(err.stack); } res.status(200).json({message: 'Status successfully updated'}); }); }); module.exports = router;