Compare commits
2 Commits
7fde2e5622
...
b7138a2b01
Author | SHA1 | Date | |
---|---|---|---|
b7138a2b01 | |||
8430c05951 |
@ -1,4 +1,5 @@
|
|||||||
using ComputerShopDataModels.Models;
|
using ComputerShopDataModels.Enums;
|
||||||
|
using ComputerShopDataModels.Models;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
@ -16,5 +17,7 @@ namespace ComputerShopContracts.BindingModels
|
|||||||
public string Password { get; set; } = string.Empty;
|
public string Password { get; set; } = string.Empty;
|
||||||
//!!!МБ НЕ НАДО string.Empty
|
//!!!МБ НЕ НАДО string.Empty
|
||||||
public string Email { get; set; } = string.Empty;
|
public string Email { get; set; } = string.Empty;
|
||||||
|
//!!!МБ НЕ НАДО ПО УМОЛЧАНИЮ СТАВИТЬ "НЕИЗВЕСТНАЯ"
|
||||||
|
public UserRole Role { get; set; } = UserRole.Неизвестная;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using System;
|
using ComputerShopDataModels.Enums;
|
||||||
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
@ -14,5 +15,6 @@ namespace ComputerShopContracts.SearchModels
|
|||||||
//!!!ПОИСК ПО ПАРОЛЮ НЕ СТАЛ ДОБАВЛЯТЬ, ИБО СТРАННО
|
//!!!ПОИСК ПО ПАРОЛЮ НЕ СТАЛ ДОБАВЛЯТЬ, ИБО СТРАННО
|
||||||
|
|
||||||
public string? Email { get; set; }
|
public string? Email { get; set; }
|
||||||
|
public UserRole? Role { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13,11 +13,13 @@ namespace ComputerShopContracts.ViewModels
|
|||||||
{
|
{
|
||||||
[DisplayName("Номер")]
|
[DisplayName("Номер")]
|
||||||
public int Id { get; set; }
|
public int Id { get; set; }
|
||||||
|
|
||||||
//!!!ТУТ МБ НЕ НУЖЕН DisplayName
|
|
||||||
[DisplayName("Номер пользователя")]
|
|
||||||
public int UserId { get; set; }
|
public int UserId { get; set; }
|
||||||
|
|
||||||
|
//!!!МБ НЕ НУЖЕН string.Empty
|
||||||
|
[DisplayName("Ник пользователя")]
|
||||||
|
public string UserLogin { get; set; } = string.Empty;
|
||||||
|
|
||||||
//!!!ТУТ МБ НАДО DisplayName (НО ВЯРД ЛИ)
|
//!!!ТУТ МБ НАДО DisplayName (НО ВЯРД ЛИ)
|
||||||
|
|
||||||
//!!!УДАЛИТЬ (если нормально работает многие-ко-многим)
|
//!!!УДАЛИТЬ (если нормально работает многие-ко-многим)
|
||||||
|
@ -14,13 +14,19 @@ namespace ComputerShopContracts.ViewModels
|
|||||||
public int Id { get; set; }
|
public int Id { get; set; }
|
||||||
|
|
||||||
//!!!ТУТ МБ НЕ НУЖЕН DisplayName
|
//!!!ТУТ МБ НЕ НУЖЕН DisplayName
|
||||||
[DisplayName("Номер пользователя")]
|
//[DisplayName("Номер пользователя")]
|
||||||
public int UserId { get; set; }
|
public int UserId { get; set; }
|
||||||
|
|
||||||
//!!!МБ ДОБАВИТЬ НИК ПОЛЬЗОВАТЕЛЯ, СОЗДАВШЕГО ЗАЯВКУ
|
//!!!МБ ДОБАВИТЬ НИК ПОЛЬЗОВАТЕЛЯ, СОЗДАВШЕГО ЗАЯВКУ
|
||||||
|
[DisplayName("Ник пользователя")]
|
||||||
|
public string UserLogin { get; set; } = string.Empty;
|
||||||
|
|
||||||
|
//id сборки
|
||||||
public int AssemblyId { get; set; }
|
public int AssemblyId { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
//!!!МБ НАДО БУДЕТ ПРИВЯЗЫВАТЬ НАЗВАНИЕ СБОРКИ И Т.Д. ДЛЯ ОТЧЁТОВ
|
||||||
|
|
||||||
public Dictionary<int, IOrderModel> RequestOrders { get; set; } = new();
|
public Dictionary<int, IOrderModel> RequestOrders { get; set; } = new();
|
||||||
|
|
||||||
//!!!МБ НЕ НУЖНО DateTime.Now
|
//!!!МБ НЕ НУЖНО DateTime.Now
|
||||||
|
@ -15,11 +15,11 @@ namespace ComputerShopContracts.ViewModels
|
|||||||
public int Id { get; set; }
|
public int Id { get; set; }
|
||||||
|
|
||||||
//!!!ТУТ МБ НЕ НУЖЕН DisplayName
|
//!!!ТУТ МБ НЕ НУЖЕН DisplayName
|
||||||
[DisplayName("Номер пользователя")]
|
|
||||||
public int UserId { get; set; }
|
public int UserId { get; set; }
|
||||||
|
|
||||||
//!!!МБ ДОБАВИТЬ НИК ПОЛЬЗОВАТЕЛЯ, СОЗДАВШЕГО ПАРТИЮ
|
//!!!МБ НЕ НУЖЕН string.Empty
|
||||||
|
[DisplayName("Ник пользователя")]
|
||||||
|
public string UserLogin { get; set; } = string.Empty;
|
||||||
|
|
||||||
public Dictionary<int, IOrderModel> ShipmentOrders { get; set; } = new();
|
public Dictionary<int, IOrderModel> ShipmentOrders { get; set; } = new();
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using ComputerShopDataModels.Models;
|
using ComputerShopDataModels.Enums;
|
||||||
|
using ComputerShopDataModels.Models;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
@ -22,5 +23,8 @@ namespace ComputerShopContracts.ViewModels
|
|||||||
|
|
||||||
[DisplayName("Почта")]
|
[DisplayName("Почта")]
|
||||||
public string Email { get; set; } = string.Empty;
|
public string Email { get; set; } = string.Empty;
|
||||||
|
|
||||||
|
//!!!МБ ТУТ НАДО DisplayName (НО ВРЯД ЛИ)
|
||||||
|
public UserRole Role { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
15
ComputerShopDataModels/Enums/UserRole.cs
Normal file
15
ComputerShopDataModels/Enums/UserRole.cs
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ComputerShopDataModels.Enums
|
||||||
|
{
|
||||||
|
public enum UserRole
|
||||||
|
{
|
||||||
|
Неизвестная = -1,
|
||||||
|
Исполнитель = 0,
|
||||||
|
Поручитель = 1
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,5 @@
|
|||||||
using System;
|
using ComputerShopDataModels.Enums;
|
||||||
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
@ -11,5 +12,6 @@ namespace ComputerShopDataModels.Models
|
|||||||
string Login { get; }
|
string Login { get; }
|
||||||
string Password { get; }
|
string Password { get; }
|
||||||
string Email { get; }
|
string Email { get; }
|
||||||
|
UserRole Role { get; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,17 +17,23 @@ namespace ComputerShopDatabaseImplement
|
|||||||
AppContext.SetSwitch("Npgsql.EnableLegacyTimestampBehavior", true);
|
AppContext.SetSwitch("Npgsql.EnableLegacyTimestampBehavior", true);
|
||||||
AppContext.SetSwitch("Npgsql.DisableDateTimeInfinityConversions", true);
|
AppContext.SetSwitch("Npgsql.DisableDateTimeInfinityConversions", true);
|
||||||
}
|
}
|
||||||
|
public virtual DbSet<User> Users { get; set; }
|
||||||
public virtual DbSet<User> Users { get; set; }
|
|
||||||
|
|
||||||
public virtual DbSet<Component> Components { get; set; }
|
public virtual DbSet<Component> Components { get; set; }
|
||||||
|
|
||||||
public virtual DbSet<Assembly> Assemblies { get; set; }
|
public virtual DbSet<Assembly> Assemblies { get; set; }
|
||||||
|
|
||||||
public virtual DbSet<AssemblyComponent> AssemblyComponents { get; set; }
|
public virtual DbSet<AssemblyComponent> AssemblyComponents { get; set; }
|
||||||
|
|
||||||
public virtual DbSet<Product> Products { get; set; }
|
public virtual DbSet<Product> Products { get; set; }
|
||||||
|
|
||||||
public virtual DbSet<ProductComponent> ProductComponents { get; set; }
|
public virtual DbSet<ProductComponent> ProductComponents { get; set; }
|
||||||
}
|
|
||||||
|
|
||||||
|
public virtual DbSet<Order> Orders { get; set; }
|
||||||
|
public virtual DbSet<Request> Requests { get; set; }
|
||||||
|
public virtual DbSet<Shipment> Shipments { get; set; }
|
||||||
|
public virtual DbSet<ShipmentOrder> ShipmentOrders { get; set; }
|
||||||
|
public virtual DbSet<RequestOrder> RequestOrders { get; set; }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
75
ComputerShopDatabaseImplement/Models/Order.cs
Normal file
75
ComputerShopDatabaseImplement/Models/Order.cs
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
using ComputerShopContracts.BindingModels;
|
||||||
|
using ComputerShopContracts.ViewModels;
|
||||||
|
using ComputerShopDataModels.Enums;
|
||||||
|
using ComputerShopDataModels.Models;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ComputerShopDatabaseImplement.Models
|
||||||
|
{
|
||||||
|
//!!!ДЛЯ СВЯЗИ МНОГИЕ-КО-МНОГИМ ДОБАВИТЬ ПО АНАЛОГИИ С Textile СЛОВАРИ КАСАТЕЛЬНО ПАРТИЙ И ЗАЯВОК
|
||||||
|
public class Order : IOrderModel
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
|
||||||
|
//!!!ТУТ МБ СДЕЛАТЬ КАК FOREIGN KEY
|
||||||
|
[Required]
|
||||||
|
public int UserId { get; private set; }
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
public DateTime DateCreate { get; private set; } = DateTime.Now;
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
public OrderStatus Status { get; private set; } = OrderStatus.Неизвестен;
|
||||||
|
|
||||||
|
[Required]
|
||||||
|
public double Sum { get; private set; }
|
||||||
|
|
||||||
|
//!!!мб не нужен
|
||||||
|
public virtual User User { get; set; }
|
||||||
|
|
||||||
|
public static Order? Create(OrderBindingModel model)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
using var context = new ComputerShopDatabase();
|
||||||
|
return new Order()
|
||||||
|
{
|
||||||
|
Id = model.Id,
|
||||||
|
UserId = model.UserId,
|
||||||
|
DateCreate = model.DateCreate,
|
||||||
|
Status = model.Status,
|
||||||
|
Sum = model.Sum,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Update(OrderBindingModel model)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
using var context = new ComputerShopDatabase();
|
||||||
|
//!!!МБ НАДО БУДЕТ ОБНОВЛЯТЬ ПОЛЬЗОВАТЕЛЯ, НО ОН ПО СУТИ НЕ ДОЛЖЕН ОБНОВЯЛТЬСЯ ПОСЛЕ СОЗДАНИЯ
|
||||||
|
Status = model.Status;
|
||||||
|
context.SaveChanges();
|
||||||
|
}
|
||||||
|
|
||||||
|
//!!!МБ НАДО БУДЕТ ДОБАВИТЬ В OrderViewModel ЕЩЁ ЧТО-ТО, И ТУТ ТОЖЕ
|
||||||
|
public OrderViewModel GetViewModel => new()
|
||||||
|
{
|
||||||
|
Id = Id,
|
||||||
|
UserId = UserId,
|
||||||
|
UserLogin = User.Login,
|
||||||
|
DateCreate = DateCreate,
|
||||||
|
Status = Status,
|
||||||
|
Sum = Sum
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
82
ComputerShopDatabaseImplement/Models/Request.cs
Normal file
82
ComputerShopDatabaseImplement/Models/Request.cs
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
using ComputerShopContracts.BindingModels;
|
||||||
|
using ComputerShopContracts.ViewModels;
|
||||||
|
using ComputerShopDataModels.Models;
|
||||||
|
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 ComputerShopDatabaseImplement.Models
|
||||||
|
{
|
||||||
|
//!!!ДОБАВИТЬ МЕТОД ПО ПРИВЯЗКЕ СБОРКИ
|
||||||
|
public class Request : IRequestModel
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int UserId { get; set; }
|
||||||
|
|
||||||
|
public virtual User User { get; set; }
|
||||||
|
|
||||||
|
public int AssemblyId { get; set; }
|
||||||
|
[Required]
|
||||||
|
public DateTime DateMake { get; set; }
|
||||||
|
[Required]
|
||||||
|
public string ClientFIO { get; set; } = string.Empty;
|
||||||
|
|
||||||
|
private Dictionary<int, IOrderModel>? _requestOrders = null;
|
||||||
|
|
||||||
|
[NotMapped]
|
||||||
|
public Dictionary<int, IOrderModel> RequestOrders
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (_requestOrders == null)
|
||||||
|
{
|
||||||
|
//!!!ТУТ ПРОПИСАТЬ ЛОГИКУ (НЕ ЗНАЮ ПОКА, КАК)
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
return _requestOrders;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[ForeignKey("OrderId")]
|
||||||
|
public virtual List<RequestOrder> Orders { get; set; } = new();
|
||||||
|
|
||||||
|
public static Request Create(ComputerShopDatabase context, RequestBindingModel model)
|
||||||
|
{
|
||||||
|
return new Request() {
|
||||||
|
Id = model.Id,
|
||||||
|
UserId = model.UserId,
|
||||||
|
AssemblyId = model.AssemblyId,
|
||||||
|
DateMake = model.DateMake,
|
||||||
|
ClientFIO = model.ClientFIO,
|
||||||
|
Orders = model.RequestOrders.Select(x => new RequestOrder
|
||||||
|
{
|
||||||
|
Order = context.Orders.First(y => y.Id == x.Key)
|
||||||
|
}).ToList()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
//!!!МБ ТУТ ЕЩЁ ЧТО-ТО ОБНОВИТЬ
|
||||||
|
public void Update(RequestBindingModel model)
|
||||||
|
{
|
||||||
|
DateMake = model.DateMake;
|
||||||
|
ClientFIO = model.ClientFIO;
|
||||||
|
}
|
||||||
|
//!!!МБ ТУТ НЕ ВСЁ НАДО ПРИСВАИВАТЬ
|
||||||
|
public RequestViewModel GetViewModel => new()
|
||||||
|
{
|
||||||
|
Id = Id,
|
||||||
|
UserId = UserId,
|
||||||
|
UserLogin = User.Login,
|
||||||
|
AssemblyId = AssemblyId,
|
||||||
|
DateMake = DateMake,
|
||||||
|
ClientFIO = ClientFIO
|
||||||
|
};
|
||||||
|
|
||||||
|
//!!!ДОПИСАТЬ UpdateOrders
|
||||||
|
}
|
||||||
|
}
|
22
ComputerShopDatabaseImplement/Models/RequestOrder.cs
Normal file
22
ComputerShopDatabaseImplement/Models/RequestOrder.cs
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
using System.ComponentModel;
|
||||||
|
|
||||||
|
namespace ComputerShopDatabaseImplement.Models
|
||||||
|
{
|
||||||
|
public class RequestOrder
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int RequestId { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int OrderId { get; set; }
|
||||||
|
//!!!МБ ТУТ КАК-ТО ПО-ДРУГОМУ
|
||||||
|
public virtual Request Request { get; set; } = new();
|
||||||
|
public virtual Order Order { get; set; } = new();
|
||||||
|
}
|
||||||
|
}
|
118
ComputerShopDatabaseImplement/Models/Shipment.cs
Normal file
118
ComputerShopDatabaseImplement/Models/Shipment.cs
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
using ComputerShopContracts.BindingModels;
|
||||||
|
using ComputerShopContracts.ViewModels;
|
||||||
|
using ComputerShopDataModels.Models;
|
||||||
|
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 ComputerShopDatabaseImplement.Models
|
||||||
|
{
|
||||||
|
//!!! МОЖНО ДЕЛАТЬ ПО АНАЛОГИИ С Product(Textile) ИЛИ С Component. Делаю по аналогии с Textile
|
||||||
|
public class Shipment : IShipmentModel
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
|
||||||
|
//!!!ТУТ МБ СДЕЛАТЬ КАК FOREIGN KEY
|
||||||
|
[Required]
|
||||||
|
public int UserId { get; private set; }
|
||||||
|
|
||||||
|
//!!!мб не нужен (для передачи логина пользователя)
|
||||||
|
public virtual User User { get; set; }
|
||||||
|
|
||||||
|
//!!!МБ ТУТ НЕ НУЖЕН string.Empty
|
||||||
|
[Required]
|
||||||
|
public string ProviderName { get; set; } = string.Empty;
|
||||||
|
|
||||||
|
//!!!МБ ТУТ НЕ НУЖЕН DateTime.Now
|
||||||
|
[Required]
|
||||||
|
public DateTime DateShipment { get; set; } = DateTime.Now;
|
||||||
|
|
||||||
|
//!!!МБ ТУТ КАК-ТО ПО-ДРУГОМУ
|
||||||
|
private Dictionary<int, IOrderModel>? _shipmentOrders = null;
|
||||||
|
|
||||||
|
[NotMapped]
|
||||||
|
public Dictionary<int, IOrderModel>? ShipmentOrders
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (_shipmentOrders == null)
|
||||||
|
{
|
||||||
|
//!!!ТУТ ПРОПИСАТЬ ЛОГИКУ (НЕ ЗНАЮ ПОКА, КАК)
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
return _shipmentOrders;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//!!!ПРОВЕРИТЬ, ЧТО ТУТ ПРАВИЛЬНО СДЕЛАНО (ЧТО НАЗВАНИЕ ПРАВИЛЬНОЕ У ВНЕШ. КЛЮЧА, ЧТО ПРАВИЛЬНЫЙ ТИП в <>)
|
||||||
|
[ForeignKey("OrderId")]
|
||||||
|
public virtual List<ShipmentOrder> Orders { get; set; } = new();
|
||||||
|
|
||||||
|
//!!!МБ ТУТ НАДО БУДЕТ ПРИСВАИВАТЬ ORDERS (но вряд ли, потому что по заданию заказы привязываются отдельно)
|
||||||
|
//!!!ПРОВЕРИТЬ, ЧТО ПРАВИЛЬНО ПРИСВАИВАЮ ЗНАЧЕНИЕ СПИСКУ ЗАКАЗОВ
|
||||||
|
public static Shipment Create(ComputerShopDatabase context, ShipmentBindingModel model)
|
||||||
|
{
|
||||||
|
return new Shipment()
|
||||||
|
{
|
||||||
|
Id = model.Id,
|
||||||
|
UserId = model.UserId,
|
||||||
|
ProviderName = model.ProviderName,
|
||||||
|
DateShipment = model.DateShipment,
|
||||||
|
Orders = model.ShipmentOrders.Select(x => new ShipmentOrder
|
||||||
|
{
|
||||||
|
Order = context.Orders.First(y => y.Id == x.Key)
|
||||||
|
}).ToList()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
//!!!МБ ТУТ КАКИЕ-ТО ДРУГИЕ ПОЛЯ НАДО БУДЕТ ОБНОВЛЯТЬ
|
||||||
|
public void Update(ShipmentBindingModel model)
|
||||||
|
{
|
||||||
|
ProviderName = model.ProviderName;
|
||||||
|
DateShipment = model.DateShipment;
|
||||||
|
}
|
||||||
|
//!!!МБ ТУТ ЕЩЁ ЧТО-ТО ПРИСВАИВАТЬ
|
||||||
|
public ShipmentViewModel GetViewModel => new()
|
||||||
|
{
|
||||||
|
Id = Id,
|
||||||
|
UserId = UserId,
|
||||||
|
UserLogin = User.Login,
|
||||||
|
ProviderName = ProviderName,
|
||||||
|
DateShipment = DateShipment,
|
||||||
|
ShipmentOrders = ShipmentOrders
|
||||||
|
};
|
||||||
|
|
||||||
|
//!!!МБ ЭТОТ МЕТОД БУДЕТ НЕ НУЖЕН, ПОТОМУ ЧТО ПО ЗАДАНИЮ НЕ НАПИСАНО, ЧТО МОЖНО ОБНОВЛЯТЬ
|
||||||
|
//!!!МБ НАЗВАТЬ КАК-ТО ПО-ДРУГОМУ (мб метод вынести в Implement)
|
||||||
|
//!!!МБ ПЕРЕДАВАТЬ ЧТО-ТО ДРУГОЕ
|
||||||
|
//!!!ПРОВЕРИТЬ, ЧТО ВСЁ ПРАВИЛЬНО ИЗВЛЕКАЮ
|
||||||
|
//!!!делаю как в Textile
|
||||||
|
public void UpdateOrders(ComputerShopDatabase context, ShipmentBindingModel model)
|
||||||
|
{
|
||||||
|
var shipmentOrders = context.ShipmentOrders.Where(x => x.ShipmentId == model.Id).ToList();
|
||||||
|
//удаление тех заказов, которых нет в модели
|
||||||
|
if (shipmentOrders != null && shipmentOrders.Count > 0)
|
||||||
|
{
|
||||||
|
|
||||||
|
//!!!ТУТ МБ НЕ x.OrderId, а x.ShipmentId, но не факт (вряд ли)
|
||||||
|
context.ShipmentOrders.RemoveRange(shipmentOrders.Where(x => !model.ShipmentOrders.ContainsKey(x.OrderId)));
|
||||||
|
context.SaveChanges();
|
||||||
|
}
|
||||||
|
//добавление новых заказов
|
||||||
|
var currentShipment = context.Shipments.First(x => x.Id == Id);
|
||||||
|
foreach (var shipment_order in model.ShipmentOrders)
|
||||||
|
{
|
||||||
|
context.ShipmentOrders.Add(new ShipmentOrder
|
||||||
|
{
|
||||||
|
Shipment = currentShipment,
|
||||||
|
Order = context.Orders.First(x => x.Id == shipment_order.Key)
|
||||||
|
});
|
||||||
|
context.SaveChanges();
|
||||||
|
}
|
||||||
|
_shipmentOrders = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
25
ComputerShopDatabaseImplement/Models/ShipmentOrder.cs
Normal file
25
ComputerShopDatabaseImplement/Models/ShipmentOrder.cs
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ComputerShopDatabaseImplement.Models
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Класс-связь партии товаров и заказа
|
||||||
|
/// </summary>
|
||||||
|
public class ShipmentOrder
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int ShipmentId { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int OrderId { get; set; }
|
||||||
|
|
||||||
|
//!!!МБ ТУТ КАК-ТО ПО-ДРУГОМУ СДЕЛАТЬ
|
||||||
|
public virtual Shipment Shipment { get; set; } = new();
|
||||||
|
public virtual Order Order { get; set; } = new();
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,7 @@
|
|||||||
using ComputerShopDataModels.Models;
|
using ComputerShopContracts.BindingModels;
|
||||||
|
using ComputerShopContracts.ViewModels;
|
||||||
|
using ComputerShopDataModels.Enums;
|
||||||
|
using ComputerShopDataModels.Models;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.ComponentModel.DataAnnotations;
|
using System.ComponentModel.DataAnnotations;
|
||||||
@ -21,5 +24,42 @@ namespace ComputerShopDatabaseImplement.Models
|
|||||||
//!!!МБ ТУТ НУЖНА ДОП. АННОТАЦИЯ ПРОВЕРКИ ПОЧТЫ
|
//!!!МБ ТУТ НУЖНА ДОП. АННОТАЦИЯ ПРОВЕРКИ ПОЧТЫ
|
||||||
[Required]
|
[Required]
|
||||||
public string Email { get; set; } = string.Empty;
|
public string Email { get; set; } = string.Empty;
|
||||||
|
|
||||||
|
//!!!МБ ТУТ НАДО ЗАДАТЬ ПО УМОЛЧАНИЮ НЕИЗВЕСТНАЯ
|
||||||
|
[Required]
|
||||||
|
public UserRole Role { get; set; }
|
||||||
|
|
||||||
|
//!!!МБ ТУТ НАДО БУДЕТ СОЗДАТЬ 2 РАЗНЫХ МЕТОДА: СОЗДАНИЕ ИСПОЛНИТЕЛЯ и СОЗДАНИЕ ПОРУЧИТЕЛЯ (хотя мб где-то потом будем задавать роль в BindingModel)
|
||||||
|
public static User Create(UserBindingModel model)
|
||||||
|
{
|
||||||
|
return new User
|
||||||
|
{
|
||||||
|
Id = model.Id,
|
||||||
|
Login = model.Login,
|
||||||
|
Password = model.Password,
|
||||||
|
Email = model.Email
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Update(UserBindingModel model)
|
||||||
|
{
|
||||||
|
if (model == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Login = model.Login;
|
||||||
|
Password = model.Password;
|
||||||
|
Email = model.Email;
|
||||||
|
}
|
||||||
|
|
||||||
|
//!!!МБ ТУТ НЕ НАДО РОЛЬ
|
||||||
|
public UserViewModel GetViewModel => new()
|
||||||
|
{
|
||||||
|
Id = Id,
|
||||||
|
Login = Login,
|
||||||
|
Password = Password,
|
||||||
|
Email = Email,
|
||||||
|
Role = Role
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user