Compare commits

..

3 Commits

Author SHA1 Message Date
95a10df89d LabWork03_Hard: Фиксы 2023-04-09 21:23:18 +04:00
32f0c536d1 Merge branch 'LabWork02_Hard' into LabWork03_Hard 2023-04-09 21:17:23 +04:00
c5f4b3caf6 LabWork02_Hard: Фиксы 2023-04-09 21:16:52 +04:00
4 changed files with 21 additions and 24 deletions

View File

@ -18,6 +18,6 @@ namespace AutomobilePlantContracts.BusinessLogicContracts
bool Update(ShopBindingModel model);
bool Delete(ShopBindingModel model);
bool SupplyCars(ShopSearchModel model, ICarModel car, int count);
bool SellCar(ICarModel document, int count);
bool SellCar(ICarModel car, int count);
}
}

View File

@ -100,6 +100,7 @@ namespace AutomobilePlantDatabaseImplement.Implements
}
car.Update(model);
car.UpdateComponents(context, model);
context.SaveChanges();
context.Database.CommitTransaction();

View File

@ -77,14 +77,17 @@ namespace AutomobilePlantDatabaseImplement.Implements
using var transaction = context.Database.BeginTransaction();
try
{
var shop = context.Shops.FirstOrDefault(x => x.Id == model.Id);
var shop = context.Shops.Include(x => x.Cars).FirstOrDefault(x => x.Id == model.Id);
if (shop == null)
{
return null;
}
shop.Update(model);
context.SaveChanges();
shop.UpdateCars(context, model);
if (model.ShopCars.Count > 0)
{
shop.UpdateCars(context, model);
}
transaction.Commit();
return shop.GetViewModel;
}

View File

@ -83,29 +83,24 @@ namespace AutomobilePlantFileImplement.Implements
public bool SellCar(ICarModel model, int count)
{
// переделать под linq
var car = source.Cars.FirstOrDefault(x => x.Id == model.Id);
var countStore = count;
if (car == null)
{
return false;
}
foreach (var shop in source.Shops)
var countStore = count;
var shopCars = source.Shops.SelectMany(shop => shop.ShopCars.Where(c => c.Value.Item1.Id == car.Id));
foreach (var c in shopCars)
{
foreach (var c in shop.ShopCars)
count -= c.Value.Item2;
if (count <= 0)
{
if (c.Value.Item1.Id == car.Id)
{
count -= c.Value.Item2;
}
if (count <= 0)
{
break;
}
break;
}
}
@ -116,9 +111,8 @@ namespace AutomobilePlantFileImplement.Implements
count = countStore;
for (int i = 0; i < source.Shops.Count; i++)
foreach (var shop in source.Shops)
{
var shop = source.Shops[i];
var cars = shop.ShopCars;
foreach (var c in cars.Where(x => x.Value.Item1.Id == car.Id))
@ -142,14 +136,13 @@ namespace AutomobilePlantFileImplement.Implements
MaxCountCars = shop.MaxCountCars,
ShopCars = cars
});
source.SaveShops();
if (count <= 0) break;
}
if (count > 0)
{
return false;
}
return true;
return count <= 0;
}
}
}