using DocumentFormat.OpenXml.InkML; using ShipyardContracts.BindingModels; using ShipyardContracts.ViewModels; using ShipyardDataModels.Enums; using ShipyardDataModels.Models; using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.Linq; using System.Text; using System.Threading.Tasks; namespace ShipyardDatabaseImplement.Models { public class Order : IOrderModel { public int Id { get; private set; } public virtual Ship Ship { get; set; } = new(); [Required] public int Count { get; private set; } [Required] public double Sum { get; private set; } [Required] public OrderStatus Status { get; private set; } [Required] public DateTime DateCreate { get; private set; } public DateTime? DateImplement { get; private set; } [Required] public int ShipId { get; private set; } [Required] public int ClientId { get; private set; } public virtual Client? Client { get; private set; } public static Order? Create(OrderBindingModel model, ShipyardDataBase context) { if (model == null) { return null; } return new Order() { Id = model.Id, ShipId = model.ShipId, Ship = context.Ships.First(x => x.Id == model.ShipId), ClientId = model.ClientId, Client = context.Clients.First(x => x.Id == model.ClientId), Count = model.Count, Sum = model.Sum, Status = model.Status, DateCreate = model.DateCreate, DateImplement = model.DateImplement, }; } public void Update(OrderBindingModel? model) { if (model == null) { return; } Status = model.Status; DateImplement = model.DateImplement; } public OrderViewModel GetViewModel => new() { ShipId = ShipId, ShipName = Ship.ShipName, Count = Count, Sum = Sum, Status = Status, DateCreate = DateCreate, DateImplement = DateImplement, Id = Id, ClientId = ClientId, ClientFIO = Client?.ClientFIO ?? String.Empty, }; } }