From 57183ac3ea6571aff6583a214a95eb5af4d4a2f7 Mon Sep 17 00:00:00 2001
From: sunpengfei <i@angelzzz.com>
Date: 星期四, 14 八月 2025 17:23:06 +0800
Subject: [PATCH] fix:运营端——C端人员管理——列表展示了企业联系人的信息

---
 FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Commands/TaskCheckReceiveCommandHandler.cs |   66 +++++++++++++++++++++-----------
 1 files changed, 43 insertions(+), 23 deletions(-)

diff --git a/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Commands/TaskCheckReceiveCommandHandler.cs b/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Commands/TaskCheckReceiveCommandHandler.cs
index 4a5a2c2..a58614c 100644
--- a/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Commands/TaskCheckReceiveCommandHandler.cs
+++ b/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Commands/TaskCheckReceiveCommandHandler.cs
@@ -41,13 +41,17 @@
             var task = await repTaskInfo.AsQueryable()
                 .FirstOrDefaultAsync(it => it.Id == request.TaskInfoId, cancellationToken);
             if (task == null) throw Oops.Oh(EnumErrorCodeType.s404, "璇ヤ换鍔�");
-            if (task.Status == EnumTaskStatus.Wait) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔℃殏鏈畨鎺掍汉鍛�");
-            if (task.ReleaseStatus == EnumTaskReleaseStatus.Stopped) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔″凡缁撴潫");
-            if (!(task.BeginTime <= now && now <= task.EndTime)) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔″凡缁撴潫");
+            if (task.Status != EnumTaskStatus.Complete) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔℃殏鏈畨鎺掍汉鍛�");
+            if (task.ReleaseStatus != EnumTaskReleaseStatus.InProcess) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔″凡缁撴潫");
+            if (task.BeginTime > request.Date.Date)
+                throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔℃湭寮�濮�");
+            if (request.Date.Date > task.EndTime)
+                throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔″凡缁撴潫");
             var taskUser = await repTaskInfoUser.AsQueryable()
                 .FirstOrDefaultAsync(it => it.TaskInfoId == task.Id && it.EnterpriseEmployee.UserId == logier.Id, cancellationToken);
             if (taskUser == null) throw Oops.Oh(EnumErrorCodeType.s404, "璇ユ姤鍚嶄俊鎭�");
-            if (taskUser.ArrangeStatus == EnumTaskUserArrangeStatus.Wait) throw Oops.Oh(EnumErrorCodeType.s510, "鏆傛湭瀹夋帓璇ヤ换鍔�");
+            if (taskUser.HireStatus != EnumTaskUserHireStatus.Pass) throw Oops.Oh(EnumErrorCodeType.s510, "鎮ㄦ湭褰曠敤");
+            if (taskUser.ArrangeStatus != EnumTaskUserArrangeStatus.Complete) throw Oops.Oh(EnumErrorCodeType.s510, "鏆傛湭瀹夋帓璇ヤ换鍔�");
             task.CheckReceiveStatus = EnumTaskCheckReceiveStatus.WaitCheckReceive;
             task.LastSubmitTime = now;
             taskUser.CheckReceiveStatus = EnumTaskCheckReceiveStatus.WaitCheckReceive;
