using AircraftPlantContracts.BindingModels; using AircraftPlantContracts.SearchModels; using AircraftPlantContracts.StoragesContracts; using AircraftPlantContracts.ViewModels; using AircraftPlantDatabaseImplement.Models; using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace AircraftPlantDatabaseImplement.Implements { /// /// Реализация интерфейса хранилища для писем /// public class MessageInfoStorage : IMessageInfoStorage { /// /// Получение полного списка /// /// public List GetFullList() { using var context = new AircraftPlantDatabase(); return context.Messages .Select(x => x.GetViewModel) .ToList(); } /// /// Получение фильтрованного списка /// /// /// public List GetFilteredList(MessageInfoSearchModel model) { if (!model.ClientId.HasValue && (!model.PageSize.HasValue || !model.CurrentPage.HasValue)) { return new(); } using var context = new AircraftPlantDatabase(); if (model.CurrentPage.HasValue && model.PageSize.HasValue && model.ClientId.HasValue) { return context.Messages .Where(x => x.ClientId == model.ClientId) .Skip((model.CurrentPage.Value - 1) * model.PageSize.Value) .Take(model.PageSize.Value) .Select(x => x.GetViewModel) .ToList(); } if (model.CurrentPage.HasValue && model.PageSize.HasValue) { return context.Messages .Skip((model.CurrentPage.Value - 1) * model.PageSize.Value) .Take(model.PageSize.Value) .Select(x => x.GetViewModel) .ToList(); } return context.Messages .Where(x => x.ClientId == model.ClientId) .Select(x => x.GetViewModel) .ToList(); } /// /// Получение элемента /// /// /// public MessageInfoViewModel? GetElement(MessageInfoSearchModel model) { if (string.IsNullOrEmpty(model.MessageId)) { return null; } using var context = new AircraftPlantDatabase(); return context.Messages .FirstOrDefault(x => x.MessageId == model.MessageId) ?.GetViewModel; } /// /// Добавление элемента /// /// /// public MessageInfoViewModel? Insert(MessageInfoBindingModel model) { var newMessage = Message.Create(model); if (newMessage == null) { return null; } using var context = new AircraftPlantDatabase(); context.Messages.Add(newMessage); context.SaveChanges(); return newMessage.GetViewModel; } /// /// Редактирование элемента /// /// /// public MessageInfoViewModel? Update(MessageInfoBindingModel model) { using var context = new AircraftPlantDatabase(); var message = context.Messages.FirstOrDefault(x => x.MessageId == model.MessageId); if (message == null) { return null; } message.Update(model); context.SaveChanges(); return message.GetViewModel; } } }