using FoodOrdersContracts.BindingModels; using FoodOrdersContracts.SearchModels; using FoodOrdersContracts.StoragesContracts; using FoodOrdersContracts.ViewModels; using FoodOrdersDatabaseImplement.Models; namespace FoodOrdersDatabaseImplement.Implements { public class MessageInfoStorage : IMessageInfoStorage { public MessageInfoViewModel? GetElement(MessageInfoSearchModel model) { using var context = new FoodOrdersDatabase(); if (!string.IsNullOrEmpty(model.MessageId)) { return context.Messages.FirstOrDefault(x => x.MessageId == model.MessageId)?.GetViewModel; } return null; } public List GetFilteredList(MessageInfoSearchModel model) { using var context = new FoodOrdersDatabase(); var res = context.Messages .Where(x => !model.ClientId.HasValue || x.ClientId == model.ClientId) .Select(x => x.GetViewModel); if (!(model.Page.HasValue && model.PageSize.HasValue)) { return res.ToList(); } return res.Skip((model.Page.Value - 1) * model.PageSize.Value).Take(model.PageSize.Value).ToList(); } public List GetFullList() { using var context = new FoodOrdersDatabase(); return context.Messages .Select(x => x.GetViewModel) .ToList(); } public MessageInfoViewModel? Insert(MessageInfoBindingModel model) { var newMessage = MessageInfo.Create(model); if (newMessage == null) { return null; } using var context = new FoodOrdersDatabase(); context.Messages.Add(newMessage); context.SaveChanges(); return context.Messages .FirstOrDefault(x => x.MessageId == newMessage.MessageId)? .GetViewModel; } public MessageInfoViewModel? Update(MessageInfoBindingModel model) { using var context = new FoodOrdersDatabase(); var res = context.Messages.FirstOrDefault(x => x.MessageId.Equals(model.MessageId)); if (res != null) { res.Update(model); context.SaveChanges(); } return res?.GetViewModel; } } }