From 6ad4db7d45eeaec5617f511010343258f245e5d4 Mon Sep 17 00:00:00 2001 From: sunpengfei <i@angelzzz.com> Date: 星期四, 28 八月 2025 17:09:02 +0800 Subject: [PATCH] feat:开发 --- FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs | 117 ++++++++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 100 insertions(+), 17 deletions(-) diff --git a/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs b/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs index 422cb3c..2c81f53 100644 --- a/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs +++ b/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs @@ -36,18 +36,23 @@ /// <returns></returns> public async Task<GetCheckReceiveTasksQueryResult> Handle(GetCheckReceiveTasksQuery request, CancellationToken cancellationToken) { + var now = DateTime.Now; var logier = JwtUtils.GetCurrentLogier(); var q = repTaskInfo.AsQueryable().AsNoTracking() .OrderBy(it => it.CreatedTime) - .AsQueryable(); + .Where(it => it.BeginTime <= now.Date && now.Date <= it.EndTime); if (logier.Type == EnumUserType.Personal) { - q = q.Where(it => it.TaskInfoUsers.Any(tu => tu.EnterpriseEmployee.UserId == logier.Id)); + q = q.Where(it => it.TaskInfoUsers.Any(tu => + tu.EnterpriseEmployee.UserId == logier.Id + && tu.ArrangeStatus == EnumTaskUserArrangeStatus.Complete)); } else if (logier.Type == EnumUserType.Enterprise) { - q = q.Where(it => it.EnterpriseId == logier.EnterpriseId); + q = q.Where(it => + it.EnterpriseId == logier.EnterpriseId + && it.Status == EnumTaskStatus.Complete); } if (request.Keywords.IsNotNull()) { @@ -68,8 +73,10 @@ throw Oops.Oh(EnumErrorCodeType.s400, "璇烽�夋嫨鏃ユ湡"); } q = q.Where(it => - it.TaskInfoUsers.Any(tu => - tu.EnterpriseEmployee.UserId == logier.Id + (logier.Type == EnumUserType.Enterprise ? it.EnterpriseId == logier.EnterpriseId : true) + && it.BeginTime.Date <= request.Date.Value && request.Date.Value <= it.EndTime.Date + && it.TaskInfoUsers.Any(tu => + (logier.Type == EnumUserType.Personal ? tu.EnterpriseEmployee.UserId == logier.Id : true) && (request.CheckReceiveStatus == EnumTaskCheckReceiveStatus.WaitSubmit ? !tu.Submits.Any(s => s.Date.Date == request.Date.Value.Date) : tu.Submits.Any(s => @@ -92,7 +99,23 @@ q = q.Where(it => it.CheckReceiveStatus == request.CheckReceiveStatus); } } - var s = q.ProjectToType<GetCheckReceiveTasksQueryResultItem>(); + var s = q.Select(it => new GetCheckReceiveTasksQueryResultItem + { + Id = it.Id, + Name = it.Name, + Code = it.Code, + BillingMethod = it.BillingMethod, + ServiceFee = it.ServiceFee, + SettlementCycle = it.SettlementCycle, + CreatedTime = it.CreatedTime, + BeginTime = it.BeginTime, + EndTime = it.EndTime, + AddressName = it.AddressName, + LastCheckReceiveTime = it.LastCheckReceiveTime, + CheckReceiveStatus = logier.Type == EnumUserType.Enterprise && logier.ClientType == EnumClientType.Wxmp && request.Date.HasValue + ? request.CheckReceiveStatus + : it.CheckReceiveStatus, + }); return await request.PageModel.GetPagedListAsync<GetCheckReceiveTasksQueryResult, GetCheckReceiveTasksQueryResultItem>(s, cancellationToken); } @@ -117,6 +140,29 @@ { q = q.Where(it => it.TaskInfo.EnterpriseId == logier.EnterpriseId); } + if (logier.Type == EnumUserType.Enterprise && logier.ClientType == EnumClientType.Wxmp) + { + if (request.CheckReceiveStatus == null) + { + throw Oops.Oh(EnumErrorCodeType.s400, "璇烽�夋嫨楠屾敹鐘舵��"); + } + if (request.Date == null) + { + throw Oops.Oh(EnumErrorCodeType.s400, "璇烽�夋嫨鏃ユ湡"); + } + q = q.Where(it => + it.TaskInfo.EnterpriseId == logier.EnterpriseId + && (request.CheckReceiveStatus == EnumTaskCheckReceiveStatus.WaitSubmit + ? !it.Submits.Any(s => s.Date.Date == request.Date.Value.Date) + : it.Submits.Any(s => + s.Date.Date == request.Date.Value.Date + && (request.CheckReceiveStatus == EnumTaskCheckReceiveStatus.WaitSubmit + ? s.CheckReceiveStatus == EnumTaskUserSubmitCheckReceiveStatus.WaitSubmit + : (request.CheckReceiveStatus == EnumTaskCheckReceiveStatus.WaitCheckReceive + ? s.CheckReceiveStatus == EnumTaskUserSubmitCheckReceiveStatus.WaitCheckReceive + : (s.CheckReceiveStatus == EnumTaskUserSubmitCheckReceiveStatus.Success + || s.CheckReceiveStatus == EnumTaskUserSubmitCheckReceiveStatus.Fail)))))); + } var s = q.Select(it => new GetCheckReceiveTaskQueryResultItem { Id = it.Id, @@ -130,13 +176,22 @@ ContactPhoneNumber = it.EnterpriseEmployee.User.ContactPhoneNumber, IsReal = it.EnterpriseEmployee.User.IsReal, RealMethod = it.EnterpriseEmployee.User.RealMethod, - CheckReceiveStatus = it.CheckReceiveStatus, + CheckReceiveStatus = logier.Type == EnumUserType.Enterprise && logier.ClientType == EnumClientType.Wxmp && request.Date.HasValue + ? it.Submits + .Where(s => s.Date == request.Date) + .Select(s => (s.CheckReceiveStatus == EnumTaskUserSubmitCheckReceiveStatus.WaitSubmit + ? EnumTaskCheckReceiveStatus.WaitSubmit + : s.CheckReceiveStatus == EnumTaskUserSubmitCheckReceiveStatus.WaitCheckReceive + ? EnumTaskCheckReceiveStatus.WaitCheckReceive + : EnumTaskCheckReceiveStatus.Completed) as EnumTaskCheckReceiveStatus?) + .FirstOrDefault() ?? EnumTaskCheckReceiveStatus.WaitSubmit + : it.CheckReceiveStatus, LastSubmitTime = it.LastSubmitTime, }); var result = await request.PageModel.GetPagedListAsync<GetCheckReceiveTaskQueryResult, GetCheckReceiveTaskQueryResultItem>(s, cancellationToken); result.ObjectData = await repTaskInfo.AsQueryable().AsNoTracking() - .Where(it => it.Id == request.TaskInfoId) - .GetDetail<TaskInfo, GetCheckReceiveTaskQueryResultObjectData>(); + .Where(it => it.Id == request.TaskInfoId) + .GetDetail<TaskInfo, GetCheckReceiveTaskQueryResultObjectData>(); return result; } @@ -151,7 +206,17 @@ var logier = JwtUtils.GetCurrentLogier(); var q = repTaskInfoUserSubmit.AsQueryable().AsNoTracking() .OrderByDescending(it => it.CreatedTime) - .Where(it => it.TaskInfoUserId == request.Id); + .AsQueryable(); + if (logier.Type == EnumUserType.Personal) + { + if (request.TaskInfoId == null) throw Oops.Oh(EnumErrorCodeType.s400, "璇烽�夋嫨浠诲姟"); + q = q.Where(it => it.TaskInfoUser.TaskInfoId == request.TaskInfoId && it.TaskInfoUser.EnterpriseEmployee.UserId == logier.Id); + } + else + { + if (request.Id == null) throw Oops.Oh(EnumErrorCodeType.s400, "璇烽�夋嫨鐏靛伐"); + q = q.Where(it => it.TaskInfoUserId == request.Id); + } var s = q.Select(it => new GetCheckReceiveTaskUserSubmitsQueryResultItem { Id = it.Id, @@ -161,11 +226,24 @@ CheckReceiveTime = it.CheckReceiveTime, }); var result = await request.PageModel.GetPagedListAsync<GetCheckReceiveTaskUserSubmitsQueryResult, GetCheckReceiveTaskUserSubmitsQueryResultItem>(s, cancellationToken); - result.ObjectData = await repTaskInfoUser.AsQueryable().AsNoTracking() - .Where(it => it.Id == request.Id) - .GetDetail<TaskInfoUser, GetCheckReceiveTaskUserSubmitsQueryResultObjectData>(); - - //await repTaskInfo.Change<UserBankCard>() + if (request.Id.HasValue) + { + result.ObjectData = await repTaskInfoUser.AsQueryable().AsNoTracking() + .Where(it => it.Id == request.Id) + .GetDetail<TaskInfoUser, GetCheckReceiveTaskUserSubmitsQueryResultObjectData>(); + } + else if (request.TaskInfoId.HasValue) + { + result.ObjectData = await repTaskInfoUser.AsQueryable().AsNoTracking() + .Where(it => it.TaskInfoId == request.TaskInfoId) + .GetDetail<TaskInfoUser, GetCheckReceiveTaskUserSubmitsQueryResultObjectData>(); + } + if (result.ObjectData != null) + { + result.ObjectData.EnterpriseEmployeeUser.IsBindBankCard = await repTaskInfo.Change<UserBankCard>() + .AsQueryable().AsNoTracking() + .AnyAsync(it => it.UserId == result.ObjectData.EnterpriseEmployeeUser.Id); + } return result; } @@ -175,7 +253,7 @@ /// <param name="request"></param> /// <param name="cancellationToken"></param> /// <returns></returns> - public Task<GetCheckReceiveTaskUserSubmitQueryResult> Handle(GetCheckReceiveTaskUserSubmitQuery request, CancellationToken cancellationToken) + public async Task<GetCheckReceiveTaskUserSubmitQueryResult> Handle(GetCheckReceiveTaskUserSubmitQuery request, CancellationToken cancellationToken) { var q = repTaskInfoUserSubmit.AsQueryable().AsNoTracking(); if (request.SubmitId.HasValue) @@ -190,7 +268,12 @@ { q = q.Where(it => it.Date.Date == request.Date.Value.Date && it.TaskInfoUserId == request.TaskInfoUserId.Value); } - return q.GetDetail<TaskInfoUserSubmit, GetCheckReceiveTaskUserSubmitQueryResult>(); + var model = await q.GetDetail<TaskInfoUserSubmit, GetCheckReceiveTaskUserSubmitQueryResult>(); + model.Files = await repTaskInfoUserSubmit.Change<TaskInfoUserSubmitFile>().AsQueryable().AsNoTracking() + .Where(it => it.SubmitId == model.Id) + .Select(it => it.File) + .ToListAsync(); + return model; } } } -- Gitblit v1.9.1