Исправление BindingModel, ViewModel, DataModels, и дополнение Models в DataBaseImplement
This commit is contained in:
parent
c0c1c2dad2
commit
d92984f518
@ -11,5 +11,6 @@ namespace HotelContracts.BindingModels
|
||||
public int Id { get; set; }
|
||||
|
||||
public int OrganiserId { get; set; }
|
||||
public Dictionary<int, IMemberModel> ConferenceMembers { get; set; }
|
||||
}
|
||||
}
|
||||
|
@ -11,5 +11,6 @@ namespace HotelContracts.BindingModels
|
||||
public int OrganiserId { get; set; }
|
||||
|
||||
public int Id { get; set; }
|
||||
public Dictionary<int, IMemberModel> MealPlanMembers { get; set; }
|
||||
}
|
||||
}
|
||||
|
@ -14,5 +14,6 @@ namespace HotelContracts.ViewModels
|
||||
public int OrganiserId { get; set; }
|
||||
|
||||
public int Id { get; set; }
|
||||
public Dictionary<int, IMemberModel> ConferenceMembers { get; set; }
|
||||
}
|
||||
}
|
||||
|
@ -14,5 +14,7 @@ namespace HotelContracts.ViewModels
|
||||
public int OrganiserId { get; set; }
|
||||
|
||||
public int Id { get; set; }
|
||||
|
||||
public Dictionary<int, IMemberModel> MealPlanMembers { get; set; }
|
||||
}
|
||||
}
|
||||
|
@ -1,9 +1,23 @@
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using HotelDataBaseImplement.Models;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace HotelDataBaseImplement
|
||||
{
|
||||
public class HotelDataBase : DbContext
|
||||
{
|
||||
|
||||
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
|
||||
{
|
||||
if (optionsBuilder.IsConfigured == false)
|
||||
{
|
||||
optionsBuilder.UseSqlServer(@"Data Source=ANNZHIMOL\SQLEXPRESS;Initial Catalog=HotelDataBaseFull;Integrated Security=True;MultipleActiveResultSets=True;;TrustServerCertificate=True");
|
||||
}
|
||||
base.OnConfiguring(optionsBuilder);
|
||||
}
|
||||
public virtual DbSet<Conference> Conferences { set; get; }
|
||||
public virtual DbSet<MealPlan> MealPlans { set; get; }
|
||||
public virtual DbSet<Member> Members { set; get; }
|
||||
public virtual DbSet<Organiser> Organisers { set; get; }
|
||||
public virtual DbSet<ConferenceMember> ConferenceMembers { set; get; }
|
||||
public virtual DbSet<MealPlanMember> MealPlanMembers { set; get; }
|
||||
}
|
||||
}
|
@ -1,15 +1,90 @@
|
||||
using HotelDataModels.Models;
|
||||
using HotelContracts.BindingModels;
|
||||
using HotelContracts.ViewModels;
|
||||
using HotelDataModels.Models;
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
using System.ComponentModel.DataAnnotations.Schema;
|
||||
|
||||
namespace HotelDataBaseImplement.Models
|
||||
{
|
||||
public class Conference : IConferenceModel
|
||||
{
|
||||
public string ConferenceName => throw new NotImplementedException();
|
||||
[Required]
|
||||
public string ConferenceName { get; set; } = string.Empty;
|
||||
[Required]
|
||||
public DateTime StartDate { get; set; } = DateTime.Now;
|
||||
|
||||
public DateTime StartDate => throw new NotImplementedException();
|
||||
public int OrganiserId { get; private set; }
|
||||
|
||||
public int OrganiserId => throw new NotImplementedException();
|
||||
public int Id { get; private set; }
|
||||
|
||||
public int Id => throw new NotImplementedException();
|
||||
public virtual Organiser Organiser { get; set; }
|
||||
|
||||
[ForeignKey("ConferenceId")]
|
||||
public virtual List<ConferenceMember> Members { get; set; }
|
||||
|
||||
private Dictionary<int, IMemberModel> _conferenceMembers = null;
|
||||
public Dictionary<int, IMemberModel> ConferenceMembers
|
||||
{
|
||||
get
|
||||
{
|
||||
if (_conferenceMembers == null)
|
||||
{
|
||||
_conferenceMembers = Members.ToDictionary(recPC => recPC.MemberId, recPC => (recPC.Member as IMemberModel));
|
||||
}
|
||||
return _conferenceMembers;
|
||||
}
|
||||
}
|
||||
|
||||
public static Conference Create(HotelDataBase context, ConferenceBindingModel model)
|
||||
{
|
||||
return new Conference()
|
||||
{
|
||||
Id = model.Id,
|
||||
ConferenceName = model.ConferenceName,
|
||||
StartDate = model.StartDate,
|
||||
Members = model.ConferenceMembers.Select(x => new ConferenceMember
|
||||
{
|
||||
Member = context.Members.First(y => y.Id == x.Key),
|
||||
}).ToList()
|
||||
};
|
||||
}
|
||||
|
||||
public void Update(ConferenceBindingModel model)
|
||||
{
|
||||
ConferenceName = model.ConferenceName;
|
||||
StartDate = model.StartDate;
|
||||
}
|
||||
|
||||
public ConferenceViewModel GetViewModel => new()
|
||||
{
|
||||
Id = Id,
|
||||
ConferenceName = ConferenceName,
|
||||
StartDate = StartDate,
|
||||
ConferenceMembers = ConferenceMembers
|
||||
};
|
||||
|
||||
public void UpdateMembers(HotelDataBase context, ConferenceBindingModel model)
|
||||
{
|
||||
var conferenceMembers = context.ConferenceMembers.Where(rec => rec.ConferenceId == model.Id).ToList();
|
||||
|
||||
if (conferenceMembers != null)
|
||||
{ // удалили те, которых нет в модели
|
||||
context.ConferenceMembers.RemoveRange(conferenceMembers.Where(rec => !model.ConferenceMembers.ContainsKey(rec.MemberId)));
|
||||
context.SaveChanges();
|
||||
}
|
||||
|
||||
var conference = context.Conferences.First(x => x.Id == Id);
|
||||
|
||||
foreach (var cm in model.ConferenceMembers)
|
||||
{
|
||||
context.ConferenceMembers.Add(new ConferenceMember
|
||||
{
|
||||
Conference = conference,
|
||||
Member = context.Members.First(x => x.Id == cm.Key)
|
||||
});
|
||||
context.SaveChanges();
|
||||
}
|
||||
_conferenceMembers = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
18
Hotel/HotelDataBaseImplement/Models/ConferenceMember.cs
Normal file
18
Hotel/HotelDataBaseImplement/Models/ConferenceMember.cs
Normal file
@ -0,0 +1,18 @@
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
|
||||
namespace HotelDataBaseImplement.Models
|
||||
{
|
||||
public class ConferenceMember
|
||||
{
|
||||
public int Id { get; set; }
|
||||
|
||||
[Required]
|
||||
public int MemberId { get; set; }
|
||||
|
||||
[Required]
|
||||
public int ConferenceId { get; set; }
|
||||
|
||||
public virtual Conference Conference { get; set; } = new();
|
||||
public virtual Member Member { get; set; } = new();
|
||||
}
|
||||
}
|
@ -1,15 +1,91 @@
|
||||
using HotelDataModels.Models;
|
||||
using HotelContracts.BindingModels;
|
||||
using HotelContracts.ViewModels;
|
||||
using HotelDataModels.Models;
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
using System.ComponentModel.DataAnnotations.Schema;
|
||||
|
||||
namespace HotelDataBaseImplement.Models
|
||||
{
|
||||
public class MealPlan : IMealPlanModel
|
||||
{
|
||||
public string MealPlanName => throw new NotImplementedException();
|
||||
[Required]
|
||||
public string MealPlanName { get; set; } = string.Empty;
|
||||
|
||||
public double MealPlanPrice => throw new NotImplementedException();
|
||||
[Required]
|
||||
public double MealPlanPrice { get; set; }
|
||||
|
||||
public int OrganiserId => throw new NotImplementedException();
|
||||
public int OrganiserId { get; private set; }
|
||||
|
||||
public int Id => throw new NotImplementedException();
|
||||
public int Id { get; private set; }
|
||||
|
||||
public virtual Organiser Organiser { get; set; }
|
||||
|
||||
[ForeignKey("MealPlanId")]
|
||||
public virtual List<MealPlanMember> Members { get; set; }
|
||||
|
||||
private Dictionary<int, IMemberModel> _mealPlanMembers = null;
|
||||
|
||||
public Dictionary<int, IMemberModel> MealPlanMembers
|
||||
{
|
||||
get
|
||||
{
|
||||
if (_mealPlanMembers == null)
|
||||
{
|
||||
_mealPlanMembers = Members.ToDictionary(recPC => recPC.MemberId, recPC => (recPC.Member as IMemberModel));
|
||||
}
|
||||
return _mealPlanMembers;
|
||||
}
|
||||
}
|
||||
public static MealPlan Create(HotelDataBase context, MealPlanBindingModel model)
|
||||
{
|
||||
return new MealPlan()
|
||||
{
|
||||
Id = model.Id,
|
||||
MealPlanName = model.MealPlanName,
|
||||
MealPlanPrice = model.MealPlanPrice,
|
||||
Members = model.MealPlanMembers.Select(x => new MealPlanMember
|
||||
{
|
||||
Member = context.Members.First(y => y.Id == x.Key),
|
||||
}).ToList()
|
||||
};
|
||||
}
|
||||
|
||||
public void Update(MealPlanBindingModel model)
|
||||
{
|
||||
MealPlanName = model.MealPlanName;
|
||||
MealPlanPrice = model.MealPlanPrice;
|
||||
}
|
||||
|
||||
public MealPlanViewModel GetViewModel => new()
|
||||
{
|
||||
Id = Id,
|
||||
MealPlanName = MealPlanName,
|
||||
MealPlanPrice = MealPlanPrice,
|
||||
MealPlanMembers = MealPlanMembers
|
||||
};
|
||||
|
||||
public void UpdateMembers(HotelDataBase context, MealPlanBindingModel model)
|
||||
{
|
||||
var mealPlanMembers = context.MealPlanMembers.Where(rec => rec.MealPlanId == model.Id).ToList();
|
||||
|
||||
if (mealPlanMembers != null)
|
||||
{ // удалили те, которых нет в модели
|
||||
context.MealPlanMembers.RemoveRange(mealPlanMembers.Where(rec => !model.MealPlanMembers.ContainsKey(rec.MemberId)));
|
||||
context.SaveChanges();
|
||||
}
|
||||
|
||||
var mealPlan = context.MealPlans.First(x => x.Id == Id);
|
||||
|
||||
foreach (var cm in model.MealPlanMembers)
|
||||
{
|
||||
context.MealPlanMembers.Add(new MealPlanMember
|
||||
{
|
||||
MealPlan = mealPlan,
|
||||
Member = context.Members.First(x => x.Id == cm.Key)
|
||||
});
|
||||
context.SaveChanges();
|
||||
}
|
||||
_mealPlanMembers = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
18
Hotel/HotelDataBaseImplement/Models/MealPlanMember.cs
Normal file
18
Hotel/HotelDataBaseImplement/Models/MealPlanMember.cs
Normal file
@ -0,0 +1,18 @@
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
|
||||
namespace HotelDataBaseImplement.Models
|
||||
{
|
||||
public class MealPlanMember
|
||||
{
|
||||
public int Id { get; set; }
|
||||
|
||||
[Required]
|
||||
public int MemberId { get; set; }
|
||||
|
||||
[Required]
|
||||
public int MealPlanId { get; set; }
|
||||
|
||||
public virtual MealPlan MealPlan { get; set; } = new();
|
||||
public virtual Member Member { get; set; } = new();
|
||||
}
|
||||
}
|
@ -1,15 +1,29 @@
|
||||
using HotelDataModels.Models;
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
using System.ComponentModel.DataAnnotations.Schema;
|
||||
|
||||
namespace HotelDataBaseImplement.Models
|
||||
{
|
||||
public class Member : IMemberModel
|
||||
{
|
||||
public string MemberFIO => throw new NotImplementedException();
|
||||
[Required]
|
||||
public string MemberFIO { get; set; } = string.Empty;
|
||||
|
||||
public string Citizenship => throw new NotImplementedException();
|
||||
[Required]
|
||||
public string Citizenship { get; set; } = string.Empty;
|
||||
|
||||
public int OrganiserId { get; private set; }
|
||||
|
||||
public int Id { get; private set; }
|
||||
|
||||
public virtual Organiser Organiser { get; set; }
|
||||
|
||||
[ForeignKey("MemberId")]
|
||||
public virtual List<MealPlanMember> MealPlanMember { get; set; }
|
||||
|
||||
[ForeignKey("MemberId")]
|
||||
public virtual List<ConferenceMember> ConferenceMember { get; set; }
|
||||
|
||||
public int OrganiserId => throw new NotImplementedException();
|
||||
|
||||
public int Id => throw new NotImplementedException();
|
||||
}
|
||||
}
|
||||
|
@ -1,19 +1,81 @@
|
||||
using HotelDataModels.Models;
|
||||
using HotelContracts.BindingModels;
|
||||
using HotelContracts.ViewModels;
|
||||
using HotelDataModels.Models;
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
using System.ComponentModel.DataAnnotations.Schema;
|
||||
|
||||
namespace HotelDataBaseImplement.Models
|
||||
{
|
||||
public class Organiser : IOrganiserModel
|
||||
{
|
||||
public string OrganiserFIO => throw new NotImplementedException();
|
||||
[Required]
|
||||
public string OrganiserFIO { get; set; } = string.Empty;
|
||||
[Required]
|
||||
public string OrganiserPassword { get; set; } = string.Empty;
|
||||
[Required]
|
||||
public string OrganiserLogin { get; set; } = string.Empty;
|
||||
[Required]
|
||||
public string OrganiserEmail { get; set; } = string.Empty;
|
||||
[Required]
|
||||
public string OrganiserNumber { get; set; } = string.Empty;
|
||||
|
||||
public string OrganiserPassword => throw new NotImplementedException();
|
||||
public int Id { get; private set; }
|
||||
|
||||
public string OrganiserLogin => throw new NotImplementedException();
|
||||
[ForeignKey("OrganiserId")]
|
||||
public virtual List<Conference> Conferences { get; set; } = new();
|
||||
[ForeignKey("OrganiserId")]
|
||||
public virtual List<MealPlan> MealPlans { get; set; } = new();
|
||||
[ForeignKey("OrganiserId")]
|
||||
public virtual List<Member> Members { get; set; } = new();
|
||||
|
||||
public string OrganiserEmail => throw new NotImplementedException();
|
||||
|
||||
public string OrganiserNumber => throw new NotImplementedException();
|
||||
|
||||
public int Id => throw new NotImplementedException();
|
||||
public static Organiser? Create(OrganiserBindingModel model)
|
||||
{
|
||||
if (model == null)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
return new Organiser()
|
||||
{
|
||||
Id = model.Id,
|
||||
OrganiserFIO = model.OrganiserFIO,
|
||||
OrganiserEmail = model.OrganiserEmail,
|
||||
OrganiserPassword = model.OrganiserPassword,
|
||||
OrganiserLogin = model.OrganiserLogin,
|
||||
OrganiserNumber = model.OrganiserNumber
|
||||
};
|
||||
}
|
||||
public static Organiser Create(OrganiserViewModel model)
|
||||
{
|
||||
return new Organiser
|
||||
{
|
||||
Id = model.Id,
|
||||
OrganiserFIO = model.OrganiserFIO,
|
||||
OrganiserEmail = model.OrganiserEmail,
|
||||
OrganiserPassword = model.OrganiserPassword,
|
||||
OrganiserLogin= model.OrganiserLogin,
|
||||
OrganiserNumber= model.OrganiserNumber
|
||||
};
|
||||
}
|
||||
public void Update(OrganiserBindingModel model)
|
||||
{
|
||||
if (model == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
OrganiserFIO = model.OrganiserFIO;
|
||||
OrganiserEmail = model.OrganiserEmail;
|
||||
OrganiserPassword = model.OrganiserPassword;
|
||||
OrganiserLogin = model.OrganiserLogin;
|
||||
OrganiserNumber = model.OrganiserNumber;
|
||||
}
|
||||
public OrganiserViewModel GetViewModel => new()
|
||||
{
|
||||
Id = Id,
|
||||
OrganiserFIO = OrganiserFIO,
|
||||
OrganiserEmail = OrganiserEmail,
|
||||
OrganiserPassword = OrganiserPassword,
|
||||
OrganiserNumber = OrganiserNumber,
|
||||
OrganiserLogin = OrganiserLogin
|
||||
};
|
||||
}
|
||||
}
|
||||
|
@ -5,5 +5,6 @@
|
||||
string ConferenceName { get; }
|
||||
DateTime StartDate { get; }
|
||||
int OrganiserId { get; }
|
||||
public Dictionary<int, IMemberModel> ConferenceMembers { get; }
|
||||
}
|
||||
}
|
||||
|
@ -5,5 +5,6 @@
|
||||
string MealPlanName { get; }
|
||||
double MealPlanPrice { get; }
|
||||
int OrganiserId { get; }
|
||||
public Dictionary<int, IMemberModel> MealPlanMembers { get; }
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user