@@ -60,7 +64,7 @@
                 submit = new TaskInfoUserSubmit
                 {
                     TaskInfoUserId = taskUser.Id,
-                    Date = now.Date,
+                    Date = request.Date,
                     Files = request.Files.Select(it => new TaskInfoUserSubmitFile
                     {
                         File = it
@@ -106,13 +110,12 @@
             var taskUser = await repTaskInfoUser.AsQueryable()
                 .FirstOrDefaultAsync(it => it.Id == submit.TaskInfoUserId, cancellationToken);
             if (taskUser == null) throw Oops.Oh(EnumErrorCodeType.s404, "璇ョ伒宸ヤ俊鎭�");
-            if (taskUser.ArrangeStatus == EnumTaskUserArrangeStatus.Wait) throw Oops.Oh(EnumErrorCodeType.s510, "鏈畨鎺掕鐏靛伐");
+            if (taskUser.HireStatus != EnumTaskUserHireStatus.Pass) throw Oops.Oh(EnumErrorCodeType.s510, "鏈綍鐢ㄨ鐏靛伐");
+            if (taskUser.ArrangeStatus != EnumTaskUserArrangeStatus.Complete) throw Oops.Oh(EnumErrorCodeType.s510, "鏈畨鎺掕鐏靛伐");
             var task = await repTaskInfo.AsQueryable()
                 .FirstOrDefaultAsync(it => it.Id == taskUser.TaskInfoId && it.EnterpriseId == logier.EnterpriseId, cancellationToken);
             if (task == null) throw Oops.Oh(EnumErrorCodeType.s404, "璇ヤ换鍔�");
-            if (task.Status == EnumTaskStatus.Wait) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔℃殏鏈畨鎺掍汉鍛�");
-            if (task.ReleaseStatus == EnumTaskReleaseStatus.Stopped) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔″凡缁撴潫");
-            if (!(task.BeginTime <= now && now <= task.EndTime)) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔″凡缁撴潫");
+            if (task.Status != EnumTaskStatus.Complete) throw Oops.Oh(EnumErrorCodeType.s510, "璇ヤ换鍔℃殏鏈畨鎺掍汉鍛�");
             if (request.CheckReceiveStatus != EnumTaskUserSubmitCheckReceiveStatus.Success
                 && request.CheckReceiveStatus != EnumTaskUserSubmitCheckReceiveStatus.Fail)
                 throw Oops.Oh(EnumErrorCodeType.s400, "璇烽�夋嫨姝g‘鐨勯獙鏀剁姸鎬�");
@@ -134,7 +137,7 @@
                     || it.CheckReceiveStatus == EnumTaskUserSubmitCheckReceiveStatus.Fail))
                 .Select(it => it.Date)
                 .ToListAsync();
-            taskUserSubmitDates.Add(now.Date);
+            taskUserSubmitDates.Add(submit.Date);
             if (dates.All(taskUserSubmitDates.Contains))
             {
                 taskUser.CheckReceiveStatus = EnumTaskCheckReceiveStatus.Completed;
@@ -164,21 +167,38 @@
         /// <returns></returns>
         public async Task<string> Handle(ExportTaskCheckReceiveTaskUsersCommand request, CancellationToken cancellationToken)
         {
-           var models = await repTaskInfoUserSubmit.AsQueryable().AsNoTracking()
-                .Where(it => it.TaskInfoUser.TaskInfoId == request.Id)
-                .Select(it => new ExportTaskCheckReceiveTaskUsersCommandModel
+            var models = await repTaskInfoUserSubmit.AsQueryable().AsNoTracking()
+                 .Where(it => it.TaskInfoUser.TaskInfoId == request.Id)
+                 .Select(it => new ExportTaskCheckReceiveTaskUsersCommandModel
+                 {
+                     UserId = it.TaskInfoUser.EnterpriseEmployee.UserId!.Value,
+                     Name = it.TaskInfoUser.EnterpriseEmployee.User.Name,
+                     Identity = it.TaskInfoUser.EnterpriseEmployee.User.Identity,
+                     ContactPhoneNumber = it.TaskInfoUser.EnterpriseEmployee.User.ContactPhoneNumber,
+                     CheckReceiveStatus = it.CheckReceiveStatus,
+                     CheckReceiveTime = it.CheckReceiveTime,
+                 })
+                 .ToListAsync(cancellationToken);
+            if (models.IsNotNull())
+            {
+                var userIds = models.DistinctSelect(it => it.UserId);
+                var bankCards = await repTaskInfoUserSubmit.Change<UserBankCard>().AsQueryable().AsNoTracking()
+                    .Where(it => userIds.Contains(it.UserId))
+                    .Select(it => new
+                    {
+                        it.UserId,
+                        it.Bank,
+                        it.Code
+                    })
+                    .ToListAsync(cancellationToken);
+                foreach (var model in models)
                 {
-                    Name = it.TaskInfoUser.EnterpriseEmployee.User.Name,
-                    Identity = it.TaskInfoUser.EnterpriseEmployee.User.Identity,
-                    ContactPhoneNumber = it.TaskInfoUser.EnterpriseEmployee.User.ContactPhoneNumber,
-                    CheckReceiveStatus = it.CheckReceiveStatus,
-                    CheckReceiveTime = it.CheckReceiveTime,
-                    Bank = "123",
-                    Code = "456"
-                })
-                .ToListAsync(cancellationToken);
+                    var bankCard = bankCards.FirstOrDefault(it => it.UserId == model.UserId);
+                    model.Bank = bankCard?.Bank;
+                    model.Code = bankCard?.Code;
+                }
+            }
             var url = await models.ExportExcelToOSS("TaskCheckReceive/Export", "楠屾敹璁板綍.xlsx");
-            url = AliyunOSSUtils.GetUrl(url);
             return url;
         }
     }

--
Gitblit v1.9.1