using CoreDatabase; using CoreDatabase.Models.Department; using DepartmentContract.BindingModels; using DepartmentContract.Services.IGenericEntityService; using DepartmentContract.ViewModels; using Microsoft.EntityFrameworkCore; using System.Linq; using ToolsModule.ManagmentEntity; using ToolsModule.ManagmentExtension; namespace DepartmentDatabaseImplementation.Implementations.AbstractGenerticEntityService { /// /// Реализация IOrderService /// public class OrderService : AbstractGenerticEntityService, IOrderService { protected override OperationResultModel AdditionalCheckingWhenAdding(DbContext context, OrderSetBindingModel model) => OperationResultModel.Success(null); protected override OperationResultModel AdditionalCheckingWhenDeleting(DbContext context, Order entity, OrderGetBindingModel model) { if (context.Set().Any(x => x.OrderId == model.Id && !x.IsDeleted)) { return OperationResultModel.Error("Error:", "Есть записи приказа по студентам, относящиеся к этому приказу", ResultServiceStatusCode.ExsistItem); } return OperationResultModel.Success(null); } protected override IQueryable AdditionalCheckingWhenReadingList(IQueryable query, OrderGetBindingModel model) { if(model.OrderDate.HasValue && model.OrderNumber.IsNotEmpty()) { query = query.Where(x => x.OrderNumber == model.OrderNumber && x.OrderDate == model.OrderDate); } return query; } protected override OperationResultModel AdditionalCheckingWhenUpdateing(DbContext context, OrderSetBindingModel model) => OperationResultModel.Success(null); protected override void AdditionalDeleting(DbContext context, Order entity, OrderGetBindingModel model) { } protected override Order GetUniqueEntity(OrderSetBindingModel model, IQueryable query) => query.FirstOrDefault(x => x.OrderNumber == model.OrderNumber && x.OrderDate == model.OrderDate && x.OrderType == model.OrderType && x.Id != model.Id); protected override IQueryable IncludingWhenReading(IQueryable query) => query; protected override IQueryable OrderingWhenReading(IQueryable query) => query.OrderBy(x => x.OrderDate).ThenBy(x => x.OrderNumber); protected override bool AdditionalCheckForSingleGet(OrderGetBindingModel model) { if (model.OrderNumber.IsNotEmpty() && model.OrderDate.HasValue && model.OrderType.HasValue) { return true; } if (model.OrderNumber.IsNotEmpty() && model.OrderDate.HasValue) { return true; } if (model.OrderNumber.IsNotEmpty()) { return true; } return base.AdditionalCheckForSingleGet(model); } protected override Order GetSingleRecord(IQueryable list, OrderGetBindingModel model) { if (model.OrderNumber.IsNotEmpty() && model.OrderDate.HasValue && model.OrderType.HasValue) { return list.FirstOrDefault(x => x.OrderNumber == model.OrderNumber && x.OrderDate == model.OrderDate && x.OrderType == model.OrderType); } if (model.OrderNumber.IsNotEmpty() && model.OrderDate.HasValue) { return list.FirstOrDefault(x => x.OrderNumber == model.OrderNumber && x.OrderDate == model.OrderDate); } if (model.OrderNumber.IsNotEmpty()) { return list.FirstOrDefault(x => x.OrderNumber == model.OrderNumber); } return base.GetSingleRecord(list, model); } } }