| | |
| | | using FlexJobApi.Core; |
| | | using Aop.Api.Domain; |
| | | using FlexJobApi.Core; |
| | | using Furion.DatabaseAccessor; |
| | | using Furion.DistributedIDGenerator; |
| | | using Furion.FriendlyException; |
| | | using Mapster; |
| | | using MediatR; |
| | | using Microsoft.AspNetCore.Components.Forms; |
| | | using Microsoft.EntityFrameworkCore; |
| | | using System; |
| | | using System.Collections.Generic; |
| | | using System.Linq; |
| | | using System.Security.Principal; |
| | | using System.Text; |
| | | using System.Threading.Tasks; |
| | | |
| | |
| | | /// 灵工查询处理器 |
| | | /// </summary> |
| | | public class EnterpriseEmployeeQueryHandler( |
| | | IRepository<EnterpriseEmployee> rep |
| | | IRepository<EnterpriseEmployee> rep, |
| | | IRepository<ContractTemplate> repContractTemplate, |
| | | IRepository<EnterpriseEmployeeContract> repEnterpriseEmployeeContract, |
| | | IRepository<Enterprise> repEnterprise, |
| | | IRepository<User> repUser, |
| | | IMediator mediator |
| | | ) : |
| | | IRequestHandler<GetEnterpriseEmployeesQuery, GetEnterpriseEmployeesQueryResult> |
| | | IRequestHandler<GetEnterpriseEmployeesQuery, GetEnterpriseEmployeesQueryResult>, |
| | | IRequestHandler<GetEnterpriseEmployeeQuery, GetEnterpriseEmployeeQueryResult>, |
| | | IRequestHandler<GetPersonalUserElectronSignsQuery, GetPersonalUserElectronSignsQueryResult>, |
| | | IRequestHandler<GetPersonalUserElectronSignQuery, GetPersonalUserElectronSignQueryResult> |
| | | { |
| | | private readonly IRepository<EnterpriseEmployee> rep = rep; |
| | | private readonly IRepository<ContractTemplate> repContractTemplate = repContractTemplate; |
| | | private readonly IRepository<EnterpriseEmployeeContract> repEnterpriseEmployeeContract = repEnterpriseEmployeeContract; |
| | | private readonly IRepository<Enterprise> repEnterprise = repEnterprise; |
| | | private readonly IRepository<User> repUser = repUser; |
| | | private readonly IMediator mediator = mediator; |
| | | |
| | | /// <summary> |
| | | /// 查询灵工分页列表数据 |
| | |
| | | var logier = JwtUtils.GetCurrentLogier(); |
| | | var q = rep.AsQueryable().AsNoTracking() |
| | | .OrderBy(it => it.CreatedTime) |
| | | .Where(it => it.EnterpriseId == logier.Id); |
| | | .Where(it => it.EnterpriseId == logier.EnterpriseId); |
| | | if (request.Keywords.IsNotNull()) |
| | | { |
| | | q = q.Where(it => |
| | | it.Name.Contains(request.Keywords) |
| | | || it.PhoneNumber.Contains(request.Keywords) |
| | | || it.ContactPhoneNumber.Contains(request.Keywords) |
| | | || it.Identity.Contains(request.Keywords)); |
| | | } |
| | | if (request.CreatedTimeStart.HasValue && request.CreatedTimeEnd.HasValue) |
| | |
| | | } |
| | | if (request.HireStatus.HasValue) |
| | | { |
| | | q = q.Where(it => it.HireStatus == request.HireStatus); |
| | | q = q.Where(it => it.TaskInfoUsers.Any(tu => tu.HireStatus == request.HireStatus)); |
| | | } |
| | | if (request.IsReal.HasValue) |
| | | { |
| | | q = q.Where(it => (it.UserId.HasValue && it.User.IsReal) == request.IsReal.Value); |
| | | } |
| | | if (request.SignContractStatus.HasValue) |
| | | { |
| | | switch (request.SignContractStatus.Value) |
| | | { |
| | | case EnumGetEnterpriseEmployeesQuerySignContractStatus.UserWait: |
| | | q = q.Where(it => it.UserSignContractStatus == null || it.UserSignContractStatus == EnumTaskUserSignContractStatus.Wait); |
| | | break; |
| | | case EnumGetEnterpriseEmployeesQuerySignContractStatus.EnterpriseWait: |
| | | q = q.Where(it => it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Wait); |
| | | break; |
| | | case EnumGetEnterpriseEmployeesQuerySignContractStatus.Pass: |
| | | q = q.Where(it => |
| | | it.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass |
| | | && it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Pass); |
| | | break; |
| | | default: |
| | | break; |
| | | } |
| | | } |
| | | else |
| | | { |
| | | if (request.UserSignContractStatus.HasValue) |
| | | { |
| | | if (logier.ClientType == EnumClientType.Wxmp) |
| | | { |
| | | switch (request.UserSignContractStatus.Value) |
| | | { |
| | | case EnumTaskUserSignContractStatus.Wait: |
| | | q = q.Where(it => it.UserSignContractStatus == null || it.UserSignContractStatus == request.UserSignContractStatus); |
| | | break; |
| | | case EnumTaskUserSignContractStatus.Pass: |
| | | q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus && it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Pass); |
| | | break; |
| | | case EnumTaskUserSignContractStatus.Stop: |
| | | q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus); |
| | | break; |
| | | default: |
| | | q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus); |
| | | break; |
| | | } |
| | | } |
| | | else |
| | | { |
| | | q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus); |
| | | } |
| | | } |
| | | if (request.EnterpriseSignContractStatus.HasValue) |
| | | { |
| | | q = q.Where(it => it.EnterpriseSignContractStatus == request.EnterpriseSignContractStatus); |
| | | } |
| | | } |
| | | var s = q.Select(it => new GetEnterpriseEmployeesQueryResultItem |
| | | { |
| | | Id = it.Id, |
| | | Avatar = it.User.Avatar, |
| | | Name = it.Name, |
| | | Identity = it.Identity, |
| | | Gender = it.Gender, |
| | | Age = it.Age, |
| | | ContactPhoneNumber = it.ContactPhoneNumber, |
| | | UserIsReal = it.User.IsReal == true, |
| | | RealMethod = it.User.RealMethod, |
| | | PersonalIdentityCode = it.User.PersonalIdentityCode, |
| | | PersonalIdentityContent = it.User.PersonalIdentity.Content, |
| | | EducationalBackgroundCode = it.User.EducationalBackgroundCode, |
| | | EducationalBackgroundContent = it.User.EducationalBackground.Content, |
| | | TaskCount = it.User.EnterpriseEmployees.SelectMany(ee => ee.TaskInfoUsers).Count(tu => tu.HireStatus == EnumTaskUserHireStatus.Pass), |
| | | WorkSeniority = it.User.WorkSeniority, |
| | | WorkExperience = it.User.WorkExperience, |
| | | HireStatus = it.TaskInfoUsers.Any(tu => tu.HireStatus == EnumTaskUserHireStatus.Pass) |
| | | ? EnumTaskUserHireStatus.Pass |
| | | : it.TaskInfoUsers.Any(tu => tu.HireStatus == EnumTaskUserHireStatus.Refuse) |
| | | ? EnumTaskUserHireStatus.Refuse |
| | | : EnumTaskUserHireStatus.Wait, |
| | | UserSignContractStatus = it.UserSignContractStatus, |
| | | HireTime = it.TaskInfoUsers |
| | | .OrderBy(tu => tu.HireTime) |
| | | .Where(tu => tu.HireTime.HasValue) |
| | | .Select(tu => tu.HireTime) |
| | | .FirstOrDefault(), |
| | | UserRealTime = it.User.RealTime, |
| | | UserSignContractTime = it.UserSignContractTime, |
| | | EnterpriseSignContractStatus = it.EnterpriseSignContractStatus, |
| | | EnterpriseSignContractTime = it.EnterpriseSignContractTime, |
| | | ContractUrl = it.ContractUrl, |
| | | }); |
| | | return await request.PageModel.GetPagedListAsync<GetEnterpriseEmployeesQueryResult, GetEnterpriseEmployeesQueryResultItem>(s, cancellationToken); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 查询灵工详情 |
| | | /// </summary> |
| | | /// <param name="request"></param> |
| | | /// <param name="cancellationToken"></param> |
| | | /// <returns></returns> |
| | | public async Task<GetEnterpriseEmployeeQueryResult> Handle(GetEnterpriseEmployeeQuery request, CancellationToken cancellationToken) |
| | | { |
| | | var logier = JwtUtils.GetCurrentLogier(); |
| | | var model = await rep.AsQueryable().AsNoTracking() |
| | | .Where(it => it.Id == request.Id) |
| | | .GetDetail<EnterpriseEmployee, GetEnterpriseEmployeeQueryResult>(cancellationToken); |
| | | if (request.TaskInfoId.HasValue) |
| | | { |
| | | model.ApplyTime = await rep.Change<TaskInfoUser>().AsQueryable().AsNoTracking() |
| | | .Where(it => it.TaskInfoId == request.TaskInfoId && it.EnterpriseEmployeeId == request.Id) |
| | | .Select(it => it.CreatedTime as DateTimeOffset?) |
| | | .FirstOrDefaultAsync(cancellationToken); |
| | | } |
| | | else if (logier.Type == EnumUserType.Enterprise) |
| | | { |
| | | model.ApplyTime = await rep.Change<TaskInfoUser>().AsQueryable().AsNoTracking() |
| | | .OrderBy(it => it.CreatedTime) |
| | | .Where(it => it.TaskInfo.EnterpriseId == logier.EnterpriseId && it.EnterpriseEmployeeId == request.Id) |
| | | .Select(it => it.CreatedTime as DateTimeOffset?) |
| | | .FirstOrDefaultAsync(cancellationToken); |
| | | } |
| | | |
| | | return model; |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 查询个人用户签约列表 |
| | | /// </summary> |
| | | /// <param name="request"></param> |
| | | /// <param name="cancellationToken"></param> |
| | | /// <returns></returns> |
| | | public async Task<GetPersonalUserElectronSignsQueryResult> Handle(GetPersonalUserElectronSignsQuery request, CancellationToken cancellationToken) |
| | | { |
| | | var logier = JwtUtils.GetCurrentLogier(); |
| | | var q = rep.AsQueryable().AsNoTracking() |
| | | .Where(it => it.UserId == logier.Id); |
| | | if (request.UserSignContractStatus.HasValue) |
| | | { |
| | | q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus); |
| | | if (request.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass) |
| | | { |
| | | q = q.Where(it => it.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass && it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Pass); |
| | | } |
| | | else |
| | | { |
| | | q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus.Value); |
| | | } |
| | | } |
| | | if (request.EnterpriseSignContractStatus.HasValue) |
| | | else |
| | | { |
| | | q = q.Where(it => it.EnterpriseSignContractStatus == request.EnterpriseSignContractStatus); |
| | | q = q.Where(it => |
| | | it.UserSignContractStatus == EnumTaskUserSignContractStatus.Wait |
| | | || it.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass && it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Pass |
| | | || it.UserSignContractStatus == EnumTaskUserSignContractStatus.Stop); |
| | | } |
| | | var s = q.ProjectToType<GetEnterpriseEmployeesQueryResultItem>(); |
| | | return await request.PageModel.GetPagedListAsync<GetEnterpriseEmployeesQueryResult, GetEnterpriseEmployeesQueryResultItem>(s, cancellationToken); |
| | | var s = q.Select(it => new GetPersonalUserElectronSignsQueryResultItem |
| | | { |
| | | Id = it.Id, |
| | | EnterpriseName = it.Enterprise.EnterpriseName, |
| | | UserSignContractStatus = it.UserSignContractStatus, |
| | | }); |
| | | return await request.PageModel.GetPagedListAsync<GetPersonalUserElectronSignsQueryResult, GetPersonalUserElectronSignsQueryResultItem>(s, cancellationToken); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 查询个人用户签约详情 |
| | | /// </summary> |
| | | /// <param name="request"></param> |
| | | /// <param name="cancellationToken"></param> |
| | | /// <returns></returns> |
| | | public async Task<GetPersonalUserElectronSignQueryResult> Handle(GetPersonalUserElectronSignQuery request, CancellationToken cancellationToken) |
| | | { |
| | | var logier = JwtUtils.GetCurrentLogier(); |
| | | if (request.Id.HasValue) |
| | | { |
| | | var model = await rep.AsQueryable().AsNoTracking() |
| | | .Where(it => it.UserId == logier.Id && it.Id == request.Id) |
| | | .GetDetail<EnterpriseEmployee, GetPersonalUserElectronSignQueryResult>(); |
| | | return model; |
| | | } |
| | | else if (request.Code.IsNotNull()) |
| | | { |
| | | var contractTemplate = await repContractTemplate.AsQueryable().AsNoTracking() |
| | | .Where(it => it.Code == request.Code) |
| | | .FirstOrDefaultAsync(); |
| | | if (contractTemplate == null) throw Oops.Oh(EnumErrorCodeType.s404, "合同"); |
| | | |
| | | await mediator.Send(new CheckContractTemplateCommand |
| | | { |
| | | Id = contractTemplate.Id |
| | | }, cancellationToken); |
| | | |
| | | var entity = await rep.AsQueryable() |
| | | .Where(it => |
| | | it.UserId == logier.Id |
| | | && it.ContractTemplateId == contractTemplate.Id) |
| | | .FirstOrDefaultAsync(); |
| | | var enterprise = await repEnterprise.AsQueryable() |
| | | .Where(it => it.Id == contractTemplate.EnterpriseId) |
| | | .Select(it => new |
| | | { |
| | | it.EnterpriseName |
| | | }) |
| | | .FirstOrDefaultAsync(); |
| | | if (enterprise == null) throw Oops.Oh(EnumErrorCodeType.s404, "企业"); |
| | | var add = false; |
| | | if (entity == null) |
| | | { |
| | | var user = await repUser.AsQueryable().AsNoTracking() |
| | | .Include(it => it.UserAuth) |
| | | .Where(it => it.Id == logier.Id) |
| | | .Select(it => new |
| | | { |
| | | it.Name, |
| | | it.Identity, |
| | | it.ContactPhoneNumber, |
| | | it.Gender, |
| | | it.Age, |
| | | it.UserAuth.IdentityImg, |
| | | it.UserAuth.IdentityBackImg |
| | | }) |
| | | .FirstOrDefaultAsync(cancellationToken); |
| | | if (user == null) throw Oops.Oh(EnumErrorCodeType.s404, "账号"); |
| | | entity = new EnterpriseEmployee |
| | | { |
| | | Id = IDGen.NextID(), |
| | | EnterpriseId = contractTemplate.EnterpriseId, |
| | | UserId = logier.Id, |
| | | Name = user.Name, |
| | | Identity = user.Identity, |
| | | ContactPhoneNumber = user.ContactPhoneNumber, |
| | | Gender = user.Gender, |
| | | Age = user.Age, |
| | | IdentityImg = user.IdentityImg, |
| | | IdentityBackImg = user.IdentityBackImg, |
| | | }; |
| | | add = true; |
| | | } |
| | | if (entity.UserSignContractStatus == null) |
| | | { |
| | | entity.ContractTemplateId = contractTemplate.Id; |
| | | entity.UserSignContractStatus = EnumTaskUserSignContractStatus.Wait; |
| | | entity.UserSignContractTime = null; |
| | | entity.EnterpriseSignContractStatus = null; |
| | | entity.EnterpriseSignContractTime = null; |
| | | entity.ContractCode = $"{DateTime.Now:yyyyMMddHHmmss}{new Random(IDGen.NextID().GetHashCode()).Next(1000, 9999)}"; |
| | | entity.ContractUrl = null; |
| | | var contract = new EnterpriseEmployeeContract |
| | | { |
| | | EnterpriseEmployeeId = entity.Id, |
| | | ContractTemplateId = entity.ContractTemplateId, |
| | | ContractCode = entity.ContractCode, |
| | | UserSignContractStatus = entity.UserSignContractStatus, |
| | | }; |
| | | await repEnterpriseEmployeeContract.InsertAsync(contract); |
| | | } |
| | | if (add) |
| | | { |
| | | await rep.InsertAsync(entity); |
| | | } |
| | | else |
| | | { |
| | | await rep.UpdateAsync(entity); |
| | | } |
| | | return new GetPersonalUserElectronSignQueryResult |
| | | { |
| | | Id = entity.Id, |
| | | ContractCode = entity.ContractCode, |
| | | ContractTemplateAccess = contractTemplate.Access, |
| | | UserSignContractStatus = entity.UserSignContractStatus, |
| | | Name = entity.Name, |
| | | Identity = entity.Identity, |
| | | ContactPhoneNumber = entity.ContactPhoneNumber, |
| | | UserSignContractTime = entity.UserSignContractTime, |
| | | EnterpriseEnterpriseName = enterprise.EnterpriseName, |
| | | EnterpriseSignContractTime = entity.EnterpriseSignContractTime, |
| | | ContractUrl = entity.ContractUrl, |
| | | }; |
| | | } |
| | | else |
| | | { |
| | | throw Oops.Oh(EnumErrorCodeType.s400, "请填写灵工Id或合同模板编号"); |
| | | } |
| | | } |
| | | } |
| | | } |