using DinerContracts.BindingModels; using DinerContracts.ViewModels; using DinerDataModels.Models; using Microsoft.EntityFrameworkCore.Query.Internal; using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; using System.Linq; using System.Text; using System.Threading.Tasks; namespace DinerDataBaseImplement.Models { public class Client : IClientModel { [Required] public string ClientFIO { get; set; } = string.Empty; [Required] public string Email { get; set; } = string.Empty; [Required] public string Password { get; set; } = string.Empty; public int ID { get; private set; } [ForeignKey("ClientID")] public virtual List Orders { get; set; } = new(); public static Client? Create(ClientBindingModel? model) { if (model == null) { return null; } return new Client() { ClientFIO = model.ClientFIO, Email = model.Email, Password = model.Password, ID = model.ID, }; } public static Client Create(ClientViewModel model) { return new Client { ID = model.ID, ClientFIO = model.ClientFIO, Email = model.Email, Password = model.Password }; } public void Update(ClientBindingModel? model) { if (model == null) { return; } ClientFIO = model.ClientFIO; Email = model.Email; Password = model.Password; } public ClientViewModel GetViewModel => new() { ClientFIO = ClientFIO, Email = Email, Password = Password, ID = ID }; } }