salix/modules/ticket/back/methods/sale/updatePrice.js

86 lines
2.7 KiB
JavaScript
Raw Normal View History

2018-12-27 11:54:16 +00:00
let UserError = require('vn-loopback/util/user-error');
module.exports = Self => {
2019-05-29 10:41:26 +00:00
Self.remoteMethod('updatePrice', {
description: 'Changes the discount of a sale',
2019-05-22 10:35:24 +00:00
accessType: 'WRITE',
accepts: [{
arg: 'params',
type: 'object',
required: true,
2019-05-29 10:41:26 +00:00
description: 'sale ID, newPrice, ticketFk',
http: {source: 'body'}
}],
returns: {
type: 'string',
root: true
},
http: {
path: `/updatePrice`,
verb: 'post'
}
});
2018-08-14 10:48:12 +00:00
Self.updatePrice = async params => {
if (!params.price) params.price = 0;
let model = Self.app.models;
2019-05-29 10:41:26 +00:00
let manaDiscount;
let buyerDiscount = await model.ComponentRate.findOne({where: {code: 'buyerDiscount'}});
let ticket = await getTicket(params);
let usesMana = await model.WorkerMana.findOne({where: {workerFk: ticket[0].client().salesPersonFk}, fields: 'amount'});
let currentLine = await Self.app.models.Sale.findOne({where: {id: params.id}});
2019-05-29 10:41:26 +00:00
let componentId = buyerDiscount.id;
2019-05-29 10:41:26 +00:00
if (usesMana) {
manaDiscount = await model.ComponentRate.findOne({where: {code: 'mana'}});
componentId = manaDiscount.id;
}
let value = (params.price - currentLine.price);
2019-04-02 12:36:49 +00:00
let saleComponent = await Self.app.models.SaleComponent.findOne({
where: {
2019-05-29 10:41:26 +00:00
componentFk: componentId,
2019-04-02 12:36:49 +00:00
saleFk: params.id
}
});
2019-05-29 10:41:26 +00:00
if (saleComponent) {
saleComponent.updateAttributes({value: saleComponent.value + value}).catch(() => {
throw new UserError(`Enter a valid number`);
});
} else {
2019-04-02 12:36:49 +00:00
await Self.app.models.SaleComponent.create({
saleFk: params.id,
2019-05-29 10:41:26 +00:00
componentFk: componentId,
2019-04-02 12:36:49 +00:00
value: value
});
}
await currentLine.updateAttributes({price: params.price});
2018-08-14 10:48:12 +00:00
query = `call vn.manaSpellersRequery(?)`;
await Self.rawSql(query, [ticket[0].client().salesPersonFk]);
};
2019-05-29 10:41:26 +00:00
async function getTicket(params) {
let model = Self.app.models;
let thisTicketIsEditable = await model.Ticket.isEditable(params.ticketFk);
if (!thisTicketIsEditable)
throw new UserError(`The sales of this ticket can't be modified`);
return await model.Ticket.find({
where: {
id: params.ticketFk
},
include: [{
relation: 'client',
scope: {
fields: ['salesPersonFk']
}
}],
fields: ['id', 'clientFk']
});
}
};