using Microsoft.EntityFrameworkCore; using PolyclinicContracts.BindingModels; using PolyclinicContracts.SearchModels; using PolyclinicContracts.StoragesContracts; using PolyclinicContracts.ViewModels; using PolyclinicDatabaseImplement.Models; using SecuritySystemDatabaseImplement; namespace PolyclinicDatabaseImplement.Implements { public class CourseStorage : ICourseStorage { public CourseViewModel? Delete(CourseBindingModel model) { using var context = new PolyclinicDatabase(); var element = context.Courses.FirstOrDefault(rec => rec.Id == model.Id); if (element != null) { context.Courses.Remove(element); context.SaveChanges(); return element.GetViewModel; } return null; } public CourseViewModel? GetElement(CourseSearchModel model) { return GetFilteredList(model).FirstOrDefault(); } public List GetFilteredList(CourseSearchModel model) { var elements = GetFullList(); foreach (var prop in model.GetType().GetProperties()) { if (model.GetType().GetProperty(prop.Name)?.GetValue(model, null) != null) { elements = elements.Where(x => x.GetType().GetProperty(prop.Name)?.GetValue(x, null) == model.GetType().GetProperty(prop.Name)?.GetValue(model, null)).ToList(); } } return elements; } public List GetFullList() { using var context = new PolyclinicDatabase(); return context.Courses .Include(x => x.Recipe) .Include(x => x.Diagnoses) .ThenInclude(x => x.Diagnose) .Select(x => x.GetViewModel) .ToList(); } public CourseViewModel? Insert(CourseBindingModel model) { using var context = new PolyclinicDatabase(); var element = Course.Create(context, model); if (element == null) { return null; } context.Courses.Add(element); context.SaveChanges(); return element.GetViewModel; } public CourseViewModel? Update(CourseBindingModel model) { using var context = new PolyclinicDatabase(); var element = context.Courses.FirstOrDefault(x => x.Id == model.Id); if (element == null) { return null; } element.Update(model); context.SaveChanges(); return element.GetViewModel; } } }