, поэтому я хочу получать продажи, которые доступны в указанную c дату и по цене (мин., Макс.) И месту (вилайя, дайра и коммуне), поэтому бронирование является ссылкой в продаже и содержит свойство даты и контакт содержит место продажи.
const contacteSchema = new mongoose.schema({
telephone:[{
type:Number,
minlength:10,
maxlength:10,
required:true
}],
adress:{
wilaya:{
type:String,
minlength:5,
maxlength:20,
required:true
},
daira:{
type:String,
minlength:5,
maxlength:50,
required:true
},
commune:{
type:String,
minlength:5,
maxlength:50,
required:true
},
rue:{
type:String,
minlength:5,
maxlength:50,
required:true
}
}
});
const Contacte = mongoose.model('Contacte',contacteSchema)
это модель бронирования
const bookingSchema = new mongoose.schema({
date:{
type: Date,
minlength:10,
maxlength:10,
required:true,
},
total:{
type:Number,
minlength:5,
maxlength:50,
required:true
},
confirmationsale:{
type:Boolean,
default:false
},
client:{
type: mongoose.Schema.Types.ObjectId,
ref:'Client'
},
sale:{
type: mongoose.Schema.Types.ObjectId,
required:true,
ref:'Sale'
},
services:[{
type: mongoose.Schema.Types.ObjectId,
ref:'SaleService'
}]
});
const Booking = mongoose.model('Booking',bookingSchema)
это модель продажи
var saleSchema = new mongoose.Schema({
name:{
type:String,
minlength:5,
maxlength:50,
required:true
},
description:{
type:String,
minlength:5,
maxlength:255,
},
rating:{
type:Number,
minlength:1,
maxlength:255,
default:0,
},
price:{
type:Number,
minlength:5,
maxlength:50,
required:true
},
login:{
type:mongoose.Schema.Types.ObjectId,
ref:'Login'
},
contacte:{
type:mongoose.Schema.Types.ObjectId,
ref:'Contacte'
},
services:[{
type:mongoose.Schema.Types.ObjectId,
ref:'SaleService'
}],
pictures:[{
type:mongoose.Schema.Types.ObjectId,
ref:'Picture'
}],
bookins:[{
type:mongoose.Schema.Types.ObjectId,
ref:'Booking'
}]
});
var Sale = mongoose.model('Sale',saleSchema);
это Метод router.get для поиска и фильтрации продаж
router.get('/get/sale', async (req, res)=>{
let skip = parseInt(req.query.offset);
let nPerPage = parseInt(req.query.limit);
let sortby = req.query.sort;
let orderby = req.query.order;
let date = new Date(req.query.date);
let wilaya = req.query.wilaya;
let daira = req.query.daira;
let commune = req.query.commune;
let pricemax = req.query.pricemax;
let pricemin = req.query.pricemin;
let salemodel = await Sale.find({
$or:[{
bookins: {
$in : [{
'booking.date' : {
$ne: date
},
}]
}
},
{
$and:[
{'contacte.wilaya':wilaya},
{'contacte.daira':daira},
{'contacte.commune':commune}
]
},
{
$and:[
{
'price': {
$lte: pricemax
}
},
{
'price': {
$gte: pricemin
}
}
]
}
]
})
.populate('login email picture -password -username -type')
.populate('contacte')
.sort([[sortby, orderby]])
.skip(skip > 0 ? (skip+1) : 0).limit(nPerPage)
.exec();
if(!salemodel) return res.status(404).send('invalid sale');
});
Это правильно или мне нужно изменить какой-то код или избавиться от него?