Compare commits

...

20 Commits

Author SHA1 Message Date
7aa92dbb74 Merge branch 'LabWork02_Base' into LabWork02_Hard 2023-03-10 19:39:05 +04:00
29a8bf30cc Merge branch 'LabWork01_Hard' into LabWork02_Hard 2023-03-10 19:38:46 +04:00
8507a11132 Исправления 2023-03-10 19:37:13 +04:00
716e94751c Merge branch 'LabWork02_Base' of http://student.git.athene.tech/Danila_Mochalov/PIbd-23_Mochalov_D.V._LawFirm into LabWork02_Base 2023-03-10 19:27:16 +04:00
b2c61a619a фикс удаления 2023-03-10 19:27:08 +04:00
862baf93b6 Сдана лаб 2 база 2023-03-10 19:25:23 +04:00
daf95e27b6 Вроде работает 2023-03-10 19:25:23 +04:00
75a544e690 Созданы реализации интерфейсов хранилищ 2023-03-10 19:25:23 +04:00
e390ece7b6 Создан синглтон класс 2023-03-10 19:25:23 +04:00
9c80b7fd37 Созданы модели 2023-03-10 19:25:22 +04:00
3b2493bbaf Merge branch 'LabWork01_Hard' of http://student.git.athene.tech/Danila_Mochalov/PIbd-23_Mochalov_D.V._LawFirm into LabWork01_Hard 2023-03-10 19:23:23 +04:00
b1dfb228b2 Сдана лаб 1 хард 2023-03-10 19:18:42 +04:00
cf13f3028e Доделал дату 2023-03-10 19:16:20 +04:00
5c57715fe3 Вроде готово. Надо исправить отображение даты открытия на форме FormShops 2023-03-10 19:16:20 +04:00
72b59a71eb Реализовано хранилище магазинов, класс магазина, изменен синглтон 2023-03-10 19:16:20 +04:00
14a2efbb78 Реализация логики магазина 2023-03-10 19:16:20 +04:00
8597edb910 Создание интерфейсов хранилища и логики магазина 2023-03-10 19:16:20 +04:00
d67f6123f2 Создание моделей магазина 2023-03-10 19:16:20 +04:00
49152e95c5 Исправления 2023-03-10 19:13:41 +04:00
ccfe49dde9 фикс удаления 2023-02-26 23:22:27 +04:00
8 changed files with 42 additions and 41 deletions

View File

@ -103,7 +103,6 @@ namespace LawFirmView
var operationResult = _logicO.CreateOrder(new OrderBindingModel
{
DocumentId = Convert.ToInt32(comboBoxDocument.SelectedValue),
DocumentName = comboBoxDocument.Text,
Count = Convert.ToInt32(textBoxCount.Text),
Sum = Convert.ToDouble(textBoxSum.Text)
});

View File

@ -64,7 +64,6 @@ namespace LawFirmBusinessLogic.BusinessLogics
{
Id = viewModel.Id,
DocumentId = viewModel.DocumentId,
DocumentName = viewModel.DocumentName,
Status = viewModel.Status,
DateCreate = viewModel.DateCreate,
DateImplement = viewModel.DateImplement,
@ -72,7 +71,7 @@ namespace LawFirmBusinessLogic.BusinessLogics
Sum = viewModel.Sum
};
CheckModel(model);
CheckModel(model, false);
if (model.Status + 1 != newStatus)
{
_logger.LogWarning("Status update to " + newStatus.ToString() +" operation failed. Order status incorrect.");

View File

@ -12,8 +12,6 @@ namespace LawFirmContracts.BindingModels
{
public int DocumentId { get; set; }
public string DocumentName { get; set; } = string.Empty;
public int Count { get; set; }
public double Sum { get; set; }

View File

@ -10,7 +10,6 @@ namespace LawFirmDataModels.Models
public interface IOrderModel : IId
{
int DocumentId { get; }
string DocumentName { get; }
int Count { get; }
double Sum { get; }
OrderStatus Status { get; }

View File

@ -26,8 +26,8 @@ namespace LawFirmFileImplement.Implements
{
return null;
}
return source.Orders
.FirstOrDefault(x => (model.Id.HasValue && x.Id == model.Id))?.GetViewModel;
return GetViewModel(source.Orders
.FirstOrDefault(x => (model.Id.HasValue && x.Id == model.Id)));
}
public List<OrderViewModel> GetFilteredList(OrderSearchModel model)
@ -38,13 +38,13 @@ namespace LawFirmFileImplement.Implements
}
return source.Orders
.Where(x => x.Id == model.Id)
.Select(x => x.GetViewModel)
.Select(x => GetViewModel(x))
.ToList();
}
public List<OrderViewModel> GetFullList()
{
return source.Orders.Select(x => x.GetViewModel).ToList();
return source.Orders.Select(x => GetViewModel(x)).ToList();
}
public OrderViewModel? Insert(OrderBindingModel model)
@ -57,7 +57,7 @@ namespace LawFirmFileImplement.Implements
}
source.Orders.Add(newOrder);
source.SaveOrders();
return newOrder.GetViewModel;
return GetViewModel(newOrder);
}
public OrderViewModel? Update(OrderBindingModel model)
@ -69,7 +69,7 @@ namespace LawFirmFileImplement.Implements
}
order.Update(model);
source.SaveOrders();
return order.GetViewModel;
return GetViewModel(order);
}
public OrderViewModel? Delete(OrderBindingModel model)
{
@ -80,7 +80,21 @@ namespace LawFirmFileImplement.Implements
}
source.Orders.Remove(order);
source.SaveOrders();
return order.GetViewModel;
return GetViewModel(order);
}
private OrderViewModel GetViewModel(Order order)
{
var viewModel = order.GetViewModel;
foreach (var document in source.Documents)
{
if (document.Id == order.DocumentId)
{
viewModel.DocumentName = document.DocumentName;
break;
}
}
return viewModel;
}
}

