Заполнение Room в HotelDataBaseImplement.Models

This commit is contained in:
Кашин Максим 2023-04-05 11:31:08 +04:00
parent edcfa8e39e
commit 9797a27a3f
3 changed files with 87 additions and 9 deletions

View File

@ -14,12 +14,14 @@ namespace HotelDataBaseImplement
base.OnConfiguring(optionsBuilder); base.OnConfiguring(optionsBuilder);
} }
public virtual DbSet<Conference> Conferences { set; get; } public virtual DbSet<Conference> Conferences { set; get; }
public virtual DbSet<Room> Rooms { set; get; }
public virtual DbSet<MealPlan> MealPlans { set; get; } public virtual DbSet<MealPlan> MealPlans { set; get; }
public virtual DbSet<ConferenceBooking> ConferenceBookings { set; get; } public virtual DbSet<ConferenceBooking> ConferenceBookings { set; get; }
public virtual DbSet<Member> Members { set; get; } public virtual DbSet<Member> Members { set; get; }
public virtual DbSet<Dinner> Dinners { set; get; } public virtual DbSet<Dinner> Dinners { set; get; }
public virtual DbSet<Organiser> Organisers { set; get; } public virtual DbSet<Organiser> Organisers { set; get; }
public virtual DbSet<ConferenceMember> ConferenceMembers { set; get; } public virtual DbSet<ConferenceMember> ConferenceMembers { set; get; }
public virtual DbSet<RoomDinner> RoomDinners { set; get; }
public virtual DbSet<MealPlanMember> MealPlanMembers { set; get; } public virtual DbSet<MealPlanMember> MealPlanMembers { set; get; }
public virtual DbSet<ConferenceBookingDinner> ConferenceBookingDinners { set; get; } public virtual DbSet<ConferenceBookingDinner> ConferenceBookingDinners { set; get; }

View File

@ -1,6 +1,10 @@
using HotelDataModels.Models; using HotelContracts.BindingModels;
using HotelContracts.ViewModels;
using HotelDataModels.Models;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.ComponentModel.DataAnnotations.Schema;
using System.ComponentModel.DataAnnotations;
using System.Linq; using System.Linq;
using System.Text; using System.Text;
using System.Threading.Tasks; using System.Threading.Tasks;
@ -9,16 +13,88 @@ namespace HotelDataBaseImplement.Models
{ {
public class Room : IRoomModel public class Room : IRoomModel
{ {
public string RoomName => throw new NotImplementedException(); [Required]
public string RoomName { get; set; } = string.Empty;
[Required]
public string RoomFrame { get; set; } = string.Empty;
[Required]
public double RoomPrice { get; set; }
public int HeadwaiterId { get; private set; }
public int MealPlanId { get; private set; }
public int Id { get; private set; }
public string RoomFrame => throw new NotImplementedException(); public virtual Headwaiter Headwaiter { get; set; }
public virtual MealPlan MealPlan { get; set; }
public double RoomPrice => throw new NotImplementedException(); [ForeignKey("RoomId")]
public virtual List<RoomDinner> Dinners { get; set; }
public int HeadwaiterId => throw new NotImplementedException(); private Dictionary<int, IDinnerModel> _roomDinners = null;
public Dictionary<int, IDinnerModel> RoomDinners
public int MealPlanId => throw new NotImplementedException(); {
get
public int Id => throw new NotImplementedException(); {
if (_roomDinners == null)
{
_roomDinners = Dinners.ToDictionary(recPC => recPC.DinnerId, recPC => (recPC.Dinner as IDinnerModel));
}
return _roomDinners;
}
}
public static Room Create(HotelDataBase context, RoomBindingModel model)
{
return new Room()
{
Id = model.Id,
RoomName = model.RoomName,
RoomFrame = model.RoomFrame,
RoomPrice = model.RoomPrice,
Dinners = model.RoomDinners.Select(x => new RoomDinner
{
Dinner = context.Dinners.First(y => y.Id == x.Key),
}).ToList()
};
}
public void Update(RoomBindingModel model)
{
RoomName = model.RoomName;
RoomFrame = model.RoomFrame;
RoomPrice = model.RoomPrice;
}
public RoomViewModel GetViewModel => new()
{
Id = Id,
RoomName = RoomName,
RoomFrame = RoomFrame,
RoomPrice = RoomPrice,
RoomDinners = RoomDinners
};
public void UpdateDinners(HotelDataBase context, RoomBindingModel model)
{
var roomDinners = context.RoomDinners.Where(rec => rec.RoomId == model.Id).ToList();
if (roomDinners != null)
{
context.RoomDinners.RemoveRange(roomDinners.Where(rec => !model.RoomDinners.ContainsKey(rec.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;
}
} }
} }

View File

@ -15,7 +15,7 @@ namespace HotelDataBaseImplement.Models
[Required] [Required]
public int Count { get; set; } public int Count { get; set; }
public virtual Room Rooms { get; set; } public virtual Room Room { get; set; }
public virtual Dinner Dinners { get; set; } public virtual Dinner Dinner { get; set; }
} }
} }