using CoreDatabase; using CoreDatabase.Models.Department; using DepartmentContract.BindingModels; using DepartmentContract.Services.IGenericEntityService; using DepartmentContract.ViewModels; using Microsoft.EntityFrameworkCore; using System; using System.Linq; using ToolsModule.ManagmentEntity; using ToolsModule.ManagmentExtension; namespace DepartmentDatabaseImplementation.Implementations.AbstractGenerticEntityService { /// /// Реализация ILecturerService /// public class LecturerService : AbstractGenerticEntityService, ILecturerService { protected override OperationResultModel AdditionalCheckingWhenAdding(DbContext context, LecturerSetBindingModel model) => OperationResultModel.Success(null); protected override OperationResultModel AdditionalCheckingWhenDeleting(DbContext context, Lecturer entity, LecturerGetBindingModel model) { if (entity.User == null) { return OperationResultModel.Error("Error:", "Не найден пользователь от сотрудника", ResultServiceStatusCode.NotFound); } if (context.Set().Any(x => x.LecturerId == model.Id && !x.IsDeleted)) { return OperationResultModel.Error("Error:", "Есть направления обучения, у которых этот преподаватель указан руководителем", ResultServiceStatusCode.ExsistItem); } if (context.Set().Any(x => x.LecturerId == model.Id && !x.IsDeleted)) { return OperationResultModel.Error("Error:", "Есть учебные группы, у которых этот преподаватель числится как куратор", ResultServiceStatusCode.ExsistItem); } return OperationResultModel.Success(null); ; } protected override IQueryable AdditionalCheckingWhenReadingList(IQueryable query, LecturerGetBindingModel model) { if (model.UserId.HasValue) { query = query.Where(x => x.UserId == model.UserId); } if (model.LecturerAcademicDegreeId.HasValue) { query = query.Where(x => x.LecturerAcademicDegreeId == model.LecturerAcademicDegreeId); } if (model.LecturerAcademicRankId.HasValue) { query = query.Where(x => x.LecturerAcademicRankId == model.LecturerAcademicRankId); } if (model.FIO.IsNotEmpty()) { var fio = model.FIO.Split(' '); if (fio.Length > 1) { query = query.Where(x => x.LastName == fio[0]); } if (fio.Length > 1) { query = query.Where(x => x.FirstName == fio[1]); } if (fio.Length > 2) { query = query.Where(x => x.Patronymic == fio[2]); } } return query; } protected override OperationResultModel AdditionalCheckingWhenUpdateing(DbContext context, LecturerSetBindingModel model) => OperationResultModel.Success(null); protected override void AdditionalDeleting(DbContext context, Lecturer entity, LecturerGetBindingModel model) { entity.User.IsDeleted = true; entity.User.DateDelete = DateTime.Now; context.SaveChanges(); var links = context.Set().Where(x => x.LecturerId == model.Id); foreach (var link in links) { link.IsDeleted = true; link.DateDelete = DateTime.Now; } context.SaveChanges(); } protected override Lecturer GetUniqueEntity(LecturerSetBindingModel model, IQueryable query) => query.FirstOrDefault(x => x.LastName == model.LastName && x.FirstName == model.FirstName && x.Patronymic == model.Patronymic && x.Id != model.Id); protected override IQueryable IncludingWhenReading(IQueryable query) => query .Include(x => x.LecturerAcademicRank) .Include(x => x.LecturerAcademicDegree) .Include(x => x.LecturerPosts).Include("LecturerPosts.Post"); protected override IQueryable OrderingWhenReading(IQueryable query) => query .OrderByDescending(x => x.LecturerPosts.Max(y => y.Post.Order)) .ThenBy(x => x.LecturerAcademicRank.Order) .ThenBy(x => x.LecturerAcademicDegree.Order) .ThenBy(x => x.LastName) .ThenBy(x => x.FirstName); } }