using AircraftPlantContracts.BindingModels;
using AircraftPlantContracts.ViewModels;
using AircraftPlantDataModels.Enums;
using AircraftPlantDataModels.Models;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace AircraftPlantDatabaseImplement.Models
{
///
/// Сущность "Заказ"
///
public class Order : IOrderModel
{
///
/// Идентификатор
///
public int Id { get; set; }
///
/// Идентификатор изделия
///
[Required]
public int PlaneId { get; set; }
///
/// Сущность "Изделие"
///
public virtual Plane Plane { get; set; } = new();
///
/// Идентификатор клиента
///
[Required]
public int ClientId { get; set; }
///
/// Сущность "Клиент"
///
public Client Client { get; set; } = new();
///
/// Количество изделий
///
[Required]
public int Count { get; set; }
///
/// Сумма заказа
///
[Required]
public double Sum { get; set; }
///
/// Статус заказа
///
[Required]
public OrderStatus Status { get; set; }
///
/// Дата создания заказа
///
[Required]
public DateTime DateCreate { get; set; }
///
/// Дата выполнения заказа
///
public DateTime? DateImplement { get; set; }
///
/// Создание модели заказа
///
///
///
public static Order? Create(AircraftPlantDatabase context, OrderBindingModel? model)
{
if (model == null)
{
return null;
}
return new Order
{
Id = model.Id,
PlaneId = model.PlaneId,
Plane = context.Planes.First(x => x.Id == model.PlaneId),
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()
{
Id = Id,
PlaneId = PlaneId,
PlaneName = Plane.PlaneName,
ClientId = ClientId,
ClientFIO = Client.ClientFIO,
Count = Count,
Sum = Sum,
Status = Status,
DateCreate = DateCreate,
DateImplement = DateImplement
};
}
}