63 lines
1.8 KiB
JavaScript
63 lines
1.8 KiB
JavaScript
module.exports = Self => {
|
|
Self.remoteMethod('getPossibleStowaways', {
|
|
description: 'Returns mana of a salesperson of a ticket',
|
|
accessType: 'READ',
|
|
accepts: [{
|
|
arg: 'id',
|
|
type: 'number',
|
|
required: true,
|
|
description: 'ticket id',
|
|
http: {source: 'path'}
|
|
}],
|
|
returns: {
|
|
root: true
|
|
},
|
|
http: {
|
|
path: `/:id/getPossibleStowaways`,
|
|
verb: 'GET'
|
|
}
|
|
});
|
|
|
|
Self.getPossibleStowaways = async ticketFk => {
|
|
let ship = await Self.app.models.Ticket.findById(ticketFk);
|
|
|
|
if (!ship || !ship.shipped)
|
|
return [];
|
|
|
|
let lowestDate = new Date(ship.shipped.getTime());
|
|
lowestDate.setHours(0, 0, -1, 0);
|
|
|
|
let highestDate = new Date(ship.shipped.getTime());
|
|
highestDate.setHours(23, 59, 59);
|
|
|
|
|
|
let possibleStowaways = await Self.app.models.Ticket.find({
|
|
where: {
|
|
id: {neq: ticketFk},
|
|
clientFk: ship.clientFk,
|
|
addressFk: ship.addressFk,
|
|
agencyModeFk: ship.agencyModeFk,
|
|
warehouse: {neq: ship.warehouseFk},
|
|
shipped: {
|
|
between: [lowestDate.toJSON(), highestDate.toJSON()]
|
|
}
|
|
},
|
|
include: [
|
|
{relation: 'agencyMode'},
|
|
{relation: 'warehouse'},
|
|
{relation: 'state',
|
|
scope: {
|
|
fields: ['stateFk'],
|
|
include: {
|
|
relation: 'state',
|
|
fields: ['id', 'name'],
|
|
}
|
|
},
|
|
},
|
|
]
|
|
});
|
|
|
|
return possibleStowaways;
|
|
};
|
|
};
|