PIbd-22_Turner_I.A._Plumbin.../PlumbingRepair/PlumbingRepairDatabaseImplement/Models/Work.cs
2023-03-04 20:23:01 +04:00

102 lines
3.4 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using PlumbingRepairContracts.BindingModels;
using PlumbingRepairContracts.ViewModels;
using PlumbingRepairDataModels.Models;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
namespace PlumbingRepairDatabaseImplement.Models
{
public class Work : IWorkModel
{
public int Id { get; set; }
[Required]
public string WorkName { get; set; } = string.Empty;
[Required]
public double Price { get; set; }
private Dictionary<int, (IComponentModel, int)>? _workComponents = null;
[NotMapped]
public Dictionary<int, (IComponentModel, int)> WorkComponents
{
get
{
if (_workComponents == null)
{
_workComponents = Components.ToDictionary(recPC => recPC.ComponentId, recPC => (recPC.Component as IComponentModel, recPC.Count));
}
return _workComponents;
}
}
[ForeignKey("WorkId")]
public virtual List<WorkComponent> Components { get; set; } = new();
[ForeignKey("WorkId")]
public virtual List<Order> Orders { get; set; } = new();
public static Work Create(PlumbingRepairDataBase context, WorkBindingModel model)
{
return new Work()
{
Id = model.Id,
WorkName = model.WorkName,
Price = model.Price,
Components = model.WorkComponents.Select(x => new WorkComponent
{
Component = context.Components.First(y => y.Id == x.Key),
Count = x.Value.Item2
}).ToList()
};
}
public void Update(WorkBindingModel model)
{
WorkName = model.WorkName;
Price = model.Price;
}
public WorkViewModel GetViewModel => new()
{
Id = Id,
WorkName = WorkName,
Price = Price,
WorkComponents = WorkComponents
};
public void UpdateComponents(PlumbingRepairDataBase context, WorkBindingModel model)
{
var workComponents = context.WorkComponents.Where(rec => rec.WorkId == model.Id).ToList();
if (workComponents != null && workComponents.Count > 0)
{ // удалили те, которых нет в модели
context.WorkComponents.RemoveRange(workComponents.Where(rec => !model.WorkComponents.ContainsKey(rec.ComponentId)));
context.SaveChanges();
// обновили количество у существующих записей
foreach (var updateComponent in workComponents)
{
updateComponent.Count = model.WorkComponents[updateComponent.ComponentId].Item2;
model.WorkComponents.Remove(updateComponent.ComponentId);
}
context.SaveChanges();
}
var work = context.Works.First(x => x.Id == Id);
foreach (var pc in model.WorkComponents)
{
context.WorkComponents.Add(new WorkComponent
{
Work = work,
Component = context.Components.First(x => x.Id == pc.Key),
Count = pc.Value.Item2
});
context.SaveChanges();
}
_workComponents = null;
}
}
}