refactor getComponentSum #399

Merged
joan merged 1 commits from 2489-ticket_component into dev 2020-10-05 06:58:11 +00:00
1 changed files with 25 additions and 26 deletions

View File

@ -20,34 +20,33 @@ module.exports = Self => {
}); });
Self.getComponentsSum = async id => { Self.getComponentsSum = async id => {
const models = Self.app.models; const models = Self.app.models;
let salesComponents = [];
let componentsSum = []; let componentsSum = [];
let sales = await models.Sale.find({where: {ticketFk: id}}); let sales = await models.Sale.find({
let components = await models.Component.find(); include: {
if (sales.length > 0) { relation: 'components',
for (let sale of sales) { scope: {fields: ['value', 'componentFk'],
let myComponents = await models.SaleComponent.find({where: {saleFk: sale.id}}); include: {
salesComponents = salesComponents.concat(myComponents); relation: 'component',
} }
salesComponents.reduce((acumulator, currentValue) => {
if (!acumulator[currentValue.componentFk]) {
let defaultValue = 0;
let tarjetComponent = components.find(component => component.id === currentValue.componentFk);
acumulator[currentValue.componentFk] = {
componentFk: currentValue.componentFk,
value: defaultValue,
name: tarjetComponent.name
};
componentsSum.push(acumulator[currentValue.componentFk]);
} }
},
acumulator[currentValue.componentFk].value += currentValue.value; where: {ticketFk: id}
});
return acumulator; for (let sale of sales) {
}); for (let component of sale.components()) {
let componentId = componentsSum[component.componentFk];
if (!componentId) {
componentsSum[component.componentFk] = {
componentFk: component.componentFk,
value: 0,
name: component.component().name
};
}
componentsSum[component.componentFk].value += component.value * sale.quantity;
}
} }
return componentsSum; return componentsSum.filter(component => {
return component != null;
});
}; };
}; };