public decimal CalculatePricePerTotalWeight(PriceRequest model) { var m = measureUnitApp.GetAll().Result; var pType = m.FirstOrDefault(m => m.MeasureUnitId == model.ProductMeasureUnit).MeasureUnitTypeId; var qType = m.FirstOrDefault(m => m.MeasureUnitId == model.QuantityMeasureUnit).MeasureUnitTypeId; return(pricingApp.CalculatePricePerTotalWeight(model, pType, qType)); }
public async Task <long> Add(NewOrder model, int corpClientId) { var ids = model.OrderItems.Select(i => i.ProductId).ToList(); var prods = await productApp.GetRange(corpClientId, ids); int i = 1; var units = await measureUnitApp.GetAll(); foreach (var item in model.OrderItems) { item.ItemNumber = i; var prod = prods.FirstOrDefault(p => p.ProductId == item.ProductId); item.ProductPrice = prod.Price; var pType = units.FirstOrDefault(u => u.MeasureUnitId == prod.MeasureUnitId).MeasureUnitTypeId; var qType = units.FirstOrDefault(u => u.MeasureUnitId == item.MeasureUnitId).MeasureUnitTypeId; await CalculateItem(item, prod.MeasureUnitId, pType, qType, corpClientId); i++; } return(await orderApp.Add(model, corpClientId)); }
public async Task <ProductionSummary> CalculateProduction(long productId, MeasureUnitEnum measureId, decimal quantity, int corpClientId) { var items = new List <ProductionItem>(); var dataSheet = await dataSheetApp.Get(productId, corpClientId); var units = await measureUnitApp.GetAll(); var sourceUnit = units.FirstOrDefault(u => u.MeasureUnitId == measureId); var p = await productApp.Get(corpClientId, productId); var pType = units.FirstOrDefault(u => u.MeasureUnitId == p.MeasureUnitId).MeasureUnitTypeId; var price = pricingApp.CalculatePricePerTotalWeight(new PriceRequest { ProductMeasureUnit = p.MeasureUnitId, ProductPrice = p.Price, Quantity = quantity, QuantityMeasureUnit = measureId, ResultPrecision = 2 }, pType, sourceUnit.MeasureUnitTypeId); if (dataSheet == null) { return new ProductionSummary { SalePrice = price, ProductionItems = items } } ; var q = Convert.ToDecimal(UnitConverter.ToBaseUnit(measureId, quantity, sourceUnit.MeasureUnitTypeId)); foreach (var di in dataSheet.DataSheetItems) { var item = new ProductionItem { AdditionalInfo = di.AdditionalInfo, DataSheetId = di.DataSheetId, DataSheetItemId = di.DataSheetItemId, IsBaseItem = di.IsBaseItem, RawMaterial = di.RawMaterial, Percentage = di.Percentage, RawMaterialId = di.RawMaterialId }; if (dataSheet.IncreaseWeight) { item.Quantity = q / (1 + (dataSheet.WeightVariationPercentage / 100)) * item.Percentage / 100; } else { item.Quantity = q / (1 - (dataSheet.WeightVariationPercentage / 100)) * item.Percentage / 100; } var rmSourceUnit = units.FirstOrDefault(u => u.MeasureUnitId == di.RawMaterial.MeasureUnitId); var rmQuantity = Convert.ToDecimal(UnitConverter.ToBaseUnit(rmSourceUnit.MeasureUnitId, 1, rmSourceUnit.MeasureUnitTypeId)); var rmPrice = di.RawMaterial.Price / rmQuantity; item.Cost = rmPrice * item.Quantity; switch (rmSourceUnit.MeasureUnitTypeId) { case MeasureUnitTypeEnum.Mass: item.MeasureUnit = units.FirstOrDefault(u => u.MeasureUnitId == MeasureUnitEnum.Grama); break; case MeasureUnitTypeEnum.Volume: item.MeasureUnit = units.FirstOrDefault(u => u.MeasureUnitId == MeasureUnitEnum.Mililitro); break; case MeasureUnitTypeEnum.Lenght: break; default: break; } items.Add(item); } return(new ProductionSummary { SalePrice = price, ProductionItems = items }); } }
public async Task <IEnumerable <MeasureUnit> > GetAllMeasureUnits() { return(await measureUnitApp.GetAll()); }