2024-08-05 13:32:36 +00:00
|
|
|
module.exports = Self => {
|
|
|
|
Self.remoteMethod('getStockBought', {
|
|
|
|
description: 'Returns the stock bought for a given date',
|
|
|
|
accessType: 'READ',
|
|
|
|
accepts: [{
|
2024-09-16 07:00:46 +00:00
|
|
|
arg: 'workerFk',
|
|
|
|
type: 'number',
|
|
|
|
description: 'The id for a buyer',
|
|
|
|
},
|
|
|
|
{
|
2024-08-05 13:32:36 +00:00
|
|
|
arg: 'dated',
|
|
|
|
type: 'date',
|
|
|
|
description: 'The date to filter',
|
|
|
|
}
|
|
|
|
],
|
|
|
|
returns: {
|
|
|
|
type: ['object'],
|
|
|
|
root: true
|
|
|
|
},
|
|
|
|
http: {
|
|
|
|
path: `/getStockBought`,
|
|
|
|
verb: 'GET'
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2024-09-16 07:00:46 +00:00
|
|
|
Self.getStockBought = async(workerFk, dated = Date.vnNew()) => {
|
2024-08-05 13:32:36 +00:00
|
|
|
const models = Self.app.models;
|
|
|
|
const today = Date.vnNew();
|
|
|
|
dated.setHours(0, 0, 0, 0);
|
|
|
|
today.setHours(0, 0, 0, 0);
|
|
|
|
|
|
|
|
if (dated.getTime() === today.getTime())
|
|
|
|
await models.StockBought.rawSql(`CALL vn.stockBought_calculate()`);
|
|
|
|
|
2024-09-16 07:00:46 +00:00
|
|
|
const filter = {
|
|
|
|
where: {
|
|
|
|
dated: dated
|
|
|
|
},
|
|
|
|
include: [
|
|
|
|
{
|
|
|
|
relation: 'worker',
|
|
|
|
scope: {
|
|
|
|
include: [
|
|
|
|
{
|
|
|
|
relation: 'user',
|
|
|
|
scope: {
|
|
|
|
fields: ['id', 'name']
|
2024-08-05 13:32:36 +00:00
|
|
|
}
|
2024-09-16 07:00:46 +00:00
|
|
|
}
|
|
|
|
]
|
2024-08-05 13:32:36 +00:00
|
|
|
}
|
2024-09-16 07:00:46 +00:00
|
|
|
}
|
|
|
|
]
|
|
|
|
};
|
|
|
|
|
|
|
|
if (workerFk) filter.where.workerFk = workerFk;
|
|
|
|
|
|
|
|
return models.StockBought.find(filter);
|
2024-08-05 13:32:36 +00:00
|
|
|
};
|
|
|
|
};
|