using HotelContracts.BindingModels; using HotelContracts.ViewModels; using HotelDataModels.Models; using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; namespace HotelDataBaseImplement.Models { public class Room : IRoomModel { public int Id { get; private set; } [Required] public int RoomNumber { get; set; } [Required] public double RoomPrice { get; set; } [Required] public DateTime DateCreate { get; set; } = DateTime.Now; public int AdministratorId { get; private set; } public int? MealPlanId { get; private set; } public virtual Administrator Administrator { get; set; } public virtual MealPlan? MealPlan { get; set; } [ForeignKey("RoomId")] public virtual List Dinners { get; set; } = new(); [ForeignKey("RoomId")] public virtual List MealPlanRooms { get; set; } private Dictionary _roomDinners = null; [NotMapped] public Dictionary RoomDinners { get { if (_roomDinners == null) { using var context = new HotelDataBase(); _roomDinners = Dinners .ToDictionary(x => x.DinnerId, x => (context.Dinners .FirstOrDefault(y => y.Id == x.DinnerId)! as IDinnerModel)); } return _roomDinners; } } public static Room Create(HotelDataBase context, RoomBindingModel model) { return new Room() { Id = model.Id, RoomNumber = model.RoomNumber, RoomPrice = model.RoomPrice, DateCreate = model.DateCreate, AdministratorId = model.AdministratorId, MealPlanId = model.MealPlanId, Dinners = model.RoomDinners.Select(x => new RoomDinner { Dinner = context.Dinners.First(y => y.Id == x.Key), }).ToList() }; } public void Update(RoomBindingModel model) { RoomNumber = model.RoomNumber; RoomPrice = model.RoomPrice; DateCreate = model.DateCreate; AdministratorId = model.AdministratorId; MealPlanId = model.MealPlanId; } public RoomViewModel GetViewModel => new() { Id = Id, RoomNumber = RoomNumber, RoomPrice = RoomPrice, DateCreate = DateCreate, AdministratorId = AdministratorId, MealPlanId = MealPlanId, RoomDinners = RoomDinners }; public void UpdateDinners(HotelDataBase context, RoomBindingModel model) { var roomDinners = context.RoomDinners.Where(rec => rec.RoomId == model.Id).ToList(); if (roomDinners != null && roomDinners.Count > 0) { context.RoomDinners.RemoveRange(roomDinners.Where(rec => !model.RoomDinners.ContainsKey(rec.DinnerId))); context.SaveChanges(); foreach (var updateDinner in roomDinners) { model.RoomDinners.Remove(updateDinner.DinnerId); } context.SaveChanges(); } var room = context.Rooms.First(x => x.Id == Id); foreach (var cm in model.RoomDinners) { context.RoomDinners.Add(new RoomDinner { Room = room, Dinner = context.Dinners.First(x => x.Id == cm.Key), }); context.SaveChanges(); } _roomDinners = null; } } }