View File

@ -15,8 +15,6 @@ namespace LawFirmFileImplement.Models
{
public int DocumentId { get; private set; }
public string DocumentName { get; private set; } = string.Empty;
public int Count { get; private set; }
public double Sum { get; private set; }
@ -38,7 +36,6 @@ namespace LawFirmFileImplement.Models
return new Order
{
DocumentId = model.DocumentId,
DocumentName = model.DocumentName,
Count = model.Count,
Sum = model.Sum,
Status = model.Status,
@ -57,7 +54,6 @@ namespace LawFirmFileImplement.Models
return new Order()
{
Id = Convert.ToInt32(element.Attribute("Id")!.Value),
DocumentName = element.Element("DocumentName")!.Value,
DocumentId = Convert.ToInt32(element.Element("DocumentId")!.Value),
Sum = Convert.ToDouble(element.Element("Sum")!.Value),
Count = Convert.ToInt32(element.Element("Count")!.Value),
@ -73,20 +69,13 @@ namespace LawFirmFileImplement.Models
{
return;
}
DocumentId = model.DocumentId;
DocumentName = model.DocumentName;
Count = model.Count;
Sum = model.Sum;
Status = model.Status;
DateCreate = model.DateCreate;
DateImplement = model.DateImplement;
Id = model.Id;
}
public OrderViewModel GetViewModel => new()
{
DocumentId = DocumentId,
DocumentName = DocumentName,
Count = Count,
Sum = Sum,
DateCreate = DateCreate,
@ -98,7 +87,6 @@ namespace LawFirmFileImplement.Models
public XElement GetXElement => new(
"Order",
new XAttribute("Id", Id),
new XElement("DocumentName", DocumentName),
new XElement("DocumentId", DocumentId.ToString()),
new XElement("Count", Count.ToString()),
new XElement("Sum", Sum.ToString()),

View File

@ -30,7 +30,7 @@ namespace LawFirmListImplements.Implements
{
if (model.Id.HasValue && order.Id == model.Id)
{
return order.GetViewModel;
return GetViewModel(order);
}
}
return null;
@ -47,7 +47,7 @@ namespace LawFirmListImplements.Implements
{
if (order.Id == model.Id)
{
result.Add(order.GetViewModel);
result.Add(GetViewModel(order));
}
}
return result;
@ -58,7 +58,7 @@ namespace LawFirmListImplements.Implements
var result = new List<OrderViewModel>();
foreach (var order in _source.Orders)
{
result.Add(order.GetViewModel);
result.Add(GetViewModel(order));
}
return result;
}
@ -79,7 +79,7 @@ namespace LawFirmListImplements.Implements
return null;
}
_source.Orders.Add(newOrder);
return newOrder.GetViewModel;
return GetViewModel(newOrder);
}
public OrderViewModel? Update(OrderBindingModel model)
@ -89,7 +89,7 @@ namespace LawFirmListImplements.Implements
if (order.Id == model.Id)
{
order.Update(model);
return order.GetViewModel;
return GetViewModel(order);
}
}
return null;
@ -102,11 +102,25 @@ namespace LawFirmListImplements.Implements
{
var element = _source.Orders[i];
_source.Orders.RemoveAt(i);
return element.GetViewModel;
return GetViewModel(element);
}
}
return null;
}
private OrderViewModel GetViewModel(Order order)
{
var viewModel = order.GetViewModel;
foreach (var document in _source.Documents)
{
if (document.Id == order.DocumentId)
{
viewModel.DocumentName = document.DocumentName;
break;
}
}
return viewModel;
}
}
}

View File

@ -14,8 +14,6 @@ namespace LawFirmListImplements.Models
{
public int DocumentId { get; private set; }
public string DocumentName { get; private set; } = string.Empty;
public int Count { get; private set; }
public double Sum { get; private set; }
@ -37,7 +35,6 @@ namespace LawFirmListImplements.Models
return new Order
{
DocumentId = model.DocumentId,
DocumentName = model.DocumentName,
Count = model.Count,
Sum = model.Sum,
Status = model.Status,
@ -53,20 +50,13 @@ namespace LawFirmListImplements.Models
{
return;
}
DocumentId = model.DocumentId;
DocumentName = model.DocumentName;
Count = model.Count;
Sum = model.Sum;
Status = model.Status;
DateCreate = model.DateCreate;
DateImplement = model.DateImplement;
Id = model.Id;
}
public OrderViewModel GetViewModel => new()
{
DocumentId = DocumentId,
DocumentName = DocumentName,
Count = Count,
Sum = Sum,
DateCreate = DateCreate,