145 lines
4.5 KiB
JavaScript
145 lines
4.5 KiB
JavaScript
|
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;